diff --git a/CHANGELOG.md b/CHANGELOG.md index d55a57b4953..62e70b64fdc 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -76,6 +76,7 @@ The format is based on Keep a Changelog, and this project adheres to Semantic Ve - Made QUIC the default method to connect with peers. - Check kzg commitments align with blobs and proofs for beacon api end point. - Increase Max Payload Size in Gossip. +- Revert "Proposer checks gas limit before accepting builder's bid". ### Deprecated diff --git a/beacon-chain/rpc/prysm/v1alpha1/validator/proposer_bellatrix.go b/beacon-chain/rpc/prysm/v1alpha1/validator/proposer_bellatrix.go index e9d74693cb9..f05b0ee6b8d 100644 --- a/beacon-chain/rpc/prysm/v1alpha1/validator/proposer_bellatrix.go +++ b/beacon-chain/rpc/prysm/v1alpha1/validator/proposer_bellatrix.go @@ -243,15 +243,6 @@ func (vs *Server) getPayloadHeaderFromBuilder(ctx context.Context, slot primitiv return nil, fmt.Errorf("incorrect parent hash %#x != %#x", header.ParentHash(), h.BlockHash()) } - reg, err := vs.BlockBuilder.RegistrationByValidatorID(ctx, idx) - if err != nil { - log.WithError(err).Warn("Proposer: failed to get registration by validator ID, could not check gas limit") - } else { - if reg.GasLimit != header.GasLimit() { - return nil, fmt.Errorf("incorrect header gas limit %d != %d", reg.GasLimit, header.GasLimit()) - } - } - t, err := slots.ToTime(uint64(vs.TimeFetcher.GenesisTime().Unix()), slot) if err != nil { return nil, err diff --git a/beacon-chain/rpc/prysm/v1alpha1/validator/proposer_bellatrix_test.go b/beacon-chain/rpc/prysm/v1alpha1/validator/proposer_bellatrix_test.go index c0d1c9d1aeb..7d02c392539 100644 --- a/beacon-chain/rpc/prysm/v1alpha1/validator/proposer_bellatrix_test.go +++ b/beacon-chain/rpc/prysm/v1alpha1/validator/proposer_bellatrix_test.go @@ -720,29 +720,6 @@ func TestServer_getPayloadHeader(t *testing.T) { Signature: sk.Sign(srCapella[:]).Marshal(), } - incorrectGasLimitBid := ðpb.BuilderBid{ - Header: &v1.ExecutionPayloadHeader{ - FeeRecipient: make([]byte, fieldparams.FeeRecipientLength), - StateRoot: make([]byte, fieldparams.RootLength), - ReceiptsRoot: make([]byte, fieldparams.RootLength), - LogsBloom: make([]byte, fieldparams.LogsBloomLength), - PrevRandao: make([]byte, fieldparams.RootLength), - BaseFeePerGas: make([]byte, fieldparams.RootLength), - BlockHash: make([]byte, fieldparams.RootLength), - TransactionsRoot: bytesutil.PadTo([]byte{1}, fieldparams.RootLength), - ParentHash: params.BeaconConfig().ZeroHash[:], - Timestamp: uint64(tiCapella.Unix()), - GasLimit: 100, - }, - Pubkey: sk.PublicKey().Marshal(), - Value: bytesutil.PadTo([]byte{1, 2, 3}, 32), - } - signedIncorrectGasLimitBid := - ðpb.SignedBuilderBid{ - Message: incorrectGasLimitBid, - Signature: sk.Sign(srCapella[:]).Marshal(), - } - require.NoError(t, err) tests := []struct { name string @@ -855,21 +832,6 @@ func TestServer_getPayloadHeader(t *testing.T) { }, err: "is different from head block version", }, - { - name: "incorrect gas limit", - mock: &builderTest.MockBuilderService{ - Bid: signedIncorrectGasLimitBid, - }, - fetcher: &blockchainTest.ChainService{ - Block: func() interfaces.ReadOnlySignedBeaconBlock { - wb, err := blocks.NewSignedBeaconBlock(util.NewBeaconBlockBellatrix()) - require.NoError(t, err) - wb.SetSlot(primitives.Slot(params.BeaconConfig().BellatrixForkEpoch) * params.BeaconConfig().SlotsPerEpoch) - return wb - }(), - }, - err: "incorrect header gas limit 0 != 100", - }, { name: "different bid version during hard fork", mock: &builderTest.MockBuilderService{ @@ -888,18 +850,9 @@ func TestServer_getPayloadHeader(t *testing.T) { } for _, tc := range tests { t.Run(tc.name, func(t *testing.T) { - vs := &Server{BeaconDB: dbTest.SetupDB(t), BlockBuilder: tc.mock, HeadFetcher: tc.fetcher, TimeFetcher: &blockchainTest.ChainService{ + vs := &Server{BlockBuilder: tc.mock, HeadFetcher: tc.fetcher, TimeFetcher: &blockchainTest.ChainService{ Genesis: genesis, }} - regCache := cache.NewRegistrationCache() - regCache.UpdateIndexToRegisteredMap(context.Background(), map[primitives.ValidatorIndex]*ethpb.ValidatorRegistrationV1{ - 0: { - GasLimit: 0, - FeeRecipient: make([]byte, 20), - Pubkey: make([]byte, 48), - }, - }) - tc.mock.RegistrationCache = regCache hb, err := vs.HeadFetcher.HeadBlock(context.Background()) require.NoError(t, err) bid, err := vs.getPayloadHeaderFromBuilder(context.Background(), hb.Block().Slot(), 0)