mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-16 06:58:20 +00:00
d077483577
* v3 import renamings * tidy * fmt * rev * Update beacon-chain/core/epoch/precompute/reward_penalty_test.go * Update beacon-chain/core/helpers/validators_test.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/iface/BUILD.bazel * Update beacon-chain/db/kv/kv.go * Update beacon-chain/db/kv/state.go * Update beacon-chain/rpc/prysm/v1alpha1/validator/attester_test.go * Update beacon-chain/rpc/prysm/v1alpha1/validator/attester_test.go * Update beacon-chain/sync/initial-sync/service.go * fix deps * fix bad replacements * fix bad replacements * change back * gohashtree version * fix deps Co-authored-by: Nishant Das <nishdas93@gmail.com> Co-authored-by: Potuz <potuz@prysmaticlabs.com>
83 lines
2.8 KiB
Go
83 lines
2.8 KiB
Go
package stategen
|
|
|
|
import (
|
|
"testing"
|
|
|
|
types "github.com/prysmaticlabs/prysm/v3/consensus-types/primitives"
|
|
"github.com/prysmaticlabs/prysm/v3/testing/assert"
|
|
"github.com/prysmaticlabs/prysm/v3/testing/require"
|
|
"github.com/prysmaticlabs/prysm/v3/testing/util"
|
|
)
|
|
|
|
func TestEpochBoundaryStateCache_BadSlotKey(t *testing.T) {
|
|
_, err := slotKeyFn("sushi")
|
|
assert.ErrorContains(t, errNotSlotRootInfo.Error(), err, "Did not get wanted error")
|
|
}
|
|
|
|
func TestEpochBoundaryStateCache_BadRootKey(t *testing.T) {
|
|
_, err := rootKeyFn("noodle")
|
|
assert.ErrorContains(t, errNotRootStateInfo.Error(), err, "Did not get wanted error")
|
|
}
|
|
|
|
func TestEpochBoundaryStateCache_CanSaveAndDelete(t *testing.T) {
|
|
e := newBoundaryStateCache()
|
|
s, err := util.NewBeaconState()
|
|
require.NoError(t, err)
|
|
require.NoError(t, s.SetSlot(1))
|
|
r := [32]byte{'a'}
|
|
require.NoError(t, e.put(r, s))
|
|
|
|
got, exists, err := e.getByBlockRoot([32]byte{'b'})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, false, exists, "Should not exist")
|
|
assert.Equal(t, (*rootStateInfo)(nil), got, "Should not exist")
|
|
|
|
got, exists, err = e.getByBlockRoot([32]byte{'a'})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, true, exists, "Should exist")
|
|
assert.DeepSSZEqual(t, s.InnerStateUnsafe(), got.state.InnerStateUnsafe(), "Should have the same state")
|
|
|
|
got, exists, err = e.getBySlot(2)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, false, exists, "Should not exist")
|
|
assert.Equal(t, (*rootStateInfo)(nil), got, "Should not exist")
|
|
|
|
got, exists, err = e.getBySlot(1)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, true, exists, "Should exist")
|
|
assert.DeepSSZEqual(t, s.InnerStateUnsafe(), got.state.InnerStateUnsafe(), "Should have the same state")
|
|
|
|
require.NoError(t, e.delete(r))
|
|
got, exists, err = e.getByBlockRoot([32]byte{'b'})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, false, exists, "Should not exist")
|
|
assert.Equal(t, (*rootStateInfo)(nil), got, "Should not exist")
|
|
|
|
got, exists, err = e.getBySlot(1)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, false, exists, "Should not exist")
|
|
assert.Equal(t, (*rootStateInfo)(nil), got, "Should not exist")
|
|
}
|
|
|
|
func TestEpochBoundaryStateCache_CanTrim(t *testing.T) {
|
|
e := newBoundaryStateCache()
|
|
offSet := types.Slot(10)
|
|
for i := types.Slot(0); i < offSet.Add(maxCacheSize); i++ {
|
|
s, err := util.NewBeaconState()
|
|
require.NoError(t, err)
|
|
require.NoError(t, s.SetSlot(i))
|
|
r := [32]byte{byte(i)}
|
|
require.NoError(t, e.put(r, s))
|
|
}
|
|
|
|
assert.Equal(t, int(maxCacheSize), len(e.rootStateCache.ListKeys()), "Did not trim to the correct amount")
|
|
assert.Equal(t, int(maxCacheSize), len(e.slotRootCache.ListKeys()), "Did not trim to the correct amount")
|
|
for _, l := range e.rootStateCache.List() {
|
|
i, ok := l.(*rootStateInfo)
|
|
require.Equal(t, true, ok, "Bad type assertion")
|
|
if i.state.Slot() < offSet {
|
|
t.Error("Did not trim the correct state")
|
|
}
|
|
}
|
|
}
|