open-nomad/helper/testlog/testlog.go

47 lines
1.2 KiB
Go
Raw Normal View History

2018-01-08 21:36:07 +00:00
// Package testlog creates a *log.Logger backed by *testing.T to ease logging
// in tests. This allows logs from components being tested to only be printed
// if the test fails (or the verbose flag is specified).
package testlog
import (
"io"
"log"
)
2018-01-08 21:36:07 +00:00
// LogPrinter is the methods of testing.T (or testing.B) needed by the test
// logger.
2018-01-08 21:36:07 +00:00
type LogPrinter interface {
Logf(format string, args ...interface{})
}
// writer implements io.Writer on top of a Logger.
type writer struct {
2018-01-08 21:36:07 +00:00
t LogPrinter
}
// Write to an underlying Logger. Never returns an error.
func (w *writer) Write(p []byte) (n int, err error) {
w.t.Logf(string(p))
return len(p), nil
}
// NewWriter creates a new io.Writer backed by a Logger.
2018-01-08 21:36:07 +00:00
func NewWriter(t LogPrinter) io.Writer {
return &writer{t}
}
2018-01-08 21:36:07 +00:00
// New returns a new test logger. See https://golang.org/pkg/log/#New
func New(t LogPrinter, prefix string, flag int) *log.Logger {
return log.New(&writer{t}, prefix, flag)
}
2018-01-08 21:36:07 +00:00
// WithPrefix returns a new test logger with the Lmicroseconds flag set.
func WithPrefix(t LogPrinter, prefix string) *log.Logger {
return New(t, prefix, log.Lmicroseconds)
}
// NewLog logger with "TEST" prefix and the Lmicroseconds flag.
func Logger(t LogPrinter) *log.Logger {
return WithPrefix(t, "TEST ")
}