From 44a0cf62e9914531f0373f46367adeedd1cb60f2 Mon Sep 17 00:00:00 2001 From: Alex Gartner Date: Thu, 5 Sep 2024 12:28:15 -0700 Subject: [PATCH] fix(zetaclient): use on-chain chain struct --- zetaclient/chains/evm/observer/observer.go | 9 +++--- .../chains/evm/observer/observer_test.go | 28 ++++++++++++++++--- zetaclient/chains/evm/signer/signer_test.go | 10 +++---- zetaclient/orchestrator/bootstrap.go | 6 +++- 4 files changed, 38 insertions(+), 15 deletions(-) diff --git a/zetaclient/chains/evm/observer/observer.go b/zetaclient/chains/evm/observer/observer.go index afe116c95e..32952c28a2 100644 --- a/zetaclient/chains/evm/observer/observer.go +++ b/zetaclient/chains/evm/observer/observer.go @@ -21,11 +21,11 @@ import ( "github.com/zeta-chain/protocol-contracts/v2/pkg/gatewayevm.sol" "github.com/zeta-chain/node/pkg/bg" + "github.com/zeta-chain/node/pkg/chains" observertypes "github.com/zeta-chain/node/x/observer/types" "github.com/zeta-chain/node/zetaclient/chains/base" "github.com/zeta-chain/node/zetaclient/chains/evm" "github.com/zeta-chain/node/zetaclient/chains/interfaces" - "github.com/zeta-chain/node/zetaclient/config" "github.com/zeta-chain/node/zetaclient/db" "github.com/zeta-chain/node/zetaclient/metrics" ) @@ -61,8 +61,9 @@ type priorityFeeConfig struct { // NewObserver returns a new EVM chain observer func NewObserver( ctx context.Context, - evmCfg config.EVMConfig, + chain chains.Chain, evmClient interfaces.EVMRPCClient, + evmJSONRPC interfaces.EVMJSONRPCClient, chainParams observertypes.ChainParams, zetacoreClient interfaces.ZetacoreClient, tss interfaces.TSSSigner, @@ -72,7 +73,7 @@ func NewObserver( ) (*Observer, error) { // create base observer baseObserver, err := base.NewObserver( - evmCfg.Chain, + chain, chainParams, zetacoreClient, tss, @@ -90,7 +91,7 @@ func NewObserver( ob := &Observer{ Observer: *baseObserver, evmClient: evmClient, - evmJSONRPC: ethrpc.NewEthRPC(evmCfg.Endpoint), + evmJSONRPC: evmJSONRPC, outboundConfirmedReceipts: make(map[string]*ethtypes.Receipt), outboundConfirmedTransactions: make(map[string]*ethtypes.Transaction), priorityFeeConfig: priorityFeeConfig{}, diff --git a/zetaclient/chains/evm/observer/observer_test.go b/zetaclient/chains/evm/observer/observer_test.go index 61c1c25ecb..f89715022a 100644 --- a/zetaclient/chains/evm/observer/observer_test.go +++ b/zetaclient/chains/evm/observer/observer_test.go @@ -100,6 +100,11 @@ func MockEVMObserver( evmClient = mocks.NewMockEvmClient().WithBlockNumber(1000) } + // use default mock evm client if not provided + if evmJSONRPC == nil { + evmJSONRPC = mocks.NewMockJSONRPCClient() + } + // use default mock zetacore client if not provided if zetacoreClient == nil { zetacoreClient = mocks.NewZetacoreClient(t). @@ -113,7 +118,7 @@ func MockEVMObserver( tss = mocks.NewTSSMainnet() } // create AppContext - appContext, evmCfg := getAppContext(t, chain, "", ¶ms) + appContext, _ := getAppContext(t, chain, "", ¶ms) database, err := db.NewFromSqliteInMemory(true) require.NoError(t, err) @@ -122,9 +127,19 @@ func MockEVMObserver( logger := base.Logger{Std: testLogger, Compliance: testLogger} // create observer - ob, err := observer.NewObserver(ctx, evmCfg, evmClient, params, zetacoreClient, tss, database, logger, nil) + ob, err := observer.NewObserver( + ctx, + chain, + evmClient, + evmJSONRPC, + params, + zetacoreClient, + tss, + database, + logger, + nil, + ) require.NoError(t, err) - ob.WithEvmJSONRPC(evmJSONRPC) ob.WithLastBlock(lastBlock) return ob, appContext @@ -143,6 +158,7 @@ func Test_NewObserver(t *testing.T) { evmCfg config.EVMConfig chainParams observertypes.ChainParams evmClient interfaces.EVMRPCClient + evmJSONRPC interfaces.EVMJSONRPCClient tss interfaces.TSSSigner logger base.Logger before func() @@ -159,6 +175,7 @@ func Test_NewObserver(t *testing.T) { }, chainParams: params, evmClient: mocks.NewMockEvmClient().WithBlockNumber(1000), + evmJSONRPC: mocks.NewMockJSONRPCClient(), tss: mocks.NewTSSMainnet(), logger: base.Logger{}, ts: nil, @@ -172,6 +189,7 @@ func Test_NewObserver(t *testing.T) { }, chainParams: params, evmClient: mocks.NewMockEvmClient().WithError(fmt.Errorf("error RPC")), + evmJSONRPC: mocks.NewMockJSONRPCClient(), tss: mocks.NewTSSMainnet(), logger: base.Logger{}, ts: nil, @@ -186,6 +204,7 @@ func Test_NewObserver(t *testing.T) { }, chainParams: params, evmClient: mocks.NewMockEvmClient().WithBlockNumber(1000), + evmJSONRPC: mocks.NewMockJSONRPCClient(), tss: mocks.NewTSSMainnet(), before: func() { envVar := base.EnvVarLatestBlockByChain(chain) @@ -222,8 +241,9 @@ func Test_NewObserver(t *testing.T) { // create observer ob, err := observer.NewObserver( ctx, - tt.evmCfg, + chain, tt.evmClient, + tt.evmJSONRPC, tt.chainParams, zetacoreClient, tt.tss, diff --git a/zetaclient/chains/evm/signer/signer_test.go b/zetaclient/chains/evm/signer/signer_test.go index b954a4624c..807d6b7819 100644 --- a/zetaclient/chains/evm/signer/signer_test.go +++ b/zetaclient/chains/evm/signer/signer_test.go @@ -69,14 +69,11 @@ func getNewEvmChainObserver(t *testing.T, tss interfaces.TSSSigner) (*observer.O if tss == nil { tss = mocks.NewTSSMainnet() } - cfg := config.New(false) // prepare mock arguments to create observer - evmcfg := config.EVMConfig{Chain: chains.BscMainnet, Endpoint: "http://localhost:8545"} evmClient := mocks.NewMockEvmClient().WithBlockNumber(1000) - params := mocks.MockChainParams(evmcfg.Chain.ChainId, 10) - cfg.EVMChainConfigs[chains.BscMainnet.ChainId] = evmcfg - //appContext := context.New(cfg, zerolog.Nop()) + evmJSONRPCClient := mocks.NewMockJSONRPCClient() + params := mocks.MockChainParams(chains.BscMainnet.ChainId, 10) logger := base.Logger{} ts := &metrics.TelemetryServer{} @@ -85,8 +82,9 @@ func getNewEvmChainObserver(t *testing.T, tss interfaces.TSSSigner) (*observer.O return observer.NewObserver( ctx, - evmcfg, + chains.BscMainnet, evmClient, + evmJSONRPCClient, params, mocks.NewZetacoreClient(t), tss, diff --git a/zetaclient/orchestrator/bootstrap.go b/zetaclient/orchestrator/bootstrap.go index 9040133c35..7dd4344b29 100644 --- a/zetaclient/orchestrator/bootstrap.go +++ b/zetaclient/orchestrator/bootstrap.go @@ -7,6 +7,7 @@ import ( "github.com/ethereum/go-ethereum/ethclient" ethrpc "github.com/ethereum/go-ethereum/rpc" solrpc "github.com/gagliardetto/solana-go/rpc" + ethrpc2 "github.com/onrik/ethrpc" "github.com/pkg/errors" "github.com/zeta-chain/node/zetaclient/chains/base" @@ -298,11 +299,14 @@ func syncObserverMap( continue } + evmJSONRPCClient := ethrpc2.NewEthRPC(cfg.Endpoint, ethrpc2.WithHttpClient(httpClient)) + // create EVM chain observer observer, err := evmobserver.NewObserver( ctx, - cfg, + *rawChain, evmClient, + evmJSONRPCClient, *params, client, tss,