2023-05-02 14:19:22 +00:00
|
|
|
package consensus_tests
|
|
|
|
|
|
|
|
import (
|
|
|
|
"io/fs"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/ledgerwatch/erigon-lib/common"
|
|
|
|
"github.com/ledgerwatch/erigon/cl/utils"
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/ef-tests-cl/spectest"
|
|
|
|
"github.com/ledgerwatch/erigon/cmd/erigon-cl/core/state"
|
2023-05-04 13:18:42 +00:00
|
|
|
"github.com/ledgerwatch/erigon/cmd/erigon-cl/core/state/shuffling"
|
2023-05-02 14:19:22 +00:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
type ShufflingCore struct {
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b *ShufflingCore) Run(t *testing.T, root fs.FS, c spectest.TestCase) (err error) {
|
|
|
|
var meta struct {
|
|
|
|
Seed common.Hash `yaml:"seed"`
|
|
|
|
Count int `yaml:"count"`
|
|
|
|
Mapping []int `yaml:"mapping"`
|
|
|
|
}
|
|
|
|
if err := spectest.ReadMeta(root, "mapping.yaml", &meta); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
s := state.GetEmptyBeaconState()
|
2023-05-04 13:18:42 +00:00
|
|
|
keccakOptimized := utils.OptimizedKeccak256NotThreadSafe()
|
|
|
|
preInputs := shuffling.ComputeShuffledIndexPreInputs(s.BeaconConfig(), meta.Seed)
|
2023-05-02 14:19:22 +00:00
|
|
|
for idx, v := range meta.Mapping {
|
2023-05-04 13:18:42 +00:00
|
|
|
shuffledIdx, err := shuffling.ComputeShuffledIndex(s.BeaconConfig(), uint64(idx), uint64(meta.Count), meta.Seed, preInputs, keccakOptimized)
|
2023-05-02 14:19:22 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
assert.EqualValues(t, v, shuffledIdx)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|