mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-10 19:51:20 +00:00
d077483577
* v3 import renamings * tidy * fmt * rev * Update beacon-chain/core/epoch/precompute/reward_penalty_test.go * Update beacon-chain/core/helpers/validators_test.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/alias.go * Update beacon-chain/db/iface/BUILD.bazel * Update beacon-chain/db/kv/kv.go * Update beacon-chain/db/kv/state.go * Update beacon-chain/rpc/prysm/v1alpha1/validator/attester_test.go * Update beacon-chain/rpc/prysm/v1alpha1/validator/attester_test.go * Update beacon-chain/sync/initial-sync/service.go * fix deps * fix bad replacements * fix bad replacements * change back * gohashtree version * fix deps Co-authored-by: Nishant Das <nishdas93@gmail.com> Co-authored-by: Potuz <potuz@prysmaticlabs.com>
73 lines
2.1 KiB
Go
73 lines
2.1 KiB
Go
package cache
|
|
|
|
import (
|
|
"testing"
|
|
|
|
types "github.com/prysmaticlabs/prysm/v3/consensus-types/primitives"
|
|
"github.com/prysmaticlabs/prysm/v3/testing/require"
|
|
)
|
|
|
|
func TestValidatorPayloadIDsCache_GetAndSaveValidatorPayloadIDs(t *testing.T) {
|
|
cache := NewProposerPayloadIDsCache()
|
|
r := [32]byte{}
|
|
i, p, ok := cache.GetProposerPayloadIDs(0, r)
|
|
require.Equal(t, false, ok)
|
|
require.Equal(t, types.ValidatorIndex(0), i)
|
|
require.Equal(t, [pIdLength]byte{}, p)
|
|
|
|
slot := types.Slot(1234)
|
|
vid := types.ValidatorIndex(34234324)
|
|
pid := [8]byte{1, 2, 3, 3, 7, 8, 7, 8}
|
|
r = [32]byte{1, 2, 3}
|
|
cache.SetProposerAndPayloadIDs(slot, vid, pid, r)
|
|
i, p, ok = cache.GetProposerPayloadIDs(slot, r)
|
|
require.Equal(t, true, ok)
|
|
require.Equal(t, vid, i)
|
|
require.Equal(t, pid, p)
|
|
|
|
slot = types.Slot(9456456)
|
|
vid = types.ValidatorIndex(6786745)
|
|
r = [32]byte{4, 5, 6}
|
|
cache.SetProposerAndPayloadIDs(slot, vid, [pIdLength]byte{}, r)
|
|
i, p, ok = cache.GetProposerPayloadIDs(slot, r)
|
|
require.Equal(t, true, ok)
|
|
require.Equal(t, vid, i)
|
|
require.Equal(t, [pIdLength]byte{}, p)
|
|
|
|
// reset cache without pid
|
|
slot = types.Slot(9456456)
|
|
vid = types.ValidatorIndex(11111)
|
|
r = [32]byte{7, 8, 9}
|
|
pid = [8]byte{3, 2, 3, 33, 72, 8, 7, 8}
|
|
cache.SetProposerAndPayloadIDs(slot, vid, pid, r)
|
|
i, p, ok = cache.GetProposerPayloadIDs(slot, r)
|
|
require.Equal(t, true, ok)
|
|
require.Equal(t, vid, i)
|
|
require.Equal(t, pid, p)
|
|
|
|
// Forked chain
|
|
r = [32]byte{1, 2, 3}
|
|
i, p, ok = cache.GetProposerPayloadIDs(slot, r)
|
|
require.Equal(t, false, ok)
|
|
require.Equal(t, types.ValidatorIndex(0), i)
|
|
require.Equal(t, [pIdLength]byte{}, p)
|
|
|
|
// existing pid - no change in cache
|
|
slot = types.Slot(9456456)
|
|
vid = types.ValidatorIndex(11111)
|
|
r = [32]byte{7, 8, 9}
|
|
newPid := [8]byte{1, 2, 3, 33, 72, 8, 7, 1}
|
|
cache.SetProposerAndPayloadIDs(slot, vid, newPid, r)
|
|
i, p, ok = cache.GetProposerPayloadIDs(slot, r)
|
|
require.Equal(t, true, ok)
|
|
require.Equal(t, vid, i)
|
|
require.Equal(t, pid, p)
|
|
|
|
// remove cache entry
|
|
cache.PrunePayloadIDs(slot + 1)
|
|
i, p, ok = cache.GetProposerPayloadIDs(slot, r)
|
|
require.Equal(t, false, ok)
|
|
require.Equal(t, types.ValidatorIndex(0), i)
|
|
require.Equal(t, [pIdLength]byte{}, p)
|
|
}
|