| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | # -*- coding: utf-8 -*- | 
					
						
							|  |  |  | # | 
					
						
							|  |  |  | #  SelfTest/Hash/common.py: Common code for Crypto.SelfTest.Hash | 
					
						
							|  |  |  | # | 
					
						
							| 
									
										
										
										
											2009-02-28 13:24:04 -05:00
										 |  |  | # Written in 2008 by Dwayne C. Litzenberger <dlitz@dlitz.net> | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | # | 
					
						
							| 
									
										
										
										
											2009-02-28 13:24:04 -05:00
										 |  |  | # =================================================================== | 
					
						
							|  |  |  | # The contents of this file are dedicated to the public domain.  To | 
					
						
							|  |  |  | # the extent that dedication to the public domain is not available, | 
					
						
							|  |  |  | # everyone is granted a worldwide, perpetual, royalty-free, | 
					
						
							|  |  |  | # non-exclusive license to exercise all rights associated with the | 
					
						
							|  |  |  | # contents of this file for any purpose whatsoever. | 
					
						
							|  |  |  | # No rights are reserved. | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | # | 
					
						
							| 
									
										
										
										
											2009-02-28 13:24:04 -05:00
										 |  |  | # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | 
					
						
							|  |  |  | # EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | 
					
						
							|  |  |  | # MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | 
					
						
							|  |  |  | # NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS | 
					
						
							|  |  |  | # BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN | 
					
						
							|  |  |  | # ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN | 
					
						
							|  |  |  | # CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | 
					
						
							|  |  |  | # SOFTWARE. | 
					
						
							|  |  |  | # =================================================================== | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | """Self-testing for PyCrypto hash modules""" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | __revision__ = "$Id$" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-14 15:20:19 -04:00
										 |  |  | import sys | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | import unittest | 
					
						
							|  |  |  | import binascii | 
					
						
							| 
									
										
										
										
											2010-12-28 16:26:52 -05:00
										 |  |  | from Crypto.Util.py3compat import * | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-14 15:20:19 -04:00
										 |  |  | # For compatibility with Python 2.1 and Python 2.2 | 
					
						
							|  |  |  | if sys.hexversion < 0x02030000: | 
					
						
							|  |  |  |     # Python 2.1 doesn't have a dict() function | 
					
						
							|  |  |  |     # Python 2.2 dict() function raises TypeError if you do dict(MD5='blah') | 
					
						
							|  |  |  |     def dict(**kwargs): | 
					
						
							|  |  |  |         return kwargs.copy() | 
					
						
							|  |  |  | else: | 
					
						
							|  |  |  |     dict = __builtins__['dict'] | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | class HashSelfTest(unittest.TestCase): | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def __init__(self, hashmod, description, expected, input): | 
					
						
							|  |  |  |         unittest.TestCase.__init__(self) | 
					
						
							|  |  |  |         self.hashmod = hashmod | 
					
						
							|  |  |  |         self.expected = expected | 
					
						
							|  |  |  |         self.input = input | 
					
						
							|  |  |  |         self.description = description | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def shortDescription(self): | 
					
						
							|  |  |  |         return self.description | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def runTest(self): | 
					
						
							|  |  |  |         h = self.hashmod.new() | 
					
						
							|  |  |  |         h.update(self.input) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         out1 = binascii.b2a_hex(h.digest()) | 
					
						
							|  |  |  |         out2 = h.hexdigest() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         h = self.hashmod.new(self.input) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         out3 = h.hexdigest() | 
					
						
							|  |  |  |         out4 = binascii.b2a_hex(h.digest()) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-28 16:26:52 -05:00
										 |  |  |         # PY3K: hexdigest() should return str(), and digest() bytes  | 
					
						
							| 
									
										
										
										
											2008-11-23 16:37:17 -05:00
										 |  |  |         self.assertEqual(self.expected, out1)   # h = .new(); h.update(data); h.digest() | 
					
						
							| 
									
										
										
										
											2010-12-28 16:26:52 -05:00
										 |  |  |         if sys.version_info[0] is 2: | 
					
						
							|  |  |  |             self.assertEqual(self.expected, out2)   # h = .new(); h.update(data); h.hexdigest() | 
					
						
							|  |  |  |             self.assertEqual(self.expected, out3)   # h = .new(data); h.hexdigest() | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             self.assertEqual(self.expected.decode(), out2)   # h = .new(); h.update(data); h.hexdigest() | 
					
						
							|  |  |  |             self.assertEqual(self.expected.decode(), out3)   # h = .new(data); h.hexdigest() | 
					
						
							| 
									
										
										
										
											2008-11-23 16:37:17 -05:00
										 |  |  |         self.assertEqual(self.expected, out4)   # h = .new(data); h.digest() | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-14 14:40:24 -04:00
										 |  |  | class MACSelfTest(unittest.TestCase): | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def __init__(self, hashmod, description, expected_dict, input, key, hashmods): | 
					
						
							|  |  |  |         unittest.TestCase.__init__(self) | 
					
						
							|  |  |  |         self.hashmod = hashmod | 
					
						
							|  |  |  |         self.expected_dict = expected_dict | 
					
						
							|  |  |  |         self.input = input | 
					
						
							|  |  |  |         self.key = key | 
					
						
							|  |  |  |         self.hashmods = hashmods | 
					
						
							|  |  |  |         self.description = description | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def shortDescription(self): | 
					
						
							|  |  |  |         return self.description | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def runTest(self): | 
					
						
							|  |  |  |         for hashname in self.expected_dict.keys(): | 
					
						
							|  |  |  |             hashmod = self.hashmods[hashname] | 
					
						
							|  |  |  |             key = binascii.a2b_hex(self.key) | 
					
						
							|  |  |  |             data = binascii.a2b_hex(self.input) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             # Strip whitespace from the expected string (which should be in lowercase-hex) | 
					
						
							| 
									
										
										
										
											2010-12-28 16:26:52 -05:00
										 |  |  |             expected = b("").join(self.expected_dict[hashname].split()) | 
					
						
							| 
									
										
										
										
											2008-09-14 14:40:24 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |             h = self.hashmod.new(key, digestmod=hashmod) | 
					
						
							|  |  |  |             h.update(data) | 
					
						
							|  |  |  |             out1 = binascii.b2a_hex(h.digest()) | 
					
						
							|  |  |  |             out2 = h.hexdigest() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             h = self.hashmod.new(key, data, hashmod) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             out3 = h.hexdigest() | 
					
						
							|  |  |  |             out4 = binascii.b2a_hex(h.digest()) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-20 12:03:37 -04:00
										 |  |  |             # Test .copy() | 
					
						
							|  |  |  |             h2 = h.copy() | 
					
						
							| 
									
										
										
										
											2010-12-28 16:26:52 -05:00
										 |  |  |             h.update(b("blah blah blah"))  # Corrupt the original hash object | 
					
						
							| 
									
										
										
										
											2008-09-20 12:03:37 -04:00
										 |  |  |             out5 = binascii.b2a_hex(h2.digest())    # The copied hash object should return the correct result | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-28 16:26:52 -05:00
										 |  |  |             # PY3K: hexdigest() should return str(), and digest() bytes  | 
					
						
							| 
									
										
										
										
											2008-09-14 14:40:24 -04:00
										 |  |  |             self.assertEqual(expected, out1) | 
					
						
							| 
									
										
										
										
											2010-12-28 16:26:52 -05:00
										 |  |  |             if sys.version_info[0] is 2: | 
					
						
							|  |  |  |                 self.assertEqual(expected, out2) | 
					
						
							|  |  |  |                 self.assertEqual(expected, out3) | 
					
						
							|  |  |  |             else: | 
					
						
							|  |  |  |                 self.assertEqual(expected.decode(), out2) | 
					
						
							|  |  |  |                 self.assertEqual(expected.decode(), out3)                 | 
					
						
							| 
									
										
										
										
											2008-09-14 14:40:24 -04:00
										 |  |  |             self.assertEqual(expected, out4) | 
					
						
							| 
									
										
										
										
											2008-09-20 12:03:37 -04:00
										 |  |  |             self.assertEqual(expected, out5) | 
					
						
							| 
									
										
										
										
											2008-09-14 14:40:24 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-17 13:12:24 -04:00
										 |  |  | def make_hash_tests(module, module_name, test_data): | 
					
						
							|  |  |  |     tests = [] | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  |     for i in range(len(test_data)): | 
					
						
							|  |  |  |         row = test_data[i] | 
					
						
							|  |  |  |         if len(row) < 3: | 
					
						
							|  |  |  |             (expected, input) = row | 
					
						
							|  |  |  |             description = repr(input) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             (expected, input, description) = row | 
					
						
							|  |  |  |         name = "%s #%d: %s" % (module_name, i+1, description) | 
					
						
							| 
									
										
										
										
											2008-09-17 13:12:24 -04:00
										 |  |  |         tests.append(HashSelfTest(module, name, expected, input)) | 
					
						
							|  |  |  |     return tests | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-17 13:12:24 -04:00
										 |  |  | def make_mac_tests(module, module_name, test_data, hashmods): | 
					
						
							|  |  |  |     tests = [] | 
					
						
							| 
									
										
										
										
											2008-09-14 14:40:24 -04:00
										 |  |  |     for i in range(len(test_data)): | 
					
						
							|  |  |  |         row = test_data[i] | 
					
						
							|  |  |  |         (key, data, results, description) = row | 
					
						
							|  |  |  |         name = "%s #%d: %s" % (module_name, i+1, description) | 
					
						
							| 
									
										
										
										
											2008-09-17 13:12:24 -04:00
										 |  |  |         tests.append(MACSelfTest(module, name, results, data, key, hashmods)) | 
					
						
							|  |  |  |     return tests | 
					
						
							| 
									
										
										
										
											2008-09-14 14:40:24 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-09-12 15:26:24 -04:00
										 |  |  | # vim:set ts=4 sw=4 sts=4 expandtab: |