Skip to content

Commit

Permalink
pkg/logger: docs (#985)
Browse files Browse the repository at this point in the history
  • Loading branch information
jmank88 authored Jan 10, 2025
1 parent 7dbb1b0 commit 149f084
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 2 deletions.
22 changes: 21 additions & 1 deletion pkg/logger/logger.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,15 +11,33 @@ import (
"go.uber.org/zap/zaptest/observer"
)

// Logger is a minimal subset of smartcontractkit/chainlink/core/logger.Logger implemented by go.uber.org/zap.SugaredLogger
// Logger is a basic logging interface implemented by smartcontractkit/chainlink/core/logger.Logger and go.uber.org/zap.SugaredLogger
//
// Loggers should be injected (and usually Named as well): e.g. lggr.Named("<service name>")
//
// Tests
// - Tests should use a [Test] logger, with [New] being reserved for actual runtime and limited direct testing.
//
// Levels
// - Fatal: Logs and then calls os.Exit(1). Be careful about using this since it does NOT unwind the stack and may exit uncleanly.
// - Panic: Unrecoverable error. Example: invariant violation, programmer error
// - Error: Something bad happened, and it was clearly on the node op side. No need for immediate action though. Example: database write timed out
// - Warn: Something bad happened, not clear who/what is at fault. Node ops should have a rough look at these once in a while to see whether anything stands out. Example: connection to peer was closed unexpectedly. observation timed out.
// - Info: High level information. First level we’d expect node ops to look at. Example: entered new epoch with leader, made an observation with value, etc.
// - Debug: Useful for forensic debugging, but we don't expect nops to look at this. Example: Got a message, dropped a message, ...
//
// Node Operator Docs: https://docs.chain.link/docs/configuration-variables/#log_level
type Logger interface {
// Name returns the fully qualified name of the logger.
Name() string

Debug(args ...interface{})
Info(args ...interface{})
Warn(args ...interface{})
Error(args ...interface{})
Panic(args ...interface{})
// Fatal logs and then calls os.Exit(1)
// Be careful about using this since it does NOT unwind the stack and may exit uncleanly
Fatal(args ...interface{})

Debugf(format string, values ...interface{})
Expand All @@ -36,6 +54,8 @@ type Logger interface {
Panicw(msg string, keysAndValues ...interface{})
Fatalw(msg string, keysAndValues ...interface{})

// Sync flushes any buffered log entries.
// Some insignificant errors are suppressed.
Sync() error
}

Expand Down
12 changes: 11 additions & 1 deletion pkg/logger/sugared.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
package logger

// SugaredLogger extends the base Logger interface with syntactic sugar, similar to zap.SugaredLogger.
// SugaredLogger extends the base Logger interface with syntactic sugar, similar to zap.SugaredLogger, include two new levels.
// - Critical: Requires quick action from the node op, obviously these should happen extremely rarely. Example: failed to listen on TCP port
// - Trace: Only included if compiled with the trace tag. For example: go test -tags trace ...
type SugaredLogger interface {
Logger

Expand Down Expand Up @@ -29,8 +31,16 @@ type SugaredLogger interface {
Tracef(format string, vals ...interface{})
Tracew(msg string, keysAndVals ...interface{})

// Named creates a new Logger sub-scoped with name.
// Names are inherited and dot-separated.
// a := l.Named("A") // logger=A
// b := a.Named("A") // logger=A.B
// Names are generally `MixedCaps`, without spaces, like Go names. `Foo.Bar.HTTPBaz`
Named(string) SugaredLogger
// With returns a new Logger with the given arguments.
With(keyvals ...any) SugaredLogger
// Helper returns a new logger with the number of callers skipped by caller annotation increased by skip.
// This allows wrappers and helpers to point higher up the stack (like testing.T.Helper()).
Helper(skip int) SugaredLogger
}

Expand Down

0 comments on commit 149f084

Please sign in to comment.