542 lines
27 KiB
Python
542 lines
27 KiB
Python
import unittest
|
|
import os, sys
|
|
parentPath = os.path.abspath("..")
|
|
if parentPath not in sys.path:
|
|
sys.path.insert(0, parentPath)
|
|
|
|
from pybtc import tools
|
|
from pybtc import BYTE_OPCODE, HEX_OPCODE
|
|
from binascii import unhexlify, hexlify
|
|
|
|
|
|
class AddressFunctionsTests(unittest.TestCase):
|
|
@classmethod
|
|
def setUpClass(cls):
|
|
print("\nTesting address functions:\n")
|
|
|
|
def test_private_key_to_WIF(self):
|
|
p = "ceda1ae4286015d45ec5147fe3f63e9377ccd6d4e98bcf0847df9937da1944a4"
|
|
pcm = "L49obCXV7fGz2YRzLCSJgeZBYmGeBbKPT7xiehUeYX2S4URkPFZX"
|
|
pum = "5KPPLXhtga99qqMceRo4Z6LXV3Kx6a9hRx3ez2U7EwP5KZfy2Wf"
|
|
put = "93A1vGXSGoDHotruGmgyRgtV8hgfFjgtmtuc4epcag886W9d44L"
|
|
pct = "cUWo47XLYiyFByuFicFS3y4FAza3r3R5XA7Bm7wA3dgSKDYox7h6"
|
|
self.assertEqual(tools.private_key_to_wif(p, compressed=1, testnet=0), pcm)
|
|
self.assertEqual(tools.private_key_to_wif(p, compressed=0, testnet=0), pum)
|
|
self.assertEqual(tools.private_key_to_wif(p, compressed=1, testnet=1), pct)
|
|
self.assertEqual(tools.private_key_to_wif(p, compressed=0, testnet=1), put)
|
|
|
|
def test_is_WIF_valid(self):
|
|
self.assertEqual(tools.is_wif_valid("L49obCXV7fGz2YRzLCSJgeZBYmGeBbKPT7xiehUeYX2S4URkPFZX"), 1)
|
|
self.assertEqual(tools.is_wif_valid("5KPPLXhtga99qqMceRo4Z6LXV3Kx6a9hRx3ez2U7EwP5KZfy2Wf"), 1)
|
|
self.assertEqual(tools.is_wif_valid("5KPPLXhtga99qqMcWRo4Z6LXV3Kx6a9hRx3ez2U7EwP5KZfy2Wf"), 0)
|
|
self.assertEqual(tools.is_wif_valid("93A1vGXSGoDHotruGmgyRgtV8hgfFjgtmtuc4epcag886W9d44L"), 1)
|
|
self.assertEqual(tools.is_wif_valid("cUWo47XLYiyFByuFicFS3y4FAza3r3R5XA7Bm7wA3dgSKDYox7h6"), 1)
|
|
self.assertEqual(tools.is_wif_valid("cUWo47XLYiyByuFicFS3y4FAza3r3R5XA7Bm7wA3dgSKDYox7h6"), 0)
|
|
|
|
def test_WIF_to_private_key(self):
|
|
p = "ceda1ae4286015d45ec5147fe3f63e9377ccd6d4e98bcf0847df9937da1944a4"
|
|
self.assertEqual(tools.wif_to_private_key("L49obCXV7fGz2YRzLCSJgeZBYmGeBbKPT7xiehUeYX2S4URkPFZX",
|
|
hex=1),p)
|
|
self.assertEqual(tools.wif_to_private_key("L49obCXV7fGz2YRzLCSJgeZBYmGeBbKPT7xiehUeYX2S4URkPFZX",
|
|
hex=0),unhexlify(p))
|
|
self.assertEqual(tools.wif_to_private_key("5KPPLXhtga99qqMceRo4Z6LXV3Kx6a9hRx3ez2U7EwP5KZfy2Wf",
|
|
hex=1),p)
|
|
self.assertEqual(tools.wif_to_private_key("93A1vGXSGoDHotruGmgyRgtV8hgfFjgtmtuc4epcag886W9d44L",
|
|
hex=1),p)
|
|
self.assertEqual(tools.wif_to_private_key("cUWo47XLYiyFByuFicFS3y4FAza3r3R5XA7Bm7wA3dgSKDYox7h6",
|
|
hex=1),p)
|
|
|
|
def test_create_private_key(self):
|
|
p = tools.create_private_key(wif=0)
|
|
pw = tools.private_key_to_wif(p)
|
|
self.assertEqual(tools.is_wif_valid(pw), True)
|
|
|
|
|
|
|
|
def test_private_to_public_key(self):
|
|
p = "ceda1ae4286015d45ec5147fe3f63e9377ccd6d4e98bcf0847df9937da1944a4"
|
|
pu = "04b635dbdc16dbdf4bb9cf5b55e7d03e514fb04dcef34208155c7d3ec88e9045f4c8cbe28702911260f2a1da099a338bed4ee98f66bb8dba8031a76ab537ff6663"
|
|
pk = "03b635dbdc16dbdf4bb9cf5b55e7d03e514fb04dcef34208155c7d3ec88e9045f4"
|
|
self.assertEqual(tools.private_to_public_key(p, hex=1), pk)
|
|
self.assertEqual(tools.private_to_public_key(p, hex=0), unhexlify(pk))
|
|
self.assertEqual(tools.private_to_public_key(p, compressed=0, hex=1), pu)
|
|
self.assertEqual(tools.private_to_public_key("L49obCXV7fGz2YRzLCSJgeZBYmGeBbKPT7xiehUeYX2S4URkPFZX", hex=1), pk)
|
|
self.assertEqual(tools.private_to_public_key("5KPPLXhtga99qqMceRo4Z6LXV3Kx6a9hRx3ez2U7EwP5KZfy2Wf", hex=1), pu)
|
|
self.assertEqual(tools.private_to_public_key("93A1vGXSGoDHotruGmgyRgtV8hgfFjgtmtuc4epcag886W9d44L", hex=1), pu)
|
|
self.assertEqual(tools.private_to_public_key("cUWo47XLYiyFByuFicFS3y4FAza3r3R5XA7Bm7wA3dgSKDYox7h6", hex=1), pk)
|
|
|
|
def test_hash_to_address(self):
|
|
pc = "0279be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"
|
|
h = tools.hash160(pc)
|
|
s = bytes([len(unhexlify(pc))])+unhexlify(pc) + BYTE_OPCODE["OP_CHECKSIG"]
|
|
self.assertEqual(tools.hash_to_address(h), "bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4")
|
|
self.assertEqual(tools.hash_to_address(h, testnet=1), "tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx")
|
|
h = tools.script_to_hash(s, 1, 1)
|
|
self.assertEqual(tools.hash_to_address(h), "bc1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3qccfmv3")
|
|
self.assertEqual(tools.hash_to_address(h, testnet=1), "tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sl5k7")
|
|
pk = "03b635dbdc16dbdf4bb9cf5b55e7d03e514fb04dcef34208155c7d3ec88e9045f4"
|
|
h = tools.hash160(pk)
|
|
self.assertEqual(tools.hash_to_address(h, witness_version=None), "1Fs2Xqrk4P2XADaJeZWykaGXJ4HEb6RyT1")
|
|
self.assertEqual(tools.hash_to_address(h, witness_version=None, testnet=1),
|
|
"mvNyptwisQTmwL3vN8VMaVUrA3swVCX83c")
|
|
# p2wpkh inside p2sh
|
|
p = "L32a8Mo1LgvjrVDbzcc3NkuUfkpoLsf2Y2oEWkV4t1KpQdFzuyff"
|
|
pk = tools.private_to_public_key(p)
|
|
script = b'\x00\x14' + tools.hash160(pk)
|
|
script_hash = tools.hash160(script)
|
|
self.assertEqual(tools.hash_to_address(script_hash,
|
|
script_hash=1,
|
|
witness_version=None), "33am12q3Bncnn3BfvLYHczyv23Sq2Wbwjw")
|
|
self.assertEqual(tools.hash_to_address(script_hash,
|
|
script_hash=1,
|
|
witness_version=None,
|
|
testnet=1), "2Mu8y4mm4oF88yppDbUAAEwyBEPezrx7CLh")
|
|
|
|
def test_address_to_hash(self):
|
|
h = "751e76e8199196d454941c45d1b3a323f1433bd6"
|
|
self.assertEqual(tools.address_to_hash("bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4", 1), h)
|
|
self.assertEqual(tools.address_to_hash("tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx", 1), h)
|
|
h = "1863143c14c5166804bd19203356da136c985678cd4d27a1b8c6329604903262"
|
|
self.assertEqual(tools.address_to_hash("bc1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3qccfmv3", 1), h)
|
|
h = "a307d67484911deee457779b17505cedd20e1fe9"
|
|
self.assertEqual(tools.address_to_hash("1Fs2Xqrk4P2XADaJeZWykaGXJ4HEb6RyT1", 1), h)
|
|
self.assertEqual(tools.address_to_hash("mvNyptwisQTmwL3vN8VMaVUrA3swVCX83c", 1), h)
|
|
h = "14c14c8d26acbea970757b78e6429ad05a6ac6bb"
|
|
self.assertEqual(tools.address_to_hash("33am12q3Bncnn3BfvLYHczyv23Sq2Wbwjw", 1), h)
|
|
self.assertEqual(tools.address_to_hash("2Mu8y4mm4oF88yppDbUAAEwyBEPezrx7CLh", 1), h)
|
|
|
|
def test_address_type(self):
|
|
self.assertEqual(tools.address_type("bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4"), 'P2WPKH')
|
|
self.assertEqual(tools.address_type("tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx"), 'P2WPKH')
|
|
self.assertEqual(tools.address_type("bc1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3qccfmv3"), 'P2WSH')
|
|
self.assertEqual(tools.address_type("tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sl5k7"), 'P2WSH')
|
|
self.assertEqual(tools.address_type("1Fs2Xqrk4P2XADaJeZWykaGXJ4HEb6RyT1"), 'P2PKH')
|
|
self.assertEqual(tools.address_type("mvNyptwisQTmwL3vN8VMaVUrA3swVCX83c"), 'P2PKH')
|
|
self.assertEqual(tools.address_type("33am12q3Bncnn3BfvLYHczyv23Sq2Wbwjw"), 'P2SH')
|
|
self.assertEqual(tools.address_type("2Mu8y4mm4oF88yppDbUAAEwyBEPezrx7CLh"), 'P2SH')
|
|
|
|
def test_address_net_type(self):
|
|
self.assertEqual(tools.address_net_type("bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4"), 'mainnet')
|
|
self.assertEqual(tools.address_net_type("tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx"), 'testnet')
|
|
self.assertEqual(tools.address_net_type("bc1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3qccfmv3"),
|
|
'mainnet')
|
|
self.assertEqual(tools.address_net_type("tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sl5k7"),
|
|
'testnet')
|
|
self.assertEqual(tools.address_net_type("1Fs2Xqrk4P2XADaJeZWykaGXJ4HEb6RyT1"), 'mainnet')
|
|
self.assertEqual(tools.address_net_type("mvNyptwisQTmwL3vN8VMaVUrA3swVCX83c"), 'testnet')
|
|
self.assertEqual(tools.address_net_type("33am12q3Bncnn3BfvLYHczyv23Sq2Wbwjw"), 'mainnet')
|
|
self.assertEqual(tools.address_net_type("2Mu8y4mm4oF88yppDbUAAEwyBEPezrx7CLh"), 'testnet')
|
|
|
|
def test_public_key_to_address(self):
|
|
pc = "0279be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"
|
|
self.assertEqual(tools.public_key_to_address(pc), "bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4")
|
|
self.assertEqual(tools.public_key_to_address(pc, testnet=1), "tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx")
|
|
pc = "03b635dbdc16dbdf4bb9cf5b55e7d03e514fb04dcef34208155c7d3ec88e9045f4"
|
|
self.assertEqual(tools.public_key_to_address(pc,
|
|
witness_version=None,
|
|
testnet=0), "1Fs2Xqrk4P2XADaJeZWykaGXJ4HEb6RyT1")
|
|
self.assertEqual(tools.public_key_to_address(pc, witness_version=None,
|
|
testnet=1), "mvNyptwisQTmwL3vN8VMaVUrA3swVCX83c")
|
|
p = "L32a8Mo1LgvjrVDbzcc3NkuUfkpoLsf2Y2oEWkV4t1KpQdFzuyff"
|
|
pk = tools.private_to_public_key(p)
|
|
self.assertEqual(tools.public_key_to_address(pk, p2sh_p2wpkh=1,
|
|
witness_version=None), "33am12q3Bncnn3BfvLYHczyv23Sq2Wbwjw")
|
|
|
|
def test_is_address_valid(self):
|
|
self.assertEqual(tools.is_address_valid("bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4"), 1)
|
|
self.assertEqual(tools.is_address_valid("tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx", 1), 1)
|
|
self.assertEqual(tools.is_address_valid("tb1qw508d6qejxtdg4y5r3zarvary0c5xw7kxpjzsx"), 0)
|
|
self.assertEqual(tools.is_address_valid("bc1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3qccfmv3"), 1)
|
|
self.assertEqual(tools.is_address_valid("tb1qrp33g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sl5k7", 1), 1)
|
|
self.assertEqual(tools.is_address_valid("1Fs2Xqrk4P2XADaJeZWykaGXJ4HEb6RyT1"), 1)
|
|
self.assertEqual(tools.is_address_valid("mvNyptwisQTmwL3vN8VMaVUrA3swVCX83c", 1), 1)
|
|
self.assertEqual(tools.is_address_valid("33am12q3Bncnn3BfvLYHczyv23Sq2Wbwjw"), 1)
|
|
self.assertEqual(tools.is_address_valid("2Mu8y4mm4oF88yppDbUAAEwyBEPezrx7CLh",1), 1)
|
|
self.assertEqual(tools.is_address_valid("2Mu8y4mm4oF89yppDbUAAEwyBEPezrx7CLh",1), 0)
|
|
self.assertEqual(tools.is_address_valid("bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4", 1), 0)
|
|
self.assertEqual(tools.is_address_valid("tb1qw508d6qejxtdg4W5r3zarvary0c5xw7kxpjzsx",1), 0)
|
|
self.assertEqual(tools.is_address_valid("bc1qrp33g0q5c5txsp8arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3qccfmv3"), 0)
|
|
self.assertEqual(tools.is_address_valid("tb1qrp23g0q5c5txsp9arysrx4k6zdkfs4nce4xj0gdcccefvpysxf3q0sl5k7",1), 0)
|
|
self.assertEqual(tools.is_address_valid("1Fs2Xqrk4P2XADaJeZWykaGXJ2HEb6RyT1"), 0)
|
|
self.assertEqual(tools.is_address_valid("mvNyptwisQTkwL3vN8VMaVUrA3swVCX83c", 1), 0)
|
|
self.assertEqual(tools.is_address_valid("33am12q3Bncmn3BfvLYHczyv23Sq2Wbwjw"), 0)
|
|
self.assertEqual(tools.is_address_valid("2Mu8y4mm4oF78yppDbUAAEwyBEPezrx7CLh", 1), 0)
|
|
|
|
def test_address_to_script(self):
|
|
self.assertEqual(tools.address_to_script("17rPqUf4Hqu6Lvpgfsavt1CzRy2GL19GD3", 1),
|
|
"76a9144b2832feeda5692c96c0594a6314136a998f515788ac")
|
|
self.assertEqual(tools.address_to_script("33RYUa9jT541UNPsKdV7V1DmwMiQHpVfD3", 1),
|
|
"a914130319921ecbcfa33fec2a8503c4ae1c86e4419387")
|
|
self.assertEqual(tools.address_to_script("bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4", 1),
|
|
"0014751e76e8199196d454941c45d1b3a323f1433bd6")
|
|
self.assertEqual(tools.address_to_script("bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4", 1),
|
|
"0014751e76e8199196d454941c45d1b3a323f1433bd6")
|
|
|
|
def test_parse_script(self):
|
|
|
|
k = tools.parse_script("76a9144b2832feeda5692c96c0594a6314136a998f515788ac")
|
|
address = tools.hash_to_address(k["addressHash"], witness_version = None)
|
|
self.assertEqual(address, "17rPqUf4Hqu6Lvpgfsavt1CzRy2GL19GD3")
|
|
self.assertEqual(k["type"],"P2PKH")
|
|
self.assertEqual(k["nType"],0)
|
|
self.assertEqual(k["reqSigs"],1)
|
|
self.assertEqual(tools.address_to_script(address, 1),
|
|
"76a9144b2832feeda5692c96c0594a6314136a998f515788ac")
|
|
|
|
k = tools.parse_script("76a914a307d67484911deee457779b17505cedd20e1fe988ac")
|
|
address = tools.hash_to_address(k["addressHash"],testnet= True, witness_version = None)
|
|
self.assertEqual(address,"mvNyptwisQTmwL3vN8VMaVUrA3swVCX83c")
|
|
self.assertEqual(k["type"],"P2PKH")
|
|
self.assertEqual(k["nType"],0)
|
|
self.assertEqual(k["reqSigs"],1)
|
|
self.assertEqual(tools.address_to_script(address, 1),
|
|
"76a914a307d67484911deee457779b17505cedd20e1fe988ac")
|
|
|
|
k = tools.parse_script("a914b316ac9bdd0816ecdec6773d1192c0eaf52ae66487")
|
|
address = tools.hash_to_address(k["addressHash"],script_hash = True ,witness_version = None)
|
|
self.assertEqual(address, "3J1x3KHjgjoTjqHjrwKax2zeT8LSDkZJae")
|
|
self.assertEqual(k["type"],"P2SH")
|
|
self.assertEqual(k["nType"],1)
|
|
self.assertEqual(k["reqSigs"], None)
|
|
self.assertEqual(tools.address_to_script(address, 1),
|
|
"a914b316ac9bdd0816ecdec6773d1192c0eaf52ae66487")
|
|
|
|
k = tools.parse_script("0014751e76e8199196d454941c45d1b3a323f1433bd6")
|
|
address = tools.hash_to_address(k["addressHash"],script_hash = False,
|
|
witness_version = 0, testnet = False)
|
|
self.assertEqual(address, "bc1qw508d6qejxtdg4y5r3zarvary0c5xw7kv8f3t4")
|
|
self.assertEqual(k["type"],"P2WPKH")
|
|
self.assertEqual(k["nType"],5)
|
|
self.assertEqual(k["reqSigs"],1)
|
|
self.assertEqual(tools.address_to_script(address, 1),
|
|
"0014751e76e8199196d454941c45d1b3a323f1433bd6")
|
|
|
|
s = [HEX_OPCODE['OP_HASH160'],
|
|
'14',
|
|
'92c2f2da37093971ca335824edae06468e60ea20',
|
|
HEX_OPCODE['OP_EQUAL']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
address = tools.hash_to_address(k["addressHash"],script_hash = True,
|
|
witness_version = None, testnet = False)
|
|
self.assertEqual(address, "3F527pX8o2pgr6FuNdNvngA2Do2wVvDoZi")
|
|
self.assertEqual(k["type"],"P2SH")
|
|
self.assertEqual(k["nType"],1)
|
|
self.assertEqual(k["reqSigs"], None)
|
|
self.assertEqual(tools.address_to_script(address, 1), h)
|
|
|
|
s = [HEX_OPCODE['OP_3'],
|
|
'21',
|
|
'021ecd2e5eb5dbd7c8e59f66e37da2ae95f7d61a07f4b2567c3bb10bbb1b2ec953',
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
sh = tools.script_to_hash(h, 0, 0)
|
|
address = tools.hash_to_address(sh,script_hash = True,
|
|
witness_version = None, testnet = False)
|
|
self.assertEqual(address, "3D2oetdNuZUqQHPJmcMDDHYoqkyNVsFk9r")
|
|
self.assertEqual(k["type"],"MULTISIG")
|
|
self.assertEqual(k["nType"],4)
|
|
self.assertEqual(k["reqSigs"],3)
|
|
|
|
s = [HEX_OPCODE['OP_0'],
|
|
'21',
|
|
'021ecd2e5eb5dbd7c8e59f66e37da2ae95f7d61a07f4b2567c3bb10bbb1b2ec953',
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
sh = tools.script_to_hash(h, 0,0)
|
|
self.assertEqual(k["type"],"NON_STANDARD")
|
|
self.assertEqual(k["nType"],7)
|
|
self.assertEqual(k["reqSigs"],20)
|
|
|
|
s = [HEX_OPCODE['OP_1'],
|
|
'21',
|
|
'021ecd2e5eb5dbd7c8e59f66e37da2ae95f7d61a07f4b2567c3bb10bbb1b2ec953',
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"],"MULTISIG")
|
|
self.assertEqual(k["nType"],4)
|
|
self.assertEqual(k["reqSigs"],1)
|
|
|
|
|
|
|
|
s = [HEX_OPCODE['OP_1'],
|
|
HEX_OPCODE['OP_1'],
|
|
'21',
|
|
'021ecd2e5eb5dbd7c8e59f66e37da2ae95f7d61a07f4b2567c3bb10bbb1b2ec953',
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
sh = tools.script_to_hash(h, 0, 0)
|
|
self.assertEqual(k["type"],"NON_STANDARD")
|
|
self.assertEqual(k["nType"],7)
|
|
self.assertEqual(k["reqSigs"],1)
|
|
|
|
s = [HEX_OPCODE['OP_1'],
|
|
HEX_OPCODE['OP_6'],
|
|
'21',
|
|
'021ecd2e5eb5dbd7c8e59f66e37da2ae95f7d61a07f4b2567c3bb10bbb1b2ec953',
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"], "NON_STANDARD")
|
|
self.assertEqual(k["nType"], 7)
|
|
self.assertEqual(k["reqSigs"], 6)
|
|
|
|
s = [HEX_OPCODE['OP_1'],
|
|
HEX_OPCODE['OP_6'],
|
|
'21',
|
|
'021ecd2e5eb5dbd7c8e59f66e37da2ae95f7d61a07f4b2567c3bb10bbb1b2ec953',
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"],"NON_STANDARD")
|
|
self.assertEqual(k["nType"],7)
|
|
self.assertEqual(k["reqSigs"],20)
|
|
|
|
s = [HEX_OPCODE['OP_1'],
|
|
HEX_OPCODE['OP_6'],
|
|
'21',
|
|
'021ecd2e5eb5dbd7c8e59f66e37da2ae95f7d61a07f4b2567c3bb10bbb1b2ec953',
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKSIG'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"],"NON_STANDARD")
|
|
self.assertEqual(k["nType"],7)
|
|
self.assertEqual(k["reqSigs"],21)
|
|
|
|
|
|
s = [HEX_OPCODE['OP_1'],
|
|
HEX_OPCODE['OP_6'],
|
|
'21',
|
|
'021ecd2e5eb5dbd7c8e59f66e37da2ae95f7d61a07f4b2567c3bb10bbb1b2ec953',
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"],"NON_STANDARD")
|
|
self.assertEqual(k["nType"],7)
|
|
self.assertEqual(k["reqSigs"],20)
|
|
|
|
s = [
|
|
HEX_OPCODE['OP_6'],
|
|
'21',
|
|
'021ecd2e5eb5dbd7c8e59f66e37da2ae95f7d61a07f4b2567c3bb10bbb1b2ec953',
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"],"NON_STANDARD")
|
|
self.assertEqual(k["nType"],7)
|
|
self.assertEqual(k["reqSigs"],20)
|
|
|
|
|
|
s = [
|
|
HEX_OPCODE['OP_6'],
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"],"MULTISIG")
|
|
self.assertEqual(k["nType"],4)
|
|
self.assertEqual(k["reqSigs"],6)
|
|
|
|
|
|
s = [
|
|
HEX_OPCODE['OP_1'],
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"],"MULTISIG")
|
|
self.assertEqual(k["nType"],4)
|
|
self.assertEqual(k["reqSigs"],1)
|
|
|
|
|
|
|
|
s = [
|
|
HEX_OPCODE['OP_1'],
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
'21',
|
|
'02b63fe474a5daac88eb74fdc9ce0ec69a8f8b81d2d89ac8d518a2f54d4bcaf4a5',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"],"NON_STANDARD")
|
|
self.assertEqual(k["nType"],7)
|
|
self.assertEqual(k["reqSigs"],20)
|
|
|
|
|
|
s = [
|
|
HEX_OPCODE['OP_1'],
|
|
'21',
|
|
'023bd78b0e7606fc1205721e4403355dfc0dbe4f1b15712cbbb17b1dc323cc8c0b',
|
|
'21',
|
|
'02afa49972b95496b39e7adc13437239ded698d81c85e9d029debb88641733528d',
|
|
HEX_OPCODE['OP_DUP'],
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
'21',
|
|
'03fedb540dd71a0211170b1857a3888d9f950231ecd0fcc7a37ffe094721ca151f',
|
|
'21',
|
|
'02fb394aaf232e114c06b1d1ca15f97602d2377c33e6fe5a1287421b09b08a5a3e',
|
|
HEX_OPCODE['OP_6'],
|
|
HEX_OPCODE['OP_CHECKMULTISIG']]
|
|
h = ''.join(s)
|
|
s = unhexlify(h)
|
|
k = tools.parse_script(s)
|
|
self.assertEqual(k["type"],"NON_STANDARD")
|
|
self.assertEqual(k["nType"],7)
|
|
self.assertEqual(k["reqSigs"],20)
|
|
|