-
Notifications
You must be signed in to change notification settings - Fork 110
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix: support tracker processing for v2 inbounds (#3179)
* add tracker processing for v2 inbound * fmt * add inbound tracker e2e test * successful test * changelgo * add comment to PR * fix tests * add back ton sidecar config * comments
- Loading branch information
Showing
9 changed files
with
272 additions
and
22 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
package e2etests | ||
|
||
import ( | ||
"math/big" | ||
|
||
"github.com/stretchr/testify/require" | ||
"github.com/zeta-chain/protocol-contracts/v2/pkg/gatewayevm.sol" | ||
|
||
"github.com/zeta-chain/node/e2e/runner" | ||
"github.com/zeta-chain/node/e2e/utils" | ||
"github.com/zeta-chain/node/pkg/coin" | ||
crosschaintypes "github.com/zeta-chain/node/x/crosschain/types" | ||
) | ||
|
||
// TestInboundTrackers tests inbound trackers processing in ZetaClient | ||
// It run deposits, send inbound trackers and check cctxs are mined | ||
// IMPORTANT: the test requires inbound observation to be disabled, the following line should be uncommented: | ||
// https://github.com/zeta-chain/node/blob/9dcb42729653e033f5ba60a77dc37e5e19b092ad/zetaclient/chains/evm/observer/inbound.go#L210 | ||
func TestInboundTrackers(r *runner.E2ERunner, args []string) { | ||
require.Len(r, args, 0) | ||
|
||
amount := big.NewInt(1e17) | ||
|
||
addTrackerAndWaitForCCTX := func(coinType coin.CoinType, txHash string) { | ||
r.AddInboundTracker(coinType, txHash) | ||
cctx := utils.WaitCctxMinedByInboundHash(r.Ctx, txHash, r.CctxClient, r.Logger, r.CctxTimeout) | ||
require.EqualValues(r, crosschaintypes.CctxStatus_OutboundMined, cctx.CctxStatus.Status) | ||
r.Logger.CCTX(*cctx, "cctx") | ||
} | ||
|
||
// send v1 eth deposit | ||
r.Logger.Print("🏃test v1 eth deposit") | ||
txHash := r.DepositEtherWithAmount(amount) | ||
addTrackerAndWaitForCCTX(coin.CoinType_Gas, txHash.Hex()) | ||
r.Logger.Print("🍾v1 eth deposit observed") | ||
|
||
// send v1 erc20 deposit | ||
r.Logger.Print("🏃test v1 erc20 deposit") | ||
txHash = r.DepositERC20WithAmountAndMessage(r.EVMAddress(), amount, []byte{}) | ||
addTrackerAndWaitForCCTX(coin.CoinType_ERC20, txHash.Hex()) | ||
r.Logger.Print("🍾v1 erc20 deposit observed") | ||
|
||
// send v2 eth deposit | ||
r.Logger.Print("🏃test v2 eth deposit") | ||
tx := r.V2ETHDeposit(r.EVMAddress(), amount, gatewayevm.RevertOptions{OnRevertGasLimit: big.NewInt(0)}) | ||
addTrackerAndWaitForCCTX(coin.CoinType_Gas, tx.Hash().Hex()) | ||
r.Logger.Print("🍾v2 eth deposit observed") | ||
|
||
// send v2 eth deposit and call | ||
r.Logger.Print("🏃test v2 eth eposit and call") | ||
tx = r.V2ETHDepositAndCall( | ||
r.TestDAppV2ZEVMAddr, | ||
amount, | ||
[]byte(randomPayload(r)), | ||
gatewayevm.RevertOptions{OnRevertGasLimit: big.NewInt(0)}, | ||
) | ||
addTrackerAndWaitForCCTX(coin.CoinType_Gas, tx.Hash().Hex()) | ||
r.Logger.Print("🍾v2 eth deposit and call observed") | ||
|
||
// send v2 erc20 deposit | ||
r.Logger.Print("🏃test v2 erc20 deposit") | ||
r.ApproveERC20OnEVM(r.GatewayEVMAddr) | ||
tx = r.V2ERC20Deposit(r.EVMAddress(), amount, gatewayevm.RevertOptions{OnRevertGasLimit: big.NewInt(0)}) | ||
addTrackerAndWaitForCCTX(coin.CoinType_Gas, tx.Hash().Hex()) | ||
r.Logger.Print("🍾v2 erc20 deposit observed") | ||
|
||
// send v2 erc20 deposit and call | ||
r.Logger.Print("🏃test v2 erc20 deposit and call") | ||
tx = r.V2ERC20DepositAndCall( | ||
r.TestDAppV2ZEVMAddr, | ||
amount, | ||
[]byte(randomPayload(r)), | ||
gatewayevm.RevertOptions{OnRevertGasLimit: big.NewInt(0)}, | ||
) | ||
addTrackerAndWaitForCCTX(coin.CoinType_Gas, tx.Hash().Hex()) | ||
r.Logger.Print("🍾v2 erc20 deposit and call observed") | ||
|
||
// send v2 call | ||
r.Logger.Print("🏃test v2 call") | ||
tx = r.V2EVMToZEMVCall( | ||
r.TestDAppV2ZEVMAddr, | ||
[]byte(randomPayload(r)), | ||
gatewayevm.RevertOptions{OnRevertGasLimit: big.NewInt(0)}, | ||
) | ||
addTrackerAndWaitForCCTX(coin.CoinType_NoAssetCall, tx.Hash().Hex()) | ||
r.Logger.Print("🍾v2 call observed") | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.