mirror of
https://github.com/foxcpp/maddy.git
synced 2025-04-05 22:17:39 +03:00
The intention is to keep to repo root clean while the list of packages is slowly growing. Additionally, a bunch of small (~30 LoC) files in the repo root is merged into a single maddy.go file, for the same reason. Most of the internal code is moved into the internal/ directory. Go toolchain will make it impossible to import these packages from external applications. Some packages are renamed and moved into the pkg/ directory in the root. According to https://github.com/golang-standards/project-layout this is the de-facto standard to place "library code that's ok to use by external applications" in. To clearly define the purpose of top-level directories, README.md files are added to each.
31 lines
526 B
Go
31 lines
526 B
Go
package testutils
|
|
|
|
import (
|
|
"flag"
|
|
"strings"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/foxcpp/maddy/internal/log"
|
|
)
|
|
|
|
var (
|
|
debugLog = flag.Bool("test.debuglog", false, "Turn on debug log messages")
|
|
)
|
|
|
|
func Logger(t *testing.T, name string) log.Logger {
|
|
return log.Logger{
|
|
Out: log.FuncOutput(func(_ time.Time, debug bool, str string) {
|
|
t.Helper()
|
|
str = strings.TrimSuffix(str, "\n")
|
|
if debug {
|
|
str = "[debug] " + str
|
|
}
|
|
t.Log(str)
|
|
}, func() error {
|
|
return nil
|
|
}),
|
|
Name: name,
|
|
Debug: *debugLog,
|
|
}
|
|
}
|