From 0d5ede0bffd434c0e58acfe2904188f2530eb09b Mon Sep 17 00:00:00 2001 From: Evgeniy Stratonikov Date: Mon, 12 Jul 2021 14:19:13 +0300 Subject: [PATCH] core/test: use testing.TB in constructors This allows to use chain in benchmarks. Signed-off-by: Evgeniy Stratonikov --- pkg/core/helper_test.go | 15 ++++++++++----- pkg/core/interop_system_test.go | 2 +- 2 files changed, 11 insertions(+), 6 deletions(-) diff --git a/pkg/core/helper_test.go b/pkg/core/helper_test.go index 6ae741619..8847bb92a 100644 --- a/pkg/core/helper_test.go +++ b/pkg/core/helper_test.go @@ -41,6 +41,7 @@ import ( "github.com/nspcc-dev/neo-go/pkg/vm/stackitem" "github.com/nspcc-dev/neo-go/pkg/wallet" "github.com/stretchr/testify/require" + "go.uber.org/zap" "go.uber.org/zap/zaptest" ) @@ -74,22 +75,22 @@ func newTestChainWithNS(t *testing.T) (*Blockchain, util.Uint160) { // newTestChain should be called before newBlock invocation to properly setup // global state. -func newTestChain(t *testing.T) *Blockchain { +func newTestChain(t testing.TB) *Blockchain { return newTestChainWithCustomCfg(t, nil) } -func newTestChainWithCustomCfg(t *testing.T, f func(*config.Config)) *Blockchain { +func newTestChainWithCustomCfg(t testing.TB, f func(*config.Config)) *Blockchain { return newTestChainWithCustomCfgAndStore(t, nil, f) } -func newTestChainWithCustomCfgAndStore(t *testing.T, st storage.Store, f func(*config.Config)) *Blockchain { +func newTestChainWithCustomCfgAndStore(t testing.TB, st storage.Store, f func(*config.Config)) *Blockchain { chain := initTestChain(t, st, f) go chain.Run() t.Cleanup(chain.Close) return chain } -func initTestChain(t *testing.T, st storage.Store, f func(*config.Config)) *Blockchain { +func initTestChain(t testing.TB, st storage.Store, f func(*config.Config)) *Blockchain { unitTestNetCfg, err := config.Load("../../config", testchain.Network()) require.NoError(t, err) if f != nil { @@ -98,7 +99,11 @@ func initTestChain(t *testing.T, st storage.Store, f func(*config.Config)) *Bloc if st == nil { st = storage.NewMemoryStore() } - chain, err := NewBlockchain(st, unitTestNetCfg.ProtocolConfiguration, zaptest.NewLogger(t)) + log := zaptest.NewLogger(t) + if _, ok := t.(*testing.B); ok { + log = zap.NewNop() + } + chain, err := NewBlockchain(st, unitTestNetCfg.ProtocolConfiguration, log) require.NoError(t, err) return chain } diff --git a/pkg/core/interop_system_test.go b/pkg/core/interop_system_test.go index a64b45aa1..1b462baf4 100644 --- a/pkg/core/interop_system_test.go +++ b/pkg/core/interop_system_test.go @@ -450,7 +450,7 @@ func createVM(t *testing.T) (*vm.VM, *interop.Context, *Blockchain) { return v, context, chain } -func createVMAndContractState(t *testing.T) (*vm.VM, *state.Contract, *interop.Context, *Blockchain) { +func createVMAndContractState(t testing.TB) (*vm.VM, *state.Contract, *interop.Context, *Blockchain) { script := []byte("testscript") m := manifest.NewManifest("Test") ne, err := nef.NewFile(script)