mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-22 23:07:59 +01:00
QA: fix rpc_setban.py race
This commit is contained in:
parent
e00ecb3d7a
commit
6011c9d72d
2 changed files with 18 additions and 9 deletions
|
@ -26,7 +26,7 @@ class SetBanTests(BitcoinTestFramework):
|
||||||
self.nodes[1].setban("127.0.0.1", "add")
|
self.nodes[1].setban("127.0.0.1", "add")
|
||||||
|
|
||||||
# Node 0 should not be able to reconnect
|
# Node 0 should not be able to reconnect
|
||||||
with self.nodes[1].assert_debug_log(expected_msgs=['dropped (banned)\n']):
|
with self.nodes[1].assert_debug_log(expected_msgs=['dropped (banned)\n'],timeout=5):
|
||||||
self.restart_node(1, [])
|
self.restart_node(1, [])
|
||||||
self.nodes[0].addnode("127.0.0.1:" + str(p2p_port(1)), "onetry")
|
self.nodes[0].addnode("127.0.0.1:" + str(p2p_port(1)), "onetry")
|
||||||
|
|
||||||
|
|
|
@ -307,7 +307,8 @@ class TestNode():
|
||||||
wait_until(self.is_node_stopped, timeout=timeout)
|
wait_until(self.is_node_stopped, timeout=timeout)
|
||||||
|
|
||||||
@contextlib.contextmanager
|
@contextlib.contextmanager
|
||||||
def assert_debug_log(self, expected_msgs):
|
def assert_debug_log(self, expected_msgs, timeout=2):
|
||||||
|
time_end = time.time() + timeout
|
||||||
debug_log = os.path.join(self.datadir, self.chain, 'debug.log')
|
debug_log = os.path.join(self.datadir, self.chain, 'debug.log')
|
||||||
with open(debug_log, encoding='utf-8') as dl:
|
with open(debug_log, encoding='utf-8') as dl:
|
||||||
dl.seek(0, 2)
|
dl.seek(0, 2)
|
||||||
|
@ -315,13 +316,21 @@ class TestNode():
|
||||||
try:
|
try:
|
||||||
yield
|
yield
|
||||||
finally:
|
finally:
|
||||||
|
while True:
|
||||||
|
found = True
|
||||||
with open(debug_log, encoding='utf-8') as dl:
|
with open(debug_log, encoding='utf-8') as dl:
|
||||||
dl.seek(prev_size)
|
dl.seek(prev_size)
|
||||||
log = dl.read()
|
log = dl.read()
|
||||||
print_log = " - " + "\n - ".join(log.splitlines())
|
print_log = " - " + "\n - ".join(log.splitlines())
|
||||||
for expected_msg in expected_msgs:
|
for expected_msg in expected_msgs:
|
||||||
if re.search(re.escape(expected_msg), log, flags=re.MULTILINE) is None:
|
if re.search(re.escape(expected_msg), log, flags=re.MULTILINE) is None:
|
||||||
self._raise_assertion_error('Expected message "{}" does not partially match log:\n\n{}\n\n'.format(expected_msg, print_log))
|
found = False
|
||||||
|
if found:
|
||||||
|
return
|
||||||
|
if time.time() >= time_end:
|
||||||
|
break
|
||||||
|
time.sleep(0.05)
|
||||||
|
self._raise_assertion_error('Expected messages "{}" does not partially match log:\n\n{}\n\n'.format(str(expected_msgs), print_log))
|
||||||
|
|
||||||
@contextlib.contextmanager
|
@contextlib.contextmanager
|
||||||
def assert_memory_usage_stable(self, *, increase_allowed=0.03):
|
def assert_memory_usage_stable(self, *, increase_allowed=0.03):
|
||||||
|
|
Loading…
Add table
Reference in a new issue