freeipa/ipapython/test/test_ipautil.py
Rob Crittenden 96469fbc88 Fix failed tests. API for utcoffset changed and strings are more robust.
In Python 2.7 the API for time.utcoffset() changed.

We do more automatic conversions of strings so need to loosen the tests
a bit.
2011-01-24 14:34:38 -05:00

310 lines
10 KiB
Python

#! /usr/bin/python -E
#
# Copyright (C) 2007 Red Hat
# see file 'COPYING' for use and warranty information
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
import sys
sys.path.insert(0, ".")
import unittest
import datetime
from ipapython import ipautil
class TestCIDict(unittest.TestCase):
def setUp(self):
self.cidict = ipautil.CIDict()
self.cidict["Key1"] = "val1"
self.cidict["key2"] = "val2"
self.cidict["KEY3"] = "VAL3"
def tearDown(self):
pass
def testLen(self):
self.assertEqual(3, len(self.cidict))
def test__GetItem(self):
self.assertEqual("val1", self.cidict["Key1"])
self.assertEqual("val1", self.cidict["key1"])
self.assertEqual("val2", self.cidict["KEY2"])
self.assertEqual("VAL3", self.cidict["key3"])
self.assertEqual("VAL3", self.cidict["KEY3"])
try:
self.cidict["key4"]
fail("should have raised KeyError")
except KeyError:
pass
def testGet(self):
self.assertEqual("val1", self.cidict.get("Key1"))
self.assertEqual("val1", self.cidict.get("key1"))
self.assertEqual("val2", self.cidict.get("KEY2"))
self.assertEqual("VAL3", self.cidict.get("key3"))
self.assertEqual("VAL3", self.cidict.get("KEY3"))
self.assertEqual("default", self.cidict.get("key4", "default"))
def test__SetItem(self):
self.cidict["key4"] = "val4"
self.assertEqual("val4", self.cidict["key4"])
self.cidict["KEY4"] = "newval4"
self.assertEqual("newval4", self.cidict["key4"])
def testDel(self):
self.assert_(self.cidict.has_key("Key1"))
del(self.cidict["Key1"])
self.failIf(self.cidict.has_key("Key1"))
self.assert_(self.cidict.has_key("key2"))
del(self.cidict["KEY2"])
self.failIf(self.cidict.has_key("key2"))
def testClear(self):
self.assertEqual(3, len(self.cidict))
self.cidict.clear()
self.assertEqual(0, len(self.cidict))
def testCopy(self):
"""A copy is no longer a CIDict, but should preserve the case of
the keys as they were inserted."""
copy = self.cidict.copy()
self.assertEqual(3, len(copy))
self.assert_(copy.has_key("Key1"))
self.assertEqual("val1", copy["Key1"])
self.failIf(copy.has_key("key1"))
def testHasKey(self):
self.assert_(self.cidict.has_key("KEY1"))
self.assert_(self.cidict.has_key("key2"))
self.assert_(self.cidict.has_key("key3"))
def testItems(self):
items = self.cidict.items()
self.assertEqual(3, len(items))
items_set = set(items)
self.assert_(("Key1", "val1") in items_set)
self.assert_(("key2", "val2") in items_set)
self.assert_(("KEY3", "VAL3") in items_set)
def testIterItems(self):
items = []
for (k,v) in self.cidict.iteritems():
items.append((k,v))
self.assertEqual(3, len(items))
items_set = set(items)
self.assert_(("Key1", "val1") in items_set)
self.assert_(("key2", "val2") in items_set)
self.assert_(("KEY3", "VAL3") in items_set)
def testIterKeys(self):
keys = []
for k in self.cidict.iterkeys():
keys.append(k)
self.assertEqual(3, len(keys))
keys_set = set(keys)
self.assert_("Key1" in keys_set)
self.assert_("key2" in keys_set)
self.assert_("KEY3" in keys_set)
def testIterValues(self):
values = []
for k in self.cidict.itervalues():
values.append(k)
self.assertEqual(3, len(values))
values_set = set(values)
self.assert_("val1" in values_set)
self.assert_("val2" in values_set)
self.assert_("VAL3" in values_set)
def testKeys(self):
keys = self.cidict.keys()
self.assertEqual(3, len(keys))
keys_set = set(keys)
self.assert_("Key1" in keys_set)
self.assert_("key2" in keys_set)
self.assert_("KEY3" in keys_set)
def testValues(self):
values = self.cidict.values()
self.assertEqual(3, len(values))
values_set = set(values)
self.assert_("val1" in values_set)
self.assert_("val2" in values_set)
self.assert_("VAL3" in values_set)
def testUpdate(self):
newdict = { "KEY2": "newval2",
"key4": "val4" }
self.cidict.update(newdict)
self.assertEqual(4, len(self.cidict))
items = self.cidict.items()
self.assertEqual(4, len(items))
items_set = set(items)
self.assert_(("Key1", "val1") in items_set)
# note the update "overwrites" the case of the key2
self.assert_(("KEY2", "newval2") in items_set)
self.assert_(("KEY3", "VAL3") in items_set)
self.assert_(("key4", "val4") in items_set)
def testSetDefault(self):
self.assertEqual("val1", self.cidict.setdefault("KEY1", "default"))
self.failIf(self.cidict.has_key("KEY4"))
self.assertEqual("default", self.cidict.setdefault("KEY4", "default"))
self.assert_(self.cidict.has_key("KEY4"))
self.assertEqual("default", self.cidict["key4"])
self.failIf(self.cidict.has_key("KEY5"))
self.assertEqual(None, self.cidict.setdefault("KEY5"))
self.assert_(self.cidict.has_key("KEY5"))
self.assertEqual(None, self.cidict["key5"])
def testPop(self):
self.assertEqual("val1", self.cidict.pop("KEY1", "default"))
self.failIf(self.cidict.has_key("key1"))
self.assertEqual("val2", self.cidict.pop("KEY2"))
self.failIf(self.cidict.has_key("key2"))
self.assertEqual("default", self.cidict.pop("key4", "default"))
try:
self.cidict.pop("key4")
fail("should have raised KeyError")
except KeyError:
pass
def testPopItem(self):
items = set(self.cidict.items())
self.assertEqual(3, len(self.cidict))
item = self.cidict.popitem()
self.assertEqual(2, len(self.cidict))
self.assert_(item in items)
items.discard(item)
item = self.cidict.popitem()
self.assertEqual(1, len(self.cidict))
self.assert_(item in items)
items.discard(item)
item = self.cidict.popitem()
self.assertEqual(0, len(self.cidict))
self.assert_(item in items)
items.discard(item)
class TestTimeParser(unittest.TestCase):
def setUp(self):
pass
def tearDown(self):
pass
def testSimple(self):
timestr = "20070803"
time = ipautil.parse_generalized_time(timestr)
self.assertEqual(2007, time.year)
self.assertEqual(8, time.month)
self.assertEqual(3, time.day)
self.assertEqual(0, time.hour)
self.assertEqual(0, time.minute)
self.assertEqual(0, time.second)
def testHourMinSec(self):
timestr = "20051213141205"
time = ipautil.parse_generalized_time(timestr)
self.assertEqual(2005, time.year)
self.assertEqual(12, time.month)
self.assertEqual(13, time.day)
self.assertEqual(14, time.hour)
self.assertEqual(12, time.minute)
self.assertEqual(5, time.second)
def testFractions(self):
timestr = "2003092208.5"
time = ipautil.parse_generalized_time(timestr)
self.assertEqual(2003, time.year)
self.assertEqual(9, time.month)
self.assertEqual(22, time.day)
self.assertEqual(8, time.hour)
self.assertEqual(30, time.minute)
self.assertEqual(0, time.second)
timestr = "199203301544,25"
time = ipautil.parse_generalized_time(timestr)
self.assertEqual(1992, time.year)
self.assertEqual(3, time.month)
self.assertEqual(30, time.day)
self.assertEqual(15, time.hour)
self.assertEqual(44, time.minute)
self.assertEqual(15, time.second)
timestr = "20060401185912,8"
time = ipautil.parse_generalized_time(timestr)
self.assertEqual(2006, time.year)
self.assertEqual(4, time.month)
self.assertEqual(1, time.day)
self.assertEqual(18, time.hour)
self.assertEqual(59, time.minute)
self.assertEqual(12, time.second)
self.assertEqual(800000, time.microsecond)
def testTimeZones(self):
timestr = "20051213141205Z"
time = ipautil.parse_generalized_time(timestr)
self.assertEqual(0, time.tzinfo.houroffset)
self.assertEqual(0, time.tzinfo.minoffset)
offset = time.tzinfo.utcoffset(time.tzinfo.dst())
self.assertEqual(0, offset.seconds)
timestr = "20051213141205+0500"
time = ipautil.parse_generalized_time(timestr)
self.assertEqual(5, time.tzinfo.houroffset)
self.assertEqual(0, time.tzinfo.minoffset)
offset = time.tzinfo.utcoffset(time.tzinfo.dst())
self.assertEqual(5 * 60 * 60, offset.seconds)
timestr = "20051213141205-0500"
time = ipautil.parse_generalized_time(timestr)
self.assertEqual(-5, time.tzinfo.houroffset)
self.assertEqual(0, time.tzinfo.minoffset)
# NOTE - the offset is always positive - it's minutes
# _east_ of UTC
offset = time.tzinfo.utcoffset(time.tzinfo.dst())
self.assertEqual((24 - 5) * 60 * 60, offset.seconds)
timestr = "20051213141205-0930"
time = ipautil.parse_generalized_time(timestr)
self.assertEqual(-9, time.tzinfo.houroffset)
self.assertEqual(-30, time.tzinfo.minoffset)
offset = time.tzinfo.utcoffset(time.tzinfo.dst())
self.assertEqual(((24 - 9) * 60 * 60) - (30 * 60), offset.seconds)
if __name__ == '__main__':
unittest.main()