2022-06-24 02:41:16 +00:00
|
|
|
package testing
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2024-01-24 20:58:35 +00:00
|
|
|
"math/big"
|
2022-06-24 02:41:16 +00:00
|
|
|
|
2023-01-26 13:07:44 +00:00
|
|
|
"github.com/pkg/errors"
|
2024-02-15 05:46:47 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/v5/api/client/builder"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/beacon-chain/cache"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/beacon-chain/db"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/config/params"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/consensus-types/blocks"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/consensus-types/interfaces"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/consensus-types/primitives"
|
|
|
|
v1 "github.com/prysmaticlabs/prysm/v5/proto/engine/v1"
|
|
|
|
ethpb "github.com/prysmaticlabs/prysm/v5/proto/prysm/v1alpha1"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/runtime/version"
|
|
|
|
"github.com/prysmaticlabs/prysm/v5/time/slots"
|
2022-06-24 02:41:16 +00:00
|
|
|
)
|
|
|
|
|
2023-04-28 21:27:47 +00:00
|
|
|
// Config defines a config struct for dependencies into the service.
|
|
|
|
type Config struct {
|
|
|
|
BeaconDB db.HeadAccessDatabase
|
|
|
|
}
|
|
|
|
|
2022-06-24 02:41:16 +00:00
|
|
|
// MockBuilderService to mock builder.
|
|
|
|
type MockBuilderService struct {
|
|
|
|
HasConfigured bool
|
|
|
|
Payload *v1.ExecutionPayload
|
2023-02-01 16:24:51 +00:00
|
|
|
PayloadCapella *v1.ExecutionPayloadCapella
|
2023-06-14 18:04:48 +00:00
|
|
|
PayloadDeneb *v1.ExecutionPayloadDeneb
|
|
|
|
BlobBundle *v1.BlobsBundle
|
2022-06-24 02:41:16 +00:00
|
|
|
ErrSubmitBlindedBlock error
|
|
|
|
Bid *ethpb.SignedBuilderBid
|
2023-02-10 16:20:38 +00:00
|
|
|
BidCapella *ethpb.SignedBuilderBidCapella
|
2023-06-14 18:04:48 +00:00
|
|
|
BidDeneb *ethpb.SignedBuilderBidDeneb
|
2023-04-28 21:27:47 +00:00
|
|
|
RegistrationCache *cache.RegistrationCache
|
2022-06-24 02:41:16 +00:00
|
|
|
ErrGetHeader error
|
|
|
|
ErrRegisterValidator error
|
2023-04-28 21:27:47 +00:00
|
|
|
Cfg *Config
|
2022-06-24 02:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Configured for mocking.
|
|
|
|
func (s *MockBuilderService) Configured() bool {
|
|
|
|
return s.HasConfigured
|
|
|
|
}
|
|
|
|
|
|
|
|
// SubmitBlindedBlock for mocking.
|
2023-11-29 14:28:37 +00:00
|
|
|
func (s *MockBuilderService) SubmitBlindedBlock(_ context.Context, b interfaces.ReadOnlySignedBeaconBlock) (interfaces.ExecutionData, *v1.BlobsBundle, error) {
|
2023-06-26 15:59:02 +00:00
|
|
|
switch b.Version() {
|
|
|
|
case version.Bellatrix:
|
2023-02-01 16:24:51 +00:00
|
|
|
w, err := blocks.WrappedExecutionPayload(s.Payload)
|
|
|
|
if err != nil {
|
2023-06-14 18:04:48 +00:00
|
|
|
return nil, nil, errors.Wrap(err, "could not wrap payload")
|
2023-02-01 16:24:51 +00:00
|
|
|
}
|
2023-06-14 18:04:48 +00:00
|
|
|
return w, nil, s.ErrSubmitBlindedBlock
|
2023-06-26 15:59:02 +00:00
|
|
|
case version.Capella:
|
2024-01-24 20:58:35 +00:00
|
|
|
w, err := blocks.WrappedExecutionPayloadCapella(s.PayloadCapella, big.NewInt(0))
|
2023-06-14 18:04:48 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, nil, errors.Wrap(err, "could not wrap capella payload")
|
|
|
|
}
|
|
|
|
return w, nil, s.ErrSubmitBlindedBlock
|
2023-06-26 15:59:02 +00:00
|
|
|
case version.Deneb:
|
2024-01-24 20:58:35 +00:00
|
|
|
w, err := blocks.WrappedExecutionPayloadDeneb(s.PayloadDeneb, big.NewInt(0))
|
2023-06-26 15:59:02 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, nil, errors.Wrap(err, "could not wrap deneb payload")
|
|
|
|
}
|
|
|
|
return w, s.BlobBundle, s.ErrSubmitBlindedBlock
|
|
|
|
default:
|
|
|
|
return nil, nil, errors.New("unknown block version for mocking")
|
2023-06-14 18:04:48 +00:00
|
|
|
}
|
2022-06-24 02:41:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetHeader for mocking.
|
2023-04-28 21:27:47 +00:00
|
|
|
func (s *MockBuilderService) GetHeader(_ context.Context, slot primitives.Slot, _ [32]byte, _ [48]byte) (builder.SignedBid, error) {
|
2023-06-14 18:04:48 +00:00
|
|
|
if slots.ToEpoch(slot) >= params.BeaconConfig().DenebForkEpoch || s.BidDeneb != nil {
|
|
|
|
return builder.WrappedSignedBuilderBidDeneb(s.BidDeneb)
|
|
|
|
}
|
2023-05-10 00:45:09 +00:00
|
|
|
if slots.ToEpoch(slot) >= params.BeaconConfig().CapellaForkEpoch || s.BidCapella != nil {
|
2023-02-10 19:36:19 +00:00
|
|
|
return builder.WrappedSignedBuilderBidCapella(s.BidCapella)
|
2023-02-10 16:20:38 +00:00
|
|
|
}
|
2023-02-10 19:36:19 +00:00
|
|
|
w, err := builder.WrappedSignedBuilderBid(s.Bid)
|
2023-01-26 13:07:44 +00:00
|
|
|
if err != nil {
|
2023-02-10 16:20:38 +00:00
|
|
|
return nil, errors.Wrap(err, "could not wrap capella bid")
|
2023-01-26 13:07:44 +00:00
|
|
|
}
|
|
|
|
return w, s.ErrGetHeader
|
2022-06-24 02:41:16 +00:00
|
|
|
}
|
|
|
|
|
2023-04-28 21:27:47 +00:00
|
|
|
// RegistrationByValidatorID returns either the values from the cache or db.
|
|
|
|
func (s *MockBuilderService) RegistrationByValidatorID(ctx context.Context, id primitives.ValidatorIndex) (*ethpb.ValidatorRegistrationV1, error) {
|
|
|
|
if s.RegistrationCache != nil {
|
|
|
|
return s.RegistrationCache.RegistrationByIndex(id)
|
|
|
|
}
|
|
|
|
if s.Cfg.BeaconDB != nil {
|
|
|
|
return s.Cfg.BeaconDB.RegistrationByValidatorID(ctx, id)
|
|
|
|
}
|
|
|
|
return nil, cache.ErrNotFoundRegistration
|
|
|
|
}
|
|
|
|
|
2022-06-24 02:41:16 +00:00
|
|
|
// RegisterValidator for mocking.
|
|
|
|
func (s *MockBuilderService) RegisterValidator(context.Context, []*ethpb.SignedValidatorRegistrationV1) error {
|
|
|
|
return s.ErrRegisterValidator
|
|
|
|
}
|