mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-12 04:30:04 +00:00
90 lines
3.0 KiB
Go
90 lines
3.0 KiB
Go
|
//go:build go1.18
|
||
|
|
||
|
package v3_test
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"testing"
|
||
|
|
||
|
coreState "github.com/prysmaticlabs/prysm/beacon-chain/core/transition"
|
||
|
native "github.com/prysmaticlabs/prysm/beacon-chain/state/state-native"
|
||
|
v3 "github.com/prysmaticlabs/prysm/beacon-chain/state/v3"
|
||
|
types "github.com/prysmaticlabs/prysm/consensus-types/primitives"
|
||
|
"github.com/prysmaticlabs/prysm/crypto/rand"
|
||
|
"github.com/prysmaticlabs/prysm/encoding/bytesutil"
|
||
|
ethpb "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1"
|
||
|
"github.com/prysmaticlabs/prysm/testing/assert"
|
||
|
"github.com/prysmaticlabs/prysm/testing/util"
|
||
|
)
|
||
|
|
||
|
func FuzzV3StateHashTreeRoot(f *testing.F) {
|
||
|
gState, _ := util.DeterministicGenesisStateBellatrix(f, 100)
|
||
|
output, err := gState.MarshalSSZ()
|
||
|
assert.NoError(f, err)
|
||
|
randPool := make([]byte, 100)
|
||
|
_, err = rand.NewDeterministicGenerator().Read(randPool)
|
||
|
assert.NoError(f, err)
|
||
|
f.Add(randPool, uint64(10))
|
||
|
f.Fuzz(func(t *testing.T, diffBuffer []byte, slotsToTransition uint64) {
|
||
|
stateSSZ := bytesutil.SafeCopyBytes(output)
|
||
|
for i := 0; i < len(diffBuffer); i += 9 {
|
||
|
if i+8 >= len(diffBuffer) {
|
||
|
return
|
||
|
}
|
||
|
num := bytesutil.BytesToUint64BigEndian(diffBuffer[i : i+8])
|
||
|
num %= uint64(len(diffBuffer))
|
||
|
// Perform a XOR on the byte of the selected index.
|
||
|
stateSSZ[num] ^= diffBuffer[i+8]
|
||
|
}
|
||
|
pbState := ðpb.BeaconStateBellatrix{}
|
||
|
err := pbState.UnmarshalSSZ(stateSSZ)
|
||
|
if err != nil {
|
||
|
return
|
||
|
}
|
||
|
nativeState, err := native.InitializeFromProtoBellatrix(pbState)
|
||
|
if err != nil {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
slotsToTransition %= 100
|
||
|
stateObj, err := v3.InitializeFromProtoUnsafe(pbState)
|
||
|
assert.NoError(t, err)
|
||
|
for stateObj.Slot() < types.Slot(slotsToTransition) {
|
||
|
stateObj, err = coreState.ProcessSlots(context.Background(), stateObj, stateObj.Slot()+1)
|
||
|
assert.NoError(t, err)
|
||
|
stateObj.Copy()
|
||
|
|
||
|
nativeState, err = coreState.ProcessSlots(context.Background(), nativeState, nativeState.Slot()+1)
|
||
|
assert.NoError(t, err)
|
||
|
nativeState.Copy()
|
||
|
}
|
||
|
assert.NoError(t, err)
|
||
|
// Perform a cold HTR calculation by initializing a new state.
|
||
|
innerState, ok := stateObj.InnerStateUnsafe().(*ethpb.BeaconStateBellatrix)
|
||
|
assert.Equal(t, true, ok, "inner state is a not a beacon state bellatrix proto")
|
||
|
newState, err := v3.InitializeFromProtoUnsafe(innerState)
|
||
|
assert.NoError(t, err)
|
||
|
|
||
|
newRt, newErr := newState.HashTreeRoot(context.Background())
|
||
|
rt, err := stateObj.HashTreeRoot(context.Background())
|
||
|
nativeRt, nativeErr := nativeState.HashTreeRoot(context.Background())
|
||
|
assert.Equal(t, newErr != nil, err != nil)
|
||
|
assert.Equal(t, newErr != nil, nativeErr != nil)
|
||
|
if err == nil {
|
||
|
assert.Equal(t, rt, newRt)
|
||
|
assert.Equal(t, rt, nativeRt)
|
||
|
}
|
||
|
|
||
|
newSSZ, newErr := newState.MarshalSSZ()
|
||
|
stateObjSSZ, err := stateObj.MarshalSSZ()
|
||
|
nativeSSZ, nativeErr := nativeState.MarshalSSZ()
|
||
|
assert.Equal(t, newErr != nil, err != nil)
|
||
|
assert.Equal(t, newErr != nil, nativeErr != nil)
|
||
|
if err == nil {
|
||
|
assert.DeepEqual(t, newSSZ, stateObjSSZ)
|
||
|
assert.DeepEqual(t, newSSZ, nativeSSZ)
|
||
|
}
|
||
|
|
||
|
})
|
||
|
}
|