/
suite.go
96 lines (78 loc) · 2.9 KB
/
suite.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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
package testutils
import (
"context"
"crypto/ecdsa"
"math"
"math/big"
"os"
"github.com/MXCzkEVM/mxc-client/pkg/jwt"
"github.com/MXCzkEVM/mxc-client/pkg/rpc"
"github.com/ethereum/go-ethereum/accounts/abi/bind"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/core/types"
"github.com/ethereum/go-ethereum/crypto"
"github.com/ethereum/go-ethereum/log"
"github.com/stretchr/testify/suite"
)
type ClientTestSuite struct {
suite.Suite
testnetL1SnapshotID string
RpcClient *rpc.Client
TestAddrPrivKey *ecdsa.PrivateKey
TestAddr common.Address
}
func (s *ClientTestSuite) SetupTest() {
// Default logger
log.Root().SetHandler(
log.LvlFilterHandler(log.LvlInfo, log.StreamHandler(os.Stdout, log.TerminalFormat(true))),
)
if os.Getenv("LOG_LEVEL") != "" {
level, err := log.LvlFromString(os.Getenv("LOG_LEVEL"))
if err != nil {
log.Crit("Invalid log level", "level", os.Getenv("LOG_LEVEL"))
}
log.Root().SetHandler(
log.LvlFilterHandler(level, log.StreamHandler(os.Stdout, log.TerminalFormat(true))),
)
}
testAddrPrivKey, err := crypto.ToECDSA(
common.Hex2Bytes("ac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80"),
)
s.Nil(err)
s.TestAddrPrivKey = testAddrPrivKey
s.TestAddr = common.HexToAddress("0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266")
jwtSecret, err := jwt.ParseSecretFromFile(os.Getenv("JWT_SECRET"))
s.Nil(err)
s.NotEmpty(jwtSecret)
rpcCli, err := rpc.NewClient(context.Background(), &rpc.ClientConfig{
L1Endpoint: os.Getenv("L1_NODE_WS_ENDPOINT"),
L2Endpoint: os.Getenv("L2_EXECUTION_ENGINE_WS_ENDPOINT"),
MxcL1Address: common.HexToAddress(os.Getenv("MXC_L1_ADDRESS")),
MxcL2Address: common.HexToAddress(os.Getenv("MXC_L2_ADDRESS")),
L2EngineEndpoint: os.Getenv("L2_EXECUTION_ENGINE_AUTH_ENDPOINT"),
JwtSecret: string(jwtSecret),
})
s.Nil(err)
s.RpcClient = rpcCli
l1ProposerPrivKey, err := crypto.ToECDSA(common.Hex2Bytes(os.Getenv("L1_PROPOSER_PRIVATE_KEY")))
s.Nil(err)
opts, err := bind.NewKeyedTransactorWithChainID(l1ProposerPrivKey, rpcCli.L1ChainID)
s.Nil(err)
balance, err := rpcCli.MxcL1.GetTaikoTokenBalance(nil, crypto.PubkeyToAddress(l1ProposerPrivKey.PublicKey))
s.Nil(err)
if balance.Cmp(common.Big0) == 0 {
tx, err := rpcCli.MxcL1.DepositTaikoToken(opts, new(big.Int).SetUint64(uint64(math.Pow(2, 32))))
s.Nil(err)
receipt, err := rpc.WaitReceipt(context.Background(), rpcCli.L1, tx)
s.Nil(err)
s.Equal(types.ReceiptStatusSuccessful, receipt.Status)
}
s.Nil(rpcCli.L1RawRPC.CallContext(context.Background(), &s.testnetL1SnapshotID, "evm_snapshot"))
s.NotEmpty(s.testnetL1SnapshotID)
}
func (s *ClientTestSuite) TearDownTest() {
var revertRes bool
s.Nil(s.RpcClient.L1RawRPC.CallContext(context.Background(), &revertRes, "evm_revert", s.testnetL1SnapshotID))
s.True(revertRes)
s.Nil(rpc.SetHead(context.Background(), s.RpcClient.L2RawRPC, common.Big0))
}