From 138e9bda650224c586d5d1eb232971bb6e986df0 Mon Sep 17 00:00:00 2001 From: Matthias Fasching <5011972+fasmat@users.noreply.github.com> Date: Thu, 5 Dec 2024 11:22:41 +0000 Subject: [PATCH] Add more info to failing systests (#6523) ## Motivation Instead of just printing `unknown error: EOF` add a bit more info as to why watching transaction results sometimes fails. --- systest/tests/common.go | 15 +++++++++++++++ systest/tests/transactions_test.go | 23 +++++++++++++++++------ 2 files changed, 32 insertions(+), 6 deletions(-) diff --git a/systest/tests/common.go b/systest/tests/common.go index adea1d3493..8b488630bd 100644 --- a/systest/tests/common.go +++ b/systest/tests/common.go @@ -133,6 +133,9 @@ BACKOFF: state, err := states.Recv() s, ok := status.FromError(err) if !ok { + if ctx.Err() != nil { + return ctx.Err() + } return fmt.Errorf("unknown error: %w", err) } switch s.Code() { @@ -190,6 +193,9 @@ BACKOFF: layer, err := layers.Recv() s, ok := status.FromError(err) if !ok { + if ctx.Err() != nil { + return ctx.Err() + } return fmt.Errorf("unknown error: %w", err) } switch s.Code() { @@ -235,6 +241,9 @@ BACKOFF: proof, err := proofs.Recv() s, ok := status.FromError(err) if !ok { + if ctx.Err() != nil { + return ctx.Err() + } return fmt.Errorf("unknown error: %w", err) } switch s.Code() { @@ -337,6 +346,9 @@ BACKOFF: rst, err := rsts.Recv() s, ok := status.FromError(err) if !ok { + if ctx.Err() != nil { + return ctx.Err() + } return fmt.Errorf("unknown error: %w", err) } switch s.Code() { @@ -384,6 +396,9 @@ func watchProposals( proposal, err := proposals.Recv() s, ok := status.FromError(err) if !ok { + if ctx.Err() != nil { + return ctx.Err() + } return fmt.Errorf("unknown error: %w", err) } switch s.Code() { diff --git a/systest/tests/transactions_test.go b/systest/tests/transactions_test.go index f2521cd80d..d8d2bece6d 100644 --- a/systest/tests/transactions_test.go +++ b/systest/tests/transactions_test.go @@ -3,11 +3,13 @@ package tests import ( "context" "encoding/hex" + "fmt" "testing" "time" pb "github.com/spacemeshos/api/release/go/spacemesh/v1" "github.com/stretchr/testify/require" + "go.uber.org/zap" "golang.org/x/sync/errgroup" "github.com/spacemeshos/go-spacemesh/common/types" @@ -60,19 +62,28 @@ func testTransactions( for i := range cl.Total() { client := cl.Client(i) eg.Go(func() error { - return watchTransactionResults(ctx, client, tctx.Log.Desugar(), + err := watchTransactionResults(ctx, client, tctx.Log.Desugar(), func(rst *pb.TransactionResult) (bool, error) { txs[i] = append(txs[i], rst.Tx) count := len(txs[i]) - tctx.Log.Debugw("received transaction client", - "layer", rst.Layer, - "client", client.Name, - "tx", "0x"+hex.EncodeToString(rst.Tx.Id), - "count", count, + tctx.Log.Desugar().Debug("received transaction client", + zap.Uint32("layer", rst.Layer), + zap.String("client", client.Name), + zap.String("tx", "0x"+hex.EncodeToString(rst.Tx.Id)), + zap.Int("count", count), ) return len(txs[i]) < expectedCount, nil }, ) + if err != nil { + tctx.Log.Desugar().Error("watching transaction results", + zap.String("client", client.Name), + zap.Error(err), + ) + return fmt.Errorf("watching transaction results for %s: %w", client.Name, err) + } + tctx.Log.Desugar().Debug("finished watching transaction results", zap.String("client", client.Name)) + return nil }) } require.NoError(tb, eg.Wait())