mirror of
https://github.com/trezor/trezor-firmware.git
synced 2024-12-28 09:08:07 +00:00
9fc5bb546b
Changes many fields to required -- as far as we were able to figure out, signing would fail if these fields aren't provided anyway, so this should not pose a compatibility problem. Co-authored-by: matejcik <ja@matejcik.cz>
179 lines
5.4 KiB
Python
179 lines
5.4 KiB
Python
from common import *
|
|
from trezor.crypto import hashlib
|
|
|
|
if not utils.BITCOIN_ONLY:
|
|
from trezor.messages import NEMAggregateModification
|
|
from trezor.messages import NEMCosignatoryModification
|
|
from trezor.messages import NEMSignTx
|
|
from trezor.messages import NEMTransactionCommon
|
|
from apps.nem.helpers import *
|
|
from apps.nem.multisig import *
|
|
from apps.nem.multisig.serialize import *
|
|
|
|
|
|
@unittest.skipUnless(not utils.BITCOIN_ONLY, "altcoin")
|
|
class TestNemMultisigAggregateModification(unittest.TestCase):
|
|
def test_nem_transaction_aggregate_modification(self):
|
|
# http://bob.nem.ninja:8765/#/aggregate/6a55471b17159e5b6cd579c421e95a4e39d92e3f78b0a55ee337e785a601d3a2
|
|
m = _create_msg(NEM_NETWORK_TESTNET, 0, 22000000, 0, 2, 0)
|
|
t = serialize_aggregate_modification(
|
|
m.transaction,
|
|
m.aggregate_modification,
|
|
unhexlify(
|
|
"462ee976890916e54fa825d26bdd0235f5eb5b6a143c199ab0ae5ee9328e08ce"
|
|
),
|
|
)
|
|
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"994793ba1c789fa9bdea918afc9b06e2d0309beb1081ac5b6952991e4defd324"
|
|
),
|
|
)
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"c54d6e33ed1446eedd7f7a80a588dd01857f723687a09200c1917d5524752f8b"
|
|
),
|
|
)
|
|
|
|
self.assertEqual(
|
|
hashlib.sha3_256(t, keccak=True).digest(),
|
|
unhexlify(
|
|
"6a55471b17159e5b6cd579c421e95a4e39d92e3f78b0a55ee337e785a601d3a2"
|
|
),
|
|
)
|
|
|
|
# http://chain.nem.ninja/#/aggregate/cc64ca69bfa95db2ff7ac1e21fe6d27ece189c603200ebc9778d8bb80ca25c3c
|
|
m = _create_msg(NEM_NETWORK_MAINNET, 0, 40000000, 0, 5, 0)
|
|
t = serialize_aggregate_modification(
|
|
m.transaction,
|
|
m.aggregate_modification,
|
|
unhexlify(
|
|
"f41b99320549741c5cce42d9e4bb836d98c50ed5415d0c3c2912d1bb50e6a0e5"
|
|
),
|
|
)
|
|
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"1fbdbdde28daf828245e4533765726f0b7790e0b7146e2ce205df3e86366980b"
|
|
),
|
|
)
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"f94e8702eb1943b23570b1b83be1b81536df35538978820e98bfce8f999e2d37"
|
|
),
|
|
)
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"826cedee421ff66e708858c17815fcd831a4bb68e3d8956299334e9e24380ba8"
|
|
),
|
|
)
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"719862cd7d0f4e875a6a0274c9a1738f38f40ad9944179006a54c34724c1274d"
|
|
),
|
|
)
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"43aa69177018fc3e2bdbeb259c81cddf24be50eef9c5386db51d82386c41475a"
|
|
),
|
|
)
|
|
|
|
self.assertEqual(
|
|
hashlib.sha3_256(t, keccak=True).digest(),
|
|
unhexlify(
|
|
"cc64ca69bfa95db2ff7ac1e21fe6d27ece189c603200ebc9778d8bb80ca25c3c"
|
|
),
|
|
)
|
|
|
|
def test_nem_transaction_aggregate_modification_relative_change(self):
|
|
# http://bob.nem.ninja:8765/#/aggregate/1fbdae5ba753e68af270930413ae90f671eb8ab58988116684bac0abd5726584
|
|
m = _create_msg(NEM_NETWORK_TESTNET, 6542254, 40000000, 6545854, 4, 2)
|
|
t = serialize_aggregate_modification(
|
|
m.transaction,
|
|
m.aggregate_modification,
|
|
unhexlify(
|
|
"6bf7849c1eec6a2002995cc457dc00c4e29bad5c88de63f51e42dfdcd7b2131d"
|
|
),
|
|
)
|
|
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"5f53d076c8c3ec3110b98364bc423092c3ec2be2b1b3c40fd8ab68d54fa39295"
|
|
),
|
|
)
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"9eb199c2b4d406f64cb7aa5b2b0815264b56ba8fe44d558a6cb423a31a33c4c2"
|
|
),
|
|
)
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"94b2323dab23a3faba24fa6ddda0ece4fbb06acfedd74e76ad9fae38d006882b"
|
|
),
|
|
)
|
|
write_cosignatory_modification(
|
|
t,
|
|
1,
|
|
unhexlify(
|
|
"d88c6ee2a2cd3929d0d76b6b14ecb549d21296ab196a2b3a4cb2536bcce32e87"
|
|
),
|
|
)
|
|
write_minimum_cosignatories(t, 2)
|
|
|
|
self.assertEqual(
|
|
hashlib.sha3_256(t, keccak=True).digest(),
|
|
unhexlify(
|
|
"1fbdae5ba753e68af270930413ae90f671eb8ab58988116684bac0abd5726584"
|
|
),
|
|
)
|
|
|
|
|
|
def _create_msg(
|
|
network: int,
|
|
timestamp: int,
|
|
fee: int,
|
|
deadline: int,
|
|
modifications: int,
|
|
relative_change: int,
|
|
):
|
|
transaction = NEMTransactionCommon(
|
|
network=network,
|
|
timestamp=timestamp,
|
|
fee=fee,
|
|
deadline=deadline,
|
|
)
|
|
|
|
aggregate_modification = NEMAggregateModification(
|
|
modifications=[NEMCosignatoryModification(type=5, public_key=b"abc") for _ in range(modifications)],
|
|
relative_change=relative_change
|
|
)
|
|
|
|
return NEMSignTx(
|
|
transaction=transaction,
|
|
aggregate_modification=aggregate_modification,
|
|
)
|
|
|
|
|
|
if __name__ == "__main__":
|
|
unittest.main()
|