mirror of
https://github.com/python/cpython.git
synced 2025-08-03 08:34:29 +00:00
Merged revisions 66496 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r66496 | benjamin.peterson | 2008-09-17 20:22:16 -0500 (Wed, 17 Sep 2008) | 1 line fix possible integer overflows in _hashopenssl #3886 ........
This commit is contained in:
parent
1308c26cf4
commit
78cb491de3
2 changed files with 59 additions and 15 deletions
|
@ -9,7 +9,7 @@
|
|||
import hashlib
|
||||
import unittest
|
||||
from test import support
|
||||
|
||||
from test.support import _4G, precisionbigmemtest
|
||||
|
||||
def hexstr(s):
|
||||
assert isinstance(s, bytes), repr(s)
|
||||
|
@ -55,7 +55,6 @@ class HashLibTestCase(unittest.TestCase):
|
|||
m2.update(aas + bees + cees)
|
||||
self.assertEqual(m1.digest(), m2.digest())
|
||||
|
||||
|
||||
def check(self, name, data, digest):
|
||||
# test the direct constructors
|
||||
computed = getattr(hashlib, name)(data).hexdigest()
|
||||
|
@ -76,6 +75,21 @@ class HashLibTestCase(unittest.TestCase):
|
|||
b'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789',
|
||||
'd174ab98d277d9f5a5611c2c9f419d9f')
|
||||
|
||||
@precisionbigmemtest(size=_4G + 5, memuse=1)
|
||||
def test_case_md5_huge(self, size):
|
||||
if size == _4G + 5:
|
||||
try:
|
||||
self.check('md5', 'A'*size, 'c9af2dff37468ce5dfee8f2cfc0a9c6d')
|
||||
except OverflowError:
|
||||
pass # 32-bit arch
|
||||
|
||||
@precisionbigmemtest(size=_4G - 1, memuse=1)
|
||||
def test_case_md5_uintmax(self, size):
|
||||
if size == _4G - 1:
|
||||
try:
|
||||
self.check('md5', 'A'*size, '28138d306ff1b8281f1a9067e1a1a2b3')
|
||||
except OverflowError:
|
||||
pass # 32-bit arch
|
||||
|
||||
# use the three examples from Federal Information Processing Standards
|
||||
# Publication 180-1, Secure Hash Standard, 1995 April 17
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue