mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2024-12-25 21:07:18 +00:00
9149c2e4f4
* Change NoGenesisDelay to CustomGenesisDelay * Implement flag * gazelle * Fix docs * Merge branch 'master' of https://github.com/prysmaticlabs/Prysm into custom-genesis-delay * Fix * Gazelle * Add case to fix bad math * Merge branch 'master' into custom-genesis-delay
174 lines
4.8 KiB
Go
174 lines
4.8 KiB
Go
package db
|
|
|
|
import (
|
|
"context"
|
|
"reflect"
|
|
"testing"
|
|
|
|
"github.com/prysmaticlabs/go-bitfield"
|
|
slashpb "github.com/prysmaticlabs/prysm/proto/slashing"
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
|
)
|
|
|
|
func TestProposalHistory_InitializesNewPubKeys(t *testing.T) {
|
|
pubkeys := [][48]byte{{30}, {25}, {20}}
|
|
db := SetupDB(t, pubkeys)
|
|
defer TeardownDB(t, db)
|
|
|
|
for _, pub := range pubkeys {
|
|
proposalHistory, err := db.ProposalHistory(context.Background(), pub[:])
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
clean := &slashpb.ProposalHistory{
|
|
EpochBits: bitfield.NewBitlist(params.BeaconConfig().WeakSubjectivityPeriod),
|
|
}
|
|
if !reflect.DeepEqual(proposalHistory, clean) {
|
|
t.Fatalf("Expected proposal history epoch bits to be empty, received %v", proposalHistory)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestProposalHistory_NilDB(t *testing.T) {
|
|
db := SetupDB(t, [][48]byte{})
|
|
defer TeardownDB(t, db)
|
|
|
|
valPubkey := []byte{1, 2, 3}
|
|
|
|
proposalHistory, err := db.ProposalHistory(context.Background(), valPubkey)
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if proposalHistory != nil {
|
|
t.Fatalf("Expected proposal history to be nil, received: %v", proposalHistory)
|
|
}
|
|
}
|
|
|
|
func TestSaveProposalHistory_OK(t *testing.T) {
|
|
db := SetupDB(t, [][48]byte{})
|
|
defer TeardownDB(t, db)
|
|
|
|
pubkey := []byte{3}
|
|
epoch := uint64(2)
|
|
history := &slashpb.ProposalHistory{
|
|
EpochBits: bitfield.Bitlist{0x04, 0x04},
|
|
LatestEpochWritten: 2,
|
|
}
|
|
|
|
if err := db.SaveProposalHistory(context.Background(), pubkey, history); err != nil {
|
|
t.Fatalf("Saving proposal history failed: %v", err)
|
|
}
|
|
savedHistory, err := db.ProposalHistory(context.Background(), pubkey)
|
|
if err != nil {
|
|
t.Fatalf("Failed to get proposal history: %v", err)
|
|
}
|
|
|
|
if savedHistory == nil || !reflect.DeepEqual(history, savedHistory) {
|
|
t.Fatalf("Expected DB to keep object the same, received: %v", history)
|
|
}
|
|
if !savedHistory.EpochBits.BitAt(epoch) {
|
|
t.Fatalf("Expected epoch %d to be marked as proposed", history.EpochBits.Count())
|
|
}
|
|
if savedHistory.EpochBits.BitAt(epoch + 1) {
|
|
t.Fatalf("Expected epoch %d to not be marked as proposed", epoch+1)
|
|
}
|
|
if savedHistory.EpochBits.BitAt(epoch - 1) {
|
|
t.Fatalf("Expected epoch %d to not be marked as proposed", epoch-1)
|
|
}
|
|
}
|
|
|
|
func TestSaveProposalHistory_Overwrites(t *testing.T) {
|
|
db := SetupDB(t, [][48]byte{})
|
|
defer TeardownDB(t, db)
|
|
tests := []struct {
|
|
pubkey []byte
|
|
epoch uint64
|
|
history *slashpb.ProposalHistory
|
|
}{
|
|
{
|
|
pubkey: []byte{0},
|
|
epoch: uint64(1),
|
|
history: &slashpb.ProposalHistory{
|
|
EpochBits: bitfield.Bitlist{0x02, 0x02},
|
|
LatestEpochWritten: 1,
|
|
},
|
|
},
|
|
{
|
|
pubkey: []byte{0},
|
|
epoch: uint64(2),
|
|
history: &slashpb.ProposalHistory{
|
|
EpochBits: bitfield.Bitlist{0x04, 0x04},
|
|
LatestEpochWritten: 2,
|
|
},
|
|
},
|
|
{
|
|
pubkey: []byte{0},
|
|
epoch: uint64(3),
|
|
history: &slashpb.ProposalHistory{
|
|
EpochBits: bitfield.Bitlist{0x08, 0x08},
|
|
LatestEpochWritten: 3,
|
|
},
|
|
},
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
if err := db.SaveProposalHistory(context.Background(), tt.pubkey, tt.history); err != nil {
|
|
t.Fatalf("Saving proposal history failed: %v", err)
|
|
}
|
|
history, err := db.ProposalHistory(context.Background(), tt.pubkey)
|
|
if err != nil {
|
|
t.Fatalf("Failed to get proposal history: %v", err)
|
|
}
|
|
|
|
if history == nil || !reflect.DeepEqual(history, tt.history) {
|
|
t.Fatalf("Expected DB to keep object the same, received: %v", history)
|
|
}
|
|
if !history.EpochBits.BitAt(tt.epoch) {
|
|
t.Fatalf("Expected epoch %d to be marked as proposed", history.EpochBits.Count())
|
|
}
|
|
if history.EpochBits.BitAt(tt.epoch + 1) {
|
|
t.Fatalf("Expected epoch %d to not be marked as proposed", tt.epoch+1)
|
|
}
|
|
if history.EpochBits.BitAt(tt.epoch - 1) {
|
|
t.Fatalf("Expected epoch %d to not be marked as proposed", tt.epoch-1)
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestDeleteProposalHistory_OK(t *testing.T) {
|
|
db := SetupDB(t, [][48]byte{})
|
|
defer TeardownDB(t, db)
|
|
|
|
pubkey := []byte{2}
|
|
history := &slashpb.ProposalHistory{
|
|
EpochBits: bitfield.Bitlist{0x01, 0x02},
|
|
LatestEpochWritten: 1,
|
|
}
|
|
|
|
if err := db.SaveProposalHistory(context.Background(), pubkey, history); err != nil {
|
|
t.Fatalf("Save proposal history failed: %v", err)
|
|
}
|
|
// Making sure everything is saved.
|
|
savedHistory, err := db.ProposalHistory(context.Background(), pubkey)
|
|
if err != nil {
|
|
t.Fatalf("Failed to get proposal history: %v", err)
|
|
}
|
|
if savedHistory == nil || !reflect.DeepEqual(savedHistory, history) {
|
|
t.Fatalf("Expected DB to keep object the same, received: %v, expected %v", savedHistory, history)
|
|
}
|
|
if err := db.DeleteProposalHistory(context.Background(), pubkey); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Check after deleting from DB.
|
|
savedHistory, err = db.ProposalHistory(context.Background(), pubkey)
|
|
if err != nil {
|
|
t.Fatalf("Failed to get proposal history: %v", err)
|
|
}
|
|
if savedHistory != nil {
|
|
t.Fatalf("Expected proposal history to be nil, received %v", savedHistory)
|
|
}
|
|
}
|