2023-11-03 15:25:27 +01:00
|
|
|
//go:build integration
|
|
|
|
|
2024-01-10 19:04:27 +00:00
|
|
|
package tests
|
2023-11-03 15:25:27 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2023-11-11 15:04:18 +03:00
|
|
|
"testing"
|
|
|
|
|
2024-01-09 20:02:14 +00:00
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
|
2023-11-03 15:25:27 +01:00
|
|
|
"github.com/ledgerwatch/erigon-lib/chain/networkname"
|
|
|
|
accounts_steps "github.com/ledgerwatch/erigon/cmd/devnet/accounts/steps"
|
|
|
|
contracts_steps "github.com/ledgerwatch/erigon/cmd/devnet/contracts/steps"
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/devnet/requests"
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/devnet/services"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestStateSync(t *testing.T) {
|
2024-01-10 19:04:27 +00:00
|
|
|
runCtx, err := ContextStart(t, networkname.BorDevnetChainName)
|
2023-11-03 15:25:27 +01:00
|
|
|
require.Nil(t, err)
|
|
|
|
var ctx context.Context = runCtx
|
|
|
|
|
|
|
|
t.Run("InitSubscriptions", func(t *testing.T) {
|
|
|
|
services.InitSubscriptions(ctx, []requests.SubMethod{requests.Methods.ETHNewHeads})
|
|
|
|
})
|
|
|
|
t.Run("CreateAccountWithFunds", func(t *testing.T) {
|
|
|
|
_, err := accounts_steps.CreateAccountWithFunds(ctx, networkname.DevChainName, "root-funder", 200.0)
|
|
|
|
require.Nil(t, err)
|
|
|
|
})
|
|
|
|
t.Run("CreateAccountWithFunds", func(t *testing.T) {
|
|
|
|
_, err := accounts_steps.CreateAccountWithFunds(ctx, networkname.BorDevnetChainName, "child-funder", 200.0)
|
|
|
|
require.Nil(t, err)
|
|
|
|
})
|
|
|
|
t.Run("DeployChildChainReceiver", func(t *testing.T) {
|
|
|
|
var err error
|
|
|
|
ctx, err = contracts_steps.DeployChildChainReceiver(ctx, "child-funder")
|
|
|
|
require.Nil(t, err)
|
|
|
|
})
|
|
|
|
t.Run("DeployRootChainSender", func(t *testing.T) {
|
|
|
|
var err error
|
|
|
|
ctx, err = contracts_steps.DeployRootChainSender(ctx, "root-funder")
|
|
|
|
require.Nil(t, err)
|
|
|
|
})
|
|
|
|
t.Run("GenerateSyncEvents", func(t *testing.T) {
|
|
|
|
require.Nil(t, contracts_steps.GenerateSyncEvents(ctx, "root-funder", 10, 2, 2))
|
|
|
|
})
|
|
|
|
t.Run("ProcessRootTransfers", func(t *testing.T) {
|
|
|
|
require.Nil(t, contracts_steps.ProcessRootTransfers(ctx, "root-funder", 10, 2, 2))
|
|
|
|
})
|
|
|
|
t.Run("BatchProcessRootTransfers", func(t *testing.T) {
|
|
|
|
require.Nil(t, contracts_steps.BatchProcessRootTransfers(ctx, "root-funder", 1, 10, 2, 2))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestChildChainExit(t *testing.T) {
|
|
|
|
t.Skip("FIXME: step CreateAccountWithFunds fails: Failed to get transfer tx: failed to search reserves for hashes: no block heads subscription")
|
|
|
|
|
2024-01-10 19:04:27 +00:00
|
|
|
runCtx, err := ContextStart(t, networkname.BorDevnetChainName)
|
2023-11-03 15:25:27 +01:00
|
|
|
require.Nil(t, err)
|
|
|
|
var ctx context.Context = runCtx
|
|
|
|
|
|
|
|
t.Run("CreateAccountWithFunds", func(t *testing.T) {
|
|
|
|
_, err := accounts_steps.CreateAccountWithFunds(ctx, networkname.DevChainName, "root-funder", 200.0)
|
|
|
|
require.Nil(t, err)
|
|
|
|
})
|
|
|
|
t.Run("CreateAccountWithFunds", func(t *testing.T) {
|
|
|
|
_, err := accounts_steps.CreateAccountWithFunds(ctx, networkname.BorDevnetChainName, "child-funder", 200.0)
|
|
|
|
require.Nil(t, err)
|
|
|
|
})
|
|
|
|
t.Run("DeployRootChainReceiver", func(t *testing.T) {
|
|
|
|
var err error
|
|
|
|
ctx, err = contracts_steps.DeployRootChainReceiver(ctx, "root-funder")
|
|
|
|
require.Nil(t, err)
|
|
|
|
})
|
|
|
|
t.Run("DeployChildChainSender", func(t *testing.T) {
|
|
|
|
var err error
|
|
|
|
ctx, err = contracts_steps.DeployChildChainSender(ctx, "child-funder")
|
|
|
|
require.Nil(t, err)
|
|
|
|
})
|
|
|
|
t.Run("ProcessChildTransfers", func(t *testing.T) {
|
|
|
|
require.Nil(t, contracts_steps.ProcessChildTransfers(ctx, "child-funder", 1, 2, 2))
|
|
|
|
})
|
|
|
|
//t.Run("BatchProcessTransfers", func(t *testing.T) {
|
|
|
|
// require.Nil(t, contracts_steps.BatchProcessTransfers(ctx, "child-funder", 1, 10, 2, 2))
|
|
|
|
//})
|
|
|
|
}
|