diff options
author | Jason Gerard DeRose <jderose@redhat.com> | 2008-07-31 22:36:15 +0000 |
---|---|---|
committer | Jason Gerard DeRose <jderose@redhat.com> | 2008-07-31 22:36:15 +0000 |
commit | a131ebf72469d416d4c08e23a7f3ac70854b237b (patch) | |
tree | acc48054c74380f194f2fa2b934c878d06270101 /ipalib/tests | |
parent | d7569a84b94ab304a1b7f353ea71c15061ebd5d4 (diff) | |
download | freeipa.git-a131ebf72469d416d4c08e23a7f3ac70854b237b.tar.gz freeipa.git-a131ebf72469d416d4c08e23a7f3ac70854b237b.tar.xz freeipa.git-a131ebf72469d416d4c08e23a7f3ac70854b237b.zip |
32: Added Plugin and Proxy base classes in plugable module, along with to_cli() and from_cli() functions; added correspending unit tests
Diffstat (limited to 'ipalib/tests')
-rw-r--r-- | ipalib/tests/test_plugable.py | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/ipalib/tests/test_plugable.py b/ipalib/tests/test_plugable.py index f0bdeb4a..0421e72b 100644 --- a/ipalib/tests/test_plugable.py +++ b/ipalib/tests/test_plugable.py @@ -24,6 +24,53 @@ Unit tests for `ipalib.plugable` module. from ipalib import plugable, errors +def test_to_cli(): + f = plugable.to_cli + assert f('initialize') == 'initialize' + assert f('find_everything') == 'find-everything' + assert f('user__add') == 'user.add' + assert f('meta_service__do_something') == 'meta-service.do-something' + + +def test_from_cli(): + f = plugable.from_cli + assert f('initialize') == 'initialize' + assert f('find-everything') == 'find_everything' + assert f('user.add') == 'user__add' + assert f('meta-service.do-something') == 'meta_service__do_something' + + +def test_Plugin(): + p = plugable.Plugin() + assert p.name == 'Plugin' + assert repr(p) == '%s.Plugin()' % plugable.__name__ + + class some_plugin(plugable.Plugin): + pass + p = some_plugin() + assert p.name == 'some_plugin' + assert repr(p) == '%s.some_plugin()' % __name__ + + +def test_Proxy(): + class CommandProxy(plugable.Proxy): + __slots__ = ( + 'get_label', + '__call__', + ) + + class Command(plugable.Plugin): + def get_label(self): + return 'Add User' + def __call__(self, *argv, **kw): + return (argv, kw) + + i = Command() + p = CommandProxy(i, 'hello') + assert '__dict__' not in dir(p) + #assert repr(p) == 'CommandProxy(%s.Command())' % __name__ + + def test_Registrar(): class Base1(object): pass |