Skip to content

Commit

Permalink
added command line flag to enable fork-choice late block reorgs (#7785)
Browse files Browse the repository at this point in the history
 Currently not enabled, just the flag, and defaulting to false, and a test that shows it can be toggled on.

 partially addresses #6595

Signed-off-by: Paul Harris <[email protected]>
  • Loading branch information
rolfyone authored Dec 5, 2023
1 parent 089f64b commit df5a22c
Show file tree
Hide file tree
Showing 7 changed files with 55 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
import static org.junit.jupiter.api.Assertions.assertDoesNotThrow;
import static tech.pegasys.teku.infrastructure.async.SafeFutureAssert.safeJoin;
import static tech.pegasys.teku.infrastructure.time.TimeUtilities.secondsToMillis;
import static tech.pegasys.teku.networks.Eth2NetworkConfiguration.DEFAULT_FORK_CHOICE_LATE_BLOCK_REORG_ENABLED;
import static tech.pegasys.teku.networks.Eth2NetworkConfiguration.DEFAULT_FORK_CHOICE_PROPOSER_BOOST_UNIQUENESS_ENABLED;
import static tech.pegasys.teku.networks.Eth2NetworkConfiguration.DEFAULT_FORK_CHOICE_UPDATE_HEAD_ON_BLOCK_IMPORT_ENABLED;

Expand Down Expand Up @@ -142,6 +143,7 @@ spec, new SignedBlockAndState(anchorBlock, anchorState)),
transitionBlockValidator,
DEFAULT_FORK_CHOICE_UPDATE_HEAD_ON_BLOCK_IMPORT_ENABLED,
DEFAULT_FORK_CHOICE_PROPOSER_BOOST_UNIQUENESS_ENABLED,
DEFAULT_FORK_CHOICE_LATE_BLOCK_REORG_ENABLED,
storageSystem.getMetricsSystem());
final ExecutionLayerChannelStub executionLayer =
new ExecutionLayerChannelStub(spec, false, Optional.empty());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,8 @@ public class Eth2NetworkConfiguration {
private static final int DEFAULT_STARTUP_TIMEOUT_SECONDS = 30;

public static final boolean DEFAULT_FORK_CHOICE_UPDATE_HEAD_ON_BLOCK_IMPORT_ENABLED = false;

public static final boolean DEFAULT_FORK_CHOICE_LATE_BLOCK_REORG_ENABLED = false;
public static final boolean DEFAULT_FORK_CHOICE_PROPOSER_BOOST_UNIQUENESS_ENABLED = true;

public static final int DEFAULT_ASYNC_P2P_MAX_THREADS = 10;
Expand Down Expand Up @@ -97,6 +99,7 @@ public class Eth2NetworkConfiguration {
private final int asyncBeaconChainMaxThreads;
private final int asyncBeaconChainMaxQueue;
private final int asyncP2pMaxQueue;
private final boolean forkChoiceLateBlockReorgEnabled;

private Eth2NetworkConfiguration(
final Spec spec,
Expand Down Expand Up @@ -124,7 +127,8 @@ private Eth2NetworkConfiguration(
final int asyncP2pMaxThreads,
final int asyncP2pMaxQueue,
final int asyncBeaconChainMaxThreads,
final int asyncBeaconChainMaxQueue) {
final int asyncBeaconChainMaxQueue,
final boolean forkChoiceLateBlockReorgEnabled) {
this.spec = spec;
this.constants = constants;
this.initialState = initialState;
Expand Down Expand Up @@ -154,6 +158,7 @@ private Eth2NetworkConfiguration(
this.asyncP2pMaxQueue = asyncP2pMaxQueue;
this.asyncBeaconChainMaxThreads = asyncBeaconChainMaxThreads;
this.asyncBeaconChainMaxQueue = asyncBeaconChainMaxQueue;
this.forkChoiceLateBlockReorgEnabled = forkChoiceLateBlockReorgEnabled;
}

public static Eth2NetworkConfiguration.Builder builder(final String network) {
Expand Down Expand Up @@ -271,6 +276,10 @@ public int getAsyncBeaconChainMaxQueue() {
return asyncBeaconChainMaxQueue;
}

public boolean isForkChoiceLateBlockReorgEnabled() {
return forkChoiceLateBlockReorgEnabled;
}

@Override
public String toString() {
return constants;
Expand Down Expand Up @@ -306,6 +315,7 @@ public static class Builder {
DEFAULT_FORK_CHOICE_UPDATE_HEAD_ON_BLOCK_IMPORT_ENABLED;
private boolean forkChoiceProposerBoostUniquenessEnabled =
DEFAULT_FORK_CHOICE_PROPOSER_BOOST_UNIQUENESS_ENABLED;
private boolean forkChoiceLateBlockReorgEnabled = DEFAULT_FORK_CHOICE_LATE_BLOCK_REORG_ENABLED;

public void spec(Spec spec) {
this.spec = spec;
Expand Down Expand Up @@ -380,7 +390,8 @@ public Eth2NetworkConfiguration build() {
asyncP2pMaxThreads,
asyncP2pMaxQueue,
asyncBeaconChainMaxThreads,
asyncBeaconChainMaxQueue);
asyncBeaconChainMaxQueue,
forkChoiceLateBlockReorgEnabled);
}

private void validateCommandLineParameters() {
Expand Down Expand Up @@ -831,5 +842,10 @@ private Optional<Integer> validateAndParseEpochsStoreBlobs(final String epochsSt
epochsStoreBlobsInt > 0, "Number of the epochs to store blobs for should be > 0");
return Optional.of(epochsStoreBlobsInt);
}

public Builder forkChoiceLateBlockReorgEnabled(boolean forkChoiceLateBlockReorgEnabled) {
this.forkChoiceLateBlockReorgEnabled = forkChoiceLateBlockReorgEnabled;
return this;
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,7 @@ public class ForkChoice implements ForkChoiceUpdatedResultSubscriber {
private final Subscribers<OptimisticHeadSubscriber> optimisticSyncSubscribers =
Subscribers.create(true);
private final TickProcessor tickProcessor;
private final boolean forkChoiceLateBlockReorgEnabled;
private Optional<Boolean> optimisticSyncing = Optional.empty();

public ForkChoice(
Expand All @@ -113,6 +114,7 @@ public ForkChoice(
final MergeTransitionBlockValidator transitionBlockValidator,
final boolean forkChoiceUpdateHeadOnBlockImportEnabled,
final boolean forkChoiceProposerBoostUniquenessEnabled,
final boolean forkChoiceLateBlockReorgEnabled,
final MetricsSystem metricsSystem) {
this.spec = spec;
this.forkChoiceExecutor = forkChoiceExecutor;
Expand All @@ -126,6 +128,9 @@ public ForkChoice(
this.tickProcessor = tickProcessor;
this.forkChoiceUpdateHeadOnBlockImportEnabled = forkChoiceUpdateHeadOnBlockImportEnabled;
this.forkChoiceProposerBoostUniquenessEnabled = forkChoiceProposerBoostUniquenessEnabled;
this.forkChoiceLateBlockReorgEnabled = forkChoiceLateBlockReorgEnabled;
LOG.debug("forkChoiceLateBlockReorgEnabled is set to {}", forkChoiceLateBlockReorgEnabled);

recentChainData.subscribeStoreInitialized(this::initializeProtoArrayForkChoice);
forkChoiceNotifier.subscribeToForkChoiceUpdatedResult(this);
}
Expand Down Expand Up @@ -154,6 +159,7 @@ public ForkChoice(
transitionBlockValidator,
true,
true,
false,
metricsSystem);
}

Expand Down Expand Up @@ -196,6 +202,10 @@ public SafeFuture<Boolean> processHead() {
return processHead(Optional.empty(), false);
}

public boolean isForkChoiceLateBlockReorgEnabled() {
return forkChoiceLateBlockReorgEnabled;
}

/** Import a block to the store. */
public SafeFuture<BlockImportResult> onBlock(
final SignedBeaconBlock block,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@
import static tech.pegasys.teku.infrastructure.async.SafeFutureAssert.safeJoin;
import static tech.pegasys.teku.infrastructure.unsigned.UInt64.ONE;
import static tech.pegasys.teku.infrastructure.unsigned.UInt64.ZERO;
import static tech.pegasys.teku.networks.Eth2NetworkConfiguration.DEFAULT_FORK_CHOICE_LATE_BLOCK_REORG_ENABLED;
import static tech.pegasys.teku.networks.Eth2NetworkConfiguration.DEFAULT_FORK_CHOICE_PROPOSER_BOOST_UNIQUENESS_ENABLED;
import static tech.pegasys.teku.networks.Eth2NetworkConfiguration.DEFAULT_FORK_CHOICE_UPDATE_HEAD_ON_BLOCK_IMPORT_ENABLED;
import static tech.pegasys.teku.statetransition.forkchoice.ForkChoice.BLOCK_CREATION_TOLERANCE_MS;
Expand Down Expand Up @@ -165,6 +166,7 @@ private void setupWithSpec(final Spec unmockedSpec) {
transitionBlockValidator,
DEFAULT_FORK_CHOICE_UPDATE_HEAD_ON_BLOCK_IMPORT_ENABLED,
DEFAULT_FORK_CHOICE_PROPOSER_BOOST_UNIQUENESS_ENABLED,
DEFAULT_FORK_CHOICE_LATE_BLOCK_REORG_ENABLED,
metricsSystem);

// Starting and mocks
Expand Down Expand Up @@ -421,6 +423,7 @@ void onBlock_shouldReorgWhenProposerWeightingMakesForkBestChain(
transitionBlockValidator,
DEFAULT_FORK_CHOICE_UPDATE_HEAD_ON_BLOCK_IMPORT_ENABLED,
DEFAULT_FORK_CHOICE_PROPOSER_BOOST_UNIQUENESS_ENABLED,
DEFAULT_FORK_CHOICE_LATE_BLOCK_REORG_ENABLED,
metricsSystem);

final UInt64 currentSlot = recentChainData.getCurrentSlot().orElseThrow();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -758,6 +758,7 @@ protected void initForkChoice() {
new MergeTransitionBlockValidator(spec, recentChainData, executionLayer),
beaconConfig.eth2NetworkConfig().isForkChoiceUpdateHeadOnBlockImportEnabled(),
beaconConfig.eth2NetworkConfig().isForkChoiceProposerBoostUniquenessEnabled(),
beaconConfig.eth2NetworkConfig().isForkChoiceLateBlockReorgEnabled(),
metricsSystem);
forkChoiceTrigger = new ForkChoiceTrigger(forkChoice);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,17 @@ public class Eth2NetworkOptions {
arity = "1")
private String trustedSetup = null; // Depends on network configuration

@Option(
names = {"--Xfork-choice-late-block-reorg-enabled"},
paramLabel = "<BOOLEAN>",
description = "Allow late blocks to be reorged out if they meet the requirements.",
arity = "0..1",
fallbackValue = "true",
showDefaultValue = Visibility.ALWAYS,
hidden = true)
private boolean forkChoiceLateBlockReorgEnabled =
Eth2NetworkConfiguration.DEFAULT_FORK_CHOICE_LATE_BLOCK_REORG_ENABLED;

@Option(
names = {"--Xnetwork-altair-fork-epoch"},
hidden = true,
Expand Down Expand Up @@ -328,6 +339,7 @@ private void configureEth2Network(Eth2NetworkConfiguration.Builder builder) {
.asyncBeaconChainMaxQueue(asyncBeaconChainMaxQueue)
.forkChoiceUpdateHeadOnBlockImportEnabled(forkChoiceUpdateHeadOnBlockImportEnabled)
.forkChoiceProposerBoostUniquenessEnabled(forkChoiceProposerBoostUniquenessEnabled)
.forkChoiceLateBlockReorgEnabled(forkChoiceLateBlockReorgEnabled)
.epochsStoreBlobs(epochsStoreBlobs);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,15 @@ void shouldSetFirstDescendentAsHead(final String value) {
.isEqualTo(Boolean.valueOf(value));
}

@ParameterizedTest
@ValueSource(strings = {"true", "false"})
void shouldSetLateBlockImportEnabled(final String value) {
final TekuConfiguration config =
getTekuConfigurationFromArguments("--Xfork-choice-late-block-reorg-enabled", value);
assertThat(config.eth2NetworkConfiguration().isForkChoiceLateBlockReorgEnabled())
.isEqualTo(Boolean.valueOf(value));
}

@Test
void shouldMergeTransitionsOverrideBeEmptyByDefault() {
final TekuConfiguration config = getTekuConfigurationFromArguments();
Expand Down

0 comments on commit df5a22c

Please sign in to comment.