2024-01-26 11:16:55 +00:00
|
|
|
from common import * # isort:skip
|
2016-04-13 18:41:33 +00:00
|
|
|
|
2016-04-15 19:13:27 +00:00
|
|
|
from trezor.crypto import hashlib
|
2016-04-13 18:41:33 +00:00
|
|
|
|
2017-12-16 01:11:26 +00:00
|
|
|
|
2016-04-13 18:41:33 +00:00
|
|
|
class TestCryptoRipemd160(unittest.TestCase):
|
|
|
|
|
|
|
|
# vectors from http://homes.esat.kuleuven.be/~bosselae/ripemd160.html
|
2017-12-16 00:24:40 +00:00
|
|
|
vectors = [
|
2023-06-28 10:46:29 +00:00
|
|
|
(b"", "9c1185a5c5e9fc54612808977ee8f548b2258d31"),
|
|
|
|
(b"a", "0bdc9d2d256b3ee9daae347be6f4dc835a467ffe"),
|
|
|
|
(b"abc", "8eb208f7e05d987a9b044a8e98c6b087f15a0bfc"),
|
|
|
|
(b"message digest", "5d0689ef49d2fae572b881b123a85ffa21595f36"),
|
|
|
|
(b"abcdefghijklmnopqrstuvwxyz", "f71c27109c692c1b56bbdceb5b9d2865b3708dbc"),
|
|
|
|
(
|
|
|
|
b"abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq",
|
|
|
|
"12a053384a9c0c88e405a06c27dcf49ada62eb2b",
|
|
|
|
),
|
|
|
|
(
|
|
|
|
b"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",
|
|
|
|
"b0e20b6e3116640286ed3a87a5713079b21f5189",
|
|
|
|
),
|
|
|
|
(
|
|
|
|
b"12345678901234567890123456789012345678901234567890123456789012345678901234567890",
|
|
|
|
"9b752e45573d4b39f4dbd3323cab82bf63326bfb",
|
|
|
|
),
|
2017-12-16 00:24:40 +00:00
|
|
|
]
|
2016-04-13 18:41:33 +00:00
|
|
|
|
|
|
|
def test_digest(self):
|
2017-12-16 00:24:40 +00:00
|
|
|
for b, d in self.vectors:
|
|
|
|
self.assertEqual(hashlib.ripemd160(b).digest(), unhexlify(d))
|
2016-04-13 18:41:33 +00:00
|
|
|
|
2016-04-14 09:08:38 +00:00
|
|
|
def test_update(self):
|
2017-12-16 00:24:40 +00:00
|
|
|
for b, d in self.vectors:
|
|
|
|
x = hashlib.ripemd160()
|
|
|
|
x.update(b)
|
|
|
|
self.assertEqual(x.digest(), unhexlify(d))
|
2016-04-14 09:08:38 +00:00
|
|
|
|
2016-04-15 19:13:27 +00:00
|
|
|
x = hashlib.ripemd160()
|
2016-04-14 09:08:38 +00:00
|
|
|
for i in range(8):
|
2023-06-28 10:46:29 +00:00
|
|
|
x.update(b"1234567890")
|
|
|
|
self.assertEqual(
|
|
|
|
x.digest(), unhexlify("9b752e45573d4b39f4dbd3323cab82bf63326bfb")
|
|
|
|
)
|
2016-04-14 09:08:38 +00:00
|
|
|
|
2016-04-14 09:17:18 +00:00
|
|
|
def test_digest_multi(self):
|
2016-04-15 19:13:27 +00:00
|
|
|
x = hashlib.ripemd160()
|
2016-04-14 09:17:18 +00:00
|
|
|
d0 = x.digest()
|
|
|
|
d1 = x.digest()
|
|
|
|
d2 = x.digest()
|
|
|
|
self.assertEqual(d0, d1)
|
|
|
|
self.assertEqual(d0, d2)
|
|
|
|
|
2017-12-16 01:11:26 +00:00
|
|
|
|
2023-06-28 10:46:29 +00:00
|
|
|
if __name__ == "__main__":
|
2016-04-13 18:41:33 +00:00
|
|
|
unittest.main()
|