Logging#
Log Level Guidelines#
Logging is a critical part of both application development and maintenance. A well-defined log level structure helps separate the concerns of developers and end users, ensuring that relevant information is communicated at the right level of detail.
Developer-Oriented Log Levels#
TRACE Used for logging detailed application events, such as when a resource is created or destroyed. Example: Logging the creation of a new object instance.
DEBUG Used for debugging purposes, particularly when a function returns a result (e.g.,
Result
in Rust or anexpected
in C++) that contains an error. Example: Logging unexpected errors during function execution to help diagnose issues.
User-Oriented Log Levels#
INFO Provides general information about the application’s operations that may be of interest to the user. Example: Notifying the user of a successful operation or process completion.
WARN Indicates warnings for the user when internal recoverable misbehaviors occur, but the application’s functionality is not severely restricted. Example: Logging minor issues that could lead to future problems but are currently being handled gracefully.
ERROR Signals severe failures that are still recoverable, meaning the error is contained within a result (e.g.,
Result
in Rust or anexpected
in C++) and the application can continue if the user takes corrective action. Example: Logging errors that require user intervention to recover from a malfunction.FATAL Indicates critical failures where the application will terminate (panic) after the log output. Example: Logging a critical error that forces the application to shut down immediately.