From b6b20ced72cc5f50e3a050015760db0bef3d00eb Mon Sep 17 00:00:00 2001 From: Jay Pipes Date: Sun, 18 Feb 2024 18:27:21 -0500 Subject: [PATCH] exec: fix debug handler For the exec plugin, we were writing debug output even when the user had not called `gdtcontext.WithDebug()`. In addition, stdout and stderr contents were only being written to debug writers when executed during `on.fail.exec`. These two problems are fixed in this commit in addition to correcting an erroneous `$LOCATION` in the README.md that needed to be `$$LOCATION`. Signed-off-by: Jay Pipes --- .github/workflows/gate-tests.yml | 9 +++++++-- README.md | 2 +- debug/print.go | 10 ++-------- plugin/exec/action.go | 6 ++++++ plugin/exec/eval.go | 10 ---------- plugin/exec/eval_test.go | 2 ++ scenario/run_test.go | 13 ++++++++++--- 7 files changed, 28 insertions(+), 24 deletions(-) diff --git a/.github/workflows/gate-tests.yml b/.github/workflows/gate-tests.yml index 6553a6c..8790e1c 100644 --- a/.github/workflows/gate-tests.yml +++ b/.github/workflows/gate-tests.yml @@ -13,7 +13,7 @@ jobs: test: strategy: matrix: - go-version: [1.19.x, 1.20.x] + go-version: ['1.19', '1.20', '1.21'] os: [ubuntu-latest, macos-latest, windows-latest] runs-on: ${{ matrix.os }} steps: @@ -24,11 +24,16 @@ jobs: disable-sudo: true allowed-endpoints: > github.com:443 + api.github.com:443 + proxy.github.com:443 + raw.githubusercontent.com:443 + objects.githubusercontent.com:443 proxy.golang.org:443 - name: checkout code uses: actions/checkout@c85c95e3d7251135ab7dc9ce3241c5835cc595a9 # v3.5.3 - name: setup go - uses: actions/setup-go@fac708d6674e30b6ba41289acaab6d4b75aa0753 # v4.0.1 + uses: actions/setup-go@cdcb36043654635271a94b9a6d1392de5bb323a7 # v5.0.1 with: go-version: ${{ matrix.go }} + check-latest: true - run: go test -v ./... diff --git a/README.md b/README.md index 62e8eeb..016933a 100644 --- a/README.md +++ b/README.md @@ -402,7 +402,7 @@ tests: headers: - Location - name: look up that created book - GET: $LOCATION + GET: $$LOCATION response: status: 200 json: diff --git a/debug/print.go b/debug/print.go index c26c2bf..87567de 100644 --- a/debug/print.go +++ b/debug/print.go @@ -23,13 +23,10 @@ func Printf( ) { t.Helper() writers := gdtcontext.Debug(ctx) - if writers == nil { - return - } - t.Logf(format, args...) if len(writers) == 0 { return } + t.Logf(format, args...) if !strings.HasPrefix(format, "[gdt] ") { format = "[gdt] " + t.Name() + " " + format @@ -50,14 +47,11 @@ func Println( ) { t.Helper() writers := gdtcontext.Debug(ctx) - if writers == nil { + if len(writers) == 0 { return } // NOTE(jaypipes): T.Logf() automatically adds newlines... t.Logf(format, args...) - if len(writers) == 0 { - return - } if !strings.HasPrefix(format, "[gdt] ") { format = "[gdt] " + t.Name() + " " + format diff --git a/plugin/exec/action.go b/plugin/exec/action.go index 9884972..cadd4b8 100644 --- a/plugin/exec/action.go +++ b/plugin/exec/action.go @@ -79,9 +79,15 @@ func (a *Action) Do( } if outbuf != nil { outbuf.ReadFrom(outpipe) + if outbuf.Len() > 0 { + debug.Println(ctx, t, "exec: stdout: %s", outbuf.String()) + } } if errbuf != nil { errbuf.ReadFrom(errpipe) + if errbuf.Len() > 0 { + debug.Println(ctx, t, "exec: stderr: %s", errbuf.String()) + } } err = cmd.Wait() diff --git a/plugin/exec/eval.go b/plugin/exec/eval.go index 243680f..34c7fd7 100644 --- a/plugin/exec/eval.go +++ b/plugin/exec/eval.go @@ -42,16 +42,6 @@ func (s *Spec) Eval(ctx context.Context, t *testing.T) *result.Result { if err != nil { debug.Println(ctx, t, "error in on.fail.exec: %s", err) } - if outbuf.Len() > 0 { - debug.Println( - ctx, t, "on.fail.exec: stdout: %s", outbuf.String(), - ) - } - if errbuf.Len() > 0 { - debug.Println( - ctx, t, "on.fail.exec: stderr: %s", errbuf.String(), - ) - } } } } diff --git a/plugin/exec/eval_test.go b/plugin/exec/eval_test.go index b598aaf..4fc024a 100644 --- a/plugin/exec/eval_test.go +++ b/plugin/exec/eval_test.go @@ -199,7 +199,9 @@ func TestDebugWriter(t *testing.T) { require.NotEqual(b.Len(), 0) debugout := b.String() require.Contains(debugout, "exec: echo [cat]") + require.Contains(debugout, "exec: stdout: cat") require.Contains(debugout, "exec: sh [-c echo cat 1>&2]") + require.Contains(debugout, "exec: stderr: cat") } func TestWait(t *testing.T) { diff --git a/scenario/run_test.go b/scenario/run_test.go index a114602..722313e 100644 --- a/scenario/run_test.go +++ b/scenario/run_test.go @@ -5,6 +5,8 @@ package scenario_test import ( + "bufio" + "bytes" "context" "os" "path/filepath" @@ -72,9 +74,9 @@ func TestDebugFlushing(t *testing.T) { f, err := os.Open(fp) require.Nil(err) - ctx := gdtcontext.New( - gdtcontext.WithDebug(), - ) + var b bytes.Buffer + w := bufio.NewWriter(&b) + ctx := gdtcontext.New(gdtcontext.WithDebug(w)) s, err := scenario.FromReader(f, scenario.WithPath(fp)) require.Nil(err) @@ -82,6 +84,11 @@ func TestDebugFlushing(t *testing.T) { err = s.Run(ctx, t) require.Nil(err) + require.False(t.Failed()) + w.Flush() + require.NotEqual(b.Len(), 0) + debugout := b.String() + require.Contains(debugout, "TestDebugFlushing/foo-debug-wait-flush wait: 250ms before") } func TestTimeoutCascade(t *testing.T) {