d7054053ae
The word "Copyright" alone is sufficient to claim copyright, the (c) symbol need not be present.[1] As per PEP 263, a Python file with non-ASCII characters must have a line with "coding: <some-encoding>". Python files containing only 7-bit ASCII characters need no such line.[2] This commit removes unnecessary Unicode copyright symbols and unnecessary encoding lines. [1]: http://www.copyright.gov/circs/circ03.pdf [2]: http://legacy.python.org/dev/peps/pep-0263/ Closes-Bug: #1324686 Change-Id: Id381ea1f029a0cfddd3773c6d9f16c47842d9c33
133 lines
4.9 KiB
Python
133 lines
4.9 KiB
Python
#
|
|
# Copyright 2012 New Dream Network, LLC (DreamHost)
|
|
# Copyright (c) 2013 OpenStack Foundation
|
|
#
|
|
# Author: Doug Hellmann <doug.hellmann@dreamhost.com>
|
|
# 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.
|
|
"""Tests for ceilometer/utils.py
|
|
"""
|
|
import datetime
|
|
import decimal
|
|
|
|
from ceilometer.openstack.common import test
|
|
from ceilometer import utils
|
|
|
|
|
|
class TestUtils(test.BaseTestCase):
|
|
|
|
def test_datetime_to_decimal(self):
|
|
expected = 1356093296.12
|
|
utc_datetime = datetime.datetime.utcfromtimestamp(expected)
|
|
actual = utils.dt_to_decimal(utc_datetime)
|
|
self.assertEqual(expected, float(actual))
|
|
|
|
def test_decimal_to_datetime(self):
|
|
expected = 1356093296.12
|
|
dexpected = decimal.Decimal(str(expected)) # Python 2.6 wants str()
|
|
expected_datetime = datetime.datetime.utcfromtimestamp(expected)
|
|
actual_datetime = utils.decimal_to_dt(dexpected)
|
|
self.assertEqual(expected_datetime, actual_datetime)
|
|
|
|
def test_recursive_keypairs(self):
|
|
data = {'a': 'A', 'b': 'B',
|
|
'nested': {'a': 'A', 'b': 'B'}}
|
|
pairs = list(utils.recursive_keypairs(data))
|
|
self.assertEqual([('a', 'A'), ('b', 'B'),
|
|
('nested:a', 'A'), ('nested:b', 'B')],
|
|
pairs)
|
|
|
|
def test_recursive_keypairs_with_separator(self):
|
|
data = {'a': 'A',
|
|
'b': 'B',
|
|
'nested': {'a': 'A',
|
|
'b': 'B',
|
|
},
|
|
}
|
|
separator = '.'
|
|
pairs = list(utils.recursive_keypairs(data, separator))
|
|
self.assertEqual([('a', 'A'),
|
|
('b', 'B'),
|
|
('nested.a', 'A'),
|
|
('nested.b', 'B')],
|
|
pairs)
|
|
|
|
def test_recursive_keypairs_with_list_of_dict(self):
|
|
small = 1
|
|
big = 1 << 64
|
|
expected = [('a', 'A'),
|
|
('b', 'B'),
|
|
('nested:list', ['{%d: 99, %dL: 42}' % (small, big)])]
|
|
# the keys 1 and 1<<64 cause a hash collision on 64bit platforms
|
|
for nested in [{small: 99, big: 42}, {big: 42, small: 99}]:
|
|
data = {'a': 'A',
|
|
'b': 'B',
|
|
'nested': {'list': [nested]}}
|
|
pairs = list(utils.recursive_keypairs(data))
|
|
self.assertEqual(expected, pairs)
|
|
|
|
def test_restore_nesting_unested(self):
|
|
metadata = {'a': 'A', 'b': 'B'}
|
|
unwound = utils.restore_nesting(metadata)
|
|
self.assertIs(metadata, unwound)
|
|
|
|
def test_restore_nesting(self):
|
|
metadata = {'a': 'A', 'b': 'B',
|
|
'nested:a': 'A',
|
|
'nested:b': 'B',
|
|
'nested:twice:c': 'C',
|
|
'nested:twice:d': 'D',
|
|
'embedded:e': 'E'}
|
|
unwound = utils.restore_nesting(metadata)
|
|
expected = {'a': 'A', 'b': 'B',
|
|
'nested': {'a': 'A', 'b': 'B',
|
|
'twice': {'c': 'C', 'd': 'D'}},
|
|
'embedded': {'e': 'E'}}
|
|
self.assertEqual(expected, unwound)
|
|
self.assertIsNot(metadata, unwound)
|
|
|
|
def test_restore_nesting_with_separator(self):
|
|
metadata = {'a': 'A', 'b': 'B',
|
|
'nested.a': 'A',
|
|
'nested.b': 'B',
|
|
'nested.twice.c': 'C',
|
|
'nested.twice.d': 'D',
|
|
'embedded.e': 'E'}
|
|
unwound = utils.restore_nesting(metadata, separator='.')
|
|
expected = {'a': 'A', 'b': 'B',
|
|
'nested': {'a': 'A', 'b': 'B',
|
|
'twice': {'c': 'C', 'd': 'D'}},
|
|
'embedded': {'e': 'E'}}
|
|
self.assertEqual(expected, unwound)
|
|
self.assertIsNot(metadata, unwound)
|
|
|
|
def test_decimal_to_dt_with_none_parameter(self):
|
|
self.assertIsNone(utils.decimal_to_dt(None))
|
|
|
|
def test_dict_to_kv(self):
|
|
data = {'a': 'A',
|
|
'b': 'B',
|
|
'nested': {'a': 'A',
|
|
'b': 'B',
|
|
},
|
|
'nested2': [{'c': 'A'}, {'c': 'B'}]
|
|
}
|
|
pairs = list(utils.dict_to_keyval(data))
|
|
self.assertEqual([('a', 'A'), ('b', 'B'),
|
|
('nested2[0].c', 'A'),
|
|
('nested2[1].c', 'B'),
|
|
('nested.a', 'A'),
|
|
('nested.b', 'B')],
|
|
pairs)
|