2019-10-17 03:12:26 +00:00
|
|
|
package rpc
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"testing"
|
|
|
|
|
2019-10-19 03:35:09 +00:00
|
|
|
"github.com/gogo/protobuf/proto"
|
2019-10-17 03:12:26 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/prysm/proto/eth/v1alpha1"
|
|
|
|
"github.com/prysmaticlabs/prysm/slasher/db"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestServer_IsSlashableBlock(t *testing.T) {
|
|
|
|
dbs := db.SetupSlasherDB(t)
|
|
|
|
defer db.TeardownSlasherDB(t, dbs)
|
|
|
|
ctx := context.Background()
|
|
|
|
slasherServer := &Server{
|
2019-11-12 17:24:56 +00:00
|
|
|
SlasherDB: dbs,
|
2019-10-17 03:12:26 +00:00
|
|
|
}
|
|
|
|
psr := ðpb.ProposerSlashingRequest{
|
|
|
|
BlockHeader: ðpb.BeaconBlockHeader{
|
|
|
|
Slot: 1,
|
|
|
|
StateRoot: []byte("A"),
|
|
|
|
},
|
|
|
|
ValidatorIndex: 1,
|
|
|
|
}
|
|
|
|
psr2 := ðpb.ProposerSlashingRequest{
|
|
|
|
BlockHeader: ðpb.BeaconBlockHeader{
|
|
|
|
Slot: 1,
|
|
|
|
StateRoot: []byte("B"),
|
|
|
|
},
|
|
|
|
ValidatorIndex: 1,
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := slasherServer.IsSlashableBlock(ctx, psr); err != nil {
|
|
|
|
t.Errorf("Could not call RPC method: %v", err)
|
|
|
|
}
|
|
|
|
sr, err := slasherServer.IsSlashableBlock(ctx, psr2)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("Could not call RPC method: %v", err)
|
|
|
|
}
|
|
|
|
want := ðpb.ProposerSlashing{
|
|
|
|
ProposerIndex: psr.ValidatorIndex,
|
|
|
|
Header_1: psr2.BlockHeader,
|
|
|
|
Header_2: psr.BlockHeader,
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(sr.ProposerSlashing) != 1 {
|
|
|
|
t.Errorf("Should return 1 slashaing proof: %v", sr)
|
|
|
|
}
|
|
|
|
if !proto.Equal(sr.ProposerSlashing[0], want) {
|
|
|
|
t.Errorf("wanted slashing proof: %v got: %v", want, sr.ProposerSlashing[0])
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestServer_IsNotSlashableBlock(t *testing.T) {
|
|
|
|
dbs := db.SetupSlasherDB(t)
|
|
|
|
defer db.TeardownSlasherDB(t, dbs)
|
|
|
|
|
|
|
|
slasherServer := &Server{
|
2019-11-12 17:24:56 +00:00
|
|
|
SlasherDB: dbs,
|
2019-10-17 03:12:26 +00:00
|
|
|
}
|
|
|
|
psr := ðpb.ProposerSlashingRequest{
|
|
|
|
BlockHeader: ðpb.BeaconBlockHeader{
|
|
|
|
Slot: 1,
|
|
|
|
StateRoot: []byte("A"),
|
|
|
|
},
|
|
|
|
ValidatorIndex: 1,
|
|
|
|
}
|
|
|
|
psr2 := ðpb.ProposerSlashingRequest{
|
|
|
|
BlockHeader: ðpb.BeaconBlockHeader{
|
|
|
|
Slot: 65,
|
|
|
|
StateRoot: []byte("B"),
|
|
|
|
},
|
|
|
|
ValidatorIndex: 1,
|
|
|
|
}
|
|
|
|
ctx := context.Background()
|
|
|
|
|
|
|
|
if _, err := slasherServer.IsSlashableBlock(ctx, psr); err != nil {
|
|
|
|
t.Errorf("Could not call RPC method: %v", err)
|
|
|
|
}
|
|
|
|
sr, err := slasherServer.IsSlashableBlock(ctx, psr2)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("Could not call RPC method: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(sr.ProposerSlashing) != 0 {
|
|
|
|
t.Errorf("Should return 0 slashaing proof: %v", sr)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestServer_DoubleBlock(t *testing.T) {
|
|
|
|
dbs := db.SetupSlasherDB(t)
|
|
|
|
defer db.TeardownSlasherDB(t, dbs)
|
|
|
|
ctx := context.Background()
|
|
|
|
slasherServer := &Server{
|
|
|
|
ctx: ctx,
|
2019-11-12 17:24:56 +00:00
|
|
|
SlasherDB: dbs,
|
2019-10-17 03:12:26 +00:00
|
|
|
}
|
|
|
|
psr := ðpb.ProposerSlashingRequest{
|
|
|
|
BlockHeader: ðpb.BeaconBlockHeader{
|
|
|
|
Slot: 1,
|
|
|
|
StateRoot: []byte("A"),
|
|
|
|
},
|
|
|
|
ValidatorIndex: 1,
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := slasherServer.IsSlashableBlock(ctx, psr); err != nil {
|
|
|
|
t.Errorf("Could not call RPC method: %v", err)
|
|
|
|
}
|
|
|
|
sr, err := slasherServer.IsSlashableBlock(ctx, psr)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("Could not call RPC method: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(sr.ProposerSlashing) != 0 {
|
|
|
|
t.Errorf("Should return 0 slashaing proof: %v", sr)
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2019-11-11 22:03:44 +00:00
|
|
|
func TestServer_SameSlotSlashable(t *testing.T) {
|
2019-10-17 03:12:26 +00:00
|
|
|
dbs := db.SetupSlasherDB(t)
|
|
|
|
defer db.TeardownSlasherDB(t, dbs)
|
|
|
|
ctx := context.Background()
|
|
|
|
slasherServer := &Server{
|
|
|
|
ctx: ctx,
|
2019-11-12 17:24:56 +00:00
|
|
|
SlasherDB: dbs,
|
2019-10-17 03:12:26 +00:00
|
|
|
}
|
|
|
|
psr := ðpb.ProposerSlashingRequest{
|
|
|
|
BlockHeader: ðpb.BeaconBlockHeader{
|
|
|
|
Slot: 1,
|
|
|
|
StateRoot: []byte("A"),
|
|
|
|
},
|
|
|
|
ValidatorIndex: 1,
|
|
|
|
}
|
|
|
|
psr2 := ðpb.ProposerSlashingRequest{
|
|
|
|
BlockHeader: ðpb.BeaconBlockHeader{
|
2019-11-11 22:03:44 +00:00
|
|
|
Slot: 1,
|
2019-10-17 03:12:26 +00:00
|
|
|
StateRoot: []byte("B"),
|
|
|
|
},
|
|
|
|
ValidatorIndex: 1,
|
|
|
|
}
|
|
|
|
want := ðpb.ProposerSlashing{
|
|
|
|
ProposerIndex: psr.ValidatorIndex,
|
|
|
|
Header_1: psr2.BlockHeader,
|
|
|
|
Header_2: psr.BlockHeader,
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := slasherServer.IsSlashableBlock(ctx, psr); err != nil {
|
|
|
|
t.Errorf("Could not call RPC method: %v", err)
|
|
|
|
}
|
|
|
|
sr, err := slasherServer.IsSlashableBlock(ctx, psr2)
|
|
|
|
if err != nil {
|
|
|
|
t.Errorf("Could not call RPC method: %v", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(sr.ProposerSlashing) != 1 {
|
|
|
|
t.Errorf("Should return 1 slashaing proof: %v", sr)
|
|
|
|
}
|
|
|
|
if !proto.Equal(sr.ProposerSlashing[0], want) {
|
|
|
|
t.Errorf("wanted slashing proof: %v got: %v", want, sr.ProposerSlashing[0])
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|