mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-13 13:43:30 +00:00
f70635a992
* WIP add deposits * Modify validator component * Merge branch 'master' of https://github.com/prysmaticlabs/prysm into e2e-add-depsoits * Fix e2e * Merge branch 'master' of https://github.com/prysmaticlabs/prysm into e2e-add-depsoits * Merge branch 'master' of https://github.com/prysmaticlabs/prysm into e2e-add-depsoits * Start running with extra deposits * Begin adding evluator for e2e deposit * Get deposit E2E working * Add more rigorous testing for deposits * Merge branch 'master' of https://github.com/prysmaticlabs/prysm into e2e-add-depsoits * Improve policy for deposits * Fix build * Remove sync testing for long running e2e * Undo shard change * Undo unneeded changes * Adjust for comments * Merge branch 'master' into e2e-add-depsoits * Fix bug where long running E2E would always run * Merge branch 'master' of https://github.com/prysmaticlabs/prysm into e2e-add-depsoits * Merge branch 'e2e-add-depsoits' of https://github.com/0xKiwi/Prysm into e2e-add-depsoits * Merge branch 'master' into e2e-add-depsoits
147 lines
4.8 KiB
Go
147 lines
4.8 KiB
Go
package endtoend
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"os"
|
|
"path"
|
|
"testing"
|
|
"time"
|
|
|
|
ptypes "github.com/gogo/protobuf/types"
|
|
eth "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/core/state"
|
|
"github.com/prysmaticlabs/prysm/endtoend/components"
|
|
ev "github.com/prysmaticlabs/prysm/endtoend/evaluators"
|
|
"github.com/prysmaticlabs/prysm/endtoend/helpers"
|
|
e2e "github.com/prysmaticlabs/prysm/endtoend/params"
|
|
"github.com/prysmaticlabs/prysm/endtoend/types"
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
|
"google.golang.org/grpc"
|
|
)
|
|
|
|
func init() {
|
|
state.SkipSlotCache.Disable()
|
|
}
|
|
|
|
func runEndToEndTest(t *testing.T, config *types.E2EConfig) {
|
|
t.Logf("Shard index: %d\n", e2e.TestParams.TestShardIndex)
|
|
t.Logf("Starting time: %s\n", time.Now().String())
|
|
t.Logf("Log Path: %s\n\n", e2e.TestParams.LogPath)
|
|
|
|
keystorePath, eth1PID := components.StartEth1Node(t)
|
|
bootnodeENR, _ := components.StartBootnode(t)
|
|
bProcessIDs := components.StartBeaconNodes(t, config, bootnodeENR)
|
|
valProcessIDs := components.StartValidatorClients(t, config, keystorePath)
|
|
processIDs := append(valProcessIDs, bProcessIDs...)
|
|
processIDs = append(processIDs, eth1PID)
|
|
defer helpers.LogOutput(t, config)
|
|
defer helpers.KillProcesses(t, processIDs)
|
|
|
|
beaconLogFile, err := os.Open(path.Join(e2e.TestParams.LogPath, fmt.Sprintf(e2e.BeaconNodeLogFileName, 0)))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if err := helpers.WaitForTextInFile(beaconLogFile, "Chain started within the last epoch"); err != nil {
|
|
t.Fatalf("failed to find chain start in logs, this means the chain did not start: %v", err)
|
|
}
|
|
|
|
// Failing early in case chain doesn't start.
|
|
if t.Failed() {
|
|
return
|
|
}
|
|
|
|
conns := make([]*grpc.ClientConn, e2e.TestParams.BeaconNodeCount)
|
|
for i := 0; i < len(conns); i++ {
|
|
conn, err := grpc.Dial(fmt.Sprintf("127.0.0.1:%d", e2e.TestParams.BeaconNodeRPCPort+i), grpc.WithInsecure())
|
|
if err != nil {
|
|
t.Fatalf("Failed to dial: %v", err)
|
|
}
|
|
conns[i] = conn
|
|
defer func() {
|
|
if err := conn.Close(); err != nil {
|
|
t.Log(err)
|
|
}
|
|
}()
|
|
}
|
|
nodeClient := eth.NewNodeClient(conns[0])
|
|
genesis, err := nodeClient.GetGenesis(context.Background(), &ptypes.Empty{})
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
// Small offset so evaluators perform in the middle of an epoch.
|
|
epochSeconds := params.BeaconConfig().SecondsPerSlot * params.BeaconConfig().SlotsPerEpoch
|
|
genesisTime := time.Unix(genesis.GenesisTime.Seconds+int64(epochSeconds/2), 0)
|
|
|
|
if config.TestSlasher {
|
|
slasherPIDs := components.StartSlashers(t)
|
|
defer helpers.KillProcesses(t, slasherPIDs)
|
|
}
|
|
if config.TestDeposits {
|
|
valCount := int(params.BeaconConfig().MinGenesisActiveValidatorCount) / e2e.TestParams.BeaconNodeCount
|
|
valPid := components.StartNewValidatorClient(t, config, valCount, e2e.TestParams.BeaconNodeCount)
|
|
defer helpers.KillProcesses(t, []int{valPid})
|
|
components.SendAndMineDeposits(t, keystorePath, valCount, int(params.BeaconConfig().MinGenesisActiveValidatorCount))
|
|
}
|
|
|
|
ticker := helpers.GetEpochTicker(genesisTime, epochSeconds)
|
|
for currentEpoch := range ticker.C() {
|
|
for _, evaluator := range config.Evaluators {
|
|
// Only run if the policy says so.
|
|
if !evaluator.Policy(currentEpoch) {
|
|
continue
|
|
}
|
|
t.Run(fmt.Sprintf(evaluator.Name, currentEpoch), func(t *testing.T) {
|
|
if err := evaluator.Evaluation(conns...); err != nil {
|
|
t.Errorf("evaluation failed for epoch %d: %v", currentEpoch, err)
|
|
}
|
|
})
|
|
}
|
|
|
|
if t.Failed() || currentEpoch >= config.EpochsToRun-1 {
|
|
ticker.Done()
|
|
if t.Failed() {
|
|
return
|
|
}
|
|
break
|
|
}
|
|
}
|
|
|
|
if !config.TestSync {
|
|
return
|
|
}
|
|
|
|
index := e2e.TestParams.BeaconNodeCount
|
|
processID := components.StartNewBeaconNode(t, config, index, bootnodeENR)
|
|
syncConn, err := grpc.Dial(fmt.Sprintf("127.0.0.1:%d", e2e.TestParams.BeaconNodeRPCPort+index), grpc.WithInsecure())
|
|
if err != nil {
|
|
t.Fatalf("Failed to dial: %v", err)
|
|
}
|
|
conns = append(conns, syncConn)
|
|
|
|
// Sleep for a few epochs to give time for the newly started node to sync.
|
|
extraTimeToSync := (config.EpochsToRun+config.EpochsToRun/2)*epochSeconds + 60
|
|
genesisTime.Add(time.Duration(extraTimeToSync) * time.Second)
|
|
// Wait until middle of epoch to request to prevent conflicts.
|
|
time.Sleep(time.Until(genesisTime))
|
|
|
|
syncLogFile, err := os.Open(path.Join(e2e.TestParams.LogPath, fmt.Sprintf(e2e.BeaconNodeLogFileName, index)))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer helpers.LogErrorOutput(t, syncLogFile, "beacon chain node", index)
|
|
defer helpers.KillProcesses(t, []int{processID})
|
|
if err := helpers.WaitForTextInFile(syncLogFile, "Synced up to"); err != nil {
|
|
t.Fatalf("Failed to sync: %v", err)
|
|
}
|
|
|
|
syncEvaluators := []types.Evaluator{ev.FinishedSyncing, ev.AllNodesHaveSameHead}
|
|
for _, evaluator := range syncEvaluators {
|
|
t.Run(evaluator.Name, func(t *testing.T) {
|
|
if err := evaluator.Evaluation(conns...); err != nil {
|
|
t.Errorf("evaluation failed for sync node: %v", err)
|
|
}
|
|
})
|
|
}
|
|
}
|