mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-10-10 19:43:13 +02:00
cli: Implement human readable -getinfo.
This commit is contained in:
@@ -5,6 +5,7 @@
|
||||
"""Test bitcoin-cli"""
|
||||
|
||||
from decimal import Decimal
|
||||
import re
|
||||
|
||||
from test_framework.blocktools import COINBASE_MATURITY
|
||||
from test_framework.test_framework import BitcoinTestFramework
|
||||
@@ -29,6 +30,41 @@ TOO_MANY_ARGS = 'error: too many arguments (maximum 2 for nblocks and maxtries)'
|
||||
WALLET_NOT_LOADED = 'Requested wallet does not exist or is not loaded'
|
||||
WALLET_NOT_SPECIFIED = 'Wallet file not specified'
|
||||
|
||||
|
||||
def cli_get_info_string_to_dict(cli_get_info_string):
|
||||
"""Helper method to convert human-readable -getinfo into a dictionary"""
|
||||
cli_get_info = {}
|
||||
lines = cli_get_info_string.splitlines()
|
||||
line_idx = 0
|
||||
ansi_escape = re.compile(r'(\x9B|\x1B\[)[0-?]*[ -\/]*[@-~]')
|
||||
while line_idx < len(lines):
|
||||
# Remove ansi colour code
|
||||
line = ansi_escape.sub('', lines[line_idx])
|
||||
if "Balances" in line:
|
||||
# When "Balances" appears in a line, all of the following lines contain "balance: wallet" until an empty line
|
||||
cli_get_info["Balances"] = {}
|
||||
while line_idx < len(lines) and not (lines[line_idx + 1] == ''):
|
||||
line_idx += 1
|
||||
balance, wallet = lines[line_idx].strip().split(" ")
|
||||
# Remove right justification padding
|
||||
wallet = wallet.strip()
|
||||
if wallet == '""':
|
||||
# Set default wallet("") to empty string
|
||||
wallet = ''
|
||||
cli_get_info["Balances"][wallet] = balance.strip()
|
||||
elif ": " in line:
|
||||
key, value = line.split(": ")
|
||||
if key == 'Wallet' and value == '""':
|
||||
# Set default wallet("") to empty string
|
||||
value = ''
|
||||
if key == "Proxy" and value == "N/A":
|
||||
# Set N/A to empty string to represent no proxy
|
||||
value = ''
|
||||
cli_get_info[key.strip()] = value.strip()
|
||||
line_idx += 1
|
||||
return cli_get_info
|
||||
|
||||
|
||||
class TestBitcoinCli(BitcoinTestFramework):
|
||||
def set_test_params(self):
|
||||
self.setup_clean_chain = True
|
||||
@@ -67,37 +103,43 @@ class TestBitcoinCli(BitcoinTestFramework):
|
||||
self.log.info("Test -getinfo with arguments fails")
|
||||
assert_raises_process_error(1, "-getinfo takes no arguments", self.nodes[0].cli('-getinfo').help)
|
||||
|
||||
self.log.info("Test -getinfo with -color=never does not return ANSI escape codes")
|
||||
assert "\u001b[0m" not in self.nodes[0].cli('-getinfo', '-color=never').send_cli()
|
||||
|
||||
self.log.info("Test -getinfo with -color=always returns ANSI escape codes")
|
||||
assert "\u001b[0m" in self.nodes[0].cli('-getinfo', '-color=always').send_cli()
|
||||
|
||||
self.log.info("Test -getinfo with invalid value for -color option")
|
||||
assert_raises_process_error(1, "Invalid value for -color option. Valid values: always, auto, never.", self.nodes[0].cli('-getinfo', '-color=foo').send_cli)
|
||||
|
||||
self.log.info("Test -getinfo returns expected network and blockchain info")
|
||||
if self.is_wallet_compiled():
|
||||
self.nodes[0].encryptwallet(password)
|
||||
cli_get_info = self.nodes[0].cli('-getinfo').send_cli()
|
||||
cli_get_info_string = self.nodes[0].cli('-getinfo').send_cli()
|
||||
cli_get_info = cli_get_info_string_to_dict(cli_get_info_string)
|
||||
|
||||
network_info = self.nodes[0].getnetworkinfo()
|
||||
blockchain_info = self.nodes[0].getblockchaininfo()
|
||||
assert_equal(cli_get_info['version'], network_info['version'])
|
||||
assert_equal(cli_get_info['blocks'], blockchain_info['blocks'])
|
||||
assert_equal(cli_get_info['headers'], blockchain_info['headers'])
|
||||
assert_equal(cli_get_info['timeoffset'], network_info['timeoffset'])
|
||||
assert_equal(
|
||||
cli_get_info['connections'],
|
||||
{
|
||||
'in': network_info['connections_in'],
|
||||
'out': network_info['connections_out'],
|
||||
'total': network_info['connections']
|
||||
}
|
||||
)
|
||||
assert_equal(cli_get_info['proxy'], network_info['networks'][0]['proxy'])
|
||||
assert_equal(cli_get_info['difficulty'], blockchain_info['difficulty'])
|
||||
assert_equal(cli_get_info['chain'], blockchain_info['chain'])
|
||||
assert_equal(int(cli_get_info['Version']), network_info['version'])
|
||||
assert_equal(cli_get_info['Verification progress'], "%.4f%%" % (blockchain_info['verificationprogress'] * 100))
|
||||
assert_equal(int(cli_get_info['Blocks']), blockchain_info['blocks'])
|
||||
assert_equal(int(cli_get_info['Headers']), blockchain_info['headers'])
|
||||
assert_equal(int(cli_get_info['Time offset (s)']), network_info['timeoffset'])
|
||||
expected_network_info = f"in {network_info['connections_in']}, out {network_info['connections_out']}, total {network_info['connections']}"
|
||||
assert_equal(cli_get_info["Network"], expected_network_info)
|
||||
assert_equal(cli_get_info['Proxy'], network_info['networks'][0]['proxy'])
|
||||
assert_equal(Decimal(cli_get_info['Difficulty']), blockchain_info['difficulty'])
|
||||
assert_equal(cli_get_info['Chain'], blockchain_info['chain'])
|
||||
|
||||
if self.is_wallet_compiled():
|
||||
self.log.info("Test -getinfo and bitcoin-cli getwalletinfo return expected wallet info")
|
||||
assert_equal(cli_get_info['balance'], BALANCE)
|
||||
assert 'balances' not in cli_get_info.keys()
|
||||
assert_equal(Decimal(cli_get_info['Balance']), BALANCE)
|
||||
assert 'Balances' not in cli_get_info_string
|
||||
wallet_info = self.nodes[0].getwalletinfo()
|
||||
assert_equal(cli_get_info['keypoolsize'], wallet_info['keypoolsize'])
|
||||
assert_equal(cli_get_info['unlocked_until'], wallet_info['unlocked_until'])
|
||||
assert_equal(cli_get_info['paytxfee'], wallet_info['paytxfee'])
|
||||
assert_equal(cli_get_info['relayfee'], network_info['relayfee'])
|
||||
assert_equal(int(cli_get_info['Keypool size']), wallet_info['keypoolsize'])
|
||||
assert_equal(int(cli_get_info['Unlocked until']), wallet_info['unlocked_until'])
|
||||
assert_equal(Decimal(cli_get_info['Transaction fee rate (-paytxfee) (BTC/kvB)']), wallet_info['paytxfee'])
|
||||
assert_equal(Decimal(cli_get_info['Min tx relay fee rate (BTC/kvB)']), network_info['relayfee'])
|
||||
assert_equal(self.nodes[0].cli.getwalletinfo(), wallet_info)
|
||||
|
||||
# Setup to test -getinfo, -generate, and -rpcwallet= with multiple wallets.
|
||||
@@ -120,44 +162,57 @@ class TestBitcoinCli(BitcoinTestFramework):
|
||||
|
||||
self.log.info("Test -getinfo with multiple wallets and -rpcwallet returns specified wallet balance")
|
||||
for i in range(len(wallets)):
|
||||
cli_get_info = self.nodes[0].cli('-getinfo', '-rpcwallet={}'.format(wallets[i])).send_cli()
|
||||
assert 'balances' not in cli_get_info.keys()
|
||||
assert_equal(cli_get_info['balance'], amounts[i])
|
||||
cli_get_info_string = self.nodes[0].cli('-getinfo', '-rpcwallet={}'.format(wallets[i])).send_cli()
|
||||
cli_get_info = cli_get_info_string_to_dict(cli_get_info_string)
|
||||
assert 'Balances' not in cli_get_info_string
|
||||
assert_equal(cli_get_info["Wallet"], wallets[i])
|
||||
assert_equal(Decimal(cli_get_info['Balance']), amounts[i])
|
||||
|
||||
self.log.info("Test -getinfo with multiple wallets and -rpcwallet=non-existing-wallet returns no balances")
|
||||
cli_get_info_keys = self.nodes[0].cli('-getinfo', '-rpcwallet=does-not-exist').send_cli().keys()
|
||||
assert 'balance' not in cli_get_info_keys
|
||||
assert 'balances' not in cli_get_info_keys
|
||||
cli_get_info_string = self.nodes[0].cli('-getinfo', '-rpcwallet=does-not-exist').send_cli()
|
||||
assert 'Balance' not in cli_get_info_string
|
||||
assert 'Balances' not in cli_get_info_string
|
||||
|
||||
self.log.info("Test -getinfo with multiple wallets returns all loaded wallet names and balances")
|
||||
assert_equal(set(self.nodes[0].listwallets()), set(wallets))
|
||||
cli_get_info = self.nodes[0].cli('-getinfo').send_cli()
|
||||
assert 'balance' not in cli_get_info.keys()
|
||||
assert_equal(cli_get_info['balances'], {k: v for k, v in zip(wallets, amounts)})
|
||||
cli_get_info_string = self.nodes[0].cli('-getinfo').send_cli()
|
||||
cli_get_info = cli_get_info_string_to_dict(cli_get_info_string)
|
||||
assert 'Balance' not in cli_get_info
|
||||
for k, v in zip(wallets, amounts):
|
||||
assert_equal(Decimal(cli_get_info['Balances'][k]), v)
|
||||
|
||||
# Unload the default wallet and re-verify.
|
||||
self.nodes[0].unloadwallet(wallets[0])
|
||||
assert wallets[0] not in self.nodes[0].listwallets()
|
||||
cli_get_info = self.nodes[0].cli('-getinfo').send_cli()
|
||||
assert 'balance' not in cli_get_info.keys()
|
||||
assert_equal(cli_get_info['balances'], {k: v for k, v in zip(wallets[1:], amounts[1:])})
|
||||
cli_get_info_string = self.nodes[0].cli('-getinfo').send_cli()
|
||||
cli_get_info = cli_get_info_string_to_dict(cli_get_info_string)
|
||||
assert 'Balance' not in cli_get_info
|
||||
assert 'Balances' in cli_get_info_string
|
||||
for k, v in zip(wallets[1:], amounts[1:]):
|
||||
assert_equal(Decimal(cli_get_info['Balances'][k]), v)
|
||||
assert wallets[0] not in cli_get_info
|
||||
|
||||
self.log.info("Test -getinfo after unloading all wallets except a non-default one returns its balance")
|
||||
self.nodes[0].unloadwallet(wallets[2])
|
||||
assert_equal(self.nodes[0].listwallets(), [wallets[1]])
|
||||
cli_get_info = self.nodes[0].cli('-getinfo').send_cli()
|
||||
assert 'balances' not in cli_get_info.keys()
|
||||
assert_equal(cli_get_info['balance'], amounts[1])
|
||||
cli_get_info_string = self.nodes[0].cli('-getinfo').send_cli()
|
||||
cli_get_info = cli_get_info_string_to_dict(cli_get_info_string)
|
||||
assert 'Balances' not in cli_get_info_string
|
||||
assert_equal(cli_get_info['Wallet'], wallets[1])
|
||||
assert_equal(Decimal(cli_get_info['Balance']), amounts[1])
|
||||
|
||||
self.log.info("Test -getinfo with -rpcwallet=remaining-non-default-wallet returns only its balance")
|
||||
cli_get_info = self.nodes[0].cli('-getinfo', rpcwallet2).send_cli()
|
||||
assert 'balances' not in cli_get_info.keys()
|
||||
assert_equal(cli_get_info['balance'], amounts[1])
|
||||
cli_get_info_string = self.nodes[0].cli('-getinfo', rpcwallet2).send_cli()
|
||||
cli_get_info = cli_get_info_string_to_dict(cli_get_info_string)
|
||||
assert 'Balances' not in cli_get_info_string
|
||||
assert_equal(cli_get_info['Wallet'], wallets[1])
|
||||
assert_equal(Decimal(cli_get_info['Balance']), amounts[1])
|
||||
|
||||
self.log.info("Test -getinfo with -rpcwallet=unloaded wallet returns no balances")
|
||||
cli_get_info_keys = self.nodes[0].cli('-getinfo', rpcwallet3).send_cli().keys()
|
||||
assert 'balance' not in cli_get_info_keys
|
||||
assert 'balances' not in cli_get_info_keys
|
||||
cli_get_info_string = self.nodes[0].cli('-getinfo', rpcwallet3).send_cli()
|
||||
cli_get_info_keys = cli_get_info_string_to_dict(cli_get_info_string)
|
||||
assert 'Balance' not in cli_get_info_keys
|
||||
assert 'Balances' not in cli_get_info_string
|
||||
|
||||
# Test bitcoin-cli -generate.
|
||||
n1 = 3
|
||||
|
Reference in New Issue
Block a user