From 262ff2d731b1bfc4acd91153088b8fcde7ae92b8 Mon Sep 17 00:00:00 2001 From: Rob Crittenden Date: Thu, 5 Feb 2009 15:03:08 -0500 Subject: Rename ipa-python directory to ipapython so it is a real python library We used to install it as ipa, now installing it as ipapython. The rpm is still ipa-python. --- ipa-python/test/test_aci.py | 127 --------------- ipa-python/test/test_ipautil.py | 309 ------------------------------------ ipa-python/test/test_ipavalidate.py | 97 ----------- 3 files changed, 533 deletions(-) delete mode 100644 ipa-python/test/test_aci.py delete mode 100644 ipa-python/test/test_ipautil.py delete mode 100644 ipa-python/test/test_ipavalidate.py (limited to 'ipa-python/test') diff --git a/ipa-python/test/test_aci.py b/ipa-python/test/test_aci.py deleted file mode 100644 index fb9d84c7..00000000 --- a/ipa-python/test/test_aci.py +++ /dev/null @@ -1,127 +0,0 @@ -#! /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; version 2 only -# -# 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, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -# - -import sys -sys.path.insert(0, ".") - -import unittest -import aci -import urllib - - -class TestACI(unittest.TestCase): - acitemplate = ('(targetattr="%s")' + - '(targetfilter="(memberOf=%s)")' + - '(version 3.0;' + - 'acl "%s";' + - 'allow (write) ' + - 'groupdn="ldap:///%s";)') - - def setUp(self): - self.aci = aci.ACI() - - def tearDown(self): - pass - - def testExport(self): - self.aci.source_group = 'cn=foo, dc=freeipa, dc=org' - self.aci.dest_group = 'cn=bar, dc=freeipa, dc=org' - self.aci.name = 'this is a "name' - self.aci.attrs = ['field1', 'field2', 'field3'] - - exportaci = self.aci.export_to_string() - aci = TestACI.acitemplate % ('field1 || field2 || field3', - self.aci.dest_group, - 'this is a "name', - self.aci.source_group) - - self.assertEqual(aci, exportaci) - - def testURLEncodedExport(self): - self.aci.source_group = 'cn=foo " bar, dc=freeipa, dc=org' - self.aci.dest_group = 'cn=bar, dc=freeipa, dc=org' - self.aci.name = 'this is a "name' - self.aci.attrs = ['field1', 'field2', 'field3'] - - exportaci = self.aci.export_to_string() - aci = TestACI.acitemplate % ('field1 || field2 || field3', - self.aci.dest_group, - 'this is a "name', - urllib.quote(self.aci.source_group, "/=, ")) - - self.assertEqual(aci, exportaci) - - def testSimpleParse(self): - attr_str = 'field3 || field4 || field5' - dest_dn = 'cn=dest\\"group, dc=freeipa, dc=org' - name = 'my name' - src_dn = 'cn=srcgroup, dc=freeipa, dc=org' - - acistr = TestACI.acitemplate % (attr_str, dest_dn, name, src_dn) - self.aci.parse_acistr(acistr) - - self.assertEqual(['field3', 'field4', 'field5'], self.aci.attrs) - self.assertEqual(dest_dn, self.aci.dest_group) - self.assertEqual(name, self.aci.name) - self.assertEqual(src_dn, self.aci.source_group) - - def testUrlEncodedParse(self): - attr_str = 'field3 || field4 || field5' - dest_dn = 'cn=dest\\"group, dc=freeipa, dc=org' - name = 'my name' - src_dn = 'cn=src " group, dc=freeipa, dc=org' - - acistr = TestACI.acitemplate % (attr_str, dest_dn, name, - urllib.quote(src_dn, "/=, ")) - self.aci.parse_acistr(acistr) - - self.assertEqual(['field3', 'field4', 'field5'], self.aci.attrs) - self.assertEqual(dest_dn, self.aci.dest_group) - self.assertEqual(name, self.aci.name) - self.assertEqual(src_dn, self.aci.source_group) - - def testInvalidParse(self): - try: - self.aci.parse_acistr('foo bar') - self.fail('Should have failed to parse') - except SyntaxError: - pass - - try: - self.aci.parse_acistr('') - self.fail('Should have failed to parse') - except SyntaxError: - pass - - attr_str = 'field3 || field4 || field5' - dest_dn = 'cn=dest\\"group, dc=freeipa, dc=org' - name = 'my name' - src_dn = 'cn=srcgroup, dc=freeipa, dc=org' - - acistr = TestACI.acitemplate % (attr_str, dest_dn, name, src_dn) - acistr += 'trailing garbage' - try: - self.aci.parse_acistr('') - self.fail('Should have failed to parse') - except SyntaxError: - pass - - -if __name__ == '__main__': - unittest.main() diff --git a/ipa-python/test/test_ipautil.py b/ipa-python/test/test_ipautil.py deleted file mode 100644 index 60d53a27..00000000 --- a/ipa-python/test/test_ipautil.py +++ /dev/null @@ -1,309 +0,0 @@ -#! /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; version 2 only -# -# 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, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -# - -import sys -sys.path.insert(0, ".") - -import unittest -import datetime - -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(None) - 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(None) - 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(None) - 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(None) - self.assertEqual(((24 - 9) * 60 * 60) - (30 * 60), offset.seconds) - - -if __name__ == '__main__': - unittest.main() diff --git a/ipa-python/test/test_ipavalidate.py b/ipa-python/test/test_ipavalidate.py deleted file mode 100644 index 8b79fbf0..00000000 --- a/ipa-python/test/test_ipavalidate.py +++ /dev/null @@ -1,97 +0,0 @@ -#! /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; version 2 only -# -# 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, write to the Free Software -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA -# - -import sys -sys.path.insert(0, ".") - -import unittest - -import ipavalidate - -class TestValidate(unittest.TestCase): - def setUp(self): - pass - - def tearDown(self): - pass - - def test_validEmail(self): - self.assertEqual(True, ipavalidate.Email("test@freeipa.org")) - self.assertEqual(True, ipavalidate.Email("", notEmpty=False)) - - def test_invalidEmail(self): - self.assertEqual(False, ipavalidate.Email("test")) - self.assertEqual(False, ipavalidate.Email("test@freeipa")) - self.assertEqual(False, ipavalidate.Email("test@.com")) - self.assertEqual(False, ipavalidate.Email("")) - self.assertEqual(False, ipavalidate.Email(None)) - - def test_validPlain(self): - self.assertEqual(True, ipavalidate.Plain("Joe User")) - self.assertEqual(True, ipavalidate.Plain("Joe O'Malley")) - self.assertEqual(True, ipavalidate.Plain("", notEmpty=False)) - self.assertEqual(True, ipavalidate.Plain(None, notEmpty=False)) - self.assertEqual(True, ipavalidate.Plain("JoeUser", allowSpaces=False)) - self.assertEqual(True, ipavalidate.Plain("JoeUser", allowSpaces=True)) - - def test_invalidPlain(self): - self.assertEqual(False, ipavalidate.Plain("Joe (User)")) - self.assertEqual(False, ipavalidate.Plain("Joe C. User")) - self.assertEqual(False, ipavalidate.Plain("", notEmpty=True)) - self.assertEqual(False, ipavalidate.Plain(None, notEmpty=True)) - self.assertEqual(False, ipavalidate.Plain("Joe User", allowSpaces=False)) - self.assertEqual(False, ipavalidate.Plain("Joe C. User")) - - def test_validString(self): - self.assertEqual(True, ipavalidate.String("Joe User")) - self.assertEqual(True, ipavalidate.String("Joe O'Malley")) - self.assertEqual(True, ipavalidate.String("", notEmpty=False)) - self.assertEqual(True, ipavalidate.String(None, notEmpty=False)) - self.assertEqual(True, ipavalidate.String("Joe C. User")) - - def test_invalidString(self): - self.assertEqual(False, ipavalidate.String("", notEmpty=True)) - self.assertEqual(False, ipavalidate.String(None, notEmpty=True)) - - def test_validPath(self): - self.assertEqual(True, ipavalidate.Path("/")) - self.assertEqual(True, ipavalidate.Path("/home/user")) - self.assertEqual(True, ipavalidate.Path("../home/user")) - self.assertEqual(True, ipavalidate.Path("", notEmpty=False)) - self.assertEqual(True, ipavalidate.Path(None, notEmpty=False)) - - def test_invalidPath(self): - self.assertEqual(False, ipavalidate.Path("(foo)")) - self.assertEqual(False, ipavalidate.Path("", notEmpty=True)) - self.assertEqual(False, ipavalidate.Path(None, notEmpty=True)) - - def test_validName(self): - self.assertEqual(True, ipavalidate.GoodName("foo")) - self.assertEqual(True, ipavalidate.GoodName("1foo")) - self.assertEqual(True, ipavalidate.GoodName("foo.bar")) - self.assertEqual(True, ipavalidate.GoodName("foo.bar$")) - - def test_invalidName(self): - self.assertEqual(False, ipavalidate.GoodName("foo bar")) - self.assertEqual(False, ipavalidate.GoodName("foo%bar")) - self.assertEqual(False, ipavalidate.GoodName("*foo")) - self.assertEqual(False, ipavalidate.GoodName("$foo.bar$")) - -if __name__ == '__main__': - unittest.main() -- cgit