2020-02-14 13:03:25 -06:00
|
|
|
package attestations
|
2019-11-19 01:19:39 +05:30
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2020-01-22 11:09:21 +05:30
|
|
|
"flag"
|
2019-11-19 01:19:39 +05:30
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/gogo/protobuf/proto"
|
2019-12-20 22:47:00 -05:00
|
|
|
slashpb "github.com/prysmaticlabs/prysm/proto/slashing"
|
2019-11-19 01:19:39 +05:30
|
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
2020-02-13 09:19:46 -07:00
|
|
|
testDB "github.com/prysmaticlabs/prysm/slasher/db/testing"
|
2020-01-22 11:09:21 +05:30
|
|
|
"github.com/urfave/cli"
|
2019-11-19 01:19:39 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
type spanMapTestStruct struct {
|
|
|
|
validatorIdx uint64
|
|
|
|
sourceEpoch uint64
|
|
|
|
targetEpoch uint64
|
|
|
|
slashingTargetEpoch uint64
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap *slashpb.EpochSpanMap
|
2019-11-19 01:19:39 +05:30
|
|
|
}
|
|
|
|
|
|
|
|
var spanTestsMax []spanMapTestStruct
|
|
|
|
var spanTestsMin []spanMapTestStruct
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
// Test data following example of a max span by https://github.com/protolambda
|
|
|
|
// from here: https://github.com/protolambda/eth2-surround/blob/master/README.md#min-max-surround
|
|
|
|
spanTestsMax = []spanMapTestStruct{
|
|
|
|
{
|
|
|
|
validatorIdx: 0,
|
|
|
|
sourceEpoch: 3,
|
|
|
|
targetEpoch: 6,
|
|
|
|
slashingTargetEpoch: 0,
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap: &slashpb.EpochSpanMap{
|
|
|
|
EpochSpanMap: map[uint64]*slashpb.MinMaxEpochSpan{
|
2019-11-19 01:19:39 +05:30
|
|
|
4: {MinEpochSpan: 0, MaxEpochSpan: 2},
|
|
|
|
5: {MinEpochSpan: 0, MaxEpochSpan: 1},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
validatorIdx: 0,
|
|
|
|
sourceEpoch: 8,
|
|
|
|
targetEpoch: 18,
|
|
|
|
slashingTargetEpoch: 0,
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap: &slashpb.EpochSpanMap{
|
|
|
|
EpochSpanMap: map[uint64]*slashpb.MinMaxEpochSpan{
|
2019-11-19 01:19:39 +05:30
|
|
|
4: {MinEpochSpan: 0, MaxEpochSpan: 2},
|
|
|
|
5: {MinEpochSpan: 0, MaxEpochSpan: 1},
|
|
|
|
9: {MinEpochSpan: 0, MaxEpochSpan: 9},
|
|
|
|
10: {MinEpochSpan: 0, MaxEpochSpan: 8},
|
|
|
|
11: {MinEpochSpan: 0, MaxEpochSpan: 7},
|
|
|
|
12: {MinEpochSpan: 0, MaxEpochSpan: 6},
|
|
|
|
13: {MinEpochSpan: 0, MaxEpochSpan: 5},
|
|
|
|
14: {MinEpochSpan: 0, MaxEpochSpan: 4},
|
|
|
|
15: {MinEpochSpan: 0, MaxEpochSpan: 3},
|
|
|
|
16: {MinEpochSpan: 0, MaxEpochSpan: 2},
|
|
|
|
17: {MinEpochSpan: 0, MaxEpochSpan: 1},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
validatorIdx: 0,
|
|
|
|
sourceEpoch: 4,
|
|
|
|
targetEpoch: 12,
|
|
|
|
slashingTargetEpoch: 0,
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap: &slashpb.EpochSpanMap{
|
|
|
|
EpochSpanMap: map[uint64]*slashpb.MinMaxEpochSpan{
|
2019-11-19 01:19:39 +05:30
|
|
|
4: {MinEpochSpan: 0, MaxEpochSpan: 2},
|
|
|
|
5: {MinEpochSpan: 0, MaxEpochSpan: 7},
|
|
|
|
6: {MinEpochSpan: 0, MaxEpochSpan: 6},
|
|
|
|
7: {MinEpochSpan: 0, MaxEpochSpan: 5},
|
|
|
|
8: {MinEpochSpan: 0, MaxEpochSpan: 4},
|
|
|
|
9: {MinEpochSpan: 0, MaxEpochSpan: 9},
|
|
|
|
10: {MinEpochSpan: 0, MaxEpochSpan: 8},
|
|
|
|
11: {MinEpochSpan: 0, MaxEpochSpan: 7},
|
|
|
|
12: {MinEpochSpan: 0, MaxEpochSpan: 6},
|
|
|
|
13: {MinEpochSpan: 0, MaxEpochSpan: 5},
|
|
|
|
14: {MinEpochSpan: 0, MaxEpochSpan: 4},
|
|
|
|
15: {MinEpochSpan: 0, MaxEpochSpan: 3},
|
|
|
|
16: {MinEpochSpan: 0, MaxEpochSpan: 2},
|
|
|
|
17: {MinEpochSpan: 0, MaxEpochSpan: 1},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
validatorIdx: 0,
|
|
|
|
sourceEpoch: 10,
|
|
|
|
targetEpoch: 15,
|
|
|
|
slashingTargetEpoch: 18,
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap: &slashpb.EpochSpanMap{
|
|
|
|
EpochSpanMap: map[uint64]*slashpb.MinMaxEpochSpan{
|
2019-11-19 01:19:39 +05:30
|
|
|
4: {MinEpochSpan: 0, MaxEpochSpan: 2},
|
|
|
|
5: {MinEpochSpan: 0, MaxEpochSpan: 7},
|
|
|
|
6: {MinEpochSpan: 0, MaxEpochSpan: 6},
|
|
|
|
7: {MinEpochSpan: 0, MaxEpochSpan: 5},
|
|
|
|
8: {MinEpochSpan: 0, MaxEpochSpan: 4},
|
|
|
|
9: {MinEpochSpan: 0, MaxEpochSpan: 9},
|
|
|
|
10: {MinEpochSpan: 0, MaxEpochSpan: 8},
|
|
|
|
11: {MinEpochSpan: 0, MaxEpochSpan: 7},
|
|
|
|
12: {MinEpochSpan: 0, MaxEpochSpan: 6},
|
|
|
|
13: {MinEpochSpan: 0, MaxEpochSpan: 5},
|
|
|
|
14: {MinEpochSpan: 0, MaxEpochSpan: 4},
|
|
|
|
15: {MinEpochSpan: 0, MaxEpochSpan: 3},
|
|
|
|
16: {MinEpochSpan: 0, MaxEpochSpan: 2},
|
|
|
|
17: {MinEpochSpan: 0, MaxEpochSpan: 1},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
spanTestsMin = []spanMapTestStruct{
|
|
|
|
{
|
|
|
|
validatorIdx: 0,
|
|
|
|
sourceEpoch: 4,
|
|
|
|
targetEpoch: 6,
|
|
|
|
slashingTargetEpoch: 0,
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap: &slashpb.EpochSpanMap{
|
|
|
|
EpochSpanMap: map[uint64]*slashpb.MinMaxEpochSpan{
|
2019-11-19 01:19:39 +05:30
|
|
|
1: {MinEpochSpan: 5, MaxEpochSpan: 0},
|
|
|
|
2: {MinEpochSpan: 4, MaxEpochSpan: 0},
|
|
|
|
3: {MinEpochSpan: 3, MaxEpochSpan: 0},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
validatorIdx: 0,
|
|
|
|
sourceEpoch: 13,
|
|
|
|
targetEpoch: 18,
|
|
|
|
slashingTargetEpoch: 0,
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap: &slashpb.EpochSpanMap{
|
|
|
|
EpochSpanMap: map[uint64]*slashpb.MinMaxEpochSpan{
|
2019-11-19 01:19:39 +05:30
|
|
|
1: {MinEpochSpan: 5, MaxEpochSpan: 0},
|
|
|
|
2: {MinEpochSpan: 4, MaxEpochSpan: 0},
|
|
|
|
3: {MinEpochSpan: 3, MaxEpochSpan: 0},
|
|
|
|
4: {MinEpochSpan: 14, MaxEpochSpan: 0},
|
|
|
|
5: {MinEpochSpan: 13, MaxEpochSpan: 0},
|
|
|
|
6: {MinEpochSpan: 12, MaxEpochSpan: 0},
|
|
|
|
7: {MinEpochSpan: 11, MaxEpochSpan: 0},
|
|
|
|
8: {MinEpochSpan: 10, MaxEpochSpan: 0},
|
|
|
|
9: {MinEpochSpan: 9, MaxEpochSpan: 0},
|
|
|
|
10: {MinEpochSpan: 8, MaxEpochSpan: 0},
|
|
|
|
11: {MinEpochSpan: 7, MaxEpochSpan: 0},
|
|
|
|
12: {MinEpochSpan: 6, MaxEpochSpan: 0},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
validatorIdx: 0,
|
|
|
|
sourceEpoch: 11,
|
|
|
|
targetEpoch: 15,
|
|
|
|
slashingTargetEpoch: 0,
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap: &slashpb.EpochSpanMap{
|
|
|
|
EpochSpanMap: map[uint64]*slashpb.MinMaxEpochSpan{
|
2019-11-19 01:19:39 +05:30
|
|
|
1: {MinEpochSpan: 5, MaxEpochSpan: 0},
|
|
|
|
2: {MinEpochSpan: 4, MaxEpochSpan: 0},
|
|
|
|
3: {MinEpochSpan: 3, MaxEpochSpan: 0},
|
|
|
|
4: {MinEpochSpan: 11, MaxEpochSpan: 0},
|
|
|
|
5: {MinEpochSpan: 10, MaxEpochSpan: 0},
|
|
|
|
6: {MinEpochSpan: 9, MaxEpochSpan: 0},
|
|
|
|
7: {MinEpochSpan: 8, MaxEpochSpan: 0},
|
|
|
|
8: {MinEpochSpan: 7, MaxEpochSpan: 0},
|
|
|
|
9: {MinEpochSpan: 6, MaxEpochSpan: 0},
|
|
|
|
10: {MinEpochSpan: 5, MaxEpochSpan: 0},
|
|
|
|
11: {MinEpochSpan: 7, MaxEpochSpan: 0},
|
|
|
|
12: {MinEpochSpan: 6, MaxEpochSpan: 0},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
validatorIdx: 0,
|
|
|
|
sourceEpoch: 10,
|
|
|
|
targetEpoch: 20,
|
|
|
|
slashingTargetEpoch: 15,
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap: &slashpb.EpochSpanMap{
|
|
|
|
EpochSpanMap: map[uint64]*slashpb.MinMaxEpochSpan{
|
2019-11-19 01:19:39 +05:30
|
|
|
1: {MinEpochSpan: 5, MaxEpochSpan: 0},
|
|
|
|
2: {MinEpochSpan: 4, MaxEpochSpan: 0},
|
|
|
|
3: {MinEpochSpan: 3, MaxEpochSpan: 0},
|
|
|
|
4: {MinEpochSpan: 11, MaxEpochSpan: 0},
|
|
|
|
5: {MinEpochSpan: 10, MaxEpochSpan: 0},
|
|
|
|
6: {MinEpochSpan: 9, MaxEpochSpan: 0},
|
|
|
|
7: {MinEpochSpan: 8, MaxEpochSpan: 0},
|
|
|
|
8: {MinEpochSpan: 7, MaxEpochSpan: 0},
|
|
|
|
9: {MinEpochSpan: 6, MaxEpochSpan: 0},
|
|
|
|
10: {MinEpochSpan: 5, MaxEpochSpan: 0},
|
|
|
|
11: {MinEpochSpan: 7, MaxEpochSpan: 0},
|
|
|
|
12: {MinEpochSpan: 6, MaxEpochSpan: 0},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestServer_UpdateMaxEpochSpan(t *testing.T) {
|
2020-01-22 11:09:21 +05:30
|
|
|
app := cli.NewApp()
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
c := cli.NewContext(app, set, nil)
|
2020-02-13 09:19:46 -07:00
|
|
|
db := testDB.SetupSlasherDB(t, c)
|
|
|
|
defer testDB.TeardownSlasherDB(t, db)
|
2019-11-19 01:19:39 +05:30
|
|
|
ctx := context.Background()
|
2020-02-13 12:51:30 -07:00
|
|
|
|
2019-11-19 01:19:39 +05:30
|
|
|
for _, tt := range spanTestsMax {
|
2020-02-14 09:46:55 -07:00
|
|
|
spanMap, err := db.ValidatorSpansMap(ctx, tt.validatorIdx)
|
2019-12-04 12:09:38 +05:30
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-02-20 09:56:37 -05:00
|
|
|
spanMap, st, err := detectAndUpdateMaxEpochSpan(ctx, spanMap, tt.sourceEpoch, tt.targetEpoch)
|
2019-11-19 01:19:39 +05:30
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Failed to update span: %v", err)
|
|
|
|
}
|
2020-02-14 09:46:55 -07:00
|
|
|
if err := db.SaveValidatorSpansMap(ctx, tt.validatorIdx, spanMap); err != nil {
|
2019-12-04 12:09:38 +05:30
|
|
|
t.Fatalf("Couldnt save span map for validator id: %d", tt.validatorIdx)
|
|
|
|
}
|
2019-11-19 01:19:39 +05:30
|
|
|
if st != tt.slashingTargetEpoch {
|
2019-12-13 13:01:37 +05:30
|
|
|
t.Fatalf("Expected slashing target: %d got: %d", tt.slashingTargetEpoch, st)
|
2019-11-19 01:19:39 +05:30
|
|
|
}
|
2020-02-14 09:46:55 -07:00
|
|
|
sm, err := db.ValidatorSpansMap(ctx, tt.validatorIdx)
|
2019-11-19 01:19:39 +05:30
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Failed to retrieve span: %v", err)
|
|
|
|
}
|
|
|
|
if sm == nil || !proto.Equal(sm, tt.resultSpanMap) {
|
|
|
|
t.Fatalf("Get should return validator span map: %v got: %v", tt.resultSpanMap, sm)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestServer_UpdateMinEpochSpan(t *testing.T) {
|
2020-01-22 11:09:21 +05:30
|
|
|
app := cli.NewApp()
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
c := cli.NewContext(app, set, nil)
|
2020-02-13 09:19:46 -07:00
|
|
|
db := testDB.SetupSlasherDB(t, c)
|
|
|
|
defer testDB.TeardownSlasherDB(t, db)
|
2019-11-19 01:19:39 +05:30
|
|
|
ctx := context.Background()
|
2020-02-14 09:46:55 -07:00
|
|
|
|
2019-11-19 01:19:39 +05:30
|
|
|
for _, tt := range spanTestsMin {
|
2020-02-14 09:46:55 -07:00
|
|
|
spanMap, err := db.ValidatorSpansMap(ctx, tt.validatorIdx)
|
2019-12-04 12:09:38 +05:30
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-02-20 09:56:37 -05:00
|
|
|
spanMap, st, err := detectAndUpdateMinEpochSpan(ctx, spanMap, tt.sourceEpoch, tt.targetEpoch)
|
2019-11-19 01:19:39 +05:30
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Failed to update span: %v", err)
|
|
|
|
}
|
2020-02-14 09:46:55 -07:00
|
|
|
if err := db.SaveValidatorSpansMap(ctx, tt.validatorIdx, spanMap); err != nil {
|
2019-12-04 12:09:38 +05:30
|
|
|
t.Fatalf("Couldnt save span map for validator id: %d", tt.validatorIdx)
|
|
|
|
}
|
2019-11-19 01:19:39 +05:30
|
|
|
if st != tt.slashingTargetEpoch {
|
2019-12-13 13:01:37 +05:30
|
|
|
t.Fatalf("Expected slashing target: %d got: %d", tt.slashingTargetEpoch, st)
|
2019-11-19 01:19:39 +05:30
|
|
|
}
|
2020-02-14 09:46:55 -07:00
|
|
|
sm, err := db.ValidatorSpansMap(ctx, tt.validatorIdx)
|
2019-11-19 01:19:39 +05:30
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Failed to retrieve span: %v", err)
|
|
|
|
}
|
|
|
|
if sm == nil || !proto.Equal(sm, tt.resultSpanMap) {
|
|
|
|
t.Fatalf("Get should return validator span map: %v got: %v", tt.resultSpanMap, sm)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestServer_FailToUpdate(t *testing.T) {
|
2020-01-22 11:09:21 +05:30
|
|
|
app := cli.NewApp()
|
|
|
|
set := flag.NewFlagSet("test", 0)
|
|
|
|
c := cli.NewContext(app, set, nil)
|
2020-02-13 09:19:46 -07:00
|
|
|
db := testDB.SetupSlasherDB(t, c)
|
|
|
|
defer testDB.TeardownSlasherDB(t, db)
|
2019-11-19 01:19:39 +05:30
|
|
|
ctx := context.Background()
|
2020-02-14 09:46:55 -07:00
|
|
|
|
2019-11-19 01:19:39 +05:30
|
|
|
spanTestsFail := spanMapTestStruct{
|
|
|
|
sourceEpoch: 0,
|
|
|
|
slashingTargetEpoch: 0,
|
|
|
|
targetEpoch: params.BeaconConfig().WeakSubjectivityPeriod + 1,
|
2019-12-20 22:47:00 -05:00
|
|
|
resultSpanMap: &slashpb.EpochSpanMap{
|
|
|
|
EpochSpanMap: map[uint64]*slashpb.MinMaxEpochSpan{
|
2019-11-19 01:19:39 +05:30
|
|
|
4: {MinEpochSpan: 0, MaxEpochSpan: 2},
|
|
|
|
5: {MinEpochSpan: 0, MaxEpochSpan: 1},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
2020-02-14 09:46:55 -07:00
|
|
|
spanMap, err := db.ValidatorSpansMap(ctx, spanTestsFail.validatorIdx)
|
2019-12-04 12:09:38 +05:30
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2020-02-20 09:56:37 -05:00
|
|
|
if _, _, err := detectAndUpdateMinEpochSpan(ctx, spanMap, spanTestsFail.sourceEpoch, spanTestsFail.targetEpoch); err == nil {
|
2019-11-19 01:19:39 +05:30
|
|
|
t.Fatalf("Update should not support diff greater then weak subjectivity period: %v ", params.BeaconConfig().WeakSubjectivityPeriod)
|
|
|
|
}
|
2020-02-20 09:56:37 -05:00
|
|
|
if _, _, err := detectAndUpdateMaxEpochSpan(ctx, spanMap, spanTestsFail.sourceEpoch, spanTestsFail.targetEpoch); err == nil {
|
2019-11-19 01:19:39 +05:30
|
|
|
t.Fatalf("Update should not support diff greater then weak subjectivity period: %v ", params.BeaconConfig().WeakSubjectivityPeriod)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|