From 15b9e77c086001705d8903ccdc7352d6b07b28ed Mon Sep 17 00:00:00 2001 From: Mihail Stoykov Date: Wed, 11 Oct 2023 11:24:12 +0300 Subject: [PATCH] fix: Set console log level to the application one when writing to file This already works when it isn't redirected to a file as it goes through the application wide logger. --- js/console.go | 3 ++- js/runner.go | 4 +++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/js/console.go b/js/console.go index b0c191fee74..d0ffa8842da 100644 --- a/js/console.go +++ b/js/console.go @@ -20,13 +20,14 @@ func newConsole(logger logrus.FieldLogger) *console { } // Creates a console logger with its output set to the file at the provided `filepath`. -func newFileConsole(filepath string, formatter logrus.Formatter) (*console, error) { +func newFileConsole(filepath string, formatter logrus.Formatter, level logrus.Level) (*console, error) { f, err := os.OpenFile(filepath, os.O_WRONLY|os.O_APPEND|os.O_CREATE, 0o644) //nolint:gosec if err != nil { return nil, err } l := logrus.New() + l.SetLevel(level) l.SetOutput(f) l.SetFormatter(formatter) diff --git a/js/runner.go b/js/runner.go index 977bd798017..d86735e2918 100644 --- a/js/runner.go +++ b/js/runner.go @@ -445,10 +445,12 @@ func (r *Runner) SetOptions(opts lib.Options) error { // TODO: fix logger hack, see https://github.com/grafana/k6/issues/2958 // and https://github.com/grafana/k6/issues/2968 var formatter logrus.Formatter = &logrus.JSONFormatter{} + level := logrus.InfoLevel if l, ok := r.preInitState.Logger.(*logrus.Logger); ok { //nolint: forbidigo formatter = l.Formatter + level = l.Level } - c, err := newFileConsole(opts.ConsoleOutput.String, formatter) + c, err := newFileConsole(opts.ConsoleOutput.String, formatter, level) if err != nil { return err }