mirror of
https://github.com/tailscale/tailscale.git
synced 2024-11-27 03:55:36 +00:00
da40609abd
Fixes #13313 Fixes #12687 Signed-off-by: Nick Khyl <nickk@tailscale.com>
54 lines
1.4 KiB
Go
54 lines
1.4 KiB
Go
// Copyright (c) Tailscale Inc & AUTHORS
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
package loggerx
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"strings"
|
|
"testing"
|
|
|
|
"tailscale.com/types/logger"
|
|
)
|
|
|
|
func TestDebugLogging(t *testing.T) {
|
|
var normal, verbose strings.Builder
|
|
SetForTest(t, logfTo(&normal), logfTo(&verbose))
|
|
|
|
checkOutput := func(wantNormal, wantVerbose string) {
|
|
t.Helper()
|
|
if gotNormal := normal.String(); gotNormal != wantNormal {
|
|
t.Errorf("Unexpected normal output: got %q; want %q", gotNormal, wantNormal)
|
|
}
|
|
if gotVerbose := verbose.String(); gotVerbose != wantVerbose {
|
|
t.Errorf("Unexpected verbose output: got %q; want %q", gotVerbose, wantVerbose)
|
|
}
|
|
normal.Reset()
|
|
verbose.Reset()
|
|
}
|
|
|
|
Errorf("This is an error message: %v", 42)
|
|
checkOutput("This is an error message: 42", "")
|
|
Verbosef("This is a verbose message: %v", 17)
|
|
checkOutput("", "This is a verbose message: 17")
|
|
|
|
SetDebugLoggingEnabled(true)
|
|
Errorf("This is an error message: %v", 42)
|
|
checkOutput("This is an error message: 42", "")
|
|
Verbosef("This is a verbose message: %v", 17)
|
|
checkOutput("This is a verbose message: 17", "")
|
|
|
|
SetDebugLoggingEnabled(false)
|
|
Errorf("This is an error message: %v", 42)
|
|
checkOutput("This is an error message: 42", "")
|
|
Verbosef("This is a verbose message: %v", 17)
|
|
checkOutput("", "This is a verbose message: 17")
|
|
}
|
|
|
|
func logfTo(w io.Writer) logger.Logf {
|
|
return func(format string, args ...any) {
|
|
fmt.Fprintf(w, format, args...)
|
|
}
|
|
}
|