Changeset View
Changeset View
Standalone View
Standalone View
test/functional/feature_logging.py
#!/usr/bin/env python3 | #!/usr/bin/env python3 | ||||
# Copyright (c) 2017 The Bitcoin Core developers | # Copyright (c) 2017 The Bitcoin Core developers | ||||
# Distributed under the MIT software license, see the accompanying | # Distributed under the MIT software license, see the accompanying | ||||
# file COPYING or http://www.opensource.org/licenses/mit-license.php. | # file COPYING or http://www.opensource.org/licenses/mit-license.php. | ||||
"""Test debug logging.""" | """Test debug logging.""" | ||||
import os | import os | ||||
from test_framework.test_framework import BitcoinTestFramework | from test_framework.test_framework import BitcoinTestFramework | ||||
from test_framework.test_node import ErrorMatch | |||||
class LoggingTest(BitcoinTestFramework): | class LoggingTest(BitcoinTestFramework): | ||||
def set_test_params(self): | def set_test_params(self): | ||||
self.num_nodes = 1 | self.num_nodes = 1 | ||||
self.setup_clean_chain = True | self.setup_clean_chain = True | ||||
def run_test(self): | def run_test(self): | ||||
Show All 12 Lines | def run_test(self): | ||||
assert os.path.isfile(tempname) | assert os.path.isfile(tempname) | ||||
# check that invalid log (relative) will cause error | # check that invalid log (relative) will cause error | ||||
invdir = os.path.join(self.nodes[0].datadir, "regtest", "foo") | invdir = os.path.join(self.nodes[0].datadir, "regtest", "foo") | ||||
invalidname = os.path.join("foo", "foo.log") | invalidname = os.path.join("foo", "foo.log") | ||||
self.stop_node(0) | self.stop_node(0) | ||||
exp_stderr = r"Error: Could not open debug log file \S+$" | exp_stderr = r"Error: Could not open debug log file \S+$" | ||||
self.nodes[0].assert_start_raises_init_error( | self.nodes[0].assert_start_raises_init_error( | ||||
["-debuglogfile={}".format(invalidname)], exp_stderr) | ["-debuglogfile={}".format(invalidname)], exp_stderr, match=ErrorMatch.FULL_REGEX) | ||||
assert not os.path.isfile(os.path.join(invdir, "foo.log")) | assert not os.path.isfile(os.path.join(invdir, "foo.log")) | ||||
# check that invalid log (relative) works after path exists | # check that invalid log (relative) works after path exists | ||||
self.stop_node(0) | self.stop_node(0) | ||||
os.mkdir(invdir) | os.mkdir(invdir) | ||||
self.start_node(0, ["-debuglogfile={}".format(invalidname)]) | self.start_node(0, ["-debuglogfile={}".format(invalidname)]) | ||||
assert os.path.isfile(os.path.join(invdir, "foo.log")) | assert os.path.isfile(os.path.join(invdir, "foo.log")) | ||||
# check that invalid log (absolute) will cause error | # check that invalid log (absolute) will cause error | ||||
self.stop_node(0) | self.stop_node(0) | ||||
invdir = os.path.join(self.options.tmpdir, "foo") | invdir = os.path.join(self.options.tmpdir, "foo") | ||||
invalidname = os.path.join(invdir, "foo.log") | invalidname = os.path.join(invdir, "foo.log") | ||||
self.nodes[0].assert_start_raises_init_error( | self.nodes[0].assert_start_raises_init_error( | ||||
["-debuglogfile={}".format(invalidname)], exp_stderr) | ["-debuglogfile={}".format(invalidname)], exp_stderr, match=ErrorMatch.FULL_REGEX) | ||||
assert not os.path.isfile(os.path.join(invdir, "foo.log")) | assert not os.path.isfile(os.path.join(invdir, "foo.log")) | ||||
# check that invalid log (absolute) works after path exists | # check that invalid log (absolute) works after path exists | ||||
self.stop_node(0) | self.stop_node(0) | ||||
os.mkdir(invdir) | os.mkdir(invdir) | ||||
self.start_node(0, ["-debuglogfile={}".format(invalidname)]) | self.start_node(0, ["-debuglogfile={}".format(invalidname)]) | ||||
assert os.path.isfile(os.path.join(invdir, "foo.log")) | assert os.path.isfile(os.path.join(invdir, "foo.log")) | ||||
if __name__ == '__main__': | if __name__ == '__main__': | ||||
LoggingTest().main() | LoggingTest().main() |