-
Notifications
You must be signed in to change notification settings - Fork 119
/
Copy pathtest_message_passing_external_chains_revert.go
76 lines (57 loc) · 2.93 KB
/
test_message_passing_external_chains_revert.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
package e2etests
import (
banktypes "github.com/cosmos/cosmos-sdk/x/bank/types"
ethcommon "github.com/ethereum/go-ethereum/common"
"github.com/stretchr/testify/require"
"github.com/zeta-chain/zetacore/e2e/contracts/testdapp"
"github.com/zeta-chain/zetacore/e2e/runner"
"github.com/zeta-chain/zetacore/e2e/utils"
cctxtypes "github.com/zeta-chain/zetacore/x/crosschain/types"
)
// TestMessagePassingRevertSuccessExternalChains tests message passing with successful revert between external EVM chains
// TODO: Use two external EVM chains for these tests
// https://github.com/zeta-chain/node/issues/2185
func TestMessagePassingRevertSuccessExternalChains(r *runner.E2ERunner, args []string) {
require.Len(r, args, 1)
// parse the amount
amount := parseBigInt(r, args[0])
chainID, err := r.EVMClient.ChainID(r.Ctx)
require.NoError(r, err)
auth := r.EVMAuth
tx, err := r.ZetaEth.Approve(auth, r.EvmTestDAppAddr, amount)
require.NoError(r, err)
r.Logger.Info("Approve tx hash: %s", tx.Hash().Hex())
receipt := utils.MustWaitForTxReceipt(r.Ctx, r.EVMClient, tx, r.Logger, r.ReceiptTimeout)
utils.RequireTxSuccessful(r, receipt)
r.Logger.Info("Approve tx receipt: %d", receipt.Status)
r.Logger.Info("Calling TestDApp.SendHello on contract address %s", r.EvmTestDAppAddr.Hex())
testDApp, err := testdapp.NewTestDApp(r.EvmTestDAppAddr, r.EVMClient)
require.NoError(r, err)
res2, err := r.BankClient.SupplyOf(r.Ctx, &banktypes.QuerySupplyOfRequest{Denom: "azeta"})
require.NoError(r, err)
r.Logger.Info("$$$ Before: SUPPLY OF AZETA: %d", res2.Amount.Amount)
tx, err = testDApp.SendHelloWorld(auth, r.EvmTestDAppAddr, chainID, amount, true)
require.NoError(r, err)
r.Logger.Info("TestDApp.SendHello tx hash: %s", tx.Hash().Hex())
receipt = utils.MustWaitForTxReceipt(r.Ctx, r.EVMClient, tx, r.Logger, r.ReceiptTimeout)
r.Logger.Info("TestDApp.SendHello tx receipt: status %d", receipt.Status)
cctx := utils.WaitCctxMinedByInboundHash(r.Ctx, receipt.TxHash.String(), r.CctxClient, r.Logger, r.CctxTimeout)
utils.RequireCCTXStatus(r, cctx, cctxtypes.CctxStatus_Reverted)
outTxHash := cctx.GetCurrentOutboundParam().Hash
receipt, err = r.EVMClient.TransactionReceipt(r.Ctx, ethcommon.HexToHash(outTxHash))
require.NoError(r, err)
for _, log := range receipt.Logs {
event, err := r.ConnectorEth.ParseZetaReverted(*log)
if err == nil {
r.Logger.Info("ZetaReverted event: ")
r.Logger.Info(" Dest Addr: %s", ethcommon.BytesToAddress(event.DestinationAddress).Hex())
r.Logger.Info(" Dest Chain: %d", event.DestinationChainId)
r.Logger.Info(" RemainingZetaValue: %d", event.RemainingZetaValue)
r.Logger.Info(" Message: %x", event.Message)
}
}
res3, err := r.BankClient.SupplyOf(r.Ctx, &banktypes.QuerySupplyOfRequest{Denom: "azeta"})
require.NoError(r, err)
r.Logger.Info("$$$ After: SUPPLY OF AZETA: %d", res3.Amount.Amount.BigInt())
r.Logger.Info("$$$ Diff: SUPPLY OF AZETA: %d", res3.Amount.Amount.Sub(res2.Amount.Amount).BigInt())
}