From 202e24b977074559bd5f42dc3012b22de347c2cc Mon Sep 17 00:00:00 2001 From: Nedyalko Andreev Date: Mon, 7 Mar 2022 11:25:16 +0200 Subject: [PATCH] Wait for file log to drain before k6 exits --- cmd/root.go | 3 ++- log/file.go | 7 ++++++- log/file_test.go | 5 ++++- 3 files changed, 12 insertions(+), 3 deletions(-) diff --git a/cmd/root.go b/cmd/root.go index b3c33e49235a..b8e680871052 100644 --- a/cmd/root.go +++ b/cmd/root.go @@ -300,7 +300,8 @@ func (c *rootCommand) setupLoggers() (<-chan struct{}, error) { c.logFmt = "raw" case strings.HasPrefix(line, "file"): - hook, err := log.FileHookFromConfigLine(c.ctx, c.fallbackLogger, line) + ch = make(chan struct{}) + hook, err := log.FileHookFromConfigLine(c.ctx, c.fallbackLogger, line, ch) if err != nil { return nil, err } diff --git a/log/file.go b/log/file.go index 6fef81dcbe78..eb248b7d92cc 100644 --- a/log/file.go +++ b/log/file.go @@ -44,15 +44,19 @@ type fileHook struct { w io.WriteCloser bw *bufio.Writer levels []logrus.Level + done chan struct{} } // FileHookFromConfigLine returns new fileHook hook. func FileHookFromConfigLine( - ctx context.Context, fallbackLogger logrus.FieldLogger, line string, + ctx context.Context, fallbackLogger logrus.FieldLogger, line string, done chan struct{}, ) (logrus.Hook, error) { + // TODO: fix this so it works correctly with relative paths from the CWD + hook := &fileHook{ fallbackLogger: fallbackLogger, levels: logrus.AllLevels, + done: done, } parts := strings.SplitN(line, "=", 2) @@ -135,6 +139,7 @@ func (h *fileHook) loop(ctx context.Context) chan []byte { h.fallbackLogger.Errorf("failed to close logfile: %w", err) } + close(h.done) return } } diff --git a/log/file_test.go b/log/file_test.go index 59da6a5d4e2a..49a36ed893da 100644 --- a/log/file_test.go +++ b/log/file_test.go @@ -115,7 +115,9 @@ func TestFileHookFromConfigLine(t *testing.T) { t.Run(test.line, func(t *testing.T) { t.Parallel() - res, err := FileHookFromConfigLine(context.Background(), logrus.New(), test.line) + res, err := FileHookFromConfigLine( + context.Background(), logrus.New(), test.line, make(chan struct{}), + ) if test.err { require.Error(t, err) @@ -147,6 +149,7 @@ func TestFileHookFire(t *testing.T) { w: nc, bw: bufio.NewWriter(nc), levels: logrus.AllLevels, + done: make(chan struct{}), } ctx, cancel := context.WithCancel(context.Background())