From 3fb572fcbb28199700594b8811533caea3729399 Mon Sep 17 00:00:00 2001 From: Gabriel-Trintinalia Date: Tue, 7 May 2024 13:46:37 -0300 Subject: [PATCH] Move unknown options check further in the startup (#7066) Signed-off-by: Gabriel-Trintinalia Signed-off-by: Justin Florentine --- .../besu/cli/util/TomlConfigurationDefaultProvider.java | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/besu/src/main/java/org/hyperledger/besu/cli/util/TomlConfigurationDefaultProvider.java b/besu/src/main/java/org/hyperledger/besu/cli/util/TomlConfigurationDefaultProvider.java index a346e260d13..1747f461dc4 100644 --- a/besu/src/main/java/org/hyperledger/besu/cli/util/TomlConfigurationDefaultProvider.java +++ b/besu/src/main/java/org/hyperledger/besu/cli/util/TomlConfigurationDefaultProvider.java @@ -50,6 +50,7 @@ public class TomlConfigurationDefaultProvider implements IDefaultValueProvider { private final CommandLine commandLine; private final InputStream configurationInputStream; private TomlParseResult result; + private boolean isUnknownOptionsChecked; /** * Instantiates a new Toml config file default value provider. @@ -230,6 +231,11 @@ private void checkConfigurationValidity() { throw new ParameterException( commandLine, String.format("Unable to read TOML configuration file %s", configurationInputStream)); + + if (!isUnknownOptionsChecked && !commandLine.isUnmatchedArgumentsAllowed()) { + checkUnknownOptions(result); + isUnknownOptionsChecked = true; + } } /** Load configuration from file. */ @@ -249,8 +255,6 @@ public void loadConfigurationFromFile() { commandLine, String.format("Invalid TOML configuration: %s", errors)); } - checkUnknownOptions(result); - this.result = result; } catch (final IOException e) {