diff options
author | n-peugnet <n.peugnet@free.fr> | 2021-09-14 16:05:55 +0200 |
---|---|---|
committer | n-peugnet <n.peugnet@free.fr> | 2021-09-14 16:05:55 +0200 |
commit | 1b29f7dafc233ed893d8f35e5edbb0c2e357d55d (patch) | |
tree | 731b6f6560ea149da3d6512a4bc757480add761e /logger/logger_test.go | |
parent | 33967236e18c33d0d83b34b76f8238c3d588b21d (diff) | |
download | dna-backup-1b29f7dafc233ed893d8f35e5edbb0c2e357d55d.tar.gz dna-backup-1b29f7dafc233ed893d8f35e5edbb0c2e357d55d.zip |
logger add SetOutput + basic tests
Diffstat (limited to 'logger/logger_test.go')
-rw-r--r-- | logger/logger_test.go | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/logger/logger_test.go b/logger/logger_test.go new file mode 100644 index 0000000..ce708bb --- /dev/null +++ b/logger/logger_test.go @@ -0,0 +1,87 @@ +package logger + +import ( + "bufio" + "bytes" + "os" + "reflect" + "strings" + "testing" +) + +func TestLoggingBeforeInit(t *testing.T) { + old := os.Stderr + r, w, err := os.Pipe() + if err != nil { + t.Fatal(err) + } + + os.Stderr = w + // Reset + initialize() + + info := "info log" + warning := "warning log" + errL := "error log" + fatal := "fatal log" + + Info(info) + Warning(warning) + Error(errL) + // We don't want os.Exit in a test + defaultLogger.output(sFatal, 0, fatal) + + w.Close() + os.Stderr = old + + var b bytes.Buffer + scanner := bufio.NewScanner(r) + for scanner.Scan() { + b.Write(scanner.Bytes()) + } + + out := b.String() + + for _, txt := range []string{info, warning, errL, fatal} { + if !strings.Contains(out, txt) { + t.Errorf("log output %q does not contain expected text: %q", out, txt) + } + } +} + +func TestInit(t *testing.T) { + var buf1 bytes.Buffer + l1 := Init(3) + l1.SetOutput(&buf1) + if !reflect.DeepEqual(l1, defaultLogger) { + t.Fatal("defaultLogger does not match logger returned by Init") + } + + // Subsequent runs of Init shouldn't change defaultLogger. + var buf2 bytes.Buffer + l2 := Init(3) + l2.SetOutput(&buf2) + if !reflect.DeepEqual(l1, defaultLogger) { + t.Error("defaultLogger should not have changed") + } + + // Check log output. + l1.Info("logger #1") + l2.Info("logger #2") + defaultLogger.Info("default logger") + + tests := []struct { + out string + want int + }{ + {buf1.String(), 2}, + {buf2.String(), 1}, + } + + for i, tt := range tests { + got := len(strings.Split(strings.TrimSpace(tt.out), "\n")) + if got != tt.want { + t.Errorf("logger %d wrong number of lines, want %d, got %d", i+1, tt.want, got) + } + } +} |