2021-09-30 20:28:14 +00:00
|
|
|
package endtoend
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"os"
|
|
|
|
"strconv"
|
|
|
|
"testing"
|
|
|
|
|
2024-02-15 05:46:47 +00:00
|
|
|
mock "github.com/prysmaticlabs/prysm/v5/beacon-chain/blockchain/testing"
|
|
|
|
dbtest "github.com/prysmaticlabs/prysm/v5/beacon-chain/db/testing"
|
|
|
|
mockslashings "github.com/prysmaticlabs/prysm/v5/beacon-chain/operations/slashings/mock"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/beacon-chain/startup"
|
|
|
|
mockstategen "github.com/prysmaticlabs/prysm/v5/beacon-chain/state/stategen/mock"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/config/params"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/consensus-types/primitives"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/crypto/bls"
|
|
|
|
ethpb "github.com/prysmaticlabs/prysm/v5/proto/prysm/v1alpha1"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/testing/require"
|
|
|
|
slashersimulator "github.com/prysmaticlabs/prysm/v5/testing/slasher/simulator"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/testing/util"
|
2021-09-30 20:28:14 +00:00
|
|
|
logTest "github.com/sirupsen/logrus/hooks/test"
|
|
|
|
)
|
|
|
|
|
2021-12-06 21:45:38 +00:00
|
|
|
type mockSyncChecker struct{}
|
|
|
|
|
|
|
|
func (c mockSyncChecker) Initialized() bool {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c mockSyncChecker) Syncing() bool {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c mockSyncChecker) Synced() bool {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c mockSyncChecker) Status() error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c mockSyncChecker) Resync() error {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (mockSyncChecker) IsSynced(_ context.Context) (bool, error) {
|
|
|
|
return true, nil
|
|
|
|
}
|
|
|
|
|
2021-09-30 20:28:14 +00:00
|
|
|
func TestEndToEnd_SlasherSimulator(t *testing.T) {
|
2022-09-15 18:47:51 +00:00
|
|
|
params.SetupTestConfigCleanup(t)
|
|
|
|
params.OverrideBeaconConfig(params.E2ETestConfig().Copy())
|
|
|
|
|
2021-09-30 20:28:14 +00:00
|
|
|
hook := logTest.NewGlobal()
|
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
// Run for 10 epochs if not in long-running to confirm long-running has no issues.
|
|
|
|
simulatorParams := slashersimulator.DefaultParams()
|
|
|
|
var err error
|
|
|
|
epochStr, longRunning := os.LookupEnv("E2E_EPOCHS")
|
|
|
|
if longRunning {
|
|
|
|
epochsToRun, err := strconv.Atoi(epochStr)
|
|
|
|
require.NoError(t, err)
|
|
|
|
simulatorParams.NumEpochs = uint64(epochsToRun)
|
|
|
|
}
|
|
|
|
|
|
|
|
slasherDB := dbtest.SetupSlasherDB(t)
|
|
|
|
beaconState, err := util.NewBeaconState()
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
// We setup validators in the beacon state along with their
|
|
|
|
// private keys used to generate valid signatures in generated objects.
|
|
|
|
validators := make([]*ethpb.Validator, simulatorParams.NumValidators)
|
2023-01-26 14:40:12 +00:00
|
|
|
privKeys := make(map[primitives.ValidatorIndex]bls.SecretKey)
|
2021-09-30 20:28:14 +00:00
|
|
|
for valIdx := range validators {
|
|
|
|
privKey, err := bls.RandKey()
|
|
|
|
require.NoError(t, err)
|
2023-01-26 14:40:12 +00:00
|
|
|
privKeys[primitives.ValidatorIndex(valIdx)] = privKey
|
2021-09-30 20:28:14 +00:00
|
|
|
validators[valIdx] = ðpb.Validator{
|
|
|
|
PublicKey: privKey.PublicKey().Marshal(),
|
|
|
|
WithdrawalCredentials: make([]byte, 32),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
err = beaconState.SetValidators(validators)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
mockChain := &mock.ChainService{State: beaconState}
|
2023-10-20 16:45:33 +00:00
|
|
|
gen := mockstategen.NewService()
|
2021-09-30 20:28:14 +00:00
|
|
|
gen.AddStateForRoot(beaconState, [32]byte{})
|
|
|
|
|
2023-05-03 04:34:01 +00:00
|
|
|
gs := startup.NewClockSynchronizer()
|
2021-09-30 20:28:14 +00:00
|
|
|
sim, err := slashersimulator.New(ctx, &slashersimulator.ServiceConfig{
|
|
|
|
Params: simulatorParams,
|
|
|
|
Database: slasherDB,
|
|
|
|
StateNotifier: &mock.MockStateNotifier{},
|
|
|
|
HeadStateFetcher: mockChain,
|
|
|
|
AttestationStateFetcher: mockChain,
|
|
|
|
StateGen: gen,
|
|
|
|
PrivateKeysByValidatorIndex: privKeys,
|
2022-01-26 14:48:20 +00:00
|
|
|
SlashingsPool: &mockslashings.PoolMock{},
|
2021-12-06 21:45:38 +00:00
|
|
|
SyncChecker: mockSyncChecker{},
|
2023-05-03 04:34:01 +00:00
|
|
|
ClockWaiter: gs,
|
|
|
|
ClockSetter: gs,
|
2021-09-30 20:28:14 +00:00
|
|
|
})
|
|
|
|
require.NoError(t, err)
|
|
|
|
sim.Start()
|
|
|
|
err = sim.Stop()
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.LogsDoNotContain(t, hook, "ERROR")
|
|
|
|
require.LogsDoNotContain(t, hook, "Did not detect")
|
|
|
|
require.LogsContain(t, hook, "Correctly detected simulated proposer slashing")
|
|
|
|
require.LogsContain(t, hook, "Correctly detected simulated attester slashing")
|
|
|
|
}
|