mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-07-02 19:52:01 +02:00
Merge #18772: rpc: calculate fees in getblock using BlockUndo data
66d012ad7f
test: RPC: getblock fee calculations (Elliott Jin)bf7d6e31b1
RPC: getblock: tx fee calculation for verbosity 2 via Undo data (Elliott Jin) Pull request description: This change is progress towards #18771 . It adapts the fee calculation part of #16083 and addresses some feedback. The additional "verbosity level 3" features are planned for a future PR. **Original PR description:** > Using block undo data (like in #14802) we can now show fee information for each transaction in a block without the need for additional -txindex and/or a ton of costly lookups. For a start we'll add transaction fee information to getblock verbosity level 2. This comes at a negligible speed penalty (<1%). ACKs for top commit: luke-jr: tACK66d012ad7f
fjahr: tACK66d012ad7f
MarcoFalke: review ACK66d012ad7f
🗜 Tree-SHA512: be1fe4b866946a8dc36427f7dc72a20e10860e320a28fa49bc85bd2a93a0d699768179be29fa52e18b2ed8505d3ec272e586753ef2239b4230e0aefd233acaa2
This commit is contained in:
@ -20,6 +20,7 @@ Tests correspond to code in rpc/blockchain.cpp.
|
||||
|
||||
from decimal import Decimal
|
||||
import http.client
|
||||
import os
|
||||
import subprocess
|
||||
|
||||
from test_framework.blocktools import (
|
||||
@ -42,7 +43,9 @@ from test_framework.util import (
|
||||
assert_raises_rpc_error,
|
||||
assert_is_hex_string,
|
||||
assert_is_hash_string,
|
||||
get_datadir_path,
|
||||
)
|
||||
from test_framework.wallet import MiniWallet
|
||||
|
||||
|
||||
class BlockchainTest(BitcoinTestFramework):
|
||||
@ -63,6 +66,7 @@ class BlockchainTest(BitcoinTestFramework):
|
||||
self._test_getnetworkhashps()
|
||||
self._test_stopatheight()
|
||||
self._test_waitforblockheight()
|
||||
self._test_getblock()
|
||||
assert self.nodes[0].verifychain(4, 0)
|
||||
|
||||
def mine_chain(self):
|
||||
@ -364,6 +368,46 @@ class BlockchainTest(BitcoinTestFramework):
|
||||
assert_waitforheight(current_height)
|
||||
assert_waitforheight(current_height + 1)
|
||||
|
||||
def _test_getblock(self):
|
||||
node = self.nodes[0]
|
||||
|
||||
miniwallet = MiniWallet(node)
|
||||
miniwallet.generate(5)
|
||||
node.generate(100)
|
||||
|
||||
fee_per_byte = Decimal('0.00000010')
|
||||
fee_per_kb = 1000 * fee_per_byte
|
||||
|
||||
miniwallet.send_self_transfer(fee_rate=fee_per_kb, from_node=node)
|
||||
blockhash = node.generate(1)[0]
|
||||
|
||||
self.log.info("Test that getblock with verbosity 1 doesn't include fee")
|
||||
block = node.getblock(blockhash, 1)
|
||||
assert 'fee' not in block['tx'][1]
|
||||
|
||||
self.log.info('Test that getblock with verbosity 2 includes expected fee')
|
||||
block = node.getblock(blockhash, 2)
|
||||
tx = block['tx'][1]
|
||||
assert 'fee' in tx
|
||||
assert_equal(tx['fee'], tx['vsize'] * fee_per_byte)
|
||||
|
||||
self.log.info("Test that getblock with verbosity 2 still works with pruned Undo data")
|
||||
datadir = get_datadir_path(self.options.tmpdir, 0)
|
||||
|
||||
def move_block_file(old, new):
|
||||
old_path = os.path.join(datadir, self.chain, 'blocks', old)
|
||||
new_path = os.path.join(datadir, self.chain, 'blocks', new)
|
||||
os.rename(old_path, new_path)
|
||||
|
||||
# Move instead of deleting so we can restore chain state afterwards
|
||||
move_block_file('rev00000.dat', 'rev_wrong')
|
||||
|
||||
block = node.getblock(blockhash, 2)
|
||||
assert 'fee' not in block['tx'][1]
|
||||
|
||||
# Restore chain state
|
||||
move_block_file('rev_wrong', 'rev00000.dat')
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
BlockchainTest().main()
|
||||
|
Reference in New Issue
Block a user