Skip to content

Commit f2195d7

Browse files
committed
Backport invalid address tests
Reduced version of the test from master/#20861 by John Newbery. Github-Pull: #20861 Rebased-From: fe5e495
1 parent 1e96711 commit f2195d7

File tree

2 files changed

+85
-0
lines changed

2 files changed

+85
-0
lines changed
Lines changed: 84 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,84 @@
1+
#!/usr/bin/env python3
2+
# Copyright (c) 2020 The Bitcoin Core developers
3+
# Distributed under the MIT software license, see the accompanying
4+
# file COPYING or http://www.opensource.org/licenses/mit-license.php.
5+
"""Test error messages for 'getaddressinfo' and 'validateaddress' RPC commands."""
6+
7+
from test_framework.test_framework import BitcoinTestFramework
8+
9+
from test_framework.util import assert_raises_rpc_error
10+
11+
BECH32_VALID = 'bcrt1qtmp74ayg7p24uslctssvjm06q5phz4yrxucgnv'
12+
BECH32_INVALID_BECH32 = 'bcrt1p0xlxvlhemja6c4dqv22uapctqupfhlxm9h8z3k2e72q4k9hcz7vqdmchcc'
13+
BECH32_INVALID_BECH32M = 'bcrt1qw508d6qejxtdg4y5r3zarvary0c5xw7k35mrzd'
14+
BECH32_INVALID_VERSION = 'bcrt130xlxvlhemja6c4dqv22uapctqupfhlxm9h8z3k2e72q4k9hcz7vqynjegk'
15+
BECH32_INVALID_SIZE = 'bcrt1s0xlxvlhemja6c4dqv22uapctqupfhlxm9h8z3k2e72q4k9hcz7v8n0nx0muaewav25430mtr'
16+
BECH32_INVALID_V0_SIZE = 'bcrt1qw508d6qejxtdg4y5r3zarvary0c5xw7kqqq5k3my'
17+
BECH32_INVALID_PREFIX = 'bc1pw508d6qejxtdg4y5r3zarvary0c5xw7kw508d6qejxtdg4y5r3zarvary0c5xw7k7grplx'
18+
19+
BASE58_VALID = 'mipcBbFg9gMiCh81Kj8tqqdgoZub1ZJRfn'
20+
BASE58_INVALID_PREFIX = '17VZNX1SN5NtKa8UQFxwQbFeFc3iqRYhem'
21+
22+
INVALID_ADDRESS = 'asfah14i8fajz0123f'
23+
24+
class InvalidAddressErrorMessageTest(BitcoinTestFramework):
25+
def set_test_params(self):
26+
self.setup_clean_chain = True
27+
self.num_nodes = 1
28+
29+
def skip_test_if_missing_module(self):
30+
self.skip_if_no_wallet()
31+
32+
def test_validateaddress(self):
33+
node = self.nodes[0]
34+
35+
# Bech32
36+
info = node.validateaddress(BECH32_INVALID_SIZE)
37+
assert not info['isvalid']
38+
39+
info = node.validateaddress(BECH32_INVALID_PREFIX)
40+
assert not info['isvalid']
41+
42+
info = node.validateaddress(BECH32_INVALID_BECH32)
43+
assert not info['isvalid']
44+
45+
info = node.validateaddress(BECH32_INVALID_BECH32M)
46+
assert not info['isvalid']
47+
48+
info = node.validateaddress(BECH32_INVALID_V0_SIZE)
49+
assert not info['isvalid']
50+
51+
info = node.validateaddress(BECH32_VALID)
52+
assert info['isvalid']
53+
assert 'error' not in info
54+
55+
# Base58
56+
info = node.validateaddress(BASE58_INVALID_PREFIX)
57+
assert not info['isvalid']
58+
59+
info = node.validateaddress(BASE58_VALID)
60+
assert info['isvalid']
61+
assert 'error' not in info
62+
63+
# Invalid address format
64+
info = node.validateaddress(INVALID_ADDRESS)
65+
assert not info['isvalid']
66+
67+
def test_getaddressinfo(self):
68+
node = self.nodes[0]
69+
70+
assert_raises_rpc_error(-5, "Invalid address", node.getaddressinfo, BECH32_INVALID_SIZE)
71+
72+
assert_raises_rpc_error(-5, "Invalid address", node.getaddressinfo, BECH32_INVALID_PREFIX)
73+
74+
assert_raises_rpc_error(-5, "Invalid address", node.getaddressinfo, BASE58_INVALID_PREFIX)
75+
76+
assert_raises_rpc_error(-5, "Invalid address", node.getaddressinfo, INVALID_ADDRESS)
77+
78+
def run_test(self):
79+
self.test_validateaddress()
80+
self.test_getaddressinfo()
81+
82+
83+
if __name__ == '__main__':
84+
InvalidAddressErrorMessageTest().main()

test/functional/test_runner.py

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -281,6 +281,7 @@
281281
'rpc_getdescriptorinfo.py',
282282
'rpc_getpeerinfo_deprecation.py',
283283
'rpc_help.py',
284+
'rpc_invalid_address_message.py',
284285
'feature_help.py',
285286
'feature_shutdown.py',
286287
'p2p_ibd_txrelay.py',

0 commit comments

Comments
 (0)