Skip to content

Commit 60ed339

Browse files
committed
tests: implement base58_decode
1 parent aa8d768 commit 60ed339

File tree

2 files changed

+49
-1
lines changed

2 files changed

+49
-1
lines changed

test/functional/test_framework/address.py

Lines changed: 48 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,12 +5,15 @@
55
"""Encode and decode BASE58, P2PKH and P2SH addresses."""
66

77
import enum
8+
import unittest
89

910
from .script import hash256, hash160, sha256, CScript, OP_0
1011
from .util import hex_str_to_bytes
1112

1213
from . import segwit_addr
1314

15+
from test_framework.util import assert_equal
16+
1417
ADDRESS_BCRT1_UNSPENDABLE = 'bcrt1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq3xueyj'
1518
ADDRESS_BCRT1_UNSPENDABLE_DESCRIPTOR = 'addr(bcrt1qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq3xueyj)#juyq9d97'
1619
# Coins sent to this address can be spent with a witness stack of just OP_TRUE
@@ -41,7 +44,32 @@ def byte_to_base58(b, version):
4144
str = str[2:]
4245
return result
4346

44-
# TODO: def base58_decode
47+
48+
def base58_to_byte(s, verify_checksum=True):
49+
if not s:
50+
return b''
51+
n = 0
52+
for c in s:
53+
n *= 58
54+
assert c in chars
55+
digit = chars.index(c)
56+
n += digit
57+
h = '%x' % n
58+
if len(h) % 2:
59+
h = '0' + h
60+
res = n.to_bytes((n.bit_length() + 7) // 8, 'big')
61+
pad = 0
62+
for c in s:
63+
if c == chars[0]:
64+
pad += 1
65+
else:
66+
break
67+
res = b'\x00' * pad + res
68+
if verify_checksum:
69+
assert_equal(hash256(res[:-4])[:4], res[-4:])
70+
71+
return res[1:-4], int(res[0])
72+
4573

4674
def keyhash_to_p2pkh(hash, main = False):
4775
assert len(hash) == 20
@@ -100,3 +128,22 @@ def check_script(script):
100128
if (type(script) is bytes or type(script) is CScript):
101129
return script
102130
assert False
131+
132+
133+
class TestFrameworkScript(unittest.TestCase):
134+
def test_base58encodedecode(self):
135+
def check_base58(data, version):
136+
self.assertEqual(base58_to_byte(byte_to_base58(data, version)), (data, version))
137+
138+
check_base58(b'\x1f\x8e\xa1p*{\xd4\x94\x1b\xca\tA\xb8R\xc4\xbb\xfe\xdb.\x05', 111)
139+
check_base58(b':\x0b\x05\xf4\xd7\xf6l;\xa7\x00\x9fE50)l\x84\\\xc9\xcf', 111)
140+
check_base58(b'A\xc1\xea\xf1\x11\x80%Y\xba\xd6\x1b`\xd6+\x1f\x89|c\x92\x8a', 111)
141+
check_base58(b'\0A\xc1\xea\xf1\x11\x80%Y\xba\xd6\x1b`\xd6+\x1f\x89|c\x92\x8a', 111)
142+
check_base58(b'\0\0A\xc1\xea\xf1\x11\x80%Y\xba\xd6\x1b`\xd6+\x1f\x89|c\x92\x8a', 111)
143+
check_base58(b'\0\0\0A\xc1\xea\xf1\x11\x80%Y\xba\xd6\x1b`\xd6+\x1f\x89|c\x92\x8a', 111)
144+
check_base58(b'\x1f\x8e\xa1p*{\xd4\x94\x1b\xca\tA\xb8R\xc4\xbb\xfe\xdb.\x05', 0)
145+
check_base58(b':\x0b\x05\xf4\xd7\xf6l;\xa7\x00\x9fE50)l\x84\\\xc9\xcf', 0)
146+
check_base58(b'A\xc1\xea\xf1\x11\x80%Y\xba\xd6\x1b`\xd6+\x1f\x89|c\x92\x8a', 0)
147+
check_base58(b'\0A\xc1\xea\xf1\x11\x80%Y\xba\xd6\x1b`\xd6+\x1f\x89|c\x92\x8a', 0)
148+
check_base58(b'\0\0A\xc1\xea\xf1\x11\x80%Y\xba\xd6\x1b`\xd6+\x1f\x89|c\x92\x8a', 0)
149+
check_base58(b'\0\0\0A\xc1\xea\xf1\x11\x80%Y\xba\xd6\x1b`\xd6+\x1f\x89|c\x92\x8a', 0)

test/functional/test_runner.py

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -67,6 +67,7 @@
6767
TEST_EXIT_SKIPPED = 77
6868

6969
TEST_FRAMEWORK_MODULES = [
70+
"address",
7071
"script",
7172
]
7273

0 commit comments

Comments
 (0)