2017-05-02 10:26:33 +09:00
|
|
|
#!/usr/bin/env python3
|
2021-07-28 13:57:16 +02:00
|
|
|
# Copyright (c) 2018-2021 The Bitcoin Core developers
|
2017-05-02 10:26:33 +09:00
|
|
|
# Distributed under the MIT software license, see the accompanying
|
|
|
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
"""Tests the includeconf argument
|
|
|
|
|
|
|
|
Verify that:
|
|
|
|
|
|
|
|
1. adding includeconf to the configuration file causes the includeconf
|
|
|
|
file to be loaded in the correct order.
|
|
|
|
2. includeconf cannot be used as a command line argument.
|
|
|
|
3. includeconf cannot be used recursively (ie includeconf can only
|
|
|
|
be used from the base config file).
|
|
|
|
4. multiple includeconf arguments can be specified in the main config
|
|
|
|
file.
|
|
|
|
"""
|
2018-02-07 10:51:13 -05:00
|
|
|
from test_framework.test_framework import BitcoinTestFramework
|
2017-05-02 10:26:33 +09:00
|
|
|
|
2023-06-14 13:00:11 +02:00
|
|
|
|
2017-05-02 10:26:33 +09:00
|
|
|
class IncludeConfTest(BitcoinTestFramework):
|
|
|
|
def set_test_params(self):
|
|
|
|
self.num_nodes = 1
|
|
|
|
|
2023-06-14 13:00:11 +02:00
|
|
|
def run_test(self):
|
2017-05-02 10:26:33 +09:00
|
|
|
# Create additional config files
|
|
|
|
# - tmpdir/node0/relative.conf
|
2023-06-14 13:00:11 +02:00
|
|
|
with open(self.nodes[0].datadir_path / "relative.conf", "w", encoding="utf8") as f:
|
2017-05-02 10:26:33 +09:00
|
|
|
f.write("uacomment=relative\n")
|
|
|
|
# - tmpdir/node0/relative2.conf
|
2023-06-14 13:00:11 +02:00
|
|
|
with open(self.nodes[0].datadir_path / "relative2.conf", "w", encoding="utf8") as f:
|
2017-05-02 10:26:33 +09:00
|
|
|
f.write("uacomment=relative2\n")
|
2023-06-14 13:00:11 +02:00
|
|
|
with open(self.nodes[0].datadir_path / "bitcoin.conf", "a", encoding="utf8") as f:
|
2017-05-02 10:26:33 +09:00
|
|
|
f.write("uacomment=main\nincludeconf=relative.conf\n")
|
2023-06-14 13:00:11 +02:00
|
|
|
self.restart_node(0)
|
2017-05-02 10:26:33 +09:00
|
|
|
|
|
|
|
self.log.info("-includeconf works from config file. subversion should end with 'main; relative)/'")
|
|
|
|
|
|
|
|
subversion = self.nodes[0].getnetworkinfo()["subversion"]
|
|
|
|
assert subversion.endswith("main; relative)/")
|
|
|
|
|
2018-06-01 13:28:14 -04:00
|
|
|
self.log.info("-includeconf cannot be used as command-line arg")
|
2017-05-02 10:26:33 +09:00
|
|
|
self.stop_node(0)
|
2021-05-21 10:52:46 +02:00
|
|
|
self.nodes[0].assert_start_raises_init_error(
|
|
|
|
extra_args=['-noincludeconf=0'],
|
|
|
|
expected_msg='Error: Error parsing command line arguments: -includeconf cannot be used from commandline; -includeconf=true',
|
|
|
|
)
|
|
|
|
self.nodes[0].assert_start_raises_init_error(
|
2021-05-20 13:46:15 +02:00
|
|
|
extra_args=['-includeconf=relative2.conf', '-includeconf=no_warn.conf'],
|
2021-05-21 10:52:46 +02:00
|
|
|
expected_msg='Error: Error parsing command line arguments: -includeconf cannot be used from commandline; -includeconf="relative2.conf"',
|
|
|
|
)
|
2017-05-02 10:26:33 +09:00
|
|
|
|
|
|
|
self.log.info("-includeconf cannot be used recursively. subversion should end with 'main; relative)/'")
|
2023-06-14 13:00:11 +02:00
|
|
|
with open(self.nodes[0].datadir_path / "relative.conf", "a", encoding="utf8") as f:
|
2017-05-02 10:26:33 +09:00
|
|
|
f.write("includeconf=relative2.conf\n")
|
2018-02-07 10:51:13 -05:00
|
|
|
self.start_node(0)
|
2017-05-02 10:26:33 +09:00
|
|
|
|
|
|
|
subversion = self.nodes[0].getnetworkinfo()["subversion"]
|
|
|
|
assert subversion.endswith("main; relative)/")
|
2018-05-09 16:50:02 +09:00
|
|
|
self.stop_node(0, expected_stderr="warning: -includeconf cannot be used from included files; ignoring -includeconf=relative2.conf")
|
2017-05-02 10:26:33 +09:00
|
|
|
|
2018-06-01 13:28:14 -04:00
|
|
|
self.log.info("-includeconf cannot contain invalid arg")
|
2018-07-30 00:25:25 -07:00
|
|
|
|
|
|
|
# Commented out as long as we ignore invalid arguments in configuration files
|
2023-06-14 13:00:11 +02:00
|
|
|
#with open(self.nodes[0].datadir_path / "relative.conf", "w", encoding="utf8") as f:
|
2018-07-30 00:25:25 -07:00
|
|
|
# f.write("foo=bar\n")
|
2019-07-10 08:06:57 -04:00
|
|
|
#self.nodes[0].assert_start_raises_init_error(expected_msg="Error: Error reading configuration file: Invalid configuration value foo")
|
2018-06-01 13:28:14 -04:00
|
|
|
|
|
|
|
self.log.info("-includeconf cannot be invalid path")
|
2023-06-14 13:00:11 +02:00
|
|
|
(self.nodes[0].datadir_path / "relative.conf").unlink()
|
2019-07-10 08:06:57 -04:00
|
|
|
self.nodes[0].assert_start_raises_init_error(expected_msg="Error: Error reading configuration file: Failed to include configuration file relative.conf")
|
2018-06-01 13:28:14 -04:00
|
|
|
|
2017-05-02 10:26:33 +09:00
|
|
|
self.log.info("multiple -includeconf args can be used from the base config file. subversion should end with 'main; relative; relative2)/'")
|
2023-06-14 13:00:11 +02:00
|
|
|
with open(self.nodes[0].datadir_path / "relative.conf", "w", encoding="utf8") as f:
|
2018-06-01 13:28:14 -04:00
|
|
|
# Restore initial file contents
|
2017-05-02 10:26:33 +09:00
|
|
|
f.write("uacomment=relative\n")
|
|
|
|
|
2023-06-14 13:00:11 +02:00
|
|
|
with open(self.nodes[0].datadir_path / "bitcoin.conf", "a", encoding="utf8") as f:
|
2017-05-02 10:26:33 +09:00
|
|
|
f.write("includeconf=relative2.conf\n")
|
|
|
|
|
2018-05-09 16:50:02 +09:00
|
|
|
self.start_node(0)
|
2017-05-02 10:26:33 +09:00
|
|
|
|
|
|
|
subversion = self.nodes[0].getnetworkinfo()["subversion"]
|
|
|
|
assert subversion.endswith("main; relative; relative2)/")
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
IncludeConfTest().main()
|