diff --git a/services/executionengine/build.gradle b/services/executionengine/build.gradle index df7ea851df1..a03be7a764b 100644 --- a/services/executionengine/build.gradle +++ b/services/executionengine/build.gradle @@ -1,6 +1,7 @@ dependencies { implementation project(':data') implementation project(':infrastructure:events') + implementation project(':infrastructure:exceptions') implementation project(':ethereum:executionlayer') implementation project(':ethereum:networks') implementation project(':ethereum:spec') diff --git a/services/executionengine/src/main/java/tech/pegasys/teku/services/executionengine/ExecutionEngineConfiguration.java b/services/executionengine/src/main/java/tech/pegasys/teku/services/executionengine/ExecutionEngineConfiguration.java index a12892e318a..34f7f792a44 100644 --- a/services/executionengine/src/main/java/tech/pegasys/teku/services/executionengine/ExecutionEngineConfiguration.java +++ b/services/executionengine/src/main/java/tech/pegasys/teku/services/executionengine/ExecutionEngineConfiguration.java @@ -16,7 +16,9 @@ import static com.google.common.base.Preconditions.checkNotNull; import java.util.Optional; +import tech.pegasys.teku.infrastructure.exceptions.InvalidConfigurationException; import tech.pegasys.teku.spec.Spec; +import tech.pegasys.teku.spec.SpecMilestone; public class ExecutionEngineConfiguration { @@ -57,6 +59,10 @@ public ExecutionEngineConfiguration build() { private void validate() { checkNotNull(spec, "Must specify a spec"); + if (spec.isMilestoneSupported(SpecMilestone.MERGE) && endpoint.isEmpty()) { + throw new InvalidConfigurationException( + "Invalid configuration. --ee-endpoint parameter is mandatory when Merge milestone is enabled"); + } } public Builder endpoint(final String endpoint) { diff --git a/services/executionengine/src/test/java/tech/pegasys/teku/services/executionengine/ExecutionEngineConfigurationTest.java b/services/executionengine/src/test/java/tech/pegasys/teku/services/executionengine/ExecutionEngineConfigurationTest.java new file mode 100644 index 00000000000..cf82b6abae1 --- /dev/null +++ b/services/executionengine/src/test/java/tech/pegasys/teku/services/executionengine/ExecutionEngineConfigurationTest.java @@ -0,0 +1,52 @@ +/* + * Copyright 2021 ConsenSys AG. + * + * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with + * the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on + * an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the + * specific language governing permissions and limitations under the License. + */ + +package tech.pegasys.teku.services.executionengine; + +import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.Test; +import tech.pegasys.teku.infrastructure.exceptions.InvalidConfigurationException; +import tech.pegasys.teku.spec.Spec; +import tech.pegasys.teku.spec.TestSpecFactory; + +public class ExecutionEngineConfigurationTest { + private final ExecutionEngineConfiguration.Builder configBuilder = + ExecutionEngineConfiguration.builder(); + private final Spec altairSpec = TestSpecFactory.createMinimalAltair(); + private final Spec mergeSpec = TestSpecFactory.createMinimalMerge(); + + @Test + public void altair_noExceptionThrownIfNoEeEndpointSpecified() { + final ExecutionEngineConfiguration.Builder builder = configBuilder.specProvider(altairSpec); + + Assertions.assertThatCode(builder::build).doesNotThrowAnyException(); + } + + @Test + public void merge_shouldThrowExceptionIfNoEeEndpointSpecified() { + final ExecutionEngineConfiguration.Builder builder = configBuilder.specProvider(mergeSpec); + + Assertions.assertThatExceptionOfType(InvalidConfigurationException.class) + .isThrownBy(builder::build) + .withMessageContaining( + "Invalid configuration. --ee-endpoint parameter is mandatory when Merge milestone is enabled"); + } + + @Test + public void merge_noExceptionThrownIfEeEndpointSpecified() { + final ExecutionEngineConfiguration.Builder builder = + configBuilder.specProvider(mergeSpec).endpoint("someEndpoint"); + + Assertions.assertThatCode(builder::build).doesNotThrowAnyException(); + } +} diff --git a/teku/src/main/java/tech/pegasys/teku/cli/options/ValidatorOptions.java b/teku/src/main/java/tech/pegasys/teku/cli/options/ValidatorOptions.java index 022e384e788..463234a7d22 100644 --- a/teku/src/main/java/tech/pegasys/teku/cli/options/ValidatorOptions.java +++ b/teku/src/main/java/tech/pegasys/teku/cli/options/ValidatorOptions.java @@ -129,13 +129,13 @@ public class ValidatorOptions { private List additionalPublishUrls = new ArrayList<>(); @Option( - names = {"--Xvalidators-fee-recipient-address"}, + names = {"--Xvalidators-suggested-fee-recipient-address"}, paramLabel = "
", description = "Suggested fee recipient sent to the execution engine, which could use it as fee recipient when producing a new execution block.", arity = "0..1", hidden = true) - private String feeRecipient = null; + private String suggestedFeeRecipient = null; public void configure(TekuConfiguration.Builder builder) { if (validatorPerformanceTrackingEnabled != null) { @@ -160,7 +160,7 @@ public void configure(TekuConfiguration.Builder builder) { .generateEarlyAttestations(generateEarlyAttestations) .sendAttestationsAsBatch(sendAttestationsAsBatch) .additionalPublishUrls(additionalPublishUrls) - .feeRecipient(feeRecipient)); + .suggestedFeeRecipient(suggestedFeeRecipient)); validatorKeysOptions.configure(builder); } } diff --git a/teku/src/main/java/tech/pegasys/teku/config/TekuConfiguration.java b/teku/src/main/java/tech/pegasys/teku/config/TekuConfiguration.java index 650f57e5a3d..167c4ce23c5 100644 --- a/teku/src/main/java/tech/pegasys/teku/config/TekuConfiguration.java +++ b/teku/src/main/java/tech/pegasys/teku/config/TekuConfiguration.java @@ -216,6 +216,7 @@ public TekuConfiguration build() { p2pConfigBuilder.specProvider(spec); powchainConfigBuilder.specProvider(spec); executionEngineConfigBuilder.specProvider(spec); + validatorConfigBuilder.specProvider(spec); Eth1Address depositContractAddress = eth2NetworkConfiguration.getEth1DepositContractAddress(); Optional depositContractDeployBlock = diff --git a/teku/src/test/java/tech/pegasys/teku/cli/options/Eth2NetworkOptionsTest.java b/teku/src/test/java/tech/pegasys/teku/cli/options/Eth2NetworkOptionsTest.java index 31925b4219a..9e9a5e617fa 100644 --- a/teku/src/test/java/tech/pegasys/teku/cli/options/Eth2NetworkOptionsTest.java +++ b/teku/src/test/java/tech/pegasys/teku/cli/options/Eth2NetworkOptionsTest.java @@ -56,7 +56,8 @@ void shouldUseAltairForkEpochIfSpecified() { @Test void shouldUseMergeForkEpochIfSpecified() { final TekuConfiguration config = - getTekuConfigurationFromArguments("--Xnetwork-merge-fork-epoch", "120000"); + getTekuConfigurationFromArguments( + "--Xnetwork-merge-fork-epoch", "120000", "--Xee-endpoint", "someEndpoint"); final Spec spec = config.eth2NetworkConfiguration().getSpec(); assertThat(spec.getForkSchedule().getSpecMilestoneAtEpoch(UInt64.valueOf(119999))) .isEqualTo(SpecMilestone.ALTAIR); @@ -64,6 +65,7 @@ void shouldUseMergeForkEpochIfSpecified() { .isEqualTo(SpecMilestone.MERGE); assertThat( createConfigBuilder() + .executionEngine(b -> b.endpoint("someEndpoint")) .eth2NetworkConfig(b -> b.mergeForkEpoch(UInt64.valueOf(120000))) .build()) .usingRecursiveComparison() diff --git a/teku/src/test/java/tech/pegasys/teku/cli/options/ValidatorOptionsTest.java b/teku/src/test/java/tech/pegasys/teku/cli/options/ValidatorOptionsTest.java index 03c03095303..198e82862a9 100644 --- a/teku/src/test/java/tech/pegasys/teku/cli/options/ValidatorOptionsTest.java +++ b/teku/src/test/java/tech/pegasys/teku/cli/options/ValidatorOptionsTest.java @@ -150,16 +150,16 @@ void shouldDetectInvalidPublishUrl() { @Test public void ShouldReportEmptyIfFeeRecipientNotSpecified() { final TekuConfiguration config = getTekuConfigurationFromArguments(); - assertThat(config.validatorClient().getValidatorConfig().getFeeRecipient()).isEmpty(); + assertThat(config.validatorClient().getValidatorConfig().getSuggestedFeeRecipient()).isEmpty(); } @Test public void ShouldReportAddressIfFeeRecipientSpecified() { final String[] args = { - "--Xvalidators-fee-recipient-address", "0xfe3b557e8fb62b89f4916b721be55ceb828dbd73" + "--Xvalidators-suggested-fee-recipient-address", "0xfe3b557e8fb62b89f4916b721be55ceb828dbd73" }; final TekuConfiguration config = getTekuConfigurationFromArguments(args); - assertThat(config.validatorClient().getValidatorConfig().getFeeRecipient()) + assertThat(config.validatorClient().getValidatorConfig().getSuggestedFeeRecipient()) .isEqualTo( Optional.of(Eth1Address.fromHexString("0xfe3b557e8fb62b89f4916b721be55ceb828dbd73"))); } diff --git a/validator/api/build.gradle b/validator/api/build.gradle index da9d88d416f..5dcfc4827d1 100644 --- a/validator/api/build.gradle +++ b/validator/api/build.gradle @@ -10,6 +10,7 @@ dependencies { implementation 'org.apache.tuweni:tuweni-bytes' testImplementation testFixtures(project(':bls')) + testImplementation testFixtures(project(':ethereum:spec')) } publishing { diff --git a/validator/api/src/main/java/tech/pegasys/teku/validator/api/ValidatorConfig.java b/validator/api/src/main/java/tech/pegasys/teku/validator/api/ValidatorConfig.java index 604c578a6b1..c2cc595b50a 100644 --- a/validator/api/src/main/java/tech/pegasys/teku/validator/api/ValidatorConfig.java +++ b/validator/api/src/main/java/tech/pegasys/teku/validator/api/ValidatorConfig.java @@ -23,6 +23,8 @@ import org.apache.commons.lang3.tuple.Pair; import org.apache.tuweni.bytes.Bytes32; import tech.pegasys.teku.infrastructure.exceptions.InvalidConfigurationException; +import tech.pegasys.teku.spec.Spec; +import tech.pegasys.teku.spec.SpecMilestone; import tech.pegasys.teku.spec.datastructures.eth1.Eth1Address; public class ValidatorConfig { @@ -57,7 +59,7 @@ public class ValidatorConfig { private final boolean useDependentRoots; private final boolean generateEarlyAttestations; private final boolean sendAttestationsAsBatch; - private final Optional feeRecipient; + private final Optional suggestedFeeRecipient; private ValidatorConfig( final List validatorKeys, @@ -78,7 +80,7 @@ private ValidatorConfig( final boolean generateEarlyAttestations, final boolean sendAttestationsAsBatch, final List additionalPublishUrls, - final Optional feeRecipient) { + final Optional suggestedFeeRecipient) { this.validatorKeys = validatorKeys; this.validatorExternalSignerPublicKeySources = validatorExternalSignerPublicKeySources; this.validatorExternalSignerUrl = validatorExternalSignerUrl; @@ -100,7 +102,7 @@ private ValidatorConfig( this.generateEarlyAttestations = generateEarlyAttestations; this.sendAttestationsAsBatch = sendAttestationsAsBatch; this.additionalPublishUrls = additionalPublishUrls; - this.feeRecipient = feeRecipient; + this.suggestedFeeRecipient = suggestedFeeRecipient; } public static Builder builder() { @@ -172,12 +174,12 @@ public List getAdditionalPublishUrls() { return additionalPublishUrls; } - public Optional getFeeRecipient() { - return feeRecipient; + public Optional getSuggestedFeeRecipient() { + return suggestedFeeRecipient; } public static final class Builder { - + private Spec spec; private List validatorKeys = new ArrayList<>(); private List additionalPublishUrls = new ArrayList<>(); private List validatorExternalSignerPublicKeySources = new ArrayList<>(); @@ -200,7 +202,7 @@ public static final class Builder { private boolean useDependentRoots = DEFAULT_USE_DEPENDENT_ROOTS; private boolean generateEarlyAttestations = DEFAULT_GENERATE_EARLY_ATTESTATIONS; private boolean sendAttestationsAsBatch = DEFAULT_SEND_ATTESTATIONS_AS_BATCH; - private Optional feeRecipient = Optional.empty(); + private Optional suggestedFeeRecipient = Optional.empty(); private Builder() {} @@ -304,25 +306,31 @@ public Builder additionalPublishUrls(final List publishUrls) { return this; } - public Builder feeRecipient(final Eth1Address feeRecipient) { - this.feeRecipient = Optional.ofNullable(feeRecipient); + public Builder suggestedFeeRecipient(final Eth1Address suggestedFeeRecipient) { + this.suggestedFeeRecipient = Optional.ofNullable(suggestedFeeRecipient); return this; } - public Builder feeRecipient(final String feeRecipient) { - if (feeRecipient == null) { - this.feeRecipient = Optional.empty(); + public Builder suggestedFeeRecipient(final String suggestedFeeRecipient) { + if (suggestedFeeRecipient == null) { + this.suggestedFeeRecipient = Optional.empty(); } else { - this.feeRecipient = Optional.of(Eth1Address.fromHexString(feeRecipient)); + this.suggestedFeeRecipient = Optional.of(Eth1Address.fromHexString(suggestedFeeRecipient)); } return this; } + public Builder specProvider(final Spec spec) { + this.spec = spec; + return this; + } + public ValidatorConfig build() { validateExternalSignerUrlAndPublicKeys(); validateExternalSignerKeystoreAndPasswordFileConfig(); validateExternalSignerTruststoreAndPasswordFileConfig(); validateExternalSignerURLScheme(); + validateFeeRecipient(); return new ValidatorConfig( validatorKeys, validatorExternalSignerPublicKeySources, @@ -342,7 +350,7 @@ public ValidatorConfig build() { generateEarlyAttestations, sendAttestationsAsBatch, additionalPublishUrls, - feeRecipient); + suggestedFeeRecipient); } private void validateExternalSignerUrlAndPublicKeys() { @@ -391,6 +399,15 @@ private void validateExternalSignerURLScheme() { } } + private void validateFeeRecipient() { + if (spec.isMilestoneSupported(SpecMilestone.MERGE) + && suggestedFeeRecipient.isEmpty() + && !(validatorKeys.isEmpty() && externalPublicKeysNotDefined())) { + throw new InvalidConfigurationException( + "Invalid configuration. --validators-fee-recipient-address must be specified when Merge milestone is active"); + } + } + private boolean externalPublicKeysNotDefined() { return validatorExternalSignerPublicKeySources == null || validatorExternalSignerPublicKeySources.isEmpty(); diff --git a/validator/api/src/test/java/tech/pegasys/teku/validator/api/ValidatorConfigTest.java b/validator/api/src/test/java/tech/pegasys/teku/validator/api/ValidatorConfigTest.java index 1c3a0f977e8..3f287d46169 100644 --- a/validator/api/src/test/java/tech/pegasys/teku/validator/api/ValidatorConfigTest.java +++ b/validator/api/src/test/java/tech/pegasys/teku/validator/api/ValidatorConfigTest.java @@ -18,13 +18,24 @@ import java.nio.file.Path; import java.util.List; import org.assertj.core.api.Assertions; +import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import tech.pegasys.teku.bls.BLSTestUtil; import tech.pegasys.teku.infrastructure.exceptions.InvalidConfigurationException; +import tech.pegasys.teku.spec.Spec; +import tech.pegasys.teku.spec.TestSpecFactory; +import tech.pegasys.teku.spec.datastructures.eth1.Eth1Address; class ValidatorConfigTest { private final ValidatorConfig.Builder configBuilder = ValidatorConfig.builder(); + private final Spec altairSpec = TestSpecFactory.createMinimalAltair(); + private final Spec mergeSpec = TestSpecFactory.createMinimalMerge(); + + @BeforeEach + void setUp() { + configBuilder.specProvider(altairSpec); + } @Test public void shouldThrowExceptionIfExternalPublicKeysAreSpecifiedWithoutExternalSignerUrl() { @@ -117,4 +128,57 @@ public void noExceptionThrownIfBothExternalSignerTruststoreAndPasswordFileAreSpe Assertions.assertThatCode(builder::build).doesNotThrowAnyException(); } + + @Test + public void merge_shouldThrowExceptionIfExternalSignerPublicKeySourcesIsSpecified() + throws MalformedURLException { + configBuilder.specProvider(mergeSpec); + final ValidatorConfig.Builder builder = + configBuilder + .validatorExternalSignerPublicKeySources( + List.of(BLSTestUtil.randomKeyPair(0).getPublicKey().toString())) + .validatorExternalSignerUrl(URI.create("http://localhost:9000").toURL()); + + Assertions.assertThatExceptionOfType(InvalidConfigurationException.class) + .isThrownBy(builder::build) + .withMessageContaining( + "Invalid configuration. --validators-fee-recipient-address must be specified when Merge milestone is active"); + } + + @Test + public void merge_shouldThrowExceptionIfValidatorKeysAreSpecified() throws MalformedURLException { + configBuilder.specProvider(mergeSpec); + final ValidatorConfig.Builder builder = configBuilder.validatorKeys(List.of("some string")); + + Assertions.assertThatExceptionOfType(InvalidConfigurationException.class) + .isThrownBy(builder::build) + .withMessageContaining( + "Invalid configuration. --validators-fee-recipient-address must be specified when Merge milestone is active"); + } + + @Test + public void merge_noExceptionThrownIfIfExternalSignerPublicKeySourcesIsSpecified() + throws MalformedURLException { + configBuilder.specProvider(mergeSpec); + final ValidatorConfig.Builder builder = + configBuilder + .validatorExternalSignerPublicKeySources( + List.of(BLSTestUtil.randomKeyPair(0).getPublicKey().toString())) + .validatorExternalSignerUrl(URI.create("http://localhost:9000").toURL()) + .suggestedFeeRecipient("0x0000000000000000000000000000000000000000"); + + Assertions.assertThatCode(builder::build).doesNotThrowAnyException(); + } + + @Test + public void merge_noExceptionThrownIfIfValidatorKeysAreSpecified() throws MalformedURLException { + configBuilder.specProvider(mergeSpec); + final ValidatorConfig.Builder builder = + configBuilder + .validatorKeys(List.of("some string")) + .suggestedFeeRecipient( + Eth1Address.fromHexString("0x0000000000000000000000000000000000000000")); + + Assertions.assertThatCode(builder::build).doesNotThrowAnyException(); + } } diff --git a/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerAltairIntegrationTest.java b/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerAltairIntegrationTest.java index ba86f5bc90b..d1dec98a317 100644 --- a/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerAltairIntegrationTest.java +++ b/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerAltairIntegrationTest.java @@ -93,6 +93,7 @@ void setup(final ClientAndServer client) throws MalformedURLException { this.client = client; final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerPublicKeySources(List.of(KEYPAIR.getPublicKey().toString())) .validatorExternalSignerUrl(new URL("http://127.0.0.1:" + client.getLocalPort())) .validatorExternalSignerTimeout(TIMEOUT) diff --git a/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerIntegrationTest.java b/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerIntegrationTest.java index 910f12d6b6e..0f9ebabdca6 100644 --- a/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerIntegrationTest.java +++ b/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerIntegrationTest.java @@ -79,6 +79,7 @@ void setup(final ClientAndServer client) throws MalformedURLException { this.client = client; final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerPublicKeySources(List.of(KEYPAIR.getPublicKey().toString())) .validatorExternalSignerUrl(new URL("http://127.0.0.1:" + client.getLocalPort())) .validatorExternalSignerTimeout(TIMEOUT) diff --git a/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerUpcheckTLSIntegrationTest.java b/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerUpcheckTLSIntegrationTest.java index 6dd2210c70a..2acddd97535 100644 --- a/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerUpcheckTLSIntegrationTest.java +++ b/validator/client/src/integration-test/java/tech/pegasys/teku/validator/client/signer/ExternalSignerUpcheckTLSIntegrationTest.java @@ -34,11 +34,14 @@ import org.mockserver.model.HttpResponse; import tech.pegasys.teku.bls.BLSKeyPair; import tech.pegasys.teku.bls.BLSTestUtil; +import tech.pegasys.teku.spec.Spec; +import tech.pegasys.teku.spec.TestSpecFactory; import tech.pegasys.teku.validator.api.ValidatorConfig; import tech.pegasys.teku.validator.client.loader.HttpClientExternalSignerFactory; @ExtendWith(MockServerExtension.class) public class ExternalSignerUpcheckTLSIntegrationTest { + private static final Spec spec = TestSpecFactory.createMinimalPhase0(); private static final BLSKeyPair KEYPAIR = BLSTestUtil.randomKeyPair(1234); private static final Duration TIMEOUT = Duration.ofMillis(500); private static final Path TEKU_KEYSTORE; @@ -81,6 +84,7 @@ void setup(final ClientAndServer server) throws MalformedURLException { private static ExternalSignerUpcheck buildExternalSignerUpcheck(final URL serverUrl) { final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerPublicKeySources(List.of(KEYPAIR.getPublicKey().toString())) .validatorExternalSignerUrl(serverUrl) .validatorExternalSignerTimeout(TIMEOUT) diff --git a/validator/client/src/main/java/tech/pegasys/teku/validator/client/ValidatorClientService.java b/validator/client/src/main/java/tech/pegasys/teku/validator/client/ValidatorClientService.java index af348b8b2d7..04c74ba44f8 100644 --- a/validator/client/src/main/java/tech/pegasys/teku/validator/client/ValidatorClientService.java +++ b/validator/client/src/main/java/tech/pegasys/teku/validator/client/ValidatorClientService.java @@ -228,7 +228,7 @@ private void initializeValidators( new BeaconProposerPreparer( validatorApiChannel, validatorIndexProvider, - config.getValidatorConfig().getFeeRecipient().map(Eth1Address::toBytes20), + config.getValidatorConfig().getSuggestedFeeRecipient().map(Eth1Address::toBytes20), validators, spec)); } diff --git a/validator/client/src/test/java/tech/pegasys/teku/validator/client/loader/ExternalValidatorSourceTest.java b/validator/client/src/test/java/tech/pegasys/teku/validator/client/loader/ExternalValidatorSourceTest.java index d3efc19d03f..78d424de9ad 100644 --- a/validator/client/src/test/java/tech/pegasys/teku/validator/client/loader/ExternalValidatorSourceTest.java +++ b/validator/client/src/test/java/tech/pegasys/teku/validator/client/loader/ExternalValidatorSourceTest.java @@ -55,6 +55,7 @@ public ExternalValidatorSourceTest() {} void setup() throws IOException, InterruptedException { config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerUrl(new URL("http://localhost:9000")) .build(); when(httpResponse.statusCode()).thenReturn(SC_OK); diff --git a/validator/client/src/test/java/tech/pegasys/teku/validator/client/loader/ValidatorLoaderTest.java b/validator/client/src/test/java/tech/pegasys/teku/validator/client/loader/ValidatorLoaderTest.java index e8fff7f6c29..5faf8f6eb2e 100644 --- a/validator/client/src/test/java/tech/pegasys/teku/validator/client/loader/ValidatorLoaderTest.java +++ b/validator/client/src/test/java/tech/pegasys/teku/validator/client/loader/ValidatorLoaderTest.java @@ -114,6 +114,7 @@ void shouldLoadPublicKeysFromUrls() { final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerUrl(SIGNER_URL) .validatorExternalSignerPublicKeySources(Collections.singletonList(publicKeysUrl)) .validatorExternalSignerSlashingProtectionEnabled(true) @@ -151,6 +152,7 @@ void shouldLoadPublicKeysFromUrls() { void initializeValidatorsWithExternalSignerAndSlashingProtection() { final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerUrl(SIGNER_URL) .validatorExternalSignerPublicKeySources( Collections.singletonList(PUBLIC_KEY1.toString())) @@ -193,6 +195,7 @@ void initializeValidatorsWithExternalSignerAndSlashingProtection() { void initializeValidatorsWithExternalSignerAndNoSlashingProtection() { final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerUrl(SIGNER_URL) .validatorExternalSignerPublicKeySources( Collections.singletonList(PUBLIC_KEY1.toString())) @@ -237,6 +240,7 @@ void initializeValidatorsWithBothLocalAndExternalSigners(@TempDir Path tempDir) writeKeystore(tempDir); final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerUrl(SIGNER_URL) .validatorExternalSignerPublicKeySources( Collections.singletonList(PUBLIC_KEY2.toString())) @@ -285,6 +289,7 @@ void shouldInitializeLocalAndMutableValidators( writeMutableKeystore(dataDirLayout); final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorKeys( List.of(tempDir.toAbsolutePath() + File.pathSeparator + tempDir.toAbsolutePath())) .build(); @@ -325,6 +330,7 @@ void shouldInitializeOnlyLocalValidatorsWhenRestDisabled( writeMutableKeystore(dataDirLayout); final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorKeys( List.of(tempDir.toAbsolutePath() + File.pathSeparator + tempDir.toAbsolutePath())) .build(); @@ -360,6 +366,7 @@ void shouldNotInitializeMutableValidatorsWithoutDirectoryStructure( final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorKeys( List.of(tempDir.toAbsolutePath() + File.pathSeparator + tempDir.toAbsolutePath())) .build(); @@ -392,6 +399,7 @@ void initializeValidatorsWithDuplicateKeysInLocalAndExternalSignersTakesExternal writeKeystore(tempDir); final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerUrl(SIGNER_URL) .validatorExternalSignerPublicKeySources( Collections.singletonList(PUBLIC_KEY1.toString())) @@ -429,6 +437,7 @@ void shouldEnableSlashingProtectionForLocalValidators(@TempDir Path tempDir) thr final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorKeys( List.of(tempDir.toAbsolutePath() + File.pathSeparator + tempDir.toAbsolutePath())) .build(); @@ -468,6 +477,7 @@ void shouldLoadAdditionalExternalValidatorsOnReload() { final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerUrl(SIGNER_URL) .validatorExternalSignerPublicKeySources(Collections.singletonList(publicKeysUrl)) .validatorExternalSignerSlashingProtectionEnabled(true) @@ -504,6 +514,7 @@ void shouldNotRemoveExternalValidatorsOnReload() { final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorExternalSignerUrl(SIGNER_URL) .validatorExternalSignerPublicKeySources(Collections.singletonList(publicKeysUrl)) .validatorExternalSignerSlashingProtectionEnabled(true) @@ -535,6 +546,7 @@ void shouldNotRemoveExternalValidatorsOnReload() { void shouldLoadAdditionalLocalValidatorsOnReload(final @TempDir Path tempDir) throws Exception { final ValidatorConfig config = ValidatorConfig.builder() + .specProvider(spec) .validatorKeys( List.of(tempDir.toAbsolutePath() + File.pathSeparator + tempDir.toAbsolutePath())) .build(); @@ -572,7 +584,7 @@ void initializeInteropValidatorsWhenInteropIsEnabled() { .interopEnabled(true) .interopOwnedValidatorCount(ownedValidatorCount) .build(); - final ValidatorConfig config = ValidatorConfig.builder().build(); + final ValidatorConfig config = ValidatorConfig.builder().specProvider(spec).build(); final ValidatorLoader validatorLoader = ValidatorLoader.create( spec, @@ -592,7 +604,7 @@ void initializeInteropValidatorsWhenInteropIsEnabled() { @Test void shouldNotLoadMutableValidatorIfNotEnabled() { - final ValidatorConfig config = ValidatorConfig.builder().build(); + final ValidatorConfig config = ValidatorConfig.builder().specProvider(spec).build(); final ValidatorLoader validatorLoader = ValidatorLoader.create( spec, @@ -611,7 +623,7 @@ void shouldNotLoadMutableValidatorIfNotEnabled() { @Test void shouldLoadMutableValidatorIfEnabled(@TempDir final Path tempDir) throws Exception { - final ValidatorConfig config = ValidatorConfig.builder().build(); + final ValidatorConfig config = ValidatorConfig.builder().specProvider(spec).build(); final ValidatorLoader validatorLoader = ValidatorLoader.create( spec, @@ -647,7 +659,7 @@ void doNotInitializeInteropValidatorsWhenInteropIsDisabled() { .interopEnabled(false) .interopOwnedValidatorCount(ownedValidatorCount) .build(); - final ValidatorConfig config = ValidatorConfig.builder().build(); + final ValidatorConfig config = ValidatorConfig.builder().specProvider(spec).build(); final ValidatorLoader validatorLoader = ValidatorLoader.create( spec,