mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-12 20:50:05 +00:00
a069738c20
* update shared/params * update eth2-types deps * update protobufs * update shared/* * fix testutil/state * update beacon-chain/state * update beacon-chain/db * update tests * fix test * update beacon-chain/core * update beacon-chain/blockchain * update beacon-chain/cache * beacon-chain/forkchoice * update beacon-chain/operations * update beacon-chain/p2p * update beacon-chain/rpc * update sync/initial-sync * update deps * update deps * go fmt * update beacon-chain/sync * update endtoend/ * bazel build //beacon-chain - works w/o issues * update slasher code * udpate tools/ * update validator/ * update fastssz * fix build * fix test building * update tests * update ethereumapis deps * fix tests * update state/stategen * fix build * fix test * add FarFutureSlot * go imports * Radek's suggestions * Ivan's suggestions * type conversions * Nishant's suggestions * add more tests to rpc_send_request * fix test * clean up * fix conflicts Co-authored-by: prylabs-bulldozer[bot] <58059840+prylabs-bulldozer[bot]@users.noreply.github.com> Co-authored-by: nisdas <nishdas93@gmail.com>
72 lines
2.4 KiB
Go
72 lines
2.4 KiB
Go
package stategen
|
|
|
|
import (
|
|
"testing"
|
|
|
|
types "github.com/prysmaticlabs/eth2-types"
|
|
"github.com/prysmaticlabs/prysm/shared/testutil"
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/assert"
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/require"
|
|
)
|
|
|
|
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_CanSave(t *testing.T) {
|
|
e := newBoundaryStateCache()
|
|
s, err := testutil.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.getByRoot([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.getByRoot([32]byte{'a'})
|
|
require.NoError(t, err)
|
|
assert.Equal(t, true, exists, "Should exist")
|
|
assert.DeepEqual(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.DeepEqual(t, s.InnerStateUnsafe(), got.state.InnerStateUnsafe(), "Should have the same state")
|
|
}
|
|
|
|
func TestEpochBoundaryStateCache_CanTrim(t *testing.T) {
|
|
e := newBoundaryStateCache()
|
|
offSet := types.Slot(10)
|
|
for i := types.Slot(0); i < offSet.Add(maxCacheSize); i++ {
|
|
s, err := testutil.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")
|
|
}
|
|
}
|
|
}
|