1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-03 12:00:59 +00:00

tests: use simplified API for MultisigRedeemScriptType where possible

This is possible when address_n is the same for all involved nodes
This commit is contained in:
Pavol Rusnak 2019-02-04 01:13:31 +01:00
parent f7aa6ae22e
commit 333af87ce2
No known key found for this signature in database
GPG Key ID: 91F3B339B9A02A3D
11 changed files with 51 additions and 172 deletions

View File

@ -25,10 +25,8 @@ from .common import TrezorTest
def getmultisig(chain, nr, xpubs, signatures=[b"", b"", b""]): def getmultisig(chain, nr, xpubs, signatures=[b"", b"", b""]):
return proto.MultisigRedeemScriptType( return proto.MultisigRedeemScriptType(
pubkeys=[ nodes=[bip32.deserialize(xpub) for xpub in xpubs],
proto.HDNodePathType(node=bip32.deserialize(xpub), address_n=[chain, nr]) address_n=[chain, nr],
for xpub in xpubs
],
signatures=signatures, signatures=signatures,
m=2, m=2,
) )

View File

@ -78,14 +78,8 @@ class TestMsgGetaddressSegwit(TrezorTest):
range(1, 4), range(1, 4),
) )
multisig1 = proto.MultisigRedeemScriptType( multisig1 = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[bip32.deserialize(n.xpub) for n in nodes],
map( address_n=[2, 0],
lambda n: proto.HDNodePathType(
node=bip32.deserialize(n.xpub), address_n=[2, 0]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )

View File

@ -76,26 +76,14 @@ class TestMsgGetaddressSegwitNative(TrezorTest):
for index in range(1, 4) for index in range(1, 4)
] ]
multisig1 = proto.MultisigRedeemScriptType( multisig1 = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[bip32.deserialize(n.xpub) for n in nodes],
map( address_n=[2, 0],
lambda n: proto.HDNodePathType(
node=bip32.deserialize(n.xpub), address_n=[2, 0]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
multisig2 = proto.MultisigRedeemScriptType( multisig2 = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[bip32.deserialize(n.xpub) for n in nodes],
map( address_n=[2, 1],
lambda n: proto.HDNodePathType(
node=bip32.deserialize(n.xpub), address_n=[2, 1]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )

View File

@ -424,14 +424,8 @@ class TestMsgSigntxBch(TrezorTest):
def getmultisig(chain, nr, signatures=[b"", b"", b""], xpubs=xpubs): def getmultisig(chain, nr, signatures=[b"", b"", b""], xpubs=xpubs):
return proto.MultisigRedeemScriptType( return proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(xpub) for xpub in xpubs],
map( address_n=[chain, nr],
lambda xpub: proto.HDNodePathType(
node=deserialize(xpub), address_n=[chain, nr]
),
xpubs,
)
),
signatures=signatures, signatures=signatures,
m=2, m=2,
) )
@ -524,14 +518,8 @@ class TestMsgSigntxBch(TrezorTest):
def getmultisig(chain, nr, signatures=[b"", b"", b""], xpubs=xpubs): def getmultisig(chain, nr, signatures=[b"", b"", b""], xpubs=xpubs):
return proto.MultisigRedeemScriptType( return proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(xpub) for xpub in xpubs],
map( address_n=[chain, nr],
lambda xpub: proto.HDNodePathType(
node=deserialize(xpub), address_n=[chain, nr]
),
xpubs,
)
),
signatures=signatures, signatures=signatures,
m=2, m=2,
) )

View File

@ -235,14 +235,8 @@ class TestMsgSigntxBitcoinGold(TrezorTest):
def getmultisig(chain, nr, signatures=[b"", b"", b""], xpubs=xpubs): def getmultisig(chain, nr, signatures=[b"", b"", b""], xpubs=xpubs):
return proto.MultisigRedeemScriptType( return proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(xpub) for xpub in xpubs],
map( address_n=[chain, nr],
lambda xpub: proto.HDNodePathType(
node=deserialize(xpub), address_n=[chain, nr]
),
xpubs,
)
),
signatures=signatures, signatures=signatures,
m=2, m=2,
) )
@ -509,14 +503,8 @@ class TestMsgSigntxBitcoinGold(TrezorTest):
range(1, 4), range(1, 4),
) )
multisig = proto.MultisigRedeemScriptType( multisig = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[1, 0],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[1, 0]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )

View File

@ -290,10 +290,8 @@ class TestMsgSigntxDecred(TrezorTest):
def create_multisig(index, address, signatures=None): def create_multisig(index, address, signatures=None):
address_n = parse_path(address) address_n = parse_path(address)
multisig = proto.MultisigRedeemScriptType( multisig = proto.MultisigRedeemScriptType(
pubkeys=[ nodes=nodes,
proto.HDNodePathType(node=node, address_n=address_n) address_n=address_n,
for node in nodes
],
signatures=signatures, signatures=signatures,
m=2, m=2,
) )

View File

@ -223,14 +223,8 @@ class TestMsgSigntxSegwit(TrezorTest):
range(1, 4), range(1, 4),
) )
multisig = proto.MultisigRedeemScriptType( multisig = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[1, 0],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[1, 0]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )

View File

@ -410,14 +410,8 @@ class TestMsgSigntxSegwitNative(TrezorTest):
for index in range(1, 4) for index in range(1, 4)
] ]
multisig = proto.MultisigRedeemScriptType( multisig = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[0, 0],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[0, 0]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
@ -517,14 +511,8 @@ class TestMsgSigntxSegwitNative(TrezorTest):
for index in range(1, 4) for index in range(1, 4)
] ]
multisig = proto.MultisigRedeemScriptType( multisig = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[0, 1],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[0, 1]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
@ -624,26 +612,14 @@ class TestMsgSigntxSegwitNative(TrezorTest):
for index in range(1, 4) for index in range(1, 4)
] ]
multisig = proto.MultisigRedeemScriptType( multisig = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[1, 0],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[1, 0]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
multisig2 = proto.MultisigRedeemScriptType( multisig2 = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[1, 1],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[1, 1]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
@ -743,26 +719,14 @@ class TestMsgSigntxSegwitNative(TrezorTest):
for index in range(1, 4) for index in range(1, 4)
] ]
multisig = proto.MultisigRedeemScriptType( multisig = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[1, 1],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[1, 1]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
multisig2 = proto.MultisigRedeemScriptType( multisig2 = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[1, 2],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[1, 2]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )

View File

@ -40,14 +40,8 @@ class TestMultisig(TrezorTest):
] ]
multisig = proto.MultisigRedeemScriptType( multisig = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[0, 0],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[0, 0]
),
nodes,
)
),
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
@ -131,14 +125,8 @@ class TestMultisig(TrezorTest):
# Let's do second signature using 3rd key # Let's do second signature using 3rd key
multisig = proto.MultisigRedeemScriptType( multisig = proto.MultisigRedeemScriptType(
pubkeys=list( nodes=[deserialize(n.xpub) for n in nodes],
map( address_n=[0, 0],
lambda n: proto.HDNodePathType(
node=deserialize(n.xpub), address_n=[0, 0]
),
nodes,
)
),
signatures=[ signatures=[
signatures1[0], signatures1[0],
b"", b"",

View File

@ -69,31 +69,22 @@ class TestMultisigChange(TrezorTest):
# input 1: 0.001 BTC # input 1: 0.001 BTC
multisig_in1 = proto.MultisigRedeemScriptType( multisig_in1 = proto.MultisigRedeemScriptType(
pubkeys=[ nodes=[node_ext2, node_ext1, node_int],
proto.HDNodePathType(node=node_ext2, address_n=[0, 0]), address_n=[0, 0],
proto.HDNodePathType(node=node_ext1, address_n=[0, 0]),
proto.HDNodePathType(node=node_int, address_n=[0, 0]),
],
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
multisig_in2 = proto.MultisigRedeemScriptType( multisig_in2 = proto.MultisigRedeemScriptType(
pubkeys=[ nodes=[node_ext1, node_ext2, node_int],
proto.HDNodePathType(node=node_ext1, address_n=[0, 1]), address_n=[0, 1],
proto.HDNodePathType(node=node_ext2, address_n=[0, 1]),
proto.HDNodePathType(node=node_int, address_n=[0, 1]),
],
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
multisig_in3 = proto.MultisigRedeemScriptType( multisig_in3 = proto.MultisigRedeemScriptType(
pubkeys=[ nodes=[node_ext1, node_ext3, node_int],
proto.HDNodePathType(node=node_ext1, address_n=[0, 1]), address_n=[0, 1],
proto.HDNodePathType(node=node_ext3, address_n=[0, 1]),
proto.HDNodePathType(node=node_int, address_n=[0, 1]),
],
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
@ -395,11 +386,8 @@ class TestMultisigChange(TrezorTest):
self.setup_mnemonic_nopin_nopassphrase() self.setup_mnemonic_nopin_nopassphrase()
multisig_out1 = proto.MultisigRedeemScriptType( multisig_out1 = proto.MultisigRedeemScriptType(
pubkeys=[ nodes=[self.node_ext2, self.node_ext1, self.node_int],
proto.HDNodePathType(node=self.node_ext2, address_n=[1, 0]), address_n=[1, 0],
proto.HDNodePathType(node=self.node_ext1, address_n=[1, 0]),
proto.HDNodePathType(node=self.node_int, address_n=[1, 0]),
],
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
@ -439,11 +427,8 @@ class TestMultisigChange(TrezorTest):
self.setup_mnemonic_nopin_nopassphrase() self.setup_mnemonic_nopin_nopassphrase()
multisig_out2 = proto.MultisigRedeemScriptType( multisig_out2 = proto.MultisigRedeemScriptType(
pubkeys=[ nodes=[self.node_ext1, self.node_ext2, self.node_int],
proto.HDNodePathType(node=self.node_ext1, address_n=[1, 1]), address_n=[1, 1],
proto.HDNodePathType(node=self.node_ext2, address_n=[1, 1]),
proto.HDNodePathType(node=self.node_int, address_n=[1, 1]),
],
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
@ -483,11 +468,8 @@ class TestMultisigChange(TrezorTest):
self.setup_mnemonic_nopin_nopassphrase() self.setup_mnemonic_nopin_nopassphrase()
multisig_out2 = proto.MultisigRedeemScriptType( multisig_out2 = proto.MultisigRedeemScriptType(
pubkeys=[ nodes=[self.node_ext1, self.node_int, self.node_ext3],
proto.HDNodePathType(node=self.node_ext1, address_n=[1, 0]), address_n=[1, 0],
proto.HDNodePathType(node=self.node_int, address_n=[1, 0]),
proto.HDNodePathType(node=self.node_ext3, address_n=[1, 0]),
],
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )
@ -525,11 +507,8 @@ class TestMultisigChange(TrezorTest):
self.setup_mnemonic_nopin_nopassphrase() self.setup_mnemonic_nopin_nopassphrase()
multisig_out1 = proto.MultisigRedeemScriptType( multisig_out1 = proto.MultisigRedeemScriptType(
pubkeys=[ nodes=[self.node_ext2, self.node_ext1, self.node_int],
proto.HDNodePathType(node=self.node_ext2, address_n=[1, 0]), address_n=[1, 0],
proto.HDNodePathType(node=self.node_ext1, address_n=[1, 0]),
proto.HDNodePathType(node=self.node_int, address_n=[1, 0]),
],
signatures=[b"", b"", b""], signatures=[b"", b"", b""],
m=2, m=2,
) )

@ -1 +1 @@
Subproject commit 4b41d2e63841517bf701618434c018acf4f1bca2 Subproject commit 0735c7d6f524b4c5108d201c789612aad7ce7920