From 93781ec0d096527e386427a9e97c6d5d36cd1793 Mon Sep 17 00:00:00 2001 From: nisdas Date: Thu, 30 Apr 2020 15:16:34 +0800 Subject: [PATCH 1/4] add fix and regression test --- beacon-chain/rpc/validator/exit.go | 7 ++ beacon-chain/rpc/validator/exit_test.go | 91 +++++++++++++++++++++++++ 2 files changed, 98 insertions(+) diff --git a/beacon-chain/rpc/validator/exit.go b/beacon-chain/rpc/validator/exit.go index 58544252e281..c0750beb92f1 100644 --- a/beacon-chain/rpc/validator/exit.go +++ b/beacon-chain/rpc/validator/exit.go @@ -9,6 +9,7 @@ import ( "github.com/prysmaticlabs/prysm/beacon-chain/core/feed" opfeed "github.com/prysmaticlabs/prysm/beacon-chain/core/feed/operation" "github.com/prysmaticlabs/prysm/beacon-chain/core/helpers" + "github.com/prysmaticlabs/prysm/shared/params" "google.golang.org/grpc/codes" "google.golang.org/grpc/status" ) @@ -22,6 +23,12 @@ func (vs *Server) ProposeExit(ctx context.Context, req *ethpb.SignedVoluntaryExi if err != nil { return nil, status.Errorf(codes.Internal, "Could not get head state: %v", err) } + if req.Exit == nil { + return nil, status.Error(codes.InvalidArgument, "voluntary exit does not exist") + } + if req.Signature == nil || len(req.Signature) != params.BeaconConfig().BLSSignatureLength { + return nil, status.Error(codes.InvalidArgument, "invalid signature provided") + } // Confirm the validator is eligible to exit with the parameters provided. val, err := s.ValidatorAtIndex(req.Exit.ValidatorIndex) diff --git a/beacon-chain/rpc/validator/exit_test.go b/beacon-chain/rpc/validator/exit_test.go index 25cdc45beb9c..89c2118f7ca6 100644 --- a/beacon-chain/rpc/validator/exit_test.go +++ b/beacon-chain/rpc/validator/exit_test.go @@ -5,6 +5,8 @@ import ( "testing" "time" + "github.com/prysmaticlabs/prysm/shared/bytesutil" + ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1" "github.com/prysmaticlabs/go-ssz" mockChain "github.com/prysmaticlabs/prysm/beacon-chain/blockchain/testing" @@ -110,3 +112,92 @@ func TestSub(t *testing.T) { } } } + +func TestProposeExit_NoPanic(t *testing.T) { + db := dbutil.SetupDB(t) + defer dbutil.TeardownDB(t, db) + ctx := context.Background() + testutil.ResetCache() + deposits, keys, err := testutil.DeterministicDepositsAndKeys(params.BeaconConfig().MinGenesisActiveValidatorCount) + if err != nil { + t.Fatal(err) + } + beaconState, err := state.GenesisBeaconState(deposits, 0, ðpb.Eth1Data{BlockHash: make([]byte, 32)}) + if err != nil { + t.Fatal(err) + } + block := blk.NewGenesisBlock([]byte{}) + if err := db.SaveBlock(ctx, block); err != nil { + t.Fatalf("Could not save genesis block: %v", err) + } + genesisRoot, err := ssz.HashTreeRoot(block.Block) + if err != nil { + t.Fatalf("Could not get signing root %v", err) + } + + // Set genesis time to be 100 epochs ago. + genesisTime := time.Now().Add(time.Duration(-100*int64(params.BeaconConfig().SecondsPerSlot*params.BeaconConfig().SlotsPerEpoch)) * time.Second) + mockChainService := &mockChain.ChainService{State: beaconState, Root: genesisRoot[:], Genesis: genesisTime} + server := &Server{ + BeaconDB: db, + HeadFetcher: mockChainService, + SyncChecker: &mockSync.Sync{IsSyncing: false}, + GenesisTimeFetcher: mockChainService, + StateNotifier: mockChainService.StateNotifier(), + OperationNotifier: mockChainService.OperationNotifier(), + ExitPool: voluntaryexits.NewPool(), + P2P: mockp2p.NewTestP2P(t), + } + + // Subscribe to operation notifications. + opChannel := make(chan *feed.Event, 1024) + opSub := server.OperationNotifier.OperationFeed().Subscribe(opChannel) + defer opSub.Unsubscribe() + + req := ðpb.SignedVoluntaryExit{} + _, err = server.ProposeExit(context.Background(), req) + if err == nil { + t.Fatal("Expected error for no exit existing") + } + + // Send the request, expect a result on the state feed. + epoch := uint64(2048) + validatorIndex := uint64(0) + req = ðpb.SignedVoluntaryExit{ + Exit: ðpb.VoluntaryExit{ + Epoch: epoch, + ValidatorIndex: validatorIndex, + }, + } + + _, err = server.ProposeExit(context.Background(), req) + if err == nil { + t.Fatal("Expected error for no signature existing existing") + } + + _, err = server.ProposeExit(context.Background(), req) + if err == nil { + t.Fatal("Expected error for no signature existing existing") + } + req.Signature = bytesutil.FromBytes48([48]byte{}) + + _, err = server.ProposeExit(context.Background(), req) + if err == nil { + t.Fatal("Expected error for invalid signature length") + } + + domain, err := helpers.Domain(beaconState.Fork(), epoch, params.BeaconConfig().DomainVoluntaryExit, beaconState.GenesisValidatorRoot()) + if err != nil { + t.Fatal(err) + } + sigRoot, err := helpers.ComputeSigningRoot(req.Exit, domain) + if err != nil { + t.Fatalf("Could not compute signing root: %v", err) + } + req.Signature = keys[0].Sign(sigRoot[:]).Marshal() + + _, err = server.ProposeExit(context.Background(), req) + if err != nil { + t.Fatalf("Unexpected error: %v", err) + } +} From 1c9205537403754d3e6a009e1c23723a191e4cf6 Mon Sep 17 00:00:00 2001 From: Nishant Das Date: Thu, 30 Apr 2020 15:20:46 +0800 Subject: [PATCH 2/4] Update beacon-chain/rpc/validator/exit_test.go Co-Authored-By: Shay Zluf --- beacon-chain/rpc/validator/exit_test.go | 1 - 1 file changed, 1 deletion(-) diff --git a/beacon-chain/rpc/validator/exit_test.go b/beacon-chain/rpc/validator/exit_test.go index 89c2118f7ca6..59ea70d35cbe 100644 --- a/beacon-chain/rpc/validator/exit_test.go +++ b/beacon-chain/rpc/validator/exit_test.go @@ -6,7 +6,6 @@ import ( "time" "github.com/prysmaticlabs/prysm/shared/bytesutil" - ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1" "github.com/prysmaticlabs/go-ssz" mockChain "github.com/prysmaticlabs/prysm/beacon-chain/blockchain/testing" From e21b4d644fe2165ca8a4d62ec25617762977bb7b Mon Sep 17 00:00:00 2001 From: Nishant Das Date: Thu, 30 Apr 2020 15:23:43 +0800 Subject: [PATCH 3/4] Update beacon-chain/rpc/validator/exit_test.go Co-Authored-By: Shay Zluf --- beacon-chain/rpc/validator/exit_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/beacon-chain/rpc/validator/exit_test.go b/beacon-chain/rpc/validator/exit_test.go index 59ea70d35cbe..e25c058ea070 100644 --- a/beacon-chain/rpc/validator/exit_test.go +++ b/beacon-chain/rpc/validator/exit_test.go @@ -176,7 +176,7 @@ func TestProposeExit_NoPanic(t *testing.T) { _, err = server.ProposeExit(context.Background(), req) if err == nil { - t.Fatal("Expected error for no signature existing existing") + t.Fatal("Expected error for no signature exists") } req.Signature = bytesutil.FromBytes48([48]byte{}) From cdfa63136ee7ba4af0cd468e832335dfd63a83ee Mon Sep 17 00:00:00 2001 From: Nishant Das Date: Thu, 30 Apr 2020 15:25:13 +0800 Subject: [PATCH 4/4] Update exit_test.go --- beacon-chain/rpc/validator/exit_test.go | 5 ----- 1 file changed, 5 deletions(-) diff --git a/beacon-chain/rpc/validator/exit_test.go b/beacon-chain/rpc/validator/exit_test.go index e25c058ea070..2ba9e8c3a289 100644 --- a/beacon-chain/rpc/validator/exit_test.go +++ b/beacon-chain/rpc/validator/exit_test.go @@ -169,11 +169,6 @@ func TestProposeExit_NoPanic(t *testing.T) { }, } - _, err = server.ProposeExit(context.Background(), req) - if err == nil { - t.Fatal("Expected error for no signature existing existing") - } - _, err = server.ProposeExit(context.Background(), req) if err == nil { t.Fatal("Expected error for no signature exists")