mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-06 19:12:19 +00:00
24987878e4
* Most of the PR changed files are extra and slightly more complicated unit tests. * Fixed Eth1DataVotes not inheriting genesis * Fixed Attestations simulation using wrong slot when reconstructing partecipation * Fixed Copy() operation on BeaconState on Eth1DataVotes * Used correct ListSSZ type for Eth1DataVotes and HistoricalSummaries * Fixed wrong []uint64 deltas on empty slots
88 lines
2.5 KiB
Go
88 lines
2.5 KiB
Go
package consensus_tests
|
|
|
|
import (
|
|
"bytes"
|
|
"io/fs"
|
|
"testing"
|
|
|
|
"github.com/ledgerwatch/erigon/spectest"
|
|
|
|
"github.com/ledgerwatch/erigon/cl/clparams"
|
|
"github.com/ledgerwatch/erigon/cl/cltypes"
|
|
"github.com/ledgerwatch/erigon/cl/persistence/format/snapshot_format"
|
|
"github.com/ledgerwatch/erigon/cl/phase1/core/state"
|
|
|
|
libcommon "github.com/ledgerwatch/erigon-lib/common"
|
|
"github.com/ledgerwatch/erigon-lib/types/clonable"
|
|
"github.com/ledgerwatch/erigon-lib/types/ssz"
|
|
|
|
"github.com/ledgerwatch/erigon/cl/utils"
|
|
"github.com/stretchr/testify/require"
|
|
"gopkg.in/yaml.v2"
|
|
)
|
|
|
|
type unmarshalerMarshalerHashable interface {
|
|
ssz.EncodableSSZ
|
|
ssz.HashableSSZ
|
|
clonable.Clonable
|
|
}
|
|
|
|
type Root struct {
|
|
Root string `yaml:"root"`
|
|
}
|
|
|
|
const rootsFile = "roots.yaml"
|
|
const serializedFile = "serialized.ssz_snappy"
|
|
|
|
func getSSZStaticConsensusTest[T unmarshalerMarshalerHashable](ref T) spectest.Handler {
|
|
return spectest.HandlerFunc(func(t *testing.T, fsroot fs.FS, c spectest.TestCase) (err error) {
|
|
rootBytes, err := fs.ReadFile(fsroot, rootsFile)
|
|
require.NoError(t, err)
|
|
root := Root{}
|
|
err = yaml.Unmarshal(rootBytes, &root)
|
|
require.NoError(t, err)
|
|
expectedRoot := libcommon.HexToHash(root.Root)
|
|
object := ref.Clone().(unmarshalerMarshalerHashable)
|
|
_, isBeaconState := object.(*state.CachingBeaconState)
|
|
|
|
snappyEncoded, err := fs.ReadFile(fsroot, serializedFile)
|
|
require.NoError(t, err)
|
|
encoded, err := utils.DecompressSnappy(snappyEncoded)
|
|
require.NoError(t, err)
|
|
|
|
if err := object.DecodeSSZ(encoded, int(c.Version())); err != nil && !isBeaconState {
|
|
return err
|
|
}
|
|
haveRoot, err := object.HashSSZ()
|
|
require.NoError(t, err)
|
|
require.EqualValues(t, expectedRoot, haveRoot)
|
|
// Cannot test it without a config.
|
|
if isBeaconState {
|
|
return nil
|
|
}
|
|
haveEncoded, err := object.EncodeSSZ(nil)
|
|
require.NoError(t, err)
|
|
require.EqualValues(t, haveEncoded, encoded)
|
|
// Now let it do the encoding in snapshot format
|
|
if blk, ok := object.(*cltypes.SignedBeaconBlock); ok {
|
|
var b bytes.Buffer
|
|
_, err := snapshot_format.WriteBlockForSnapshot(&b, blk, nil)
|
|
require.NoError(t, err)
|
|
var br snapshot_format.MockBlockReader
|
|
if blk.Version() >= clparams.BellatrixVersion {
|
|
br = snapshot_format.MockBlockReader{Block: blk.Block.Body.ExecutionPayload}
|
|
|
|
}
|
|
|
|
blk2, err := snapshot_format.ReadBlockFromSnapshot(&b, &br, &clparams.MainnetBeaconConfig)
|
|
require.NoError(t, err)
|
|
|
|
haveRoot, err := blk2.HashSSZ()
|
|
require.NoError(t, err)
|
|
require.EqualValues(t, expectedRoot, haveRoot)
|
|
}
|
|
|
|
return nil
|
|
})
|
|
}
|