/
main.go
42 lines (34 loc) · 1.12 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
package main
import (
"errors"
"fmt"
"os"
"github.com/go-logr/logr"
"github.com/mattn/go-colorable"
pkgerrs "github.com/pkg/errors"
"github.com/omaskery/simple-logr"
)
var (
ErrItBroke = errors.New("wow it super broke yo")
)
func main() {
opts := simplelogr.DevelopmentLogSinkOptions{
Output: colorable.NewColorable(os.Stdout),
ColouredOutput: simplelogr.ColourModeForceOn,
}
opts.AssertDefaults()
logSink := simplelogr.New(simplelogr.Options{
Sink: simplelogr.NewDevelopmentLogSink(opts),
Verbosity: 10,
})
logger := logr.New(logSink).WithName("example").WithValues("hello", "kitty")
logger.Info("start")
defer logger.Info("end")
logger.Info("such a good test", "wow", 10)
logger.Error(pkgerrs.WithStack(ErrItBroke), "oops", "foo", "flange")
logger.Error(ErrItBroke, "so upsetting")
logger.Error(pkgerrs.Wrap(pkgerrs.Wrap(pkgerrs.WithStack(ErrItBroke), "nesting A"), "nesting B"), "so nested")
logger.Error(fmt.Errorf("go 1.13 wrapping: %w", ErrItBroke), "other wrapping methods")
logger.V(1).Info("meow", "this", "is a test")
logger.V(2).Info("woof", "this", "is an even more verbose test")
}