mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-22 06:52:36 +01:00
Merge #19624: Warn on unknown rw_settings
fa48405ef8
Warn on unknown rw_settings (MarcoFalke) Pull request description: Log a warning to debug log if unknown settings are encountered. This should probably only ever happen when the software is upgraded. Something similar is already done for the command line and config file. See: * test: Add test for unknown args #16234 (commitfa7dd88b71
) ACKs for top commit: ryanofsky: Code review ACKfa48405ef8
. Looks good and I could see this being helpful for debugging. Thanks for taking suggestions Tree-SHA512: cec7d88adf84fa0a842f56b26245157736eb50df433db951e622ea07fd145b899822b24cdab1d8b36c066415ce4f0ef09b493fa8a8d691532822a59c573aafa7
This commit is contained in:
commit
4769942d90
2 changed files with 17 additions and 3 deletions
|
@ -427,6 +427,14 @@ bool ArgsManager::ReadSettingsFile(std::vector<std::string>* errors)
|
|||
SaveErrors(read_errors, errors);
|
||||
return false;
|
||||
}
|
||||
for (const auto& setting : m_settings.rw_settings) {
|
||||
std::string section;
|
||||
std::string key = setting.first;
|
||||
(void)InterpretOption(section, key, /* value */ {}); // Split setting key into section and argname
|
||||
if (!GetArgFlags('-' + key)) {
|
||||
LogPrintf("Ignoring unknown rw_settings value %s\n", setting.first);
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
|
|
@ -31,19 +31,25 @@ class SettingsTest(BitcoinTestFramework):
|
|||
|
||||
# Assert settings are parsed and logged
|
||||
with settings.open("w") as fp:
|
||||
json.dump({"string": "string", "num": 5, "bool": True, "null": None, "list": [6,7]}, fp)
|
||||
json.dump({"string": "string", "num": 5, "bool": True, "null": None, "list": [6, 7]}, fp)
|
||||
with node.assert_debug_log(expected_msgs=[
|
||||
'Ignoring unknown rw_settings value bool',
|
||||
'Ignoring unknown rw_settings value list',
|
||||
'Ignoring unknown rw_settings value null',
|
||||
'Ignoring unknown rw_settings value num',
|
||||
'Ignoring unknown rw_settings value string',
|
||||
'Setting file arg: string = "string"',
|
||||
'Setting file arg: num = 5',
|
||||
'Setting file arg: bool = true',
|
||||
'Setting file arg: null = null',
|
||||
'Setting file arg: list = [6,7]']):
|
||||
'Setting file arg: list = [6,7]',
|
||||
]):
|
||||
self.start_node(0)
|
||||
self.stop_node(0)
|
||||
|
||||
# Assert settings are unchanged after shutdown
|
||||
with settings.open() as fp:
|
||||
assert_equal(json.load(fp), {"string": "string", "num": 5, "bool": True, "null": None, "list": [6,7]})
|
||||
assert_equal(json.load(fp), {"string": "string", "num": 5, "bool": True, "null": None, "list": [6, 7]})
|
||||
|
||||
# Test invalid json
|
||||
with settings.open("w") as fp:
|
||||
|
|
Loading…
Add table
Reference in a new issue