refactor test: Cleaner combine_logs.py logic

This commit is contained in:
Hodlinator 2024-12-06 00:49:37 +01:00
parent 11f68cc810
commit c9fb38a590
No known key found for this signature in database

View file

@ -1,5 +1,5 @@
#!/usr/bin/env python3 #!/usr/bin/env python3
# Copyright (c) 2017-2021 The Bitcoin Core developers # Copyright (c) 2017-present 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.
"""Combine logs from multiple bitcoin nodes as well as the test_framework log. """Combine logs from multiple bitcoin nodes as well as the test_framework log.
@ -81,13 +81,14 @@ def read_logs(tmp_dir):
# Find out what the folder is called that holds node 0's debug.log file # Find out what the folder is called that holds node 0's debug.log file
debug_logs = list(pathlib.Path(tmp_dir).glob('node0/**/debug.log')) debug_logs = list(pathlib.Path(tmp_dir).glob('node0/**/debug.log'))
if len(debug_logs) > 0: match len(debug_logs):
assert len(debug_logs) < 2, 'Max one debug.log is supported, ' \ case 0:
'found several:\n\t' + '\n\t'.join([str(f) for f in debug_logs]) chain = 'regtest' # fallback to regtest
path = debug_logs[0] case 1:
chain = re.search(r'node0/(.+?)/debug\.log$', path.as_posix()).group(1) # extract the chain name chain = re.search(r'node0/(.+?)/debug\.log$', debug_logs[0].as_posix()).group(1)
else: case _:
chain = 'regtest' # fallback to regtest (should only happen when none exists) raise RuntimeError('Max one debug.log is supported, found several:\n\t' +
'\n\t'.join(map(str, debug_logs)))
files = [("test", "%s/test_framework.log" % tmp_dir)] files = [("test", "%s/test_framework.log" % tmp_dir)]
for i in itertools.count(): for i in itertools.count():