2020-03-02 04:27:56 +00:00
|
|
|
package kv
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
2021-02-16 07:45:34 +00:00
|
|
|
types "github.com/prysmaticlabs/eth2-types"
|
2020-03-02 04:27:56 +00:00
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/bytesutil"
|
2020-08-08 18:39:01 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/assert"
|
|
|
|
"github.com/prysmaticlabs/prysm/shared/testutil/require"
|
2020-03-02 04:27:56 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestStateSummary_CanSaveRretrieve(t *testing.T) {
|
|
|
|
db := setupDB(t)
|
|
|
|
ctx := context.Background()
|
|
|
|
r1 := bytesutil.ToBytes32([]byte{'A'})
|
|
|
|
r2 := bytesutil.ToBytes32([]byte{'B'})
|
2020-03-27 20:28:38 +00:00
|
|
|
s1 := &pb.StateSummary{Slot: 1, Root: r1[:]}
|
2020-03-02 04:27:56 +00:00
|
|
|
|
|
|
|
// State summary should not exist yet.
|
2020-08-08 18:39:01 +00:00
|
|
|
require.Equal(t, false, db.HasStateSummary(ctx, r1), "State summary should not be saved")
|
|
|
|
require.NoError(t, db.SaveStateSummary(ctx, s1))
|
|
|
|
require.Equal(t, true, db.HasStateSummary(ctx, r1), "State summary should be saved")
|
2020-03-02 04:27:56 +00:00
|
|
|
|
|
|
|
saved, err := db.StateSummary(ctx, r1)
|
2020-08-08 18:39:01 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
assert.DeepEqual(t, s1, saved, "State summary does not equal")
|
2020-03-02 04:27:56 +00:00
|
|
|
|
|
|
|
// Save a new state summary.
|
2020-03-27 20:28:38 +00:00
|
|
|
s2 := &pb.StateSummary{Slot: 2, Root: r2[:]}
|
2020-03-02 04:27:56 +00:00
|
|
|
|
|
|
|
// State summary should not exist yet.
|
2020-08-08 18:39:01 +00:00
|
|
|
require.Equal(t, false, db.HasStateSummary(ctx, r2), "State summary should not be saved")
|
|
|
|
require.NoError(t, db.SaveStateSummary(ctx, s2))
|
|
|
|
require.Equal(t, true, db.HasStateSummary(ctx, r2), "State summary should be saved")
|
2020-03-02 04:27:56 +00:00
|
|
|
|
|
|
|
saved, err = db.StateSummary(ctx, r2)
|
2020-08-08 18:39:01 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
assert.DeepEqual(t, s2, saved, "State summary does not equal")
|
2020-03-02 04:27:56 +00:00
|
|
|
}
|
2020-12-16 16:56:21 +00:00
|
|
|
|
|
|
|
func TestStateSummary_CacheToDB(t *testing.T) {
|
|
|
|
db := setupDB(t)
|
|
|
|
|
|
|
|
summaries := make([]*pb.StateSummary, stateSummaryCachePruneCount-1)
|
|
|
|
for i := range summaries {
|
2021-02-16 07:45:34 +00:00
|
|
|
summaries[i] = &pb.StateSummary{Slot: types.Slot(i), Root: bytesutil.PadTo(bytesutil.Uint64ToBytesLittleEndian(uint64(i)), 32)}
|
2020-12-16 16:56:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
require.NoError(t, db.SaveStateSummaries(context.Background(), summaries))
|
|
|
|
require.Equal(t, db.stateSummaryCache.len(), stateSummaryCachePruneCount-1)
|
|
|
|
|
|
|
|
require.NoError(t, db.SaveStateSummary(context.Background(), &pb.StateSummary{Slot: 1000, Root: []byte{'a', 'b'}}))
|
|
|
|
require.Equal(t, db.stateSummaryCache.len(), stateSummaryCachePruneCount)
|
|
|
|
|
|
|
|
require.NoError(t, db.SaveStateSummary(context.Background(), &pb.StateSummary{Slot: 1001, Root: []byte{'c', 'd'}}))
|
|
|
|
require.Equal(t, db.stateSummaryCache.len(), 1)
|
|
|
|
|
|
|
|
for i := range summaries {
|
|
|
|
r := bytesutil.Uint64ToBytesLittleEndian(uint64(i))
|
|
|
|
require.Equal(t, true, db.HasStateSummary(context.Background(), bytesutil.ToBytes32(r)))
|
|
|
|
}
|
|
|
|
}
|