Merge pull request #7194
135d6ec
Add RPC tests for getblockheader. (James O'Beirne)4745636
Add RPC documentation for getblockheader[chainwork]. (James O'Beirne)16d4fce
Add assert_is_hex_string and assert_is_hash_string to RPC test utils. (James O'Beirne)
This commit is contained in:
commit
e4e77ee55d
3 changed files with 54 additions and 2 deletions
|
@ -4,19 +4,25 @@
|
||||||
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
#
|
#
|
||||||
# Test RPC calls related to blockchain state.
|
# Test RPC calls related to blockchain state. Tests correspond to code in
|
||||||
|
# rpcblockchain.cpp.
|
||||||
#
|
#
|
||||||
|
|
||||||
from decimal import Decimal
|
from decimal import Decimal
|
||||||
|
|
||||||
from test_framework.test_framework import BitcoinTestFramework
|
from test_framework.test_framework import BitcoinTestFramework
|
||||||
|
from test_framework.authproxy import JSONRPCException
|
||||||
from test_framework.util import (
|
from test_framework.util import (
|
||||||
initialize_chain,
|
initialize_chain,
|
||||||
assert_equal,
|
assert_equal,
|
||||||
|
assert_raises,
|
||||||
|
assert_is_hex_string,
|
||||||
|
assert_is_hash_string,
|
||||||
start_nodes,
|
start_nodes,
|
||||||
connect_nodes_bi,
|
connect_nodes_bi,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
class BlockchainTest(BitcoinTestFramework):
|
class BlockchainTest(BitcoinTestFramework):
|
||||||
"""
|
"""
|
||||||
Test blockchain-related RPC calls:
|
Test blockchain-related RPC calls:
|
||||||
|
@ -36,6 +42,10 @@ class BlockchainTest(BitcoinTestFramework):
|
||||||
self.sync_all()
|
self.sync_all()
|
||||||
|
|
||||||
def run_test(self):
|
def run_test(self):
|
||||||
|
self._test_gettxoutsetinfo()
|
||||||
|
self._test_getblockheader()
|
||||||
|
|
||||||
|
def _test_gettxoutsetinfo(self):
|
||||||
node = self.nodes[0]
|
node = self.nodes[0]
|
||||||
res = node.gettxoutsetinfo()
|
res = node.gettxoutsetinfo()
|
||||||
|
|
||||||
|
@ -47,6 +57,30 @@ class BlockchainTest(BitcoinTestFramework):
|
||||||
assert_equal(len(res[u'bestblock']), 64)
|
assert_equal(len(res[u'bestblock']), 64)
|
||||||
assert_equal(len(res[u'hash_serialized']), 64)
|
assert_equal(len(res[u'hash_serialized']), 64)
|
||||||
|
|
||||||
|
def _test_getblockheader(self):
|
||||||
|
node = self.nodes[0]
|
||||||
|
|
||||||
|
assert_raises(
|
||||||
|
JSONRPCException, lambda: node.getblockheader('nonsense'))
|
||||||
|
|
||||||
|
besthash = node.getbestblockhash()
|
||||||
|
secondbesthash = node.getblockhash(199)
|
||||||
|
header = node.getblockheader(besthash)
|
||||||
|
|
||||||
|
assert_equal(header['hash'], besthash)
|
||||||
|
assert_equal(header['height'], 200)
|
||||||
|
assert_equal(header['confirmations'], 1)
|
||||||
|
assert_equal(header['previousblockhash'], secondbesthash)
|
||||||
|
assert_is_hex_string(header['chainwork'])
|
||||||
|
assert_is_hash_string(header['hash'])
|
||||||
|
assert_is_hash_string(header['previousblockhash'])
|
||||||
|
assert_is_hash_string(header['merkleroot'])
|
||||||
|
assert_is_hash_string(header['bits'], length=None)
|
||||||
|
assert isinstance(header['time'], int)
|
||||||
|
assert isinstance(header['mediantime'], int)
|
||||||
|
assert isinstance(header['nonce'], int)
|
||||||
|
assert isinstance(header['version'], int)
|
||||||
|
assert isinstance(header['difficulty'], decimal.Decimal)
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
BlockchainTest().main()
|
BlockchainTest().main()
|
||||||
|
|
|
@ -407,6 +407,23 @@ def assert_raises(exc, fun, *args, **kwds):
|
||||||
else:
|
else:
|
||||||
raise AssertionError("No exception raised")
|
raise AssertionError("No exception raised")
|
||||||
|
|
||||||
|
def assert_is_hex_string(string):
|
||||||
|
try:
|
||||||
|
int(string, 16)
|
||||||
|
except Exception as e:
|
||||||
|
raise AssertionError(
|
||||||
|
"Couldn't interpret %r as hexadecimal; raised: %s" % (string, e))
|
||||||
|
|
||||||
|
def assert_is_hash_string(string, length=64):
|
||||||
|
if not isinstance(string, basestring):
|
||||||
|
raise AssertionError("Expected a string, got type %r" % type(string))
|
||||||
|
elif length and len(string) != length:
|
||||||
|
raise AssertionError(
|
||||||
|
"String of length %d expected; got %d" % (length, len(string)))
|
||||||
|
elif not re.match('[abcdef0-9]+$', string):
|
||||||
|
raise AssertionError(
|
||||||
|
"String %r contains invalid characters for a hash." % string)
|
||||||
|
|
||||||
def satoshi_round(amount):
|
def satoshi_round(amount):
|
||||||
return Decimal(amount).quantize(Decimal('0.00000001'), rounding=ROUND_DOWN)
|
return Decimal(amount).quantize(Decimal('0.00000001'), rounding=ROUND_DOWN)
|
||||||
|
|
||||||
|
|
|
@ -323,7 +323,8 @@ UniValue getblockheader(const UniValue& params, bool fHelp)
|
||||||
" \"bits\" : \"1d00ffff\", (string) The bits\n"
|
" \"bits\" : \"1d00ffff\", (string) The bits\n"
|
||||||
" \"difficulty\" : x.xxx, (numeric) The difficulty\n"
|
" \"difficulty\" : x.xxx, (numeric) The difficulty\n"
|
||||||
" \"previousblockhash\" : \"hash\", (string) The hash of the previous block\n"
|
" \"previousblockhash\" : \"hash\", (string) The hash of the previous block\n"
|
||||||
" \"nextblockhash\" : \"hash\" (string) The hash of the next block\n"
|
" \"nextblockhash\" : \"hash\", (string) The hash of the next block\n"
|
||||||
|
" \"chainwork\" : \"0000...1f3\" (string) Expected number of hashes required to produce the current chain (in hex)\n"
|
||||||
"}\n"
|
"}\n"
|
||||||
"\nResult (for verbose=false):\n"
|
"\nResult (for verbose=false):\n"
|
||||||
"\"data\" (string) A string that is serialized, hex-encoded data for block 'hash'.\n"
|
"\"data\" (string) A string that is serialized, hex-encoded data for block 'hash'.\n"
|
||||||
|
|
Loading…
Add table
Reference in a new issue