package cache import ( "reflect" "testing" ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1" pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1" "github.com/prysmaticlabs/prysm/shared/hashutil" ) func TestCheckpointStateCacheKeyFn_OK(t *testing.T) { cp := ðpb.Checkpoint{Epoch: 1, Root: []byte{'A'}} info := &CheckpointState{ Checkpoint: cp, State: &pb.BeaconState{Slot: 64}, } key, err := checkpointState(info) if err != nil { t.Fatal(err) } wantedKey, err := hashutil.HashProto(cp) if err != nil { t.Fatal(err) } if key != string(wantedKey[:]) { t.Errorf("Incorrect hash key: %s, expected %s", key, string(wantedKey[:])) } } func TestCheckpointStateCacheKeyFn_InvalidObj(t *testing.T) { _, err := checkpointState("bad") if err != ErrNotCheckpointState { t.Errorf("Expected error %v, got %v", ErrNotCheckpointState, err) } } func TestCheckpointStateCache_StateByCheckpoint(t *testing.T) { cache := NewCheckpointStateCache() cp1 := ðpb.Checkpoint{Epoch: 1, Root: []byte{'A'}} info1 := &CheckpointState{ Checkpoint: cp1, State: &pb.BeaconState{Slot: 64}, } state, err := cache.StateByCheckpoint(cp1) if err != nil { t.Fatal(err) } if state != nil { t.Error("Expected state not to exist in empty cache") } if err := cache.AddCheckpointState(info1); err != nil { t.Fatal(err) } state, err = cache.StateByCheckpoint(cp1) if err != nil { t.Fatal(err) } if !reflect.DeepEqual(state, info1.State) { t.Error("incorrectly cached state") } cp2 := ðpb.Checkpoint{Epoch: 2, Root: []byte{'B'}} info2 := &CheckpointState{ Checkpoint: cp2, State: &pb.BeaconState{Slot: 128}, } if err := cache.AddCheckpointState(info2); err != nil { t.Fatal(err) } state, err = cache.StateByCheckpoint(cp2) if err != nil { t.Fatal(err) } if !reflect.DeepEqual(state, info2.State) { t.Error("incorrectly cached state") } state, err = cache.StateByCheckpoint(cp1) if err != nil { t.Fatal(err) } if !reflect.DeepEqual(state, info1.State) { t.Error("incorrectly cached state") } } func TestCheckpointStateCache__MaxSize(t *testing.T) { c := NewCheckpointStateCache() for i := 0; i < maxCheckpointStateSize+100; i++ { info := &CheckpointState{ Checkpoint: ðpb.Checkpoint{Epoch: uint64(i)}, State: &pb.BeaconState{Slot: uint64(i)}, } if err := c.AddCheckpointState(info); err != nil { t.Fatal(err) } } if len(c.cache.ListKeys()) != maxCheckpointStateSize { t.Errorf( "Expected hash cache key size to be %d, got %d", maxCheckpointStateSize, len(c.cache.ListKeys()), ) } }