2022-05-04 06:15:09 +00:00
|
|
|
//go:build !fuzz
|
|
|
|
// +build !fuzz
|
|
|
|
|
2021-08-25 16:39:12 +00:00
|
|
|
package cache
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/binary"
|
|
|
|
"math"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
state "github.com/prysmaticlabs/prysm/beacon-chain/state/v1"
|
2021-09-21 19:59:25 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/config/params"
|
2022-04-29 14:32:11 +00:00
|
|
|
types "github.com/prysmaticlabs/prysm/consensus-types/primitives"
|
2021-08-25 16:39:12 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1"
|
2021-09-23 18:53:46 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/testing/require"
|
2021-08-25 16:39:12 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestBalanceCache_AddGetBalance(t *testing.T) {
|
|
|
|
blockRoots := make([][]byte, params.BeaconConfig().SlotsPerHistoricalRoot)
|
|
|
|
for i := 0; i < len(blockRoots); i++ {
|
|
|
|
b := make([]byte, 8)
|
|
|
|
binary.LittleEndian.PutUint64(b, uint64(i))
|
|
|
|
blockRoots[i] = b
|
|
|
|
}
|
|
|
|
raw := ðpb.BeaconState{
|
|
|
|
BlockRoots: blockRoots,
|
|
|
|
}
|
|
|
|
st, err := state.InitializeFromProto(raw)
|
|
|
|
require.NoError(t, err)
|
|
|
|
|
|
|
|
cache := NewEffectiveBalanceCache()
|
|
|
|
_, err = cache.Get(st)
|
|
|
|
require.ErrorContains(t, ErrNotFound.Error(), err)
|
|
|
|
|
|
|
|
b := uint64(100)
|
|
|
|
require.NoError(t, cache.AddTotalEffectiveBalance(st, b))
|
|
|
|
cachedB, err := cache.Get(st)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, b, cachedB)
|
|
|
|
|
|
|
|
require.NoError(t, st.SetSlot(1000))
|
|
|
|
_, err = cache.Get(st)
|
|
|
|
require.ErrorContains(t, ErrNotFound.Error(), err)
|
|
|
|
|
|
|
|
b = uint64(200)
|
|
|
|
require.NoError(t, cache.AddTotalEffectiveBalance(st, b))
|
|
|
|
cachedB, err = cache.Get(st)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, b, cachedB)
|
|
|
|
|
|
|
|
require.NoError(t, st.SetSlot(1000+params.BeaconConfig().SlotsPerHistoricalRoot))
|
|
|
|
_, err = cache.Get(st)
|
|
|
|
require.ErrorContains(t, ErrNotFound.Error(), err)
|
|
|
|
|
|
|
|
b = uint64(300)
|
|
|
|
require.NoError(t, cache.AddTotalEffectiveBalance(st, b))
|
|
|
|
cachedB, err = cache.Get(st)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.Equal(t, b, cachedB)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestBalanceCache_BalanceKey(t *testing.T) {
|
|
|
|
blockRoots := make([][]byte, params.BeaconConfig().SlotsPerHistoricalRoot)
|
|
|
|
for i := 0; i < len(blockRoots); i++ {
|
|
|
|
b := make([]byte, 8)
|
|
|
|
binary.LittleEndian.PutUint64(b, uint64(i))
|
|
|
|
blockRoots[i] = b
|
|
|
|
}
|
|
|
|
raw := ðpb.BeaconState{
|
|
|
|
BlockRoots: blockRoots,
|
|
|
|
}
|
|
|
|
st, err := state.InitializeFromProto(raw)
|
|
|
|
require.NoError(t, err)
|
|
|
|
require.NoError(t, st.SetSlot(types.Slot(math.MaxUint64)))
|
|
|
|
|
|
|
|
_, err = balanceCacheKey(st)
|
|
|
|
require.NoError(t, err)
|
|
|
|
}
|