summaryrefslogtreecommitdiff
blob: 521148b33edbd3421f093fb7d9f0556dfbc25617 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
import unittest

import whirlpool

from binascii import b2a_hex


results = {
    'empty'     : '19fa61d75522a4669b44e39c1d2e1726c530232130d407f89afee0964997f7a73e83be698b288febcf88e3e03c4f0757ea8964e59b63d93708b138cc42a66eb3',
    'tqbfjotld' : 'b97de512e91e3828b40d2b0fdce9ceb3c4a71f9bea8d88e75c4fa854df36725fd2b52eb6544edcacd6f8beddfea403cb55ae31f03ad62a5ef54e42ee82c3fb35',
    'tqbfjotle' : 'c27ba124205f72e6847f3e19834f925cc666d0974167af915bb462420ed40cc50900d85a1f923219d832357750492d5c143011a76988344c2635e69d06f2d38c',
    'tqbf'      : '317edc3c5172ea5987902aa9c4f1defedf4d5aa59209bdf7574cc6da0039852c24b8da70ecb07997ff83e86d32d2851215d3dcbd6bb9736bdef21c349d483e6d',
}


class TestWhirlpool(unittest.TestCase):

    def test_hash_empty(self):
        self.assertEqual(b2a_hex(whirlpool.hash('')), results['empty'])
    
    def test_hash_fox(self):
        self.assertEqual(
            b2a_hex(whirlpool.hash('The quick brown fox jumps over the lazy dog')),
            results['tqbfjotld'])
        self.assertEqual(
            b2a_hex(whirlpool.hash('The quick brown fox jumps over the lazy eog')),
            results['tqbfjotle'])

    def test_new_empty(self):
        wp = whirlpool.new()
        self.assertEqual(b2a_hex(wp.digest()), results['empty'])
        self.assertEqual(wp.hexdigest(), results['empty'])

    def test_new_fox(self):
        wp1 = whirlpool.new('The quick brown fox jumps over the lazy dog')
        self.assertEqual(b2a_hex(wp1.digest()), results['tqbfjotld'])
        self.assertEqual(wp1.hexdigest(), results['tqbfjotld'])

        wp2 = whirlpool.new('The quick brown fox jumps over the lazy eog')
        self.assertEqual(b2a_hex(wp2.digest()), results['tqbfjotle'])
        self.assertEqual(wp2.hexdigest(), results['tqbfjotle'])

    def test_update_copy(self):
        wp1 = whirlpool.new()
        wp2 = wp1.copy()
        wp1.update('The quick brown fox')
        wp3 = wp1.copy()

        self.assertEqual(b2a_hex(wp1.digest()), results['tqbf'])
        self.assertEqual(wp1.hexdigest(), results['tqbf'])

        self.assertEqual(b2a_hex(wp2.digest()), results['empty'])
        self.assertEqual(wp2.hexdigest(), results['empty'])

        self.assertEqual(b2a_hex(wp3.digest()), results['tqbf'])
        self.assertEqual(wp3.hexdigest(), results['tqbf'])

        wp1.update(' jumps over the lazy dog')

        self.assertEqual(b2a_hex(wp1.digest()), results['tqbfjotld'])
        self.assertEqual(wp1.hexdigest(), results['tqbfjotld'])

        self.assertEqual(b2a_hex(wp2.digest()), results['empty'])
        self.assertEqual(wp2.hexdigest(), results['empty'])

        self.assertEqual(b2a_hex(wp3.digest()), results['tqbf'])
        self.assertEqual(wp3.hexdigest(), results['tqbf'])

        wp3.update(' jumps over the lazy eog')

        self.assertEqual(b2a_hex(wp1.digest()), results['tqbfjotld'])
        self.assertEqual(wp1.hexdigest(), results['tqbfjotld'])

        self.assertEqual(b2a_hex(wp2.digest()), results['empty'])
        self.assertEqual(wp2.hexdigest(), results['empty'])

        self.assertEqual(b2a_hex(wp3.digest()), results['tqbfjotle'])
        self.assertEqual(wp3.hexdigest(), results['tqbfjotle'])

    def test_digest_size(self):
        wp = whirlpool.new()
        self.assertEqual(wp.digest_size, 64)
        with self.assertRaisesRegexp(AttributeError,
                                     'digest_size.*not writable'):
            wp.digest_size = 32
    
    def test_block_size(self):
        wp = whirlpool.new()
        self.assertEqual(wp.block_size, 64)
        with self.assertRaisesRegexp(AttributeError,
                                     'block_size.*not writable'):
            wp.block_size = 32


if __name__ == '__main__':
    unittest.main()