#! /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 . # 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()