2023-02-15 16:53:28 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
"os"
|
|
|
|
|
|
|
|
"github.com/ledgerwatch/erigon/cl/clparams"
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/erigon-cl/core/transition"
|
|
|
|
)
|
|
|
|
|
|
|
|
func getTestEpochProcessing(f func(s *transition.StateTransistor) error) testFunc {
|
|
|
|
return func() (err error) {
|
|
|
|
defer func() {
|
|
|
|
// recover from panic if one occured. Set err to nil otherwise.
|
|
|
|
if recovered := recover(); recovered != nil {
|
|
|
|
err = fmt.Errorf("panic: %s", recovered)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-02-17 14:13:00 +00:00
|
|
|
// Read post and
|
|
|
|
testState, err := decodeStateFromFile("pre.ssz_snappy")
|
2023-02-15 16:53:28 +00:00
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
2023-02-17 14:13:00 +00:00
|
|
|
var isErrExpected bool
|
|
|
|
expectedState, err := decodeStateFromFile("post.ssz_snappy")
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
isErrExpected = true
|
|
|
|
} else {
|
2023-02-15 16:53:28 +00:00
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Make up state transistor
|
2023-02-16 19:04:16 +00:00
|
|
|
s := transition.New(testState, &clparams.MainnetBeaconConfig, nil, false)
|
2023-02-15 16:53:28 +00:00
|
|
|
if err := f(s); err != nil {
|
|
|
|
if isErrExpected {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if isErrExpected && err == nil {
|
|
|
|
return fmt.Errorf("expected an error got none")
|
|
|
|
}
|
|
|
|
haveRoot, err := testState.HashSSZ()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
expectedRoot, err := expectedState.HashSSZ()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if expectedRoot != haveRoot {
|
|
|
|
return errors.New("mismatching roots")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var effectiveBalancesUpdateTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
2023-02-16 19:04:16 +00:00
|
|
|
return s.ProcessEffectiveBalanceUpdates()
|
2023-02-15 16:53:28 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
var eth1DataResetTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
s.ProcessEth1DataReset()
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
var historicalRootsUpdateTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
s.ProcessHistoricalRootsUpdate()
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
var inactivityUpdateTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
return s.ProcessInactivityScores()
|
|
|
|
})
|
|
|
|
|
|
|
|
var justificationFinalizationTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
return s.ProcessJustificationBitsAndFinality()
|
|
|
|
})
|
|
|
|
|
|
|
|
var participationFlagUpdatesTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
s.ProcessParticipationFlagUpdates()
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
var randaoMixesTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
s.ProcessRandaoMixesReset()
|
|
|
|
return nil
|
|
|
|
})
|
|
|
|
|
|
|
|
var registryUpdatesTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
return s.ProcessRegistryUpdates()
|
|
|
|
})
|
|
|
|
|
|
|
|
var rewardsAndPenaltiesTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
return s.ProcessRewardsAndPenalties()
|
|
|
|
})
|
|
|
|
|
|
|
|
var slashingsTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
return s.ProcessSlashings()
|
|
|
|
})
|
|
|
|
|
|
|
|
var slashingsResetTest = getTestEpochProcessing(func(s *transition.StateTransistor) error {
|
|
|
|
s.ProcessSlashingsReset()
|
|
|
|
return nil
|
|
|
|
})
|