-
Notifications
You must be signed in to change notification settings - Fork 1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
PrepareBeaconProposer API #10367
PrepareBeaconProposer API #10367
Changes from all commits
c5efcbd
18a4f96
ee65ad2
25ba6a3
294e117
6389e6e
b011ff2
655ac36
264304a
cc9e775
8398747
2a185c9
5ae640d
3c755d4
14024b8
088aa96
f7a388b
3dd1f06
c60602d
bde8d6e
2a27474
5e1b284
02c26ea
d75be76
a6c1795
acec392
700190d
40c2c70
4ee2847
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,6 +7,7 @@ import ( | |
"testing" | ||
"time" | ||
|
||
"github.com/ethereum/go-ethereum/common" | ||
types "github.com/prysmaticlabs/eth2-types" | ||
"github.com/prysmaticlabs/go-bitfield" | ||
mockChain "github.com/prysmaticlabs/prysm/beacon-chain/blockchain/testing" | ||
|
@@ -2011,3 +2012,65 @@ func TestSubmitContributionAndProofs(t *testing.T) { | |
require.DeepEqual(t, expectedContributions, savedMsgs) | ||
}) | ||
} | ||
|
||
func TestPrepareBeaconProposer(t *testing.T) { | ||
type args struct { | ||
request *ethpbv1.PrepareBeaconProposerRequest | ||
} | ||
tests := []struct { | ||
name string | ||
args args | ||
wantErr string | ||
}{ | ||
{ | ||
name: "Happy Path", | ||
args: args{ | ||
request: ðpbv1.PrepareBeaconProposerRequest{ | ||
Recipients: []*ethpbv1.PrepareBeaconProposerRequest_FeeRecipientContainer{ | ||
{ | ||
FeeRecipient: make([]byte, fieldparams.FeeRecipientLength), | ||
ValidatorIndex: 1, | ||
}, | ||
}, | ||
}, | ||
}, | ||
wantErr: "", | ||
}, | ||
{ | ||
name: "invalid fee recipient length", | ||
args: args{ | ||
request: ðpbv1.PrepareBeaconProposerRequest{ | ||
Recipients: []*ethpbv1.PrepareBeaconProposerRequest_FeeRecipientContainer{ | ||
{ | ||
FeeRecipient: make([]byte, fieldparams.BLSPubkeyLength), | ||
ValidatorIndex: 1, | ||
}, | ||
}, | ||
}, | ||
}, | ||
wantErr: "Invalid fee recipient address", | ||
}, | ||
} | ||
for _, tt := range tests { | ||
t.Run(tt.name, func(t *testing.T) { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This test should also read from the DB to ensure the expected data was saved |
||
db := dbutil.SetupDB(t) | ||
ctx := context.Background() | ||
v1Server := &v1alpha1validator.Server{ | ||
BeaconDB: db, | ||
} | ||
server := &Server{ | ||
V1Alpha1Server: v1Server, | ||
} | ||
_, err := server.PrepareBeaconProposer(ctx, tt.args.request) | ||
if tt.wantErr != "" { | ||
require.ErrorContains(t, tt.wantErr, err) | ||
return | ||
} | ||
require.NoError(t, err) | ||
address, err := server.V1Alpha1Server.BeaconDB.FeeRecipientByValidatorID(ctx, 1) | ||
require.NoError(t, err) | ||
require.Equal(t, common.BytesToAddress(tt.args.request.Recipients[0].FeeRecipient), address) | ||
}) | ||
} | ||
|
||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,8 +6,11 @@ import ( | |
"fmt" | ||
"time" | ||
|
||
"github.com/ethereum/go-ethereum/common" | ||
"github.com/ethereum/go-ethereum/common/hexutil" | ||
emptypb "github.com/golang/protobuf/ptypes/empty" | ||
"github.com/pkg/errors" | ||
types "github.com/prysmaticlabs/eth2-types" | ||
"github.com/prysmaticlabs/prysm/beacon-chain/core/feed" | ||
blockfeed "github.com/prysmaticlabs/prysm/beacon-chain/core/feed/block" | ||
"github.com/prysmaticlabs/prysm/beacon-chain/core/transition" | ||
|
@@ -116,11 +119,26 @@ func (vs *Server) ProposeBlock(ctx context.Context, rBlk *ethpb.SignedBeaconBloc | |
return vs.proposeGenericBeaconBlock(ctx, blk) | ||
} | ||
|
||
// PrepareBeaconProposer -- | ||
// PrepareBeaconProposer caches and updates the fee recipient for the given proposer. | ||
func (vs *Server) PrepareBeaconProposer( | ||
_ context.Context, _ *ethpb.PrepareBeaconProposerRequest, | ||
ctx context.Context, request *ethpb.PrepareBeaconProposerRequest, | ||
) (*emptypb.Empty, error) { | ||
return &emptypb.Empty{}, status.Error(codes.Unimplemented, "Unimplemented") | ||
_, span := trace.StartSpan(ctx, "validator.PrepareBeaconProposer") | ||
defer span.End() | ||
var FeeRecipients []common.Address | ||
var ValidatorIndices []types.ValidatorIndex | ||
for _, recipientContainer := range request.Recipients { | ||
recipient := hexutil.Encode(recipientContainer.FeeRecipient) | ||
if !common.IsHexAddress(recipient) { | ||
return nil, status.Errorf(codes.InvalidArgument, fmt.Sprintf("Invalid fee recipient address: %v", recipient)) | ||
} | ||
FeeRecipients = append(FeeRecipients, common.BytesToAddress(recipientContainer.FeeRecipient)) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same here. Worth validating |
||
ValidatorIndices = append(ValidatorIndices, recipientContainer.ValidatorIndex) | ||
} | ||
if err := vs.BeaconDB.SaveFeeRecipientsByValidatorIDs(ctx, ValidatorIndices, FeeRecipients); err != nil { | ||
return nil, status.Errorf(codes.Internal, "Could not save fee recipients: %v", err) | ||
} | ||
return &emptypb.Empty{}, nil | ||
} | ||
|
||
func (vs *Server) proposeGenericBeaconBlock(ctx context.Context, blk block.SignedBeaconBlock) (*ethpb.ProposeResponse, error) { | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2431,6 +2431,63 @@ func TestProposer_GetSyncAggregate_OK(t *testing.T) { | |
require.DeepEqual(t, bitfield.NewBitvector512(), aggregate.SyncCommitteeBits) | ||
} | ||
|
||
func TestProposer_PrepareBeaconProposer(t *testing.T) { | ||
type args struct { | ||
request *ethpb.PrepareBeaconProposerRequest | ||
} | ||
tests := []struct { | ||
name string | ||
args args | ||
wantErr string | ||
}{ | ||
{ | ||
name: "Happy Path", | ||
args: args{ | ||
request: ðpb.PrepareBeaconProposerRequest{ | ||
Recipients: []*ethpb.PrepareBeaconProposerRequest_FeeRecipientContainer{ | ||
{ | ||
FeeRecipient: make([]byte, fieldparams.FeeRecipientLength), | ||
ValidatorIndex: 1, | ||
}, | ||
}, | ||
}, | ||
}, | ||
wantErr: "", | ||
}, | ||
{ | ||
name: "invalid fee recipient length", | ||
args: args{ | ||
request: ðpb.PrepareBeaconProposerRequest{ | ||
Recipients: []*ethpb.PrepareBeaconProposerRequest_FeeRecipientContainer{ | ||
{ | ||
FeeRecipient: make([]byte, fieldparams.BLSPubkeyLength), | ||
ValidatorIndex: 1, | ||
}, | ||
}, | ||
}, | ||
}, | ||
wantErr: "Invalid fee recipient address", | ||
}, | ||
} | ||
for _, tt := range tests { | ||
t.Run(tt.name, func(t *testing.T) { | ||
db := dbutil.SetupDB(t) | ||
ctx := context.Background() | ||
proposerServer := &Server{BeaconDB: db} | ||
_, err := proposerServer.PrepareBeaconProposer(ctx, tt.args.request) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. +1 here |
||
if tt.wantErr != "" { | ||
require.ErrorContains(t, tt.wantErr, err) | ||
return | ||
} | ||
require.NoError(t, err) | ||
address, err := proposerServer.BeaconDB.FeeRecipientByValidatorID(ctx, 1) | ||
require.NoError(t, err) | ||
require.Equal(t, common.BytesToAddress(tt.args.request.Recipients[0].FeeRecipient), address) | ||
|
||
}) | ||
} | ||
} | ||
|
||
func majorityVoteBoundaryTime(slot types.Slot) (uint64, uint64) { | ||
slots := params.BeaconConfig().SlotsPerEpoch.Mul(uint64(params.BeaconConfig().EpochsPerEth1VotingPeriod)) | ||
slotStartTime := uint64(mockPOW.GenesisTime) + uint64((slot - (slot % (slots))).Mul(params.BeaconConfig().SecondsPerSlot)) | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it's worth validating
common.BytesToAddress(recipientContainer.FeeRecipient)