2012-08-01 16:04:37 +00:00
|
|
|
# Copyright 2012 OpenStack LLC.
|
|
|
|
# All Rights Reserved.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
# not use this file except in compliance with the License. You may obtain
|
|
|
|
# a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
# License for the specific language governing permissions and limitations
|
|
|
|
# under the License.
|
|
|
|
|
|
|
|
import errno
|
2012-12-24 22:37:01 -06:00
|
|
|
import testtools
|
2012-08-01 16:04:37 +00:00
|
|
|
|
|
|
|
from glanceclient.common import utils
|
|
|
|
|
|
|
|
|
2012-12-24 22:37:01 -06:00
|
|
|
class TestUtils(testtools.TestCase):
|
2012-08-01 16:04:37 +00:00
|
|
|
|
|
|
|
def test_integrity_iter_without_checksum(self):
|
|
|
|
try:
|
|
|
|
data = ''.join([f for f in utils.integrity_iter('A', None)])
|
|
|
|
self.fail('integrity checked passed without checksum.')
|
|
|
|
except IOError, e:
|
|
|
|
self.assertEqual(errno.EPIPE, e.errno)
|
|
|
|
msg = 'was 7fc56270e7a70fa81a5935b72eacbe29 expected None'
|
|
|
|
self.assertTrue(msg in str(e))
|
|
|
|
|
|
|
|
def test_integrity_iter_with_wrong_checksum(self):
|
|
|
|
try:
|
|
|
|
data = ''.join([f for f in utils.integrity_iter('BB', 'wrong')])
|
|
|
|
self.fail('integrity checked passed with wrong checksum')
|
|
|
|
except IOError, e:
|
|
|
|
self.assertEqual(errno.EPIPE, e.errno)
|
|
|
|
msg = 'was 9d3d9048db16a7eee539e93e3618cbe7 expected wrong'
|
|
|
|
self.assertTrue('expected wrong' in str(e))
|
|
|
|
|
|
|
|
def test_integrity_iter_with_checksum(self):
|
|
|
|
fixture = 'CCC'
|
|
|
|
checksum = 'defb99e69a9f1f6e06f15006b1f166ae'
|
|
|
|
data = ''.join([f for f in utils.integrity_iter(fixture, checksum)])
|
2012-11-07 19:39:43 +01:00
|
|
|
|
|
|
|
def test_make_size_human_readable(self):
|
2012-11-19 10:35:04 -08:00
|
|
|
self.assertEqual("106B", utils.make_size_human_readable(106))
|
|
|
|
self.assertEqual("1000kB", utils.make_size_human_readable(1024000))
|
|
|
|
self.assertEqual("1MB", utils.make_size_human_readable(1048576))
|
|
|
|
self.assertEqual("1.4GB", utils.make_size_human_readable(1476395008))
|
|
|
|
self.assertEqual("9.3MB", utils.make_size_human_readable(9761280))
|
2013-01-30 15:18:44 +01:00
|
|
|
|
|
|
|
def test_ensure_unicode(self):
|
|
|
|
ensure_unicode = utils.ensure_unicode
|
|
|
|
self.assertEqual(u'True', ensure_unicode(True))
|
|
|
|
self.assertEqual(u'ni\xf1o', ensure_unicode("ni\xc3\xb1o",
|
|
|
|
incoming="utf-8"))
|
|
|
|
self.assertEqual(u"test", ensure_unicode("dGVzdA==",
|
|
|
|
incoming='base64'))
|
|
|
|
|
|
|
|
self.assertEqual(u"strange", ensure_unicode('\x80strange',
|
|
|
|
errors='ignore'))
|
|
|
|
|
|
|
|
self.assertEqual(u'\xc0', ensure_unicode('\xc0',
|
|
|
|
incoming='iso-8859-1'))
|
|
|
|
|
|
|
|
# Forcing incoming to ascii so it falls back to utf-8
|
|
|
|
self.assertEqual(u'ni\xf1o', ensure_unicode('ni\xc3\xb1o',
|
|
|
|
incoming='ascii'))
|
|
|
|
|
|
|
|
def test_ensure_str(self):
|
|
|
|
ensure_str = utils.ensure_str
|
|
|
|
self.assertEqual("True", ensure_str(True))
|
|
|
|
self.assertEqual("ni\xc3\xb1o", ensure_str(u'ni\xf1o',
|
|
|
|
encoding="utf-8"))
|
|
|
|
self.assertEqual("dGVzdA==\n", ensure_str("test",
|
|
|
|
encoding='base64'))
|
|
|
|
self.assertEqual('ni\xf1o', ensure_str("ni\xc3\xb1o",
|
|
|
|
encoding="iso-8859-1",
|
|
|
|
incoming="utf-8"))
|
|
|
|
|
|
|
|
# Forcing incoming to ascii so it falls back to utf-8
|
|
|
|
self.assertEqual('ni\xc3\xb1o', ensure_str('ni\xc3\xb1o',
|
|
|
|
incoming='ascii'))
|