Commit 9e27e744 authored by QM's avatar QM

uodata relayer unit test

parent 59458523
package ethtxs
import (
"math/big"
"testing"
"github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/ethinterface"
"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
"github.com/ethereum/go-ethereum/core"
"github.com/ethereum/go-ethereum/crypto"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
)
func Test_LoadABI(t *testing.T) {
abi1 := LoadABI(Chain33BankABI)
abi2 := LoadABI(Chain33BridgeABI)
abi3 := LoadABI(EthereumBankABI)
assert.NotEmpty(t, abi1, abi2, abi3)
}
func Test_isWebsocketURL(t *testing.T) {
bret := isWebsocketURL("ws://127.0.0.1:7545/")
assert.Equal(t, bret, true)
bret = isWebsocketURL("https://127.0.0.1:7545/")
assert.Equal(t, bret, false)
}
func TestContractRegistry_String(t *testing.T) {
assert.Equal(t, Valset.String(), "valset")
assert.Equal(t, Oracle.String(), "oracle")
assert.Equal(t, BridgeBank.String(), "bridgebank")
assert.Equal(t, Chain33Bridge.String(), "chain33bridge")
}
func Test_GetAddressFromBridgeRegistry(t *testing.T) {
genesiskey, _ := crypto.GenerateKey()
alloc := make(core.GenesisAlloc)
genesisAddr := crypto.PubkeyToAddress(genesiskey.PublicKey)
genesisAccount := core.GenesisAccount{
Balance: big.NewInt(10000000000 * 10000),
PrivateKey: crypto.FromECDSA(genesiskey),
}
alloc[genesisAddr] = genesisAccount
gasLimit := uint64(100000000)
sim := new(ethinterface.SimExtend)
sim.SimulatedBackend = backends.NewSimulatedBackend(alloc, gasLimit)
var bridgebankTest ContractRegistry
bridgebankTest = 5
_, err := GetAddressFromBridgeRegistry(sim, genesisAddr, genesisAddr, bridgebankTest)
require.NotNil(t, err)
}
...@@ -27,7 +27,7 @@ const ( ...@@ -27,7 +27,7 @@ const (
// String : returns the event type as a string // String : returns the event type as a string
func (d ContractRegistry) String() string { func (d ContractRegistry) String() string {
return [...]string{"valset", "oracle", "bridgebank", "chain33bridge"}[d-1] return [...]string{"valset", "oracle", "bridgebank", "chain33bridge", "notsupport"}[d-1]
} }
// GetAddressFromBridgeRegistry : utility method which queries the requested contract address from the BridgeRegistry // GetAddressFromBridgeRegistry : utility method which queries the requested contract address from the BridgeRegistry
......
...@@ -14,9 +14,9 @@ func NewEventWrite(txHash string, event LockEvent) { ...@@ -14,9 +14,9 @@ func NewEventWrite(txHash string, event LockEvent) {
} }
// IsEventRecorded : checks the sessions stored events for this transaction hash // IsEventRecorded : checks the sessions stored events for this transaction hash
func IsEventRecorded(txHash string) bool { //func IsEventRecorded(txHash string) bool {
return EventRecords[txHash].Nonce != nil // return EventRecords[txHash].Nonce != nil
} //}
//// PrintLockEventByTx : prints any witnessed events associated with a given transaction hash //// PrintLockEventByTx : prints any witnessed events associated with a given transaction hash
//func PrintLockEventByTx(txHash string) { //func PrintLockEventByTx(txHash string) {
......
...@@ -128,6 +128,7 @@ func (chain33Relayer *Relayer4Chain33) getCurrentHeight() int64 { ...@@ -128,6 +128,7 @@ func (chain33Relayer *Relayer4Chain33) getCurrentHeight() int64 {
func (chain33Relayer *Relayer4Chain33) onNewHeightProc(currentHeight int64) { func (chain33Relayer *Relayer4Chain33) onNewHeightProc(currentHeight int64) {
//检查已经提交的交易结果 //检查已经提交的交易结果
chain33Relayer.rwLock.Lock()
for chain33Relayer.statusCheckedIndex < chain33Relayer.totalTx4Chain33ToEth { for chain33Relayer.statusCheckedIndex < chain33Relayer.totalTx4Chain33ToEth {
index := chain33Relayer.statusCheckedIndex + 1 index := chain33Relayer.statusCheckedIndex + 1
txhash, err := chain33Relayer.getEthTxhash(index) txhash, err := chain33Relayer.getEthTxhash(index)
...@@ -145,6 +146,7 @@ func (chain33Relayer *Relayer4Chain33) onNewHeightProc(currentHeight int64) { ...@@ -145,6 +146,7 @@ func (chain33Relayer *Relayer4Chain33) onNewHeightProc(currentHeight int64) {
atomic.AddInt64(&chain33Relayer.statusCheckedIndex, 1) atomic.AddInt64(&chain33Relayer.statusCheckedIndex, 1)
_ = chain33Relayer.setStatusCheckedIndex(chain33Relayer.statusCheckedIndex) _ = chain33Relayer.setStatusCheckedIndex(chain33Relayer.statusCheckedIndex)
} }
chain33Relayer.rwLock.Unlock()
//未达到足够的成熟度,不进行处理 //未达到足够的成熟度,不进行处理
// +++++++++||++++++++++++||++++++++++|| // +++++++++||++++++++++++||++++++++++||
// ^ ^ ^ // ^ ^ ^
......
...@@ -5,11 +5,10 @@ import ( ...@@ -5,11 +5,10 @@ import (
"encoding/hex" "encoding/hex"
"flag" "flag"
"fmt" "fmt"
"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"os" "os"
"os/signal"
"sync"
"sync/atomic"
"syscall"
"testing" "testing"
"time" "time"
...@@ -20,15 +19,15 @@ import ( ...@@ -20,15 +19,15 @@ import (
"github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/ethcontract/test/setup" "github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/ethcontract/test/setup"
"github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/ethinterface" "github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/ethinterface"
"github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/ethtxs" "github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/ethtxs"
"github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/events"
syncTx "github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/relayer/chain33/transceiver/sync" syncTx "github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/relayer/chain33/transceiver/sync"
ebTypes "github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/types" ebTypes "github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/types"
relayerTypes "github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/types" relayerTypes "github.com/33cn/plugin/plugin/dapp/x2ethereum/ebrelayer/types"
tml "github.com/BurntSushi/toml" tml "github.com/BurntSushi/toml"
"github.com/ethereum/go-ethereum" "github.com/ethereum/go-ethereum"
"github.com/ethereum/go-ethereum/accounts/abi/bind" //"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
"github.com/ethereum/go-ethereum/accounts/abi/bind/backends"
"github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/common"
"github.com/stretchr/testify/suite" //"github.com/stretchr/testify/suite"
// 需要显示引用系统插件,以加载系统内置合约 // 需要显示引用系统插件,以加载系统内置合约
"github.com/33cn/chain33/client/mocks" "github.com/33cn/chain33/client/mocks"
...@@ -43,169 +42,267 @@ var ( ...@@ -43,169 +42,267 @@ var (
accountAddr = "0x92c8b16afd6d423652559c6e266cbe1c29bfd84f" accountAddr = "0x92c8b16afd6d423652559c6e266cbe1c29bfd84f"
passphrase = "123456hzj" passphrase = "123456hzj"
test = "0ac3050aa3020a0a7832657468657265756d126d60671a690a2a3078303030303030303030303030303030303030303030303030303030303030303030303030303030301a2a307830633035626135633233306664616135303362353337303261663139363265303864306336306266220831303030303030302a0365746838121a6e080112210320bbac09528e19c55b0f89cb37ab265e7e856b1a8c388780322dbbfd194b52ba1a473045022100c403d9a6e531292336b44d52e4f4dbb9b8ab1e16335383954583728b909478da022031d8a29efcbcea8df648c4054f3c09ab1ab7a330797cf79fd891a3d9336922e920a08d0628e0f193f60530a1d7ad93e5ebc28e253a22314c7538586d537459765777664e716951336e4e4b33345239466648346b5270425612ce0208021a5e0802125a0a2b10c0d59294bb192222313271796f6361794e46374c7636433971573461767873324537553431664b536676122b10a0c88c94bb192222313271796f6361794e46374c7636433971573461767873324537553431664b5366761a55080f12510a291080ade2042222313271796f6361794e46374c7636433971573461767873324537553431664b53667612242222313271796f6361794e46374c7636433971573461767873324537553431664b5366761a92010867128d010a2a3078303030303030303030303030303030303030303030303030303030303030303030303030303030301222313271796f6361794e46374c7636433971573461767873324537553431664b5366761a2a307830633035626135633233306664616135303362353337303261663139363265303864306336306266220831303030303030302a03657468301220c4092a207a38e1da7de4444f2d34c7488293f3a2e01ce2561e720e9bbef355e83755ad833220e68d8418f69d5f18278a53dca53b101f26f76883337a60a5754d5f6d94e42e3c400148c409" test = "0ac3050aa3020a0a7832657468657265756d126d60671a690a2a3078303030303030303030303030303030303030303030303030303030303030303030303030303030301a2a307830633035626135633233306664616135303362353337303261663139363265303864306336306266220831303030303030302a0365746838121a6e080112210320bbac09528e19c55b0f89cb37ab265e7e856b1a8c388780322dbbfd194b52ba1a473045022100c403d9a6e531292336b44d52e4f4dbb9b8ab1e16335383954583728b909478da022031d8a29efcbcea8df648c4054f3c09ab1ab7a330797cf79fd891a3d9336922e920a08d0628e0f193f60530a1d7ad93e5ebc28e253a22314c7538586d537459765777664e716951336e4e4b33345239466648346b5270425612ce0208021a5e0802125a0a2b10c0d59294bb192222313271796f6361794e46374c7636433971573461767873324537553431664b536676122b10a0c88c94bb192222313271796f6361794e46374c7636433971573461767873324537553431664b5366761a55080f12510a291080ade2042222313271796f6361794e46374c7636433971573461767873324537553431664b53667612242222313271796f6361794e46374c7636433971573461767873324537553431664b5366761a92010867128d010a2a3078303030303030303030303030303030303030303030303030303030303030303030303030303030301222313271796f6361794e46374c7636433971573461767873324537553431664b5366761a2a307830633035626135633233306664616135303362353337303261663139363265303864306336306266220831303030303030302a03657468301220c4092a207a38e1da7de4444f2d34c7488293f3a2e01ce2561e720e9bbef355e83755ad833220e68d8418f69d5f18278a53dca53b101f26f76883337a60a5754d5f6d94e42e3c400148c409"
)
type suiteChain33Relayer struct {
suite.Suite
chain33Relayer *Relayer4Chain33
sim *ethinterface.SimExtend
x2EthContracts *ethtxs.X2EthContracts
x2EthDeployInfo *ethtxs.X2EthDeployInfo
para *ethtxs.DeployPara
}
func TestRunSuiteX2Ethereum(t *testing.T) {
var ret = types.ReplySubscribePush{IsOk: true}
var he = types.Header{Height: 10000}
mockapi := &mocks.QueueProtocolAPI{} // 0x8AFDADFC88a1087c9A1D6c0F5Dd04634b87F303a
// 这里对需要mock的方法打桩,Close是必须的,其它方法根据需要 deployerPrivateKey = "8656d2bc732a8a816a461ba5e2d8aac7c7f85c26a813df30d5327210465eb230"
mockapi.On("Close").Return() // 0x92C8b16aFD6d423652559C6E266cBE1c29Bfd84f
mockapi.On("AddPushSubscribe", mock.Anything).Return(&ret, nil) ethValidatorAddrKeyA = "3fa21584ae2e4fd74db9b58e2386f5481607dfa4d7ba0617aaa7858e5025dc1e"
mockapi.On("GetLastHeader", mock.Anything).Return(&he, nil) ethValidatorAddrKeyB = "a5f3063552f4483cfc20ac4f40f45b798791379862219de9e915c64722c1d400"
mockapi.On("GetConfig", mock.Anything).Return(chainTestCfg, nil) ethValidatorAddrKeyC = "bbf5e65539e9af0eb0cfac30bad475111054b09c11d668fc0731d54ea777471e"
ethValidatorAddrKeyD = "c9fa31d7984edf81b8ef3b40c761f1847f6fcd5711ab2462da97dc458f1f896b"
)
mock33 := testnode.New("", mockapi) func Test_HandleRequest(t *testing.T) {
mock33 := newMock33("127.0.0.1:8801")
defer mock33.Close() defer mock33.Close()
rpcCfg := mock33.GetCfg().RPC _, sim, _, x2EthDeployInfo := deployContracts()
// 这里必须设置监听端口,默认的是无效值 //require.NoError(t, err)
rpcCfg.JrpcBindAddr = "127.0.0.1:8801" chain33Relayer := newChain33Relayer(sim, x2EthDeployInfo, "127.0.0.1:60002", "http://127.0.0.1:8801", t)
mock33.GetRPC().Listen() _, err := chain33Relayer.ImportPrivateKey(passphrase, privateKeyStr)
assert.NoError(t, err)
log := new(suiteChain33Relayer)
suite.Run(t, log)
}
func (r *suiteChain33Relayer) SetupSuite() {
r.deployContracts()
r.chain33Relayer = r.newChain33Relayer()
}
func (r *suiteChain33Relayer) Test_1_ImportPrivateKey() {
addr, err := r.chain33Relayer.ImportPrivateKey(passphrase, privateKeyStr)
r.NoError(err)
r.Equal(addr, accountAddr)
time.Sleep(50 * time.Millisecond)
addr, err = r.chain33Relayer.GetAccountAddr()
r.NoError(err)
r.Equal(addr, accountAddr)
key, _, _ := r.chain33Relayer.GetAccount("123")
r.NotEqual(key, privateKeyStr)
key, _, _ = r.chain33Relayer.GetAccount(passphrase)
r.Equal(key, privateKeyStr)
}
func (r *suiteChain33Relayer) Test_2_HandleRequest() {
body, err := hex.DecodeString(test) body, err := hex.DecodeString(test)
r.NoError(err) assert.NoError(t, err)
r.chain33Relayer.statusCheckedIndex = 1220 chain33Relayer.statusCheckedIndex = 1220
err = syncTx.HandleRequest(body) err = syncTx.HandleRequest(body)
r.NoError(err) assert.NoError(t, err)
time.Sleep(50 * time.Millisecond) time.Sleep(time.Second)
}
func (r *suiteChain33Relayer) Test_3_QueryTxhashRelay2Eth() { ret := chain33Relayer.QueryTxhashRelay2Eth()
ret := r.chain33Relayer.QueryTxhashRelay2Eth() assert.NotEmpty(t, ret)
r.NotEmpty(ret)
}
func (r *suiteChain33Relayer) Test_4_getEthTxhash() { event := getOracleClaimType(events.MsgLock.String())
txIndex := atomic.LoadInt64(&r.chain33Relayer.totalTx4Chain33ToEth) assert.Equal(t, event, events.Event(events.ClaimTypeLock))
hash, err := r.chain33Relayer.getEthTxhash(txIndex)
r.NoError(err)
r.Equal(hash.String(), "0x6fa087c7a2a8a4421f6e269fbc6c0838e99fa59d5760155a71cd7eb1c01aafad")
} }
func (r *suiteChain33Relayer) Test_5_RestorePrivateKeys() { func Test_ImportPrivateKey(t *testing.T) {
go func() { mock33 := newMock33("127.0.0.1:8802")
for range r.chain33Relayer.unlock { defer mock33.Close()
} _, sim, _, x2EthDeployInfo, err := setup.DeployContracts()
}() require.NoError(t, err)
temp := r.chain33Relayer.ethSender chain33Relayer := newChain33Relayer(sim, x2EthDeployInfo, "127.0.0.1:60000", "http://127.0.0.1:8802", t)
err := r.chain33Relayer.RestorePrivateKeys("123") addr, err := chain33Relayer.ImportPrivateKey(passphrase, privateKeyStr)
r.NotEqual(hex.EncodeToString(temp.Bytes()), hex.EncodeToString(r.chain33Relayer.ethSender.Bytes())) assert.NoError(t, err)
r.NoError(err) assert.Equal(t, addr, accountAddr)
err = r.chain33Relayer.RestorePrivateKeys(passphrase) time.Sleep(50 * time.Millisecond)
r.Equal(hex.EncodeToString(temp.Bytes()), hex.EncodeToString(r.chain33Relayer.ethSender.Bytes()))
r.NoError(err)
err = r.chain33Relayer.StoreAccountWithNewPassphase("new123", passphrase) addr, err = chain33Relayer.GetAccountAddr()
r.NoError(err) assert.NoError(t, err)
assert.Equal(t, addr, accountAddr)
err = r.chain33Relayer.RestorePrivateKeys("new123") key, _, _ := chain33Relayer.GetAccount("123")
r.Equal(hex.EncodeToString(temp.Bytes()), hex.EncodeToString(r.chain33Relayer.ethSender.Bytes())) assert.NotEqual(t, key, privateKeyStr)
r.NoError(err)
time.Sleep(time.Second) key, _, _ = chain33Relayer.GetAccount(passphrase)
assert.Equal(t, key, privateKeyStr)
} }
func (r *suiteChain33Relayer) newChain33Relayer() *Relayer4Chain33 { //func Test_Lockbty(t *testing.T) {
// mock33 := newMock33("127.0.0.1:8803")
// defer mock33.Close()
// para, sim, x2EthContracts, x2EthDeployInfo, err := setup.DeployContracts()
// require.NoError(t, err)
// chain33Relayer := newChain33Relayer(sim, x2EthDeployInfo, "127.0.0.1:60001", "http://127.0.0.1:8803", t)
// _, err = chain33Relayer.ImportPrivateKey(passphrase, privateKeyStr)
// assert.NoError(t, err)
//
// //Test_1_ImportPrivateKey()
// ctx := context.Background()
//
// //2nd:订阅事件
// eventName := "LogNewBridgeToken"
// bridgeBankABI := ethtxs.LoadABI(ethtxs.BridgeBankABI)
// logNewBridgeTokenSig := bridgeBankABI.Events[eventName].ID().Hex()
// query := ethereum.FilterQuery{
// Addresses: []common.Address{x2EthDeployInfo.BridgeBank.Address},
// }
// // We will check logs for new events
// logs := make(chan ethTypes.Log)
// // Filter by contract and event, write results to logs
// sub, err := sim.SubscribeFilterLogs(ctx, query, logs)
// //require.Nil(t, err)
//
// opts := &bind.CallOpts{
// Pending: true,
// From: para.Operator,
// Context: ctx,
// }
//
// tokenCount, err := x2EthContracts.BridgeBank.BridgeTokenCount(opts)
// require.Nil(t, err)
// assert.Equal(t, tokenCount.Int64(), int64(0))
//
// //3rd:创建token
// symbol := "BTY"
// auth, err := ethtxs.PrepareAuth(sim, para.DeployPrivateKey, para.Operator)
// require.Nil(t, err)
// _, err = x2EthContracts.BridgeBank.BridgeBankTransactor.CreateNewBridgeToken(auth, symbol)
// require.Nil(t, err)
// sim.Commit()
//
// logEvent := &events.LogNewBridgeToken{}
// select {
// // Handle any errors
// case err := <-sub.Err():
// t.Fatalf("sub error:%s", err.Error())
// // vLog is raw event data
// case vLog := <-logs:
// // Check if the event is a 'LogLock' event
// if vLog.Topics[0].Hex() == logNewBridgeTokenSig {
// err = bridgeBankABI.Unpack(logEvent, eventName, vLog.Data)
// require.Nil(t, err)
// require.Equal(t, symbol, logEvent.Symbol)
//
// //tokenCount正确加1
// tokenCount, err = x2EthContracts.BridgeBank.BridgeTokenCount(opts)
// require.Nil(t, err)
// require.Equal(t, tokenCount.Int64(), int64(1))
// break
// }
// }
//
// ///////////newOracleClaim///////////////////////////
// balance, _ := sim.BalanceAt(ctx, para.InitValidators[0], nil)
// fmt.Println("InitValidators[0] addr,", para.InitValidators[0].String(), "balance =", balance.String())
//
// chain33Sender := []byte("14KEKbYtKKQm4wMthSK9J4La4nAiidGozt")
// amount := int64(99)
// ethReceiver := para.InitValidators[2]
// claimID := crypto.Keccak256Hash(chain33Sender, ethReceiver.Bytes(), logEvent.Token.Bytes(), big.NewInt(amount).Bytes())
//
// authOracle, err := ethtxs.PrepareAuth(sim, para.ValidatorPriKey[0], para.InitValidators[0])
// require.Nil(t, err)
//
// signature, err := ethtxs.SignClaim4Eth(claimID, para.ValidatorPriKey[0])
// require.Nil(t, err)
//
// bridgeToken, err := generated.NewBridgeToken(logEvent.Token, sim)
// require.Nil(t, err)
// opts = &bind.CallOpts{
// Pending: true,
// Context: ctx,
// }
//
// balance, err = bridgeToken.BalanceOf(opts, ethReceiver)
// require.Nil(t, err)
// require.Equal(t, balance.Int64(), int64(0))
//
// tx, err := x2EthContracts.Oracle.NewOracleClaim(
// authOracle,
// events.ClaimTypeLock,
// chain33Sender,
// ethReceiver,
// logEvent.Token,
// logEvent.Symbol,
// big.NewInt(amount),
// claimID,
// signature)
// require.Nil(t, err)
//
// sim.Commit()
// balance, err = bridgeToken.BalanceOf(opts, ethReceiver)
// require.Nil(t, err)
// require.Equal(t, balance.Int64(), amount)
// //t.Logf("The minted amount is:%d", balance.Int64())
//
// txhash := tx.Hash().Hex()
//
// chain33Relayer.rwLock.Lock()
// chain33Relayer.totalTx4Chain33ToEth = 2
// chain33Relayer.rwLock.Unlock()
// _ = chain33Relayer.setLastestRelay2EthTxhash(relayerTx.EthTxPending.String(), txhash, 3)
//
// time.Sleep(200 * time.Millisecond)
//
// chain33Relayer.rwLock.Lock()
// chain33Relayer.totalTx4Chain33ToEth = 9
// chain33Relayer.totalTx4Chain33ToEth = 11
// chain33Relayer.rwLock.Unlock()
// _ = chain33Relayer.setLastestRelay2EthTxhash(relayerTx.EthTxPending.String(), "", 11)
//
// time.Sleep(200 * time.Millisecond)
//}
//
//func Test_RestorePrivateKeys(t *testing.T) {
// mock33 := newMock33("127.0.0.1:8804")
// defer mock33.Close()
// _, sim, _, x2EthDeployInfo, err := setup.DeployContracts()
// require.NoError(t, err)
// chain33Relayer := newChain33Relayer(sim, x2EthDeployInfo, "127.0.0.1:60003", "http://127.0.0.1:8804", t)
// _, err = chain33Relayer.ImportPrivateKey(passphrase, privateKeyStr)
// assert.NoError(t, err)
//
// go func() {
// for range chain33Relayer.unlock {
// }
// }()
// temp := chain33Relayer.ethSender
//
// err = chain33Relayer.RestorePrivateKeys("123")
// assert.NotEqual(t, hex.EncodeToString(temp.Bytes()), hex.EncodeToString(chain33Relayer.ethSender.Bytes()))
// assert.NoError(t, err)
//
// err = chain33Relayer.RestorePrivateKeys(passphrase)
// assert.Equal(t, hex.EncodeToString(temp.Bytes()), hex.EncodeToString(chain33Relayer.ethSender.Bytes()))
// assert.NoError(t, err)
//
// err = chain33Relayer.StoreAccountWithNewPassphase("new123", passphrase)
// assert.NoError(t, err)
//
// err = chain33Relayer.RestorePrivateKeys("new123")
// assert.Equal(t, hex.EncodeToString(temp.Bytes()), hex.EncodeToString(chain33Relayer.ethSender.Bytes()))
// assert.NoError(t, err)
//
// time.Sleep(time.Second)
//
//}
func newChain33Relayer(sim *ethinterface.SimExtend, x2EthDeployInfo *ethtxs.X2EthDeployInfo, pushBind, chain33Host string, t *testing.T) *Relayer4Chain33 {
cfg := initCfg(*configPath) cfg := initCfg(*configPath)
cfg.SyncTxConfig.Chain33Host = "http://127.0.0.1:8801" cfg.SyncTxConfig.Chain33Host = chain33Host //"http://127.0.0.1:8801"
cfg.BridgeRegistry = r.x2EthDeployInfo.BridgeRegistry.Address.String() cfg.BridgeRegistry = x2EthDeployInfo.BridgeRegistry.Address.String()
cfg.SyncTxConfig.PushBind = "127.0.0.1:60000" cfg.SyncTxConfig.PushBind = pushBind // "127.0.0.1:60000"
cfg.SyncTxConfig.FetchHeightPeriodMs = 50 cfg.SyncTxConfig.FetchHeightPeriodMs = 50
cfg.SyncTxConfig.Dbdriver = "memdb" cfg.SyncTxConfig.Dbdriver = "memdb"
db := dbm.NewDB("relayer_db_service", cfg.SyncTxConfig.Dbdriver, cfg.SyncTxConfig.DbPath, cfg.SyncTxConfig.DbCache) db := dbm.NewDB("relayer_db_service", cfg.SyncTxConfig.Dbdriver, cfg.SyncTxConfig.DbPath, cfg.SyncTxConfig.DbCache)
ctx, cancel := context.WithCancel(context.Background()) ctx, _ := context.WithCancel(context.Background())
relayer := &Relayer4Chain33{ relayer := &Relayer4Chain33{
rpcLaddr: cfg.SyncTxConfig.Chain33Host, rpcLaddr: chain33Host, //cfg.SyncTxConfig.Chain33Host,
fetchHeightPeriodMs: cfg.SyncTxConfig.FetchHeightPeriodMs, fetchHeightPeriodMs: cfg.SyncTxConfig.FetchHeightPeriodMs,
unlock: make(chan int), unlock: make(chan int),
db: db, db: db,
ctx: ctx, ctx: ctx,
bridgeRegistryAddr: r.x2EthDeployInfo.BridgeRegistry.Address, bridgeRegistryAddr: x2EthDeployInfo.BridgeRegistry.Address,
} }
err := relayer.setStatusCheckedIndex(1) err := relayer.setStatusCheckedIndex(1)
r.NoError(err) assert.NoError(t, err)
relayer.ethClient = r.sim relayer.ethClient = sim
relayer.totalTx4Chain33ToEth = relayer.getTotalTxAmount2Eth() relayer.totalTx4Chain33ToEth = relayer.getTotalTxAmount2Eth()
relayer.statusCheckedIndex = relayer.getStatusCheckedIndex() relayer.statusCheckedIndex = relayer.getStatusCheckedIndex()
r.Equal(relayer.statusCheckedIndex, int64(1)) assert.Equal(t, relayer.statusCheckedIndex, int64(1))
syncCfg := &ebTypes.SyncTxReceiptConfig{ syncCfg := &ebTypes.SyncTxReceiptConfig{
Chain33Host: cfg.SyncTxConfig.Chain33Host, Chain33Host: cfg.SyncTxConfig.Chain33Host,
PushHost: cfg.SyncTxConfig.PushHost, PushHost: cfg.SyncTxConfig.PushHost,
PushName: cfg.SyncTxConfig.PushName, PushName: cfg.SyncTxConfig.PushName,
PushBind: cfg.SyncTxConfig.PushBind, PushBind: pushBind, //cfg.SyncTxConfig.PushBind,
StartSyncHeight: cfg.SyncTxConfig.StartSyncHeight, StartSyncHeight: cfg.SyncTxConfig.StartSyncHeight,
StartSyncSequence: cfg.SyncTxConfig.StartSyncSequence, StartSyncSequence: cfg.SyncTxConfig.StartSyncSequence,
StartSyncHash: cfg.SyncTxConfig.StartSyncHash, StartSyncHash: cfg.SyncTxConfig.StartSyncHash,
} }
go relayer.syncProc(syncCfg) go relayer.syncProc(syncCfg)
var wg sync.WaitGroup
ch := make(chan os.Signal, 1)
signal.Notify(ch, syscall.SIGTERM)
go func() {
<-ch
cancel()
wg.Wait()
os.Exit(0)
}()
return relayer return relayer
} }
func (r *suiteChain33Relayer) deployContracts() { func deployContracts() (*ethtxs.DeployPara, *ethinterface.SimExtend, *ethtxs.X2EthContracts, *ethtxs.X2EthDeployInfo) {
// 0x8AFDADFC88a1087c9A1D6c0F5Dd04634b87F303a
var deployerPrivateKey = "8656d2bc732a8a816a461ba5e2d8aac7c7f85c26a813df30d5327210465eb230"
// 0x92C8b16aFD6d423652559C6E266cBE1c29Bfd84f
var ethValidatorAddrKeyA = "3fa21584ae2e4fd74db9b58e2386f5481607dfa4d7ba0617aaa7858e5025dc1e"
var ethValidatorAddrKeyB = "a5f3063552f4483cfc20ac4f40f45b798791379862219de9e915c64722c1d400"
var ethValidatorAddrKeyC = "bbf5e65539e9af0eb0cfac30bad475111054b09c11d668fc0731d54ea777471e"
var ethValidatorAddrKeyD = "c9fa31d7984edf81b8ef3b40c761f1847f6fcd5711ab2462da97dc458f1f896b"
ethValidatorAddrKeys := make([]string, 0) ethValidatorAddrKeys := make([]string, 0)
ethValidatorAddrKeys = append(ethValidatorAddrKeys, ethValidatorAddrKeyA) ethValidatorAddrKeys = append(ethValidatorAddrKeys, ethValidatorAddrKeyA)
ethValidatorAddrKeys = append(ethValidatorAddrKeys, ethValidatorAddrKeyB) ethValidatorAddrKeys = append(ethValidatorAddrKeys, ethValidatorAddrKeyB)
...@@ -213,28 +310,21 @@ func (r *suiteChain33Relayer) deployContracts() { ...@@ -213,28 +310,21 @@ func (r *suiteChain33Relayer) deployContracts() {
ethValidatorAddrKeys = append(ethValidatorAddrKeys, ethValidatorAddrKeyD) ethValidatorAddrKeys = append(ethValidatorAddrKeys, ethValidatorAddrKeyD)
ctx := context.Background() ctx := context.Background()
var backend bind.ContractBackend //var backend bind.ContractBackend
backend, r.para = setup.PrepareTestEnvironment(deployerPrivateKey, ethValidatorAddrKeys) backend, para := setup.PrepareTestEnvironment(deployerPrivateKey, ethValidatorAddrKeys)
r.sim = new(ethinterface.SimExtend) sim := new(ethinterface.SimExtend)
r.sim.SimulatedBackend = backend.(*backends.SimulatedBackend) sim.SimulatedBackend = backend.(*backends.SimulatedBackend)
balance, _ := r.sim.BalanceAt(ctx, r.para.Deployer, nil)
fmt.Println("deployer addr,", r.para.Deployer.String(), "balance =", balance.String())
/////////////////////////EstimateGas///////////////////////////
callMsg := ethereum.CallMsg{ callMsg := ethereum.CallMsg{
From: r.para.Deployer, From: para.Deployer,
Data: common.FromHex(generated.BridgeBankBin), Data: common.FromHex(generated.BridgeBankBin),
} }
gas, err := r.sim.EstimateGas(ctx, callMsg) _, _ = sim.EstimateGas(ctx, callMsg)
r.NoError(err) x2EthContracts, x2EthDeployInfo, _ := ethtxs.DeployAndInit(sim, para)
fmt.Printf("\nThe estimated gas=%d\n", gas) sim.Commit()
////////////////////////////////////////////////////
r.x2EthContracts, r.x2EthDeployInfo, err = ethtxs.DeployAndInit(r.sim, r.para) return para, sim, x2EthContracts, x2EthDeployInfo
r.NoError(err)
r.sim.Commit()
} }
func initCfg(path string) *relayerTypes.RelayerConfig { func initCfg(path string) *relayerTypes.RelayerConfig {
...@@ -245,3 +335,24 @@ func initCfg(path string) *relayerTypes.RelayerConfig { ...@@ -245,3 +335,24 @@ func initCfg(path string) *relayerTypes.RelayerConfig {
} }
return &cfg return &cfg
} }
func newMock33(JrpcBindAddr string) *testnode.Chain33Mock {
var ret = types.ReplySubscribePush{IsOk: true, Msg: ""}
var he = types.Header{Height: 10000}
mockapi := &mocks.QueueProtocolAPI{}
// 这里对需要mock的方法打桩,Close是必须的,其它方法根据需要
mockapi.On("Close").Return()
mockapi.On("AddPushSubscribe", mock.Anything).Return(&ret, nil)
mockapi.On("GetLastHeader", mock.Anything).Return(&he, nil)
mockapi.On("GetConfig", mock.Anything).Return(chainTestCfg, nil)
mock33 := testnode.New("", mockapi)
//defer mock33.Close()
rpcCfg := mock33.GetCfg().RPC
// 这里必须设置监听端口,默认的是无效值
rpcCfg.JrpcBindAddr = JrpcBindAddr
mock33.GetRPC().Listen()
return mock33
}
...@@ -36,9 +36,9 @@ func StartSyncTxReceipt(cfg *relayerTypes.SyncTxReceiptConfig, db dbm.DB) *TxRec ...@@ -36,9 +36,9 @@ func StartSyncTxReceipt(cfg *relayerTypes.SyncTxReceiptConfig, db dbm.DB) *TxRec
return syncTxReceipts return syncTxReceipts
} }
func StopSyncTxReceipt() { //func StopSyncTxReceipt() {
syncTxReceipts.Stop() // syncTxReceipts.Stop()
} //}
func startHTTPService(url string, clientHost string) { func startHTTPService(url string, clientHost string) {
listen, err := net.Listen("tcp", url) listen, err := net.Listen("tcp", url)
......
...@@ -4,7 +4,6 @@ import ( ...@@ -4,7 +4,6 @@ import (
"context" "context"
"encoding/hex" "encoding/hex"
"flag" "flag"
"fmt"
"math/big" "math/big"
"os" "os"
"testing" "testing"
...@@ -436,16 +435,6 @@ func Test_BurnBty(t *testing.T) { ...@@ -436,16 +435,6 @@ func Test_BurnBty(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
sim.Commit() sim.Commit()
time.Sleep(time.Second * 2)
fetchCnt := int32(10)
logs, err := ethRelayer.getNextValidEthTxEventLogs(ethRelayer.eventLogIndex.Height, ethRelayer.eventLogIndex.Index, fetchCnt)
require.NoError(t, err)
for _, vLog := range logs {
ethRelayer.procBridgeBankLogs(*vLog)
}
balanceNew, err = ethRelayer.GetBalance(tokenAddrbty, ethReceiver.String()) balanceNew, err = ethRelayer.GetBalance(tokenAddrbty, ethReceiver.String())
require.Nil(t, err) require.Nil(t, err)
require.Equal(t, balanceNew, "90") require.Equal(t, balanceNew, "90")
...@@ -462,8 +451,15 @@ func Test_BurnBty(t *testing.T) { ...@@ -462,8 +451,15 @@ func Test_BurnBty(t *testing.T) {
require.Nil(t, err) require.Nil(t, err)
require.Equal(t, balanceNew, "80") require.Equal(t, balanceNew, "80")
fetchCnt := int32(10)
logs, err := ethRelayer.getNextValidEthTxEventLogs(ethRelayer.eventLogIndex.Height, ethRelayer.eventLogIndex.Index, fetchCnt)
require.NoError(t, err)
for _, vLog := range logs {
ethRelayer.procBridgeBankLogs(*vLog)
}
time.Sleep(time.Second) time.Sleep(time.Second)
fmt.Println("---------------------- end ----------------------")
} }
func Test_RestorePrivateKeys(t *testing.T) { func Test_RestorePrivateKeys(t *testing.T) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment