diff options
| author | Christian Heimes <christian@cheimes.de> | 2013-10-19 14:12:02 +0200 | 
|---|---|---|
| committer | Christian Heimes <christian@cheimes.de> | 2013-10-19 14:12:02 +0200 | 
| commit | 3626a505dbffc5539888bfdb596dc20560f0d2a1 (patch) | |
| tree | bc612b09b26216a1db2a248490887b4b7a191574 /Lib/test/test_hashlib.py | |
| parent | a412f763b36250cc8c9c521a7c9a7e3a2a3ba58c (diff) | |
| download | cpython-git-3626a505dbffc5539888bfdb596dc20560f0d2a1.tar.gz | |
Issue #19254: Provide an optimized Python implementation of PBKDF2_HMAC
Diffstat (limited to 'Lib/test/test_hashlib.py')
| -rw-r--r-- | Lib/test/test_hashlib.py | 20 | 
1 files changed, 16 insertions, 4 deletions
| diff --git a/Lib/test/test_hashlib.py b/Lib/test/test_hashlib.py index 3eadee1cc7..18fe4b50de 100644 --- a/Lib/test/test_hashlib.py +++ b/Lib/test/test_hashlib.py @@ -18,11 +18,13 @@ except ImportError:  import unittest  import warnings  from test import support -from test.support import _4G, bigmemtest +from test.support import _4G, bigmemtest, import_fresh_module  # Were we compiled --with-pydebug or with #define Py_DEBUG?  COMPILED_WITH_PYDEBUG = hasattr(sys, 'gettotalrefcount') +c_hashlib = import_fresh_module('hashlib', fresh=['_hashlib']) +py_hashlib = import_fresh_module('hashlib', blocked=['_hashlib'])  def hexstr(s):      assert isinstance(s, bytes), repr(s) @@ -545,6 +547,10 @@ class HashLibTestCase(unittest.TestCase):          self.assertEqual(expected_hash, hasher.hexdigest()) + +class KDFTests: +    hashlibmod = None +      pbkdf2_test_vectors = [          (b'password', b'salt', 1, None),          (b'password', b'salt', 2, None), @@ -594,10 +600,8 @@ class HashLibTestCase(unittest.TestCase):              (bytes.fromhex('9d9e9c4cd21fe4be24d5b8244c759665'), None),],      } -    @unittest.skipUnless(hasattr(hashlib, 'pbkdf2_hmac'), -                         'pbkdf2_hmac required for this test.')      def test_pbkdf2_hmac(self): -        pbkdf2 = hashlib.pbkdf2_hmac +        pbkdf2 = self.hashlibmod.pbkdf2_hmac          for digest_name, results in self.pbkdf2_results.items():              for i, vector in enumerate(self.pbkdf2_test_vectors): @@ -628,5 +632,13 @@ class HashLibTestCase(unittest.TestCase):              pbkdf2('unknown', b'pass', b'salt', 1) +class PyKDFTests(KDFTests, unittest.TestCase): +    hashlibmod = py_hashlib + + +class CKDFTests(KDFTests, unittest.TestCase): +    hashlibmod = c_hashlib + +  if __name__ == "__main__":      unittest.main() | 
