mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-10 21:11:20 +00:00
3ab373787e
we need to extract this interface from the struct. i need to also break down the interface more, to better show what parts the caching is used, move some functions from the cache state to the underlying. don't merge
109 lines
2.9 KiB
Go
109 lines
2.9 KiB
Go
package consensus_tests
|
|
|
|
import (
|
|
"io/fs"
|
|
"os"
|
|
"testing"
|
|
|
|
"github.com/ledgerwatch/erigon/cl/abstract"
|
|
"github.com/ledgerwatch/erigon/cl/transition/impl/eth2/statechange"
|
|
|
|
"github.com/ledgerwatch/erigon/spectest"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
type EpochProcessing struct {
|
|
Fn func(s abstract.BeaconState) error
|
|
}
|
|
|
|
func NewEpochProcessing(fn func(s abstract.BeaconState) error) *EpochProcessing {
|
|
return &EpochProcessing{
|
|
Fn: fn,
|
|
}
|
|
}
|
|
|
|
func (b *EpochProcessing) Run(t *testing.T, root fs.FS, c spectest.TestCase) (err error) {
|
|
testState, err := spectest.ReadBeaconState(root, c.Version(), spectest.PreSsz)
|
|
require.NoError(t, err)
|
|
|
|
var expectedError bool
|
|
expectedState, err := spectest.ReadBeaconState(root, c.Version(), spectest.PostSsz)
|
|
if os.IsNotExist(err) {
|
|
expectedError = true
|
|
err = nil
|
|
}
|
|
require.NoError(t, err)
|
|
if err := b.Fn(testState); err != nil {
|
|
if expectedError {
|
|
return nil
|
|
}
|
|
return err
|
|
}
|
|
|
|
haveRoot, err := testState.HashSSZ()
|
|
require.NoError(t, err)
|
|
|
|
expectedRoot, err := expectedState.HashSSZ()
|
|
require.NoError(t, err)
|
|
|
|
assert.EqualValues(t, expectedRoot, haveRoot)
|
|
return nil
|
|
}
|
|
|
|
var effectiveBalancesUpdateTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
return statechange.ProcessEffectiveBalanceUpdates(s)
|
|
})
|
|
|
|
var eth1DataResetTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
statechange.ProcessEth1DataReset(s)
|
|
return nil
|
|
})
|
|
|
|
var historicalRootsUpdateTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
return statechange.ProcessHistoricalRootsUpdate(s)
|
|
})
|
|
|
|
var inactivityUpdateTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
return statechange.ProcessInactivityScores(s)
|
|
})
|
|
|
|
var justificationFinalizationTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
return statechange.ProcessJustificationBitsAndFinality(s)
|
|
})
|
|
|
|
var participationFlagUpdatesTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
statechange.ProcessParticipationFlagUpdates(s)
|
|
return nil
|
|
})
|
|
var participationRecordUpdatesTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
return statechange.ProcessParticipationRecordUpdates(s)
|
|
})
|
|
|
|
var randaoMixesTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
statechange.ProcessRandaoMixesReset(s)
|
|
return nil
|
|
})
|
|
|
|
var registryUpdatesTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
return statechange.ProcessRegistryUpdates(s)
|
|
})
|
|
|
|
var rewardsAndPenaltiesTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
return statechange.ProcessRewardsAndPenalties(s)
|
|
})
|
|
|
|
var slashingsTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
return statechange.ProcessSlashings(s)
|
|
})
|
|
|
|
var slashingsResetTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
statechange.ProcessSlashingsReset(s)
|
|
return nil
|
|
})
|
|
|
|
var recordsResetTest = NewEpochProcessing(func(s abstract.BeaconState) error {
|
|
statechange.ProcessParticipationRecordUpdates(s)
|
|
return nil
|
|
})
|