Enable logs in tests (#852)

Pass `-log` option to `go test` in order to change the log level. By default, it's `INFO`.
This commit is contained in:
Adam Babik 2018-04-22 18:50:34 +02:00 committed by GitHub
parent 56292fb505
commit 5f075eeaba
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 58 additions and 56 deletions

View File

@ -11,6 +11,8 @@ import (
"runtime"
"strings"
"github.com/status-im/status-go/logutils"
"github.com/ethereum/go-ethereum/log"
"github.com/ethereum/go-ethereum/p2p/discv5"
"github.com/status-im/status-go/cmd/statusd/debug"
@ -83,32 +85,6 @@ var (
// All general log messages in this package should be routed through this logger.
var logger = log.New("package", "status-go/cmd/statusd")
func enhanceLogger(logger *log.Logger, config *params.NodeConfig) error {
var (
handler log.Handler
err error
)
if config.LogFile != "" {
handler, err = log.FileHandler(config.LogFile, log.LogfmtFormat())
if err != nil {
return err
}
} else {
handler = log.StreamHandler(os.Stderr, log.TerminalFormat(true))
}
level, err := log.LvlFromString(strings.ToLower(config.LogLevel))
if err != nil {
return err
}
filteredHandler := log.LvlFilterHandler(level, handler)
log.Root().SetHandler(filteredHandler)
return nil
}
func main() {
flag.Var(&searchTopics, "topic.search", "Topic that will be searched in discovery v5, e.g (mailserver=1,1)")
flag.Var(&registerTopics, "topic.register", "Topic that will be registered using discovery v5.")
@ -126,7 +102,7 @@ func main() {
return
}
if err := enhanceLogger(&logger, config); err != nil {
if err := logutils.OverrideRootLog(config.LogLevel, config.LogFile, true); err != nil {
stdlog.Fatalf("Error initializing logger: %s", err)
}

View File

@ -9,6 +9,7 @@ import (
"github.com/NaySoftware/go-fcm"
"github.com/ethereum/go-ethereum/log"
"github.com/status-im/status-go/geth/params"
"github.com/status-im/status-go/logutils"
"github.com/status-im/status-go/profiling"
"gopkg.in/go-playground/validator.v9"
)
@ -32,43 +33,18 @@ func GenerateConfig(datadir *C.char, networkID C.int, devMode C.int) *C.char {
return C.CString(string(outBytes))
}
func initLogger(config *params.NodeConfig) {
var (
handler log.Handler
err error
)
if config.LogFile != "" {
handler, err = log.FileHandler(config.LogFile, log.LogfmtFormat())
if err != nil {
return
}
} else {
handler = log.StreamHandler(os.Stderr, log.TerminalFormat(true))
}
// level, err := log.LvlFromString(strings.ToLower(config.LogLevel))
level, err := log.LvlFromString("trace")
if err != nil {
return
}
filteredHandler := log.LvlFilterHandler(level, handler)
log.Root().SetHandler(filteredHandler)
return
}
//StartNode - start Status node
//export StartNode
func StartNode(configJSON *C.char) *C.char {
config, err := params.LoadNodeConfig(C.GoString(configJSON))
if err != nil {
return makeJSONResponse(err)
}
initLogger(config)
if err := logutils.OverrideRootLog(config.LogLevel, config.LogFile, false); err != nil {
return makeJSONResponse(err)
}
statusAPI.StartNodeAsync(config)
return makeJSONResponse(nil)

40
logutils/override.go Normal file
View File

@ -0,0 +1,40 @@
package logutils
import (
"os"
"strings"
"github.com/ethereum/go-ethereum/log"
)
// OverrideRootLog overrides root logger with file handler, if defined,
// and log level (defaults to INFO).
func OverrideRootLog(levelStr, logFile string, terminal bool) error {
var (
handler log.Handler
err error
)
if logFile != "" {
handler, err = log.FileHandler(logFile, log.LogfmtFormat())
if err != nil {
return err
}
} else {
handler = log.StreamHandler(os.Stderr, log.TerminalFormat(terminal))
}
if levelStr == "" {
levelStr = "INFO"
}
level, err := log.LvlFromString(strings.ToLower(levelStr))
if err != nil {
return err
}
filteredHandler := log.LvlFilterHandler(level, handler)
log.Root().SetHandler(filteredHandler)
return nil
}

View File

@ -17,6 +17,8 @@ import (
"testing"
"time"
"github.com/status-im/status-go/logutils"
"github.com/ethereum/go-ethereum/log"
"github.com/status-im/status-go/geth/params"
"github.com/status-im/status-go/static"
@ -26,7 +28,10 @@ import (
var (
networkSelected = flag.String("network", "statuschain", "-network=NETWORKID or -network=NETWORKNAME to select network used for tests")
logLevel = flag.String("log", "INFO", `Log level, one of: "ERROR", "WARN", "INFO", "DEBUG", and "TRACE"`)
)
var (
// ErrNoRemoteURL is returned when network id has no associated url.
ErrNoRemoteURL = errors.New("network id requires a remote URL")
@ -64,6 +69,11 @@ func init() {
flag.Parse()
// set up logger
if err := logutils.OverrideRootLog(*logLevel, "", true); err != nil {
panic(err)
}
// setup root directory
const pathSeparator = string(os.PathSeparator)
RootDir = filepath.Dir(pwd)