-
Notifications
You must be signed in to change notification settings - Fork 8
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
workflow: Use smaller logger dependency with override support #25
Conversation
d20568b
to
ce447f0
Compare
LGTM, would be good to get @adamhicks's eyes on it too 👍 |
If you need to Wrap and New with metadata, you should be using jettison. Your implementation (in internal/errors/errors.go) of errors is notably different to jettison and has made different choices that ignore some of the nuances that jettison handles with wrapping and unwrapping errors. If you don't really need to wrap metadata, then you don't need an error package and you should be able to expose a simpler Logger func or interface that allows the user to bring their own logger. |
The main concern around jettison is that it's errors are tightly coupled to the logger it provides. If jettison exported it's errors independently from it's logger then I would use that but I would ultimately like to make this leaner and allow the user to add bloat where it makes sense like providing a logger. I will see if wrapping is really necessary as it would be first prize to not have a custom error type internally. I would like to use the std package. |
What do you need from the error? Jettison has a couple of utilities to extract info. |
From the error side I would like to wrap and add context around the error that can be propagated and as it is propagated more context can be added then logged at a top level. How the log is written and structured is a different concern. It would also be nice if the jettison module can be broken down into specific modules but its largely built as one thing. So for example I would like to avoid logger format dependencies that jettison uses if I just want to use jettison errors for example. You kind of need to commit to the whole package. |
I don't think that's true at all, I spent a decent amount of time separating out the errors and logging. |
I think you might be confusing package with module. I am specifically referring to not needing to import the entire jettison module to access the errors package. (i.e https://github.com/luno/jettison/blob/main/go.mod is the single mod for all jettison's pakcages) |
Jettison isn't large, I'm not sure why we'd need to do that. Do you have anything that I can look at to see what the benefit of doing that (adding more go.mod files) would be? |
Sorry havn't been able to get back to this but should be able to later this week |
@adamhicks I have stripped it back further to not have a custom error type (depending on how you look at it) for "workflow core" which is the go module |
Quality Gate passedIssues Measures |
Motivation
The motivation for this change is to begin trimming down the dependencies that workflow has. It forces good questions and healthy decisions as to what the core package needs and what it does not need. Since go's core library supported structured logging which is provided already and normalised the need to use https://github.com/luno/jettison became unclear especially as it brings some indirect dependencies itself.
It (https://github.com/luno/jettison) provides useful things beyond logging such as better errors than the stdlib error when it comes to tracing errors back but this should be a choice for the user of Workflow not something you need to use if you use workflow.
Research /Impact:
By creating a new project / go module, solely importing workflow (using the most current version [6c589eb]), implementing a simple:
Start -> Middle ->End
workflow, and then compiling it the output size is8.2 Megabytes
. When using the same project but using the changes via a go mod's replace command, the new output is8.0Megabytes
which is a 200 Kilobyte reduction. I think a 200Kilobytes shaved off an application is worth it if the user is content with the stdlib's loggerRemoved dependencies