C
C#•12mo ago
PurplePeopleEater

Automatically logging all errors without using try-catch

Is there a way to automatically log all errors without using try-catch's. For example, I could write the following pseudo-code: try { func-that-could-cause-an-error-to-be-thrown(); } catch { logfunc(...); } by using try-catch, but I would like the logging to happen WITHOUT the try-catch and WITHOUT the logfunc(...) call. The reason I want this is because I don't want to add try-catches to the entire large code base - it would require many, many edits. The errors only seem to be thrown once every few hours to once every few days depending on the situation so it is problematic to always run the app via Visual Studio to see the errors because the errors happen so infrequently. When running my app in Visual Studio the debugger captures the errors for me and shows them... which is great except that I don't want to run my app in Visual Studio. That said, I want any error that would be shown in the debugger to be the errors that get logged. I am open to logging via file or via the Windows Events though I would prefer via file. I am open to using some built in logging feature of C#, or a logging library, etc. Thank you in advance for any help.
20 Replies
Angius
Angius•12mo ago
Exceptions bubble up You don't have to catch them at the point where they occur You could just as easily have a global handler like
try {
new App().Run();
} catch (Exception e) {
Log.Error(e.Message);
}
try {
new App().Run();
} catch (Exception e) {
Log.Error(e.Message);
}
Far as where to log them... the most common way is probably using the Serilog library It has a selection of sinks, which is where your logs go It can be a file, a database, an email, hell, even a Discord server
Jimmacle
Jimmacle•12mo ago
you can also add a handler to the appdomain's unhandled exception event
PurplePeopleEater
PurplePeopleEaterOP•12mo ago
Thank you ZZZZ, I like this solution. But will it work even for places where I am using Task.Run?
Angius
Angius•12mo ago
Why would you use Task.Run()? As long as there are no async voids and everything async gets awaited, it should be fine
Jimmacle
Jimmacle•12mo ago
AppDomain.CurrentDomain.UnhandledException
TaskScheduler.UnobservedTaskException
AppDomain.CurrentDomain.UnhandledException
TaskScheduler.UnobservedTaskException
are the relevant events if you just want to handle anything afaik
PurplePeopleEater
PurplePeopleEaterOP•12mo ago
I use Task.Run because my app is responding to events in Windows that are happening such a the creation of new windows. My app needs to do processing on each new window that is being created but that processing can take a long time and the app needs to continue to listen for new windows being created. That is why I was using Task.Run to handle the processing step.
Angius
Angius•12mo ago
Gotcha
PurplePeopleEater
PurplePeopleEaterOP•12mo ago
Looking at my code, I do not see any async void's, but I also do not think I am awaiting - I specifically want things to happen asynchronously. Thank you jIMMACLE, I am not familiar with this method at all
Angius
Angius•12mo ago
So you want fire and forget?
PurplePeopleEater
PurplePeopleEaterOP•12mo ago
Yes, I am fire and forget
Angius
Angius•12mo ago
If so, then each task you fire and forget should handle the exceptions
PurplePeopleEater
PurplePeopleEaterOP•12mo ago
Yes, that is what I am thinking too
Angius
Angius•12mo ago
It doesn't need to be handled anywhere deep, though. Exception bubbling is still a thing
PurplePeopleEater
PurplePeopleEaterOP•12mo ago
Unless maybe jIMMACLE's method provides a way to declare that I need logging in a single place? Yes, I get what you are saying
casog
casog•12mo ago
You can use centralized exception handling in middleware by setting your applicationbuilder to "UseExceptionhandler()". Ihttps://andrewhalil.com/2022/03/10/centralized-logging-and-exception-handling-in-a-net-core-application/
Andrew Halil
andrewhalil.com
Centralized Logging and Exception Handling in a .NET Core Application
Welcome to today’s post. In today’s post I will be discussing how to use error handling and diagnostics logging middleware to trap and process unhandled errors from a .NET Core API. One useful tactic for handling unhandled errors within an application is to create a centralized error handling method or delegate that can trap the exception ...
PurplePeopleEater
PurplePeopleEaterOP•12mo ago
Thank you CASOG, but it isn't clear to me, does this also apply to an application like mine which is a WPF desktop app?
casog
casog•12mo ago
Never used WPF 😦 Sorry Seems not, but there are patterns you can use. Maybe a CQRS pattern with a exception / logging handler at the highest level of the stack, the place where the services/data is queried It's an application/structure design decision, it has to be built in when you imagine the program or added later
PurplePeopleEater
PurplePeopleEaterOP•12mo ago
Ok, thank you again
casog
casog•12mo ago
Task.run has a parameter for a cancellation token, just one reason I can think of
Unknown User
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View

Did you find this page helpful?