summaryrefslogtreecommitdiffstats
path: root/ipalib/tests/test_plugable.py
diff options
context:
space:
mode:
authorJason Gerard DeRose <jderose@redhat.com>2008-08-09 19:28:01 +0000
committerJason Gerard DeRose <jderose@redhat.com>2008-08-09 19:28:01 +0000
commit0e532cd7b30023b10f97690540f4209106d7f832 (patch)
tree7b87d5d6948aa3471ef67b212d70b009443f3d76 /ipalib/tests/test_plugable.py
parente756e12718a538d82de45fbba3a5e97f3a4d7d7f (diff)
downloadfreeipa.git-0e532cd7b30023b10f97690540f4209106d7f832.tar.gz
freeipa.git-0e532cd7b30023b10f97690540f4209106d7f832.tar.xz
freeipa.git-0e532cd7b30023b10f97690540f4209106d7f832.zip
100: Cleaned up NameSpace docstrings; cleanup up NameSpace unit tests
Diffstat (limited to 'ipalib/tests/test_plugable.py')
-rw-r--r--ipalib/tests/test_plugable.py113
1 files changed, 60 insertions, 53 deletions
diff --git a/ipalib/tests/test_plugable.py b/ipalib/tests/test_plugable.py
index af52f4ee..b8242dce 100644
--- a/ipalib/tests/test_plugable.py
+++ b/ipalib/tests/test_plugable.py
@@ -332,62 +332,69 @@ class test_Plugin(ClassChecker):
raises(AssertionError, sub.finalize, api)
-def test_NameSpace():
- cls = plugable.NameSpace
- assert issubclass(cls, plugable.ReadOnly)
+class test_NameSpace(ClassChecker):
+ """
+ Tests the `NameSpace` class.
+ """
+ _cls = plugable.NameSpace
- class base(object):
- __public__ = frozenset((
- 'plusplus',
- ))
+ def test_class(self):
+ assert self.cls.__bases__ == (plugable.ReadOnly,)
- def plusplus(self, n):
- return n + 1
+ def test_namespace(self):
+ class base(object):
+ __public__ = frozenset((
+ 'plusplus',
+ ))
+
+ def plusplus(self, n):
+ return n + 1
- class plugin(base):
- def __init__(self, name):
- self.name = name
-
- def get_name(i):
- return 'noun_verb%d' % i
-
- def get_proxies(n):
- for i in xrange(n):
- yield plugable.Proxy(base, plugin(get_name(i)))
-
- cnt = 20
- ns = cls(get_proxies(cnt))
-
- # Test __len__
- assert len(ns) == cnt
-
- # Test __iter__
- i = None
- for (i, proxy) in enumerate(ns):
- assert type(proxy) is plugable.Proxy
- assert proxy.name == get_name(i)
- assert i == cnt - 1
-
- # Test __contains__, __getitem__, getattr():
- proxies = frozenset(ns)
- for i in xrange(cnt):
- name = get_name(i)
- assert name in ns
- proxy = ns[name]
- assert proxy.name == name
- assert type(proxy) is plugable.Proxy
- assert proxy in proxies
- assert read_only(ns, name) is proxy
-
- # Test dir():
- assert set(get_name(i) for i in xrange(cnt)).issubset(set(dir(ns)))
-
- # Test that KeyError, AttributeError is raised:
- name = get_name(cnt)
- assert name not in ns
- raises(KeyError, getitem, ns, name)
- raises(AttributeError, getattr, ns, name)
- no_set(ns, name)
+ class plugin(base):
+ def __init__(self, name):
+ self.name = name
+
+ def get_name(i):
+ return 'noun_verb%d' % i
+
+ def get_proxies(n):
+ for i in xrange(n):
+ yield plugable.Proxy(base, plugin(get_name(i)))
+
+ cnt = 20
+ ns = self.cls(get_proxies(cnt))
+ assert ns.__islocked__() is True
+
+ # Test __len__
+ assert len(ns) == cnt
+
+ # Test __iter__
+ i = None
+ for (i, proxy) in enumerate(ns):
+ assert type(proxy) is plugable.Proxy
+ assert proxy.name == get_name(i)
+ assert i == cnt - 1
+
+ # Test __contains__, __getitem__, getattr():
+ proxies = frozenset(ns)
+ for i in xrange(cnt):
+ name = get_name(i)
+ assert name in ns
+ proxy = ns[name]
+ assert proxy.name == name
+ assert type(proxy) is plugable.Proxy
+ assert proxy in proxies
+ assert read_only(ns, name) is proxy
+
+ # Test dir():
+ assert set(get_name(i) for i in xrange(cnt)).issubset(dir(ns))
+
+ # Test that KeyError, AttributeError is raised:
+ name = get_name(cnt)
+ assert name not in ns
+ raises(KeyError, getitem, ns, name)
+ raises(AttributeError, getattr, ns, name)
+ no_set(ns, name)
def test_Registrar():