2022-04-11 13:45:22 +00:00
|
|
|
package evaluators
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2022-06-09 23:24:53 +00:00
|
|
|
"strconv"
|
2022-04-11 13:45:22 +00:00
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
2022-08-16 12:20:13 +00:00
|
|
|
ctypes "github.com/prysmaticlabs/prysm/v3/consensus-types/primitives"
|
|
|
|
mathutil "github.com/prysmaticlabs/prysm/v3/math"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/proto/eth/service"
|
|
|
|
v2 "github.com/prysmaticlabs/prysm/v3/proto/eth/v2"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/testing/endtoend/policies"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/testing/endtoend/types"
|
|
|
|
"github.com/prysmaticlabs/prysm/v3/time/slots"
|
2022-04-11 13:45:22 +00:00
|
|
|
"google.golang.org/grpc"
|
|
|
|
)
|
|
|
|
|
2022-06-09 23:24:53 +00:00
|
|
|
// OptimisticSyncEnabled checks that the node is in an optimistic state.
|
|
|
|
var OptimisticSyncEnabled = types.Evaluator{
|
|
|
|
Name: "optimistic_sync_at_epoch_%d",
|
|
|
|
Policy: policies.AllEpochs,
|
|
|
|
Evaluation: optimisticSyncEnabled,
|
|
|
|
}
|
|
|
|
|
2023-01-06 07:49:42 +00:00
|
|
|
func optimisticSyncEnabled(_ *types.EvaluationContext, conns ...*grpc.ClientConn) error {
|
2022-06-09 23:24:53 +00:00
|
|
|
for _, conn := range conns {
|
|
|
|
client := service.NewBeaconChainClient(conn)
|
|
|
|
head, err := client.GetBlockV2(context.Background(), &v2.BlockRequestV2{BlockId: []byte("head")})
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
headSlot := uint64(0)
|
|
|
|
switch hb := head.Data.Message.(type) {
|
2022-08-17 01:35:27 +00:00
|
|
|
case *v2.SignedBeaconBlockContainer_Phase0Block:
|
2022-06-09 23:24:53 +00:00
|
|
|
headSlot = uint64(hb.Phase0Block.Slot)
|
2022-08-17 01:35:27 +00:00
|
|
|
case *v2.SignedBeaconBlockContainer_AltairBlock:
|
2022-06-09 23:24:53 +00:00
|
|
|
headSlot = uint64(hb.AltairBlock.Slot)
|
2022-08-17 01:35:27 +00:00
|
|
|
case *v2.SignedBeaconBlockContainer_BellatrixBlock:
|
2022-06-09 23:24:53 +00:00
|
|
|
headSlot = uint64(hb.BellatrixBlock.Slot)
|
|
|
|
default:
|
|
|
|
return errors.New("no valid block type retrieved")
|
|
|
|
}
|
|
|
|
currEpoch := slots.ToEpoch(ctypes.Slot(headSlot))
|
|
|
|
startSlot, err := slots.EpochStart(currEpoch)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
isOptimistic := false
|
|
|
|
for i := startSlot; i <= ctypes.Slot(headSlot); i++ {
|
|
|
|
castI, err := mathutil.Int(uint64(i))
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
block, err := client.GetBlockV2(context.Background(), &v2.BlockRequestV2{BlockId: []byte(strconv.Itoa(castI))})
|
|
|
|
if err != nil {
|
|
|
|
// Continue in the event of non-existent blocks.
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
if !block.ExecutionOptimistic {
|
|
|
|
return errors.New("expected block to be optimistic, but it is not")
|
|
|
|
}
|
|
|
|
isOptimistic = true
|
|
|
|
}
|
|
|
|
if !isOptimistic {
|
|
|
|
return errors.New("expected block to be optimistic, but it is not")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|