Skip to content
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

Important messages are not necessarily Errors #559

Closed
ple1n opened this issue Apr 23, 2023 · 5 comments
Closed

Important messages are not necessarily Errors #559

ple1n opened this issue Apr 23, 2023 · 5 comments

Comments

@ple1n
Copy link

ple1n commented Apr 23, 2023

I came across a situation where, a dependency logs in Errors, but my app can handle the Errors and still succeed in the task.

It just feels too weird to log Successes as Errors, like having some cognitive dissonance

If a user sets the logging level to Error, he will only see the Error messages by the dependency while the success messages are logged in Info (they aren't errors), and get confused.

@KodrAus
Copy link
Contributor

KodrAus commented Apr 23, 2023

The level of a log event is really relative to the context it’s produced in.

In general, I‘d discourage most libraries from logging at all unless they’re particularly stateful. In my experience, any that’s there tends to be filtered out by end-user applications in favour of more semantic events surrounding their integration points anyways.

For the case of errors I think there’s really no need for a library to both return an error as well as log it, since that erroneous condition is already observable through the error return value.

@ple1n
Copy link
Author

ple1n commented Apr 23, 2023

In my case the rtnetlink doesn't include anything meaningful in the returned error. I guess many other libraries could be doing that too, since bad practices are not banned (if you think thats bad).

@NobodyXu
Copy link

since bad practices are not banned (if you think thats bad).

TL;DR: Just avoid using crates with bad practices.

Unfortunately there's just no way to ban this behaviour easily.

You can use a capability based system where even printing and logging is capsulated as a value implementing a trait (which itself is easy to do) but then you would have to explicitly pass them to every function.

This over-explicit way of passing cap would be fixed by the capability proposal in rust https://tmandry.gitlab.io/blog/posts/2021-12-21-context-capabilities/

But AFAIK it's still in pre-RFC stage, so you would have to wait for quite some time until that is there.

Even with cap, not every crate would support it.

@KodrAus
Copy link
Contributor

KodrAus commented Apr 29, 2023

It looks like the case where rtnetlink does logging is the sort of place I'd say is reasonable to log in a library. It looks like a sort of long-running process? They may be better off keeping all their messages as trace, but depending on the destination you're logging to you may be able to either filter out messages from the rtnetlink crate entirely.

EFanZh pushed a commit to EFanZh/log that referenced this issue Jul 23, 2023
chore: Release

Co-authored-by: github-actions <github-actions@github.com>
Co-authored-by: Jiahao XU <Jiahao_XU@outlook.com>
@Thomasdezeeuw
Copy link
Collaborator

After nearly a year of no activity I'm closing this. Feel free to reopen if more needs to be discussed.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants