[tests] Move bech32 unit tests to test framework

This commit is contained in:
John Newbery 2020-06-11 13:42:37 -04:00
parent 68f0ab26bc
commit e4557133f5
3 changed files with 16 additions and 14 deletions

View File

@ -3,7 +3,7 @@
# Distributed under the MIT software license, see the accompanying # Distributed under the MIT software license, see the accompanying
# file COPYING or http://www.opensource.org/licenses/mit-license.php. # file COPYING or http://www.opensource.org/licenses/mit-license.php.
"""Reference implementation for Bech32 and segwit addresses.""" """Reference implementation for Bech32 and segwit addresses."""
import unittest
CHARSET = "qpzry9x8gf2tvdw0s3jn54khce6mua7l" CHARSET = "qpzry9x8gf2tvdw0s3jn54khce6mua7l"
@ -105,3 +105,17 @@ def encode(hrp, witver, witprog):
if decode(hrp, ret) == (None, None): if decode(hrp, ret) == (None, None):
return None return None
return ret return ret
class TestFrameworkScript(unittest.TestCase):
def test_segwit_encode_decode(self):
def test_python_bech32(addr):
hrp = addr[:4]
self.assertEqual(hrp, "bcrt")
(witver, witprog) = decode(hrp, addr)
self.assertEqual(encode(hrp, witver, witprog), addr)
# P2WPKH
test_python_bech32('bcrt1qthmht0k2qnh3wy7336z05lu2km7emzfpm3wg46')
# P2WSH
test_python_bech32('bcrt1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq3xueyj')
test_python_bech32('bcrt1qft5p2uhsdcdc3l2ua4ap5qqfg4pjaqlp250x7us7a8qqhrxrxfsqseac85')

View File

@ -71,6 +71,7 @@ TEST_FRAMEWORK_MODULES = [
"blocktools", "blocktools",
"muhash", "muhash",
"script", "script",
"segwit_addr",
"util", "util",
] ]

View File

@ -64,10 +64,6 @@ from test_framework.util import (
assert_raises_rpc_error, assert_raises_rpc_error,
connect_nodes, connect_nodes,
) )
from test_framework.segwit_addr import (
encode,
decode,
)
class AddressTypeTest(BitcoinTestFramework): class AddressTypeTest(BitcoinTestFramework):
def set_test_params(self): def set_test_params(self):
@ -101,13 +97,6 @@ class AddressTypeTest(BitcoinTestFramework):
"""Return a list of balances.""" """Return a list of balances."""
return [self.nodes[i].getbalances()['mine'][key] for i in range(4)] return [self.nodes[i].getbalances()['mine'][key] for i in range(4)]
# Quick test of python bech32 implementation
def test_python_bech32(self, addr):
hrp = addr[:4]
assert_equal(hrp, "bcrt")
(witver, witprog) = decode(hrp, addr)
assert_equal(encode(hrp, witver, witprog), addr)
def test_address(self, node, address, multisig, typ): def test_address(self, node, address, multisig, typ):
"""Run sanity checks on an address.""" """Run sanity checks on an address."""
info = self.nodes[node].getaddressinfo(address) info = self.nodes[node].getaddressinfo(address)
@ -132,7 +121,6 @@ class AddressTypeTest(BitcoinTestFramework):
assert_equal(info['witness_version'], 0) assert_equal(info['witness_version'], 0)
assert_equal(len(info['witness_program']), 40) assert_equal(len(info['witness_program']), 40)
assert 'pubkey' in info assert 'pubkey' in info
self.test_python_bech32(info["address"])
elif typ == 'legacy': elif typ == 'legacy':
# P2SH-multisig # P2SH-multisig
assert info['isscript'] assert info['isscript']
@ -158,7 +146,6 @@ class AddressTypeTest(BitcoinTestFramework):
assert_equal(info['witness_version'], 0) assert_equal(info['witness_version'], 0)
assert_equal(len(info['witness_program']), 64) assert_equal(len(info['witness_program']), 64)
assert 'pubkeys' in info assert 'pubkeys' in info
self.test_python_bech32(info["address"])
else: else:
# Unknown type # Unknown type
assert False assert False