Changeset View
Changeset View
Standalone View
Standalone View
test/functional/feature_notifications.py
#!/usr/bin/env python3 | #!/usr/bin/env python3 | ||||
# Copyright (c) 2014-2019 The Bitcoin Core developers | # Copyright (c) 2014-2019 The Bitcoin Core developers | ||||
# Copyright (c) 2018 The Bitcoin developers | # Copyright (c) 2018 The Bitcoin 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 the -alertnotify, -blocknotify and -walletnotify options.""" | """Test the -alertnotify, -blocknotify and -walletnotify options.""" | ||||
import os | import os | ||||
from test_framework.address import ADDRESS_BCHREG_UNSPENDABLE | from test_framework.address import ADDRESS_ECREG_UNSPENDABLE | ||||
from test_framework.test_framework import BitcoinTestFramework | from test_framework.test_framework import BitcoinTestFramework | ||||
from test_framework.util import ( | from test_framework.util import ( | ||||
assert_equal, | assert_equal, | ||||
connect_nodes, | connect_nodes, | ||||
wait_until | wait_until | ||||
) | ) | ||||
FORK_WARNING_MESSAGE = "Warning: Large-work fork detected, forking after block {}" | FORK_WARNING_MESSAGE = "Warning: Large-work fork detected, forking after block {}" | ||||
Show All 38 Lines | def setup_network(self): | ||||
super().setup_network() | super().setup_network() | ||||
def run_test(self): | def run_test(self): | ||||
self.log.info("test -blocknotify") | self.log.info("test -blocknotify") | ||||
block_count = 10 | block_count = 10 | ||||
blocks = self.nodes[1].generatetoaddress( | blocks = self.nodes[1].generatetoaddress( | ||||
block_count, | block_count, | ||||
self.nodes[1].getnewaddress() if self.is_wallet_compiled() | self.nodes[1].getnewaddress() if self.is_wallet_compiled() | ||||
else ADDRESS_BCHREG_UNSPENDABLE | else ADDRESS_ECREG_UNSPENDABLE | ||||
) | ) | ||||
# wait at most 10 seconds for expected number of files before reading | # wait at most 10 seconds for expected number of files before reading | ||||
# the content | # the content | ||||
wait_until( | wait_until( | ||||
lambda: len( | lambda: len( | ||||
os.listdir( | os.listdir( | ||||
self.blocknotify_dir)) == block_count, | self.blocknotify_dir)) == block_count, | ||||
Show All 40 Lines | def run_test(self): | ||||
assert_equal( | assert_equal( | ||||
sorted(txids_rpc), sorted( | sorted(txids_rpc), sorted( | ||||
os.listdir( | os.listdir( | ||||
self.walletnotify_dir))) | self.walletnotify_dir))) | ||||
# Create an invalid chain and ensure the node warns. | # Create an invalid chain and ensure the node warns. | ||||
self.log.info("test -alertnotify for forked chain") | self.log.info("test -alertnotify for forked chain") | ||||
fork_block = self.nodes[0].getbestblockhash() | fork_block = self.nodes[0].getbestblockhash() | ||||
self.nodes[0].generatetoaddress(1, ADDRESS_BCHREG_UNSPENDABLE) | self.nodes[0].generatetoaddress(1, ADDRESS_ECREG_UNSPENDABLE) | ||||
invalid_block = self.nodes[0].getbestblockhash() | invalid_block = self.nodes[0].getbestblockhash() | ||||
self.nodes[0].generatetoaddress(7, ADDRESS_BCHREG_UNSPENDABLE) | self.nodes[0].generatetoaddress(7, ADDRESS_ECREG_UNSPENDABLE) | ||||
# Invalidate a large branch, which should trigger an alert. | # Invalidate a large branch, which should trigger an alert. | ||||
self.nodes[0].invalidateblock(invalid_block) | self.nodes[0].invalidateblock(invalid_block) | ||||
# Give bitcoind 10 seconds to write the alert notification | # Give bitcoind 10 seconds to write the alert notification | ||||
wait_until(lambda: len(os.listdir(self.alertnotify_dir)), timeout=10) | wait_until(lambda: len(os.listdir(self.alertnotify_dir)), timeout=10) | ||||
# The notification command is unable to properly handle the spaces on | # The notification command is unable to properly handle the spaces on | ||||
Show All 11 Lines |