Merge "Fixes hashing issues for py3.5"
This commit is contained in:
commit
3483102350
@ -281,8 +281,13 @@ def hash_file(file_like_object, hash_algo='md5'):
|
|||||||
:returns: a condensed digest of the bytes of contents.
|
:returns: a condensed digest of the bytes of contents.
|
||||||
"""
|
"""
|
||||||
checksum = _get_hash_object(hash_algo)
|
checksum = _get_hash_object(hash_algo)
|
||||||
for chunk in iter(lambda: file_like_object.read(32768), b''):
|
while True:
|
||||||
checksum.update(chunk)
|
chunk = file_like_object.read(32768)
|
||||||
|
if not chunk:
|
||||||
|
break
|
||||||
|
encoded_chunk = (chunk.encode(encoding='utf-8')
|
||||||
|
if isinstance(chunk, six.string_types) else chunk)
|
||||||
|
checksum.update(encoded_chunk)
|
||||||
return checksum.hexdigest()
|
return checksum.hexdigest()
|
||||||
|
|
||||||
|
|
||||||
@ -298,7 +303,9 @@ def file_has_content(path, content, hash_algo='md5'):
|
|||||||
with open(path, 'rb') as existing:
|
with open(path, 'rb') as existing:
|
||||||
file_hash_hex = hash_file(existing, hash_algo=hash_algo)
|
file_hash_hex = hash_file(existing, hash_algo=hash_algo)
|
||||||
ref_hash = _get_hash_object(hash_algo)
|
ref_hash = _get_hash_object(hash_algo)
|
||||||
ref_hash.update(content)
|
encoded_content = (content.encode(encoding='utf-8')
|
||||||
|
if isinstance(content, six.string_types) else content)
|
||||||
|
ref_hash.update(encoded_content)
|
||||||
return file_hash_hex == ref_hash.hexdigest()
|
return file_hash_hex == ref_hash.hexdigest()
|
||||||
|
|
||||||
|
|
||||||
|
@ -127,6 +127,16 @@ class GenericUtilsTestCase(base.TestCase):
|
|||||||
# | THEN |
|
# | THEN |
|
||||||
self.assertEqual(expected, actual)
|
self.assertEqual(expected, actual)
|
||||||
|
|
||||||
|
def test_hash_file_for_md5_not_binary(self):
|
||||||
|
# | GIVEN |
|
||||||
|
data = u'Mary had a little lamb, its fleece as white as sno\u0449'
|
||||||
|
file_like_object = six.StringIO(data)
|
||||||
|
expected = hashlib.md5(data.encode('utf-8')).hexdigest()
|
||||||
|
# | WHEN |
|
||||||
|
actual = utils.hash_file(file_like_object) # using default, 'md5'
|
||||||
|
# | THEN |
|
||||||
|
self.assertEqual(expected, actual)
|
||||||
|
|
||||||
def test_hash_file_for_sha1(self):
|
def test_hash_file_for_sha1(self):
|
||||||
# | GIVEN |
|
# | GIVEN |
|
||||||
data = b'Mary had a little lamb, its fleece as white as snow'
|
data = b'Mary had a little lamb, its fleece as white as snow'
|
||||||
@ -163,6 +173,14 @@ class GenericUtilsTestCase(base.TestCase):
|
|||||||
self.assertTrue(utils.file_has_content('foo', ref))
|
self.assertTrue(utils.file_has_content('foo', ref))
|
||||||
mopen.assert_called_once_with('foo', 'rb')
|
mopen.assert_called_once_with('foo', 'rb')
|
||||||
|
|
||||||
|
def test_file_has_content_equal_not_binary(self):
|
||||||
|
data = u'Mary had a little lamb, its fleece as white as sno\u0449'
|
||||||
|
ref = data
|
||||||
|
with mock.patch('ironic.common.utils.open',
|
||||||
|
mock.mock_open(read_data=data)) as mopen:
|
||||||
|
self.assertTrue(utils.file_has_content('foo', ref))
|
||||||
|
mopen.assert_called_once_with('foo', 'rb')
|
||||||
|
|
||||||
def test_file_has_content_differ(self):
|
def test_file_has_content_differ(self):
|
||||||
data = b'Mary had a little lamb, its fleece as white as snow'
|
data = b'Mary had a little lamb, its fleece as white as snow'
|
||||||
ref = data + b'!'
|
ref = data + b'!'
|
||||||
|
Loading…
Reference in New Issue
Block a user