From c587844687c1da9e5a35a0df0085f326d77dd157 Mon Sep 17 00:00:00 2001 From: Brian Sztamfater Date: Fri, 10 Jan 2025 03:13:20 -0300 Subject: [PATCH] fix_: unit tests for router Signed-off-by: Brian Sztamfater --- api/default_networks.go | 4 +- api/default_networks_test.go | 4 +- .../community-tokens/deployer/address.go | 2 - services/wallet/router/router_test_data.go | 914 +++++++++++++++--- .../token/balancefetcher/balance_fetcher.go | 2 - 5 files changed, 790 insertions(+), 136 deletions(-) diff --git a/api/default_networks.go b/api/default_networks.go index c3b5c94c299..e5ac88a6574 100644 --- a/api/default_networks.go +++ b/api/default_networks.go @@ -127,7 +127,7 @@ func base(stageName string) params.Network { FallbackURL: "https://base-archival.rpc.grove.city/v1/", BlockExplorerURL: "https://basescan.org", IconURL: "network/Network=Base", - ChainColor: "#E90101", + ChainColor: "#0052FF", ShortName: "base", NativeCurrencyName: "Ether", NativeCurrencySymbol: "ETH", @@ -150,7 +150,7 @@ func baseSepolia(stageName string) params.Network { FallbackURL: "https://base-sepolia-archival.rpc.grove.city/v1/", BlockExplorerURL: "https://sepolia.basescan.org/", IconURL: "network/Network=Base", - ChainColor: "#E90101", + ChainColor: "#0052FF", ShortName: "base", NativeCurrencyName: "Ether", NativeCurrencySymbol: "ETH", diff --git a/api/default_networks_test.go b/api/default_networks_test.go index ed8870d8626..1ff394ee97c 100644 --- a/api/default_networks_test.go +++ b/api/default_networks_test.go @@ -23,7 +23,7 @@ func TestBuildDefaultNetworks(t *testing.T) { actualNetworks := BuildDefaultNetworks(&request.WalletSecretsConfig) - require.Len(t, actualNetworks, 6) + require.Len(t, actualNetworks, 8) for _, n := range actualNetworks { var err error @@ -65,7 +65,7 @@ func TestBuildDefaultNetworksGanache(t *testing.T) { actualNetworks := BuildDefaultNetworks(&request.WalletSecretsConfig) - require.Len(t, actualNetworks, 6) + require.Len(t, actualNetworks, 8) for _, n := range actualNetworks { require.True(t, strings.Contains(n.RPCURL, ganacheURL)) diff --git a/contracts/community-tokens/deployer/address.go b/contracts/community-tokens/deployer/address.go index 43c7e15caaf..1420ceeb0a6 100644 --- a/contracts/community-tokens/deployer/address.go +++ b/contracts/community-tokens/deployer/address.go @@ -13,11 +13,9 @@ var contractAddressByChainID = map[uint64]common.Address{ 1: common.HexToAddress("0xB3Ef5B0825D5f665bE14394eea41E684CE96A4c5"), // Mainnet 10: common.HexToAddress("0x31463D22750324C8721FF7751584EF62F2ff93b3"), // Optimism 42161: common.HexToAddress("0x744Fd6e98dad09Fb8CCF530B5aBd32B56D64943b"), // Arbitrum - 8453: common.HexToAddress(""), // Base 11155111: common.HexToAddress("0xCDE984e57cdb88c70b53437cc694345B646371f9"), // Sepolia 421614: common.HexToAddress("0x7Ff554af5b6624db2135E4364F416d1D397f43e6"), // Arbitrum Sepolia 11155420: common.HexToAddress("0xcE2A896eEA2F585BC0C3753DC8116BbE2AbaE541"), // Optimism Sepolia - 84532: common.HexToAddress(""), // Base Sepolia } func ContractAddress(chainID uint64) (common.Address, error) { diff --git a/services/wallet/router/router_test_data.go b/services/wallet/router/router_test_data.go index d30e437b947..89c1e39c682 100644 --- a/services/wallet/router/router_test_data.go +++ b/services/wallet/router/router_test_data.go @@ -85,6 +85,8 @@ var ( makeBalanceKey(walletCommon.OptimismMainnet, walletCommon.UsdcSymbol): big.NewInt(testAmount100USDC), makeBalanceKey(walletCommon.ArbitrumMainnet, walletCommon.EthSymbol): big.NewInt(testAmount2ETHInWei), makeBalanceKey(walletCommon.ArbitrumMainnet, walletCommon.UsdcSymbol): big.NewInt(testAmount100USDC), + makeBalanceKey(walletCommon.BaseMainnet, walletCommon.EthSymbol): big.NewInt(testAmount2ETHInWei), + makeBalanceKey(walletCommon.BaseMainnet, walletCommon.UsdcSymbol): big.NewInt(testAmount100USDC), } ) @@ -150,10 +152,31 @@ var arbitrum = params.Network{ RelatedChainID: walletCommon.ArbitrumMainnet, } +var base = params.Network{ + ChainID: walletCommon.BaseMainnet, + ChainName: "Base", + DefaultRPCURL: fmt.Sprintf("https://%s.api.status.im/nodefleet/base/mainnet/", stageName), + DefaultFallbackURL: fmt.Sprintf("https://%s.api.status.im/infura/base/mainnet/", stageName), + DefaultFallbackURL2: "https://base-mainnet.infura.io/v3/", + RPCURL: fmt.Sprintf("https://%s.api.status.im/grove/base/mainnet/", stageName), + FallbackURL: "https://base.rpc.grove.city/v1/", + IconURL: "network/Network=Base", + ChainColor: "#0052FF", + ShortName: "base", + NativeCurrencyName: "Ether", + NativeCurrencySymbol: "ETH", + NativeCurrencyDecimals: 18, + IsTest: false, + Layer: 2, + Enabled: true, + RelatedChainID: walletCommon.BaseMainnet, +} + var defaultNetworks = []params.Network{ mainnet, optimism, arbitrum, + base, } type normalTestParams struct { @@ -175,8 +198,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -250,6 +273,11 @@ func getNormalTestParamsList() []normalTestParams { FromChain: &arbitrum, ToChain: &arbitrum, ApprovalRequired: false, + }, { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &base, + ToChain: &base, + ApprovalRequired: false, }, }, }, @@ -299,6 +327,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &base, + ToChain: &base, + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &mainnet, @@ -311,6 +345,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &optimism, @@ -323,6 +363,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, @@ -335,6 +381,30 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + ApprovalRequired: false, + }, }, }, { @@ -347,7 +417,7 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -385,6 +455,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &mainnet, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + ApprovalRequired: false, + }, }, }, { @@ -397,7 +473,7 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -453,6 +529,18 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + ApprovalRequired: false, + }, }, }, { @@ -465,7 +553,7 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -504,6 +592,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: false, + }, }, }, { @@ -548,6 +642,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &base, + ToChain: &base, + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &optimism, @@ -560,6 +660,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, @@ -572,6 +678,30 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + ApprovalRequired: false, + }, }, }, { @@ -584,8 +714,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -623,8 +753,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -662,8 +792,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -701,8 +831,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -758,8 +888,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -797,8 +927,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -874,6 +1004,13 @@ func getNormalTestParamsList() []normalTestParams { AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point8ETHInWei)), ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &base, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point8ETHInWei)), + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &mainnet, @@ -888,6 +1025,13 @@ func getNormalTestParamsList() []normalTestParams { AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &optimism, @@ -902,6 +1046,13 @@ func getNormalTestParamsList() []normalTestParams { AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point8ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point8ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, @@ -916,6 +1067,34 @@ func getNormalTestParamsList() []normalTestParams { AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point8ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point8ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point8ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point8ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point8ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, }, }, { @@ -928,10 +1107,11 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, FromLockedAmount: map[uint64]*hexutil.Big{ walletCommon.EthereumMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), walletCommon.ArbitrumMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), + walletCommon.BaseMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), }, TestsMode: true, @@ -956,7 +1136,7 @@ func getNormalTestParamsList() []normalTestParams { ProcessorName: pathProcessorCommon.ProcessorTransferName, FromChain: &optimism, ToChain: &optimism, - AmountOut: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei - testAmount0Point2ETHInWei - testAmount0Point3ETHInWei)), + AmountOut: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei - testAmount0Point2ETHInWei - testAmount0Point3ETHInWei - testAmount0Point3ETHInWei)), ApprovalRequired: false, }, { @@ -973,6 +1153,13 @@ func getNormalTestParamsList() []normalTestParams { AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), //(*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), //(*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), + ApprovalRequired: false, + }, }, }, { @@ -988,6 +1175,7 @@ func getNormalTestParamsList() []normalTestParams { FromLockedAmount: map[uint64]*hexutil.Big{ walletCommon.EthereumMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), walletCommon.OptimismMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), + walletCommon.BaseMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), }, TestsMode: true, @@ -1026,7 +1214,14 @@ func getNormalTestParamsList() []normalTestParams { ProcessorName: pathProcessorCommon.ProcessorTransferName, FromChain: &arbitrum, ToChain: &arbitrum, - AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point5ETHInWei)), + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &base, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), ApprovalRequired: false, }, { @@ -1043,6 +1238,13 @@ func getNormalTestParamsList() []normalTestParams { AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &optimism, @@ -1057,18 +1259,53 @@ func getNormalTestParamsList() []normalTestParams { AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, ToChain: &mainnet, - AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point5ETHInWei - testBonderFeeETH)), + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, ToChain: &optimism, - AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point5ETHInWei - testBonderFeeETH)), + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, }, @@ -1086,7 +1323,8 @@ func getNormalTestParamsList() []normalTestParams { FromLockedAmount: map[uint64]*hexutil.Big{ walletCommon.EthereumMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), walletCommon.OptimismMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), - walletCommon.ArbitrumMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point5ETHInWei)), + walletCommon.ArbitrumMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), + walletCommon.BaseMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), }, TestsMode: true, @@ -1125,7 +1363,14 @@ func getNormalTestParamsList() []normalTestParams { ProcessorName: pathProcessorCommon.ProcessorTransferName, FromChain: &arbitrum, ToChain: &arbitrum, - AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point5ETHInWei)), + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &base, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), ApprovalRequired: false, }, { @@ -1142,6 +1387,13 @@ func getNormalTestParamsList() []normalTestParams { AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &optimism, @@ -1156,18 +1408,53 @@ func getNormalTestParamsList() []normalTestParams { AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, ToChain: &mainnet, - AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point5ETHInWei - testBonderFeeETH)), + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, ToChain: &optimism, - AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point5ETHInWei - testBonderFeeETH)), + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei - testBonderFeeETH)), ApprovalRequired: false, }, }, @@ -1184,8 +1471,9 @@ func getNormalTestParamsList() []normalTestParams { TokenID: walletCommon.EthSymbol, FromLockedAmount: map[uint64]*hexutil.Big{ walletCommon.EthereumMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), - walletCommon.OptimismMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point3ETHInWei)), - walletCommon.ArbitrumMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point4ETHInWei)), + walletCommon.OptimismMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), + walletCommon.ArbitrumMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), + walletCommon.BaseMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point2ETHInWei)), }, TestsMode: true, @@ -1290,6 +1578,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: false, }, + { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &base, + ToChain: &base, + ApprovalRequired: false, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &mainnet, @@ -1302,6 +1596,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + ApprovalRequired: true, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &optimism, @@ -1314,6 +1614,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + ApprovalRequired: true, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, @@ -1326,6 +1632,30 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + ApprovalRequired: true, + }, }, }, { @@ -1338,7 +1668,7 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1376,6 +1706,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &mainnet, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + ApprovalRequired: true, + }, }, }, { @@ -1388,7 +1724,7 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1444,6 +1780,18 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + ApprovalRequired: true, + }, }, }, { @@ -1456,7 +1804,7 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1494,6 +1842,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: true, + }, }, }, { @@ -1506,7 +1860,7 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1550,6 +1904,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + ApprovalRequired: true, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, @@ -1562,6 +1922,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: true, + }, }, }, { @@ -1574,8 +1940,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1613,8 +1979,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1652,8 +2018,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1691,8 +2057,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1748,8 +2114,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1787,8 +2153,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -1818,7 +2184,7 @@ func getNormalTestParamsList() []normalTestParams { SendType: sendtype.Transfer, AddrFrom: common.HexToAddress("0x1"), AddrTo: common.HexToAddress("0x2"), - AmountIn: (*hexutil.Big)(big.NewInt(2.5 * testAmount100USDC)), + AmountIn: (*hexutil.Big)(big.NewInt(3.5 * testAmount100USDC)), TokenID: walletCommon.UsdcSymbol, TestsMode: true, @@ -1843,7 +2209,7 @@ func getNormalTestParamsList() []normalTestParams { ProcessorName: pathProcessorCommon.ProcessorTransferName, FromChain: &mainnet, ToChain: &mainnet, - AmountOut: (*hexutil.Big)(big.NewInt(2.5 * testAmount100USDC)), + AmountOut: (*hexutil.Big)(big.NewInt(3.5 * testAmount100USDC)), ApprovalRequired: false, }, { @@ -1857,7 +2223,7 @@ func getNormalTestParamsList() []normalTestParams { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &mainnet, ToChain: &optimism, - AmountOut: (*hexutil.Big)(big.NewInt(2.5*testAmount100USDC - testBonderFeeUSDC)), + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { @@ -1869,142 +2235,254 @@ func getNormalTestParamsList() []normalTestParams { }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &mainnet, - ToChain: &arbitrum, - AmountOut: (*hexutil.Big)(big.NewInt(2.5*testAmount100USDC - testBonderFeeUSDC)), + FromChain: &mainnet, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &optimism, + ToChain: &optimism, + AmountOut: (*hexutil.Big)(big.NewInt(3.5 * testAmount100USDC)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &optimism, + ToChain: &optimism, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC)), + ApprovalRequired: false, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &mainnet, + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &mainnet, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &mainnet, - ToChain: &arbitrum, + FromChain: &optimism, + ToChain: &base, AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorTransferName, - FromChain: &optimism, - ToChain: &optimism, + FromChain: &arbitrum, + ToChain: &arbitrum, AmountOut: (*hexutil.Big)(big.NewInt(0.5 * testAmount100USDC)), ApprovalRequired: false, }, { ProcessorName: pathProcessorCommon.ProcessorTransferName, - FromChain: &optimism, - ToChain: &optimism, + FromChain: &arbitrum, + ToChain: &arbitrum, AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC)), ApprovalRequired: false, }, { ProcessorName: pathProcessorCommon.ProcessorTransferName, - FromChain: &optimism, - ToChain: &optimism, - AmountOut: (*hexutil.Big)(big.NewInt(2.5 * testAmount100USDC)), + FromChain: &arbitrum, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(3.5 * testAmount100USDC)), ApprovalRequired: false, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &optimism, + FromChain: &arbitrum, ToChain: &mainnet, AmountOut: (*hexutil.Big)(big.NewInt(0.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &optimism, + FromChain: &arbitrum, ToChain: &mainnet, AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &optimism, + FromChain: &arbitrum, ToChain: &mainnet, - AmountOut: (*hexutil.Big)(big.NewInt(2.5*testAmount100USDC - testBonderFeeUSDC)), + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &optimism, - ToChain: &arbitrum, + FromChain: &arbitrum, + ToChain: &optimism, AmountOut: (*hexutil.Big)(big.NewInt(0.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &optimism, - ToChain: &arbitrum, + FromChain: &arbitrum, + ToChain: &optimism, AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &optimism, - ToChain: &arbitrum, - AmountOut: (*hexutil.Big)(big.NewInt(2.5*testAmount100USDC - testBonderFeeUSDC)), + FromChain: &arbitrum, + ToChain: &optimism, + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { - ProcessorName: pathProcessorCommon.ProcessorTransferName, + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, - ToChain: &arbitrum, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(0.5*testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorTransferName, + FromChain: &base, + ToChain: &base, AmountOut: (*hexutil.Big)(big.NewInt(0.5 * testAmount100USDC)), ApprovalRequired: false, }, { ProcessorName: pathProcessorCommon.ProcessorTransferName, - FromChain: &arbitrum, - ToChain: &arbitrum, + FromChain: &base, + ToChain: &base, AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC)), ApprovalRequired: false, }, { ProcessorName: pathProcessorCommon.ProcessorTransferName, - FromChain: &arbitrum, - ToChain: &arbitrum, - AmountOut: (*hexutil.Big)(big.NewInt(2.5 * testAmount100USDC)), + FromChain: &base, + ToChain: &base, + AmountOut: (*hexutil.Big)(big.NewInt(3.5 * testAmount100USDC)), ApprovalRequired: false, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &arbitrum, + FromChain: &base, ToChain: &mainnet, AmountOut: (*hexutil.Big)(big.NewInt(0.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &arbitrum, + FromChain: &base, ToChain: &mainnet, AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &arbitrum, + FromChain: &base, ToChain: &mainnet, - AmountOut: (*hexutil.Big)(big.NewInt(2.5*testAmount100USDC - testBonderFeeUSDC)), + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &arbitrum, + FromChain: &base, ToChain: &optimism, AmountOut: (*hexutil.Big)(big.NewInt(0.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &arbitrum, + FromChain: &base, ToChain: &optimism, AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, - FromChain: &arbitrum, + FromChain: &base, ToChain: &optimism, - AmountOut: (*hexutil.Big)(big.NewInt(2.5*testAmount100USDC - testBonderFeeUSDC)), + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(0.5*testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(testAmount100USDC - testBonderFeeUSDC)), + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + AmountOut: (*hexutil.Big)(big.NewInt(3.5*testAmount100USDC - testBonderFeeUSDC)), ApprovalRequired: true, }, }, @@ -2050,6 +2528,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + ApprovalRequired: true, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &optimism, @@ -2062,6 +2546,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + ApprovalRequired: true, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, @@ -2074,6 +2564,30 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + ApprovalRequired: true, + }, }, }, { @@ -2086,7 +2600,7 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2118,6 +2632,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &mainnet, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + ApprovalRequired: true, + }, }, }, { @@ -2162,18 +2682,48 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + ApprovalRequired: true, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &optimism, ToChain: &arbitrum, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &optimism, + ApprovalRequired: true, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, ToChain: &optimism, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + ApprovalRequired: true, + }, }, }, { @@ -2186,7 +2736,7 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2218,6 +2768,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: true, + }, }, }, { @@ -2262,6 +2818,12 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &optimism, + ToChain: &base, + ApprovalRequired: true, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, @@ -2274,6 +2836,30 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &optimism, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &mainnet, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + ApprovalRequired: true, + }, }, }, { @@ -2286,8 +2872,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2319,8 +2905,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2358,8 +2944,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2418,12 +3004,36 @@ func getNormalTestParamsList() []normalTestParams { ToChain: &arbitrum, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &mainnet, + ToChain: &base, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &arbitrum, + ToChain: &mainnet, + ApprovalRequired: true, + }, { ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, FromChain: &arbitrum, + ToChain: &base, + ApprovalRequired: true, + }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, ToChain: &mainnet, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &arbitrum, + ApprovalRequired: true, + }, }, }, { @@ -2436,8 +3046,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2475,8 +3085,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2508,8 +3118,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount3ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2550,8 +3160,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(5 * testAmount100USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2592,8 +3202,8 @@ func getNormalTestParamsList() []normalTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(0.01 * testAmount1USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet}, - DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.OptimismMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.OptimismMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2645,8 +3255,8 @@ func getNoBalanceTestParamsList() []noBalanceTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount100USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2678,8 +3288,8 @@ func getNoBalanceTestParamsList() []noBalanceTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount100USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2725,7 +3335,7 @@ func getNoBalanceTestParamsList() []noBalanceTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount100USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2743,6 +3353,8 @@ func getNoBalanceTestParamsList() []noBalanceTestParams { makeBalanceKey(walletCommon.OptimismMainnet, walletCommon.EthSymbol): big.NewInt(0), makeBalanceKey(walletCommon.ArbitrumMainnet, walletCommon.UsdcSymbol): big.NewInt(0), makeBalanceKey(walletCommon.ArbitrumMainnet, walletCommon.EthSymbol): big.NewInt(0), + makeBalanceKey(walletCommon.BaseMainnet, walletCommon.UsdcSymbol): big.NewInt(0), + makeBalanceKey(walletCommon.BaseMainnet, walletCommon.EthSymbol): big.NewInt(0), }, EstimationMap: testEstimationMap, BonderFeeMap: testBBonderFeeMap, @@ -2755,14 +3367,15 @@ func getNoBalanceTestParamsList() []noBalanceTestParams { { name: "ERC20 transfer - No Specific FromChain - Specific ToChain - Enough Token Balance On Arbitrum Chain But Not Enough Native Balance", input: &requests.RouteInputParams{ - TestnetMode: false, - Uuid: uuid.NewString(), - SendType: sendtype.Transfer, - AddrFrom: common.HexToAddress("0x1"), - AddrTo: common.HexToAddress("0x2"), - AmountIn: (*hexutil.Big)(big.NewInt(testAmount100USDC)), - TokenID: walletCommon.UsdcSymbol, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, + TestnetMode: false, + Uuid: uuid.NewString(), + SendType: sendtype.Transfer, + AddrFrom: common.HexToAddress("0x1"), + AddrTo: common.HexToAddress("0x2"), + AmountIn: (*hexutil.Big)(big.NewInt(testAmount100USDC)), + TokenID: walletCommon.UsdcSymbol, + DisabledFromChainIDs: []uint64{walletCommon.BaseMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2824,7 +3437,7 @@ func getNoBalanceTestParamsList() []noBalanceTestParams { AddrTo: common.HexToAddress("0x2"), AmountIn: (*hexutil.Big)(big.NewInt(testAmount100USDC)), TokenID: walletCommon.UsdcSymbol, - DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, + DisabledToChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2866,6 +3479,12 @@ func getNoBalanceTestParamsList() []noBalanceTestParams { ToChain: &optimism, ApprovalRequired: true, }, + { + ProcessorName: pathProcessorCommon.ProcessorBridgeHopName, + FromChain: &base, + ToChain: &optimism, + ApprovalRequired: true, + }, }, expectedBest: routes.Route{ { @@ -2895,7 +3514,7 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { SendType: sendtype.Transfer, AmountIn: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.ArbitrumMainnet, walletCommon.BaseMainnet}, TestsMode: true, TestParams: &requests.RouterTestParams{ @@ -2956,7 +3575,7 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { SendType: sendtype.Transfer, AmountIn: (*hexutil.Big)(big.NewInt(testAmount2ETHInWei)), TokenID: walletCommon.EthSymbol, - DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet}, + DisabledFromChainIDs: []uint64{walletCommon.EthereumMainnet, walletCommon.BaseMainnet}, FromLockedAmount: map[uint64]*hexutil.Big{ walletCommon.OptimismMainnet: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), }, @@ -3105,6 +3724,12 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { locked: false, }, }, + walletCommon.BaseMainnet: { + { + amount: big.NewInt(testAmount3ETHInWei), + locked: false, + }, + }, }, }, { @@ -3113,7 +3738,7 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { TestnetMode: false, Uuid: uuid.NewString(), SendType: sendtype.Transfer, - AmountIn: (*hexutil.Big)(big.NewInt(testAmount3ETHInWei)), + AmountIn: (*hexutil.Big)(big.NewInt(testAmount3ETHInWei + testAmount1ETHInWei)), TokenID: walletCommon.EthSymbol, TestsMode: true, @@ -3127,13 +3752,14 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { makeBalanceKey(walletCommon.EthereumMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), makeBalanceKey(walletCommon.OptimismMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), makeBalanceKey(walletCommon.ArbitrumMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), + makeBalanceKey(walletCommon.BaseMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), }, }, }, expectedAmountOptions: map[uint64][]amountOption{ walletCommon.OptimismMainnet: { { - amount: big.NewInt(testAmount3ETHInWei), + amount: big.NewInt(testAmount3ETHInWei + testAmount1ETHInWei), locked: false, }, { @@ -3143,7 +3769,7 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { }, walletCommon.ArbitrumMainnet: { { - amount: big.NewInt(testAmount3ETHInWei), + amount: big.NewInt(testAmount3ETHInWei + testAmount1ETHInWei), locked: false, }, { @@ -3153,7 +3779,17 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { }, walletCommon.EthereumMainnet: { { - amount: big.NewInt(testAmount3ETHInWei), + amount: big.NewInt(testAmount3ETHInWei + testAmount1ETHInWei), + locked: false, + }, + { + amount: big.NewInt(testAmount1ETHInWei), + locked: false, + }, + }, + walletCommon.BaseMainnet: { + { + amount: big.NewInt(testAmount3ETHInWei + testAmount1ETHInWei), locked: false, }, { @@ -3186,6 +3822,7 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { makeBalanceKey(walletCommon.EthereumMainnet, walletCommon.EthSymbol): big.NewInt(testAmount2ETHInWei), makeBalanceKey(walletCommon.OptimismMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), makeBalanceKey(walletCommon.ArbitrumMainnet, walletCommon.EthSymbol): big.NewInt(testAmount3ETHInWei), + makeBalanceKey(walletCommon.BaseMainnet, walletCommon.EthSymbol): big.NewInt(testAmount3ETHInWei), }, }, }, @@ -3201,10 +3838,6 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { amount: big.NewInt(testAmount2ETHInWei + testAmount0Point5ETHInWei), locked: false, }, - { - amount: big.NewInt(testAmount0Point5ETHInWei), - locked: false, - }, }, walletCommon.EthereumMainnet: { { @@ -3216,6 +3849,16 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { locked: false, }, }, + walletCommon.BaseMainnet: { + { + amount: big.NewInt(testAmount0Point5ETHInWei), + locked: false, + }, + { + amount: big.NewInt(testAmount2ETHInWei + testAmount0Point5ETHInWei), + locked: false, + }, + }, }, }, { @@ -3228,6 +3871,7 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { TokenID: walletCommon.EthSymbol, FromLockedAmount: map[uint64]*hexutil.Big{ walletCommon.OptimismMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point5ETHInWei)), + walletCommon.BaseMainnet: (*hexutil.Big)(big.NewInt(testAmount0Point5ETHInWei)), walletCommon.EthereumMainnet: (*hexutil.Big)(big.NewInt(testAmount1ETHInWei)), }, @@ -3242,6 +3886,7 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { makeBalanceKey(walletCommon.EthereumMainnet, walletCommon.EthSymbol): big.NewInt(testAmount2ETHInWei), makeBalanceKey(walletCommon.OptimismMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), makeBalanceKey(walletCommon.ArbitrumMainnet, walletCommon.EthSymbol): big.NewInt(testAmount3ETHInWei), + makeBalanceKey(walletCommon.BaseMainnet, walletCommon.EthSymbol): big.NewInt(testAmount3ETHInWei), }, }, }, @@ -3252,9 +3897,15 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { locked: true, }, }, + walletCommon.BaseMainnet: { + { + amount: big.NewInt(testAmount0Point5ETHInWei), + locked: true, + }, + }, walletCommon.ArbitrumMainnet: { { - amount: big.NewInt(testAmount1ETHInWei + testAmount0Point5ETHInWei), + amount: big.NewInt(testAmount1ETHInWei), locked: false, }, }, @@ -3286,6 +3937,7 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { makeBalanceKey(walletCommon.EthereumMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), makeBalanceKey(walletCommon.OptimismMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), makeBalanceKey(walletCommon.ArbitrumMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), + makeBalanceKey(walletCommon.BaseMainnet, walletCommon.EthSymbol): big.NewInt(testAmount1ETHInWei), }, }, }, @@ -3302,6 +3954,12 @@ func getAmountOptionsTestParamsList() []amountOptionsTestParams { locked: false, }, }, + walletCommon.BaseMainnet: { + { + amount: big.NewInt(testAmount5ETHInWei), + locked: false, + }, + }, walletCommon.EthereumMainnet: { { amount: big.NewInt(testAmount5ETHInWei), diff --git a/services/wallet/token/balancefetcher/balance_fetcher.go b/services/wallet/token/balancefetcher/balance_fetcher.go index ab358beef1f..9a63267c6ed 100644 --- a/services/wallet/token/balancefetcher/balance_fetcher.go +++ b/services/wallet/token/balancefetcher/balance_fetcher.go @@ -313,10 +313,8 @@ func (bf *DefaultBalanceFetcher) GetBalancesAtByChain(parent context.Context, cl group.Add(func(parent context.Context) error { balances, err := bf.fetchBalancesForChain(parent, client, accounts, tokens, atBlocks[client.NetworkID()]) if err != nil { - logutils.ZapLogger().Error("failed to get balances for chain", zap.Uint64("chainId", client.NetworkID()), zap.Error(err)) return err } - logutils.ZapLogger().Info("fetched balances for chain", zap.Uint64("chainId", client.NetworkID())) updateBalance(client.NetworkID(), balances) return nil })