2021-08-05 17:44:13 +00:00
|
|
|
package cache_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
2022-08-16 12:20:13 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/v3/beacon-chain/cache"
|
|
|
|
types "github.com/prysmaticlabs/prysm/v3/consensus-types/primitives"
|
|
|
|
ethpb "github.com/prysmaticlabs/prysm/v3/proto/prysm/v1alpha1"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/testing/require"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/testing/util"
|
2021-08-05 17:44:13 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestSyncCommitteeCache_CanUpdateAndRetrieve(t *testing.T) {
|
|
|
|
numValidators := 101
|
2021-09-23 18:53:46 +00:00
|
|
|
deterministicState, _ := util.DeterministicGenesisStateAltair(t, uint64(numValidators))
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys := make([][]byte, deterministicState.NumValidators())
|
|
|
|
for i, val := range deterministicState.Validators() {
|
|
|
|
pubKeys[i] = val.PublicKey
|
|
|
|
}
|
|
|
|
tests := []struct {
|
|
|
|
name string
|
|
|
|
currentSyncCommittee *ethpb.SyncCommittee
|
|
|
|
nextSyncCommittee *ethpb.SyncCommittee
|
|
|
|
currentSyncMap map[types.ValidatorIndex][]types.CommitteeIndex
|
|
|
|
nextSyncMap map[types.ValidatorIndex][]types.CommitteeIndex
|
|
|
|
}{
|
|
|
|
{
|
|
|
|
name: "only current epoch",
|
2021-11-24 01:56:34 +00:00
|
|
|
currentSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[1], pubKeys[2], pubKeys[3], pubKeys[2], pubKeys[2],
|
|
|
|
}),
|
2021-11-24 01:56:34 +00:00
|
|
|
nextSyncCommittee: util.ConvertToCommittee([][]byte{}),
|
2021-08-05 17:44:13 +00:00
|
|
|
currentSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
1: {0},
|
|
|
|
2: {1, 3, 4},
|
|
|
|
3: {2},
|
|
|
|
},
|
|
|
|
nextSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
1: {},
|
|
|
|
2: {},
|
|
|
|
3: {},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "only next epoch",
|
2021-11-24 01:56:34 +00:00
|
|
|
currentSyncCommittee: util.ConvertToCommittee([][]byte{}),
|
|
|
|
nextSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[1], pubKeys[2], pubKeys[3], pubKeys[2], pubKeys[2],
|
|
|
|
}),
|
|
|
|
currentSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
1: {},
|
|
|
|
2: {},
|
|
|
|
3: {},
|
|
|
|
},
|
|
|
|
nextSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
1: {0},
|
|
|
|
2: {1, 3, 4},
|
|
|
|
3: {2},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "some current epoch and some next epoch",
|
2021-11-24 01:56:34 +00:00
|
|
|
currentSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[1],
|
|
|
|
pubKeys[2],
|
|
|
|
pubKeys[3],
|
|
|
|
pubKeys[2],
|
|
|
|
pubKeys[2],
|
|
|
|
}),
|
2021-11-24 01:56:34 +00:00
|
|
|
nextSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[7],
|
|
|
|
pubKeys[6],
|
|
|
|
pubKeys[5],
|
|
|
|
pubKeys[4],
|
|
|
|
pubKeys[7],
|
|
|
|
}),
|
|
|
|
currentSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
1: {0},
|
|
|
|
2: {1, 3, 4},
|
|
|
|
3: {2},
|
|
|
|
},
|
|
|
|
nextSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
7: {0, 4},
|
|
|
|
6: {1},
|
|
|
|
5: {2},
|
|
|
|
4: {3},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "some current epoch and some next epoch duplicated across",
|
2021-11-24 01:56:34 +00:00
|
|
|
currentSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[1],
|
|
|
|
pubKeys[2],
|
|
|
|
pubKeys[3],
|
|
|
|
pubKeys[2],
|
|
|
|
pubKeys[2],
|
|
|
|
}),
|
2021-11-24 01:56:34 +00:00
|
|
|
nextSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[2],
|
|
|
|
pubKeys[1],
|
|
|
|
pubKeys[3],
|
|
|
|
pubKeys[2],
|
|
|
|
pubKeys[1],
|
|
|
|
}),
|
|
|
|
currentSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
1: {0},
|
|
|
|
2: {1, 3, 4},
|
|
|
|
3: {2},
|
|
|
|
},
|
|
|
|
nextSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
1: {1, 4},
|
|
|
|
2: {0, 3},
|
|
|
|
3: {2},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "all duplicated",
|
2021-11-24 01:56:34 +00:00
|
|
|
currentSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
}),
|
2021-11-24 01:56:34 +00:00
|
|
|
nextSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
}),
|
|
|
|
currentSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
100: {0, 1, 2, 3},
|
|
|
|
},
|
|
|
|
nextSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
100: {0, 1, 2, 3},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: "unknown keys",
|
2021-11-24 01:56:34 +00:00
|
|
|
currentSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
}),
|
2021-11-24 01:56:34 +00:00
|
|
|
nextSyncCommittee: util.ConvertToCommittee([][]byte{
|
2021-08-05 17:44:13 +00:00
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
pubKeys[100],
|
|
|
|
}),
|
|
|
|
currentSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
1: {},
|
|
|
|
},
|
|
|
|
nextSyncMap: map[types.ValidatorIndex][]types.CommitteeIndex{
|
|
|
|
1: {},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
for _, tt := range tests {
|
|
|
|
t.Run(tt.name, func(t *testing.T) {
|
2021-09-23 18:53:46 +00:00
|
|
|
s, _ := util.DeterministicGenesisStateAltair(t, uint64(numValidators))
|
2021-08-05 17:44:13 +00:00
|
|
|
require.NoError(t, s.SetCurrentSyncCommittee(tt.currentSyncCommittee))
|
|
|
|
require.NoError(t, s.SetNextSyncCommittee(tt.nextSyncCommittee))
|
2022-06-27 13:34:38 +00:00
|
|
|
c := cache.NewSyncCommittee()
|
2021-08-05 17:44:13 +00:00
|
|
|
r := [32]byte{'a'}
|
2022-06-27 13:34:38 +00:00
|
|
|
require.NoError(t, c.UpdatePositionsInCommittee(r, s))
|
2021-08-05 17:44:13 +00:00
|
|
|
for key, indices := range tt.currentSyncMap {
|
2022-06-27 13:34:38 +00:00
|
|
|
pos, err := c.CurrentPeriodIndexPosition(r, key)
|
2021-08-05 17:44:13 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.DeepEqual(t, indices, pos)
|
|
|
|
}
|
|
|
|
for key, indices := range tt.nextSyncMap {
|
2022-06-27 13:34:38 +00:00
|
|
|
pos, err := c.NextPeriodIndexPosition(r, key)
|
2021-08-05 17:44:13 +00:00
|
|
|
require.NoError(t, err)
|
|
|
|
require.DeepEqual(t, indices, pos)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSyncCommitteeCache_RootDoesNotExist(t *testing.T) {
|
|
|
|
c := cache.NewSyncCommittee()
|
|
|
|
_, err := c.CurrentPeriodIndexPosition([32]byte{}, 0)
|
|
|
|
require.Equal(t, cache.ErrNonExistingSyncCommitteeKey, err)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSyncCommitteeCache_CanRotate(t *testing.T) {
|
|
|
|
c := cache.NewSyncCommittee()
|
2021-09-23 18:53:46 +00:00
|
|
|
s, _ := util.DeterministicGenesisStateAltair(t, 64)
|
2021-11-24 01:56:34 +00:00
|
|
|
require.NoError(t, s.SetCurrentSyncCommittee(util.ConvertToCommittee([][]byte{{1}})))
|
2021-08-05 17:44:13 +00:00
|
|
|
require.NoError(t, c.UpdatePositionsInCommittee([32]byte{'a'}, s))
|
2021-11-24 01:56:34 +00:00
|
|
|
require.NoError(t, s.SetCurrentSyncCommittee(util.ConvertToCommittee([][]byte{{2}})))
|
2021-08-05 17:44:13 +00:00
|
|
|
require.NoError(t, c.UpdatePositionsInCommittee([32]byte{'b'}, s))
|
2021-11-24 01:56:34 +00:00
|
|
|
require.NoError(t, s.SetCurrentSyncCommittee(util.ConvertToCommittee([][]byte{{3}})))
|
2021-08-05 17:44:13 +00:00
|
|
|
require.NoError(t, c.UpdatePositionsInCommittee([32]byte{'c'}, s))
|
2021-11-24 01:56:34 +00:00
|
|
|
require.NoError(t, s.SetCurrentSyncCommittee(util.ConvertToCommittee([][]byte{{4}})))
|
2021-08-05 17:44:13 +00:00
|
|
|
require.NoError(t, c.UpdatePositionsInCommittee([32]byte{'d'}, s))
|
|
|
|
|
|
|
|
_, err := c.CurrentPeriodIndexPosition([32]byte{'a'}, 0)
|
|
|
|
require.Equal(t, cache.ErrNonExistingSyncCommitteeKey, err)
|
|
|
|
|
|
|
|
_, err = c.CurrentPeriodIndexPosition([32]byte{'c'}, 0)
|
|
|
|
require.NoError(t, err)
|
|
|
|
}
|