2020-06-19 12:49:51 -04:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
# Copyright (c) 2020 The Bitcoin Core developers
|
|
|
|
# Distributed under the MIT software license, see the accompanying
|
|
|
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
"""Test fee filters during and after IBD."""
|
|
|
|
|
|
|
|
from decimal import Decimal
|
|
|
|
|
|
|
|
from test_framework.messages import COIN
|
|
|
|
from test_framework.test_framework import BitcoinTestFramework
|
|
|
|
|
|
|
|
MAX_FEE_FILTER = Decimal(9170997) / COIN
|
|
|
|
NORMAL_FEE_FILTER = Decimal(100) / COIN
|
|
|
|
|
|
|
|
|
|
|
|
class P2PIBDTxRelayTest(BitcoinTestFramework):
|
|
|
|
def set_test_params(self):
|
|
|
|
self.setup_clean_chain = True
|
|
|
|
self.num_nodes = 2
|
|
|
|
self.extra_args = [
|
|
|
|
["-minrelaytxfee={}".format(NORMAL_FEE_FILTER)],
|
|
|
|
["-minrelaytxfee={}".format(NORMAL_FEE_FILTER)],
|
|
|
|
]
|
2020-07-19 02:39:15 -04:00
|
|
|
|
2020-06-19 12:49:51 -04:00
|
|
|
def run_test(self):
|
|
|
|
self.log.info("Check that nodes set minfilter to MAX_MONEY while still in IBD")
|
|
|
|
for node in self.nodes:
|
|
|
|
assert node.getblockchaininfo()['initialblockdownload']
|
2020-07-19 02:39:15 -04:00
|
|
|
self.wait_until(lambda: all(peer['minfeefilter'] == MAX_FEE_FILTER for peer in node.getpeerinfo()))
|
2020-06-19 12:49:51 -04:00
|
|
|
|
|
|
|
# Come out of IBD by generating a block
|
2021-08-19 11:10:24 -04:00
|
|
|
self.generate(self.nodes[0], 1)
|
2020-06-19 12:49:51 -04:00
|
|
|
self.sync_all()
|
|
|
|
|
|
|
|
self.log.info("Check that nodes reset minfilter after coming out of IBD")
|
|
|
|
for node in self.nodes:
|
|
|
|
assert not node.getblockchaininfo()['initialblockdownload']
|
2020-07-19 02:39:15 -04:00
|
|
|
self.wait_until(lambda: all(peer['minfeefilter'] == NORMAL_FEE_FILTER for peer in node.getpeerinfo()))
|
2020-06-19 12:49:51 -04:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
P2PIBDTxRelayTest().main()
|