123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165 |
- # -*- coding: utf-8 -*-
- # Import python libs
- from __future__ import absolute_import, unicode_literals, print_function
- # Import Salt Testing libs
- from tests.support.unit import TestCase
- # Import Salt libs
- import salt.utils.hashutils
- class HashutilsTestCase(TestCase):
- hmac_secret = 's00p3r s3kr1t'
- # Use a non-ascii unicode type to confirm that no UnicodeEncodeError is
- # raised on Python 2.
- str = 'спам'
- str_b64encode_result = '0YHQv9Cw0Lw='
- str_encodestring_result = '0YHQv9Cw0Lw=\n'
- str_md5 = 'a035ac08ab2f03556f9b3ee640052e5c'
- str_sha256 = '095291ffa3d361436d4617879e22c1da06c6ab61a3fb081321ec854a27a091ac'
- str_sha512 = '12efd90e507289f1f21e5dcfe2e92cf0bb4904abccb55c3ce9177670c711981501054b32b807c37058675590d1c484bd2b72a4215a2fa397aa4f2b12f298b1f0'
- str_hmac_challenge = b'qz2k0t1aevKEme3JGsNQJX/xpmf+/w3q6qmWDk1ZqbY='
- # 16 bytes of random data
- bytes = b'b\x19\xf6\x86\x0e\x1a\x1cs\x0c\xda&zv\xfc\xa2\xdd'
- bytes_b64encode_result = 'Yhn2hg4aHHMM2iZ6dvyi3Q=='
- bytes_encodestring_result = 'Yhn2hg4aHHMM2iZ6dvyi3Q==\n'
- bytes_md5 = '4d064241724791641dc15930c65f75c8'
- bytes_sha256 = '25711a31c2673a48f3d1f29b25add574697872968e546d266f441de63b17954a'
- bytes_sha512 = '69f1524e602c1599fc374e1e3e2941e6f6949f4f7fe7321304e4e67bb850f3204dd5cbf9c13e231814540c2f5cd370c24ea257771d9fbf311d8f6085bad12b24'
- bytes_hmac_challenge = b'lQibiD9r1Hpo+5JYknaudIKfTx1L5J3U58M9yQOd04c='
- def test_base64_b64encode(self):
- '''
- Ensure that this function converts the value passed to bytes before
- attempting to encode, avoiding a UnicodeEncodeError on Python 2 and a
- TypeError on Python 3.
- '''
- self.assertEqual(
- salt.utils.hashutils.base64_b64encode(self.str),
- self.str_b64encode_result
- )
- self.assertEqual(
- salt.utils.hashutils.base64_b64encode(self.bytes),
- self.bytes_b64encode_result
- )
- def test_base64_b64decode(self):
- '''
- Ensure that this function converts the value passed to a unicode type
- (if possible) on Python 2, and a str type (if possible) on Python 3.
- '''
- self.assertEqual(
- salt.utils.hashutils.base64_b64decode(self.str_b64encode_result),
- self.str
- )
- self.assertEqual(
- salt.utils.hashutils.base64_b64decode(self.bytes_b64encode_result),
- self.bytes
- )
- def test_base64_encodestring(self):
- '''
- Ensure that this function converts the value passed to bytes before
- attempting to encode, avoiding a UnicodeEncodeError on Python 2 and a
- TypeError on Python 3.
- '''
- self.assertEqual(
- salt.utils.hashutils.base64_encodestring(self.str),
- self.str_encodestring_result
- )
- self.assertEqual(
- salt.utils.hashutils.base64_encodestring(self.bytes),
- self.bytes_encodestring_result
- )
- def test_base64_decodestring(self):
- '''
- Ensure that this function converts the value passed to a unicode type
- (if possible) on Python 2, and a str type (if possible) on Python 3.
- '''
- self.assertEqual(
- salt.utils.hashutils.base64_decodestring(self.str_encodestring_result),
- self.str
- )
- self.assertEqual(
- salt.utils.hashutils.base64_decodestring(self.bytes_encodestring_result),
- self.bytes
- )
- def test_md5_digest(self):
- '''
- Ensure that this function converts the value passed to bytes before
- attempting to encode, avoiding a UnicodeEncodeError on Python 2 and a
- TypeError on Python 3.
- '''
- self.assertEqual(
- salt.utils.hashutils.md5_digest(self.str),
- self.str_md5
- )
- self.assertEqual(
- salt.utils.hashutils.md5_digest(self.bytes),
- self.bytes_md5
- )
- def test_sha256_digest(self):
- '''
- Ensure that this function converts the value passed to bytes before
- attempting to encode, avoiding a UnicodeEncodeError on Python 2 and a
- TypeError on Python 3.
- '''
- self.assertEqual(
- salt.utils.hashutils.sha256_digest(self.str),
- self.str_sha256
- )
- self.assertEqual(
- salt.utils.hashutils.sha256_digest(self.bytes),
- self.bytes_sha256
- )
- def test_sha512_digest(self):
- '''
- Ensure that this function converts the value passed to bytes before
- attempting to encode, avoiding a UnicodeEncodeError on Python 2 and a
- TypeError on Python 3.
- '''
- self.assertEqual(
- salt.utils.hashutils.sha512_digest(self.str),
- self.str_sha512
- )
- self.assertEqual(
- salt.utils.hashutils.sha512_digest(self.bytes),
- self.bytes_sha512
- )
- def test_hmac_signature(self):
- '''
- Ensure that this function converts the value passed to bytes before
- attempting to validate the hmac challenge, avoiding a
- UnicodeEncodeError on Python 2 and a TypeError on Python 3.
- '''
- self.assertTrue(
- salt.utils.hashutils.hmac_signature(
- self.str,
- self.hmac_secret,
- self.str_hmac_challenge
- )
- )
- self.assertTrue(
- salt.utils.hashutils.hmac_signature(
- self.bytes,
- self.hmac_secret,
- self.bytes_hmac_challenge
- )
- )
- def test_get_hash_exception(self):
- self.assertRaises(
- ValueError,
- salt.utils.hashutils.get_hash,
- '/tmp/foo/',
- form='INVALID')
|