mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-11 08:41:55 -06:00
138: Added ProxyTarget.doc property; CLI.print_commands() now uses cmd.doc instead of cmd.get_doc()
This commit is contained in:
parent
69f7132365
commit
0fed74b56d
@ -63,7 +63,7 @@ class CLI(object):
|
|||||||
for cmd in self.api.cmd:
|
for cmd in self.api.cmd:
|
||||||
print ' %s %s' % (
|
print ' %s %s' % (
|
||||||
to_cli(cmd.name).ljust(self.mcl),
|
to_cli(cmd.name).ljust(self.mcl),
|
||||||
cmd.get_doc(_),
|
cmd.doc,
|
||||||
)
|
)
|
||||||
|
|
||||||
def __contains__(self, key):
|
def __contains__(self, key):
|
||||||
|
@ -128,6 +128,7 @@ class Proxy(ReadOnly):
|
|||||||
'__name_attr',
|
'__name_attr',
|
||||||
'__public__',
|
'__public__',
|
||||||
'name',
|
'name',
|
||||||
|
'doc',
|
||||||
)
|
)
|
||||||
|
|
||||||
def __init__(self, base, target, name_attr='name'):
|
def __init__(self, base, target, name_attr='name'):
|
||||||
@ -146,10 +147,11 @@ class Proxy(ReadOnly):
|
|||||||
self.__target = target
|
self.__target = target
|
||||||
self.__name_attr = name_attr
|
self.__name_attr = name_attr
|
||||||
self.__public__ = base.__public__
|
self.__public__ = base.__public__
|
||||||
assert type(self.__public__) is frozenset
|
|
||||||
self.name = getattr(target, name_attr)
|
self.name = getattr(target, name_attr)
|
||||||
check_identifier(self.name)
|
self.doc = target.doc
|
||||||
self.__lock__()
|
self.__lock__()
|
||||||
|
assert type(self.__public__) is frozenset
|
||||||
|
check_identifier(self.name)
|
||||||
|
|
||||||
def implements(self, arg):
|
def implements(self, arg):
|
||||||
"""
|
"""
|
||||||
@ -225,6 +227,13 @@ class ProxyTarget(ReadOnly):
|
|||||||
return self.__class__.__name__
|
return self.__class__.__name__
|
||||||
name = property(__get_name)
|
name = property(__get_name)
|
||||||
|
|
||||||
|
def __get_doc(self):
|
||||||
|
"""
|
||||||
|
Convenience property to return the class docstring.
|
||||||
|
"""
|
||||||
|
return self.__class__.__doc__
|
||||||
|
doc = property(__get_doc)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def implements(cls, arg):
|
def implements(cls, arg):
|
||||||
"""
|
"""
|
||||||
|
@ -28,52 +28,43 @@ from ipalib.api import api
|
|||||||
|
|
||||||
# Hypothetical functional commands (not associated with any object):
|
# Hypothetical functional commands (not associated with any object):
|
||||||
class krbtest(public.cmd):
|
class krbtest(public.cmd):
|
||||||
def get_doc(self, _):
|
'test your Kerberos ticket'
|
||||||
return _('test your Kerberos ticket')
|
|
||||||
api.register(krbtest)
|
api.register(krbtest)
|
||||||
|
|
||||||
class discover(public.cmd):
|
class discover(public.cmd):
|
||||||
def get_doc(self, _):
|
'discover IPA servers on network'
|
||||||
return _('discover IPA servers on network')
|
|
||||||
api.register(discover)
|
api.register(discover)
|
||||||
|
|
||||||
|
|
||||||
# Register some methods for the 'user' object:
|
# Register some methods for the 'user' object:
|
||||||
class user_add(public.mthd):
|
class user_add(public.mthd):
|
||||||
def get_doc(self, _):
|
'add new user'
|
||||||
return _('add new user')
|
|
||||||
api.register(user_add)
|
api.register(user_add)
|
||||||
|
|
||||||
class user_del(public.mthd):
|
class user_del(public.mthd):
|
||||||
def get_doc(self, _):
|
'delete existing user'
|
||||||
return _('delete existing user')
|
|
||||||
api.register(user_del)
|
api.register(user_del)
|
||||||
|
|
||||||
class user_mod(public.mthd):
|
class user_mod(public.mthd):
|
||||||
def get_doc(self, _):
|
'edit existing user'
|
||||||
return _('edit existing user')
|
|
||||||
api.register(user_mod)
|
api.register(user_mod)
|
||||||
|
|
||||||
class user_find(public.mthd):
|
class user_find(public.mthd):
|
||||||
def get_doc(self, _):
|
'search for users'
|
||||||
return _('search for users')
|
|
||||||
api.register(user_find)
|
api.register(user_find)
|
||||||
|
|
||||||
|
|
||||||
# Register some properties for the 'user' object:
|
# Register some properties for the 'user' object:
|
||||||
class user_givenname(public.prop):
|
class user_givenname(public.prop):
|
||||||
def get_doc(self, _):
|
'user first name'
|
||||||
return _('user first name')
|
|
||||||
api.register(user_givenname)
|
api.register(user_givenname)
|
||||||
|
|
||||||
class user_sn(public.prop):
|
class user_sn(public.prop):
|
||||||
def get_doc(self, _):
|
'user last name'
|
||||||
return _('user last name')
|
|
||||||
api.register(user_sn)
|
api.register(user_sn)
|
||||||
|
|
||||||
class user_login(public.prop):
|
class user_login(public.prop):
|
||||||
def get_doc(self, _):
|
'user login'
|
||||||
return _('user login')
|
|
||||||
def default(self, **kw):
|
def default(self, **kw):
|
||||||
givenname = kw.get('givenname', None)
|
givenname = kw.get('givenname', None)
|
||||||
sn = kw.get('sn', None)
|
sn = kw.get('sn', None)
|
||||||
@ -83,8 +74,7 @@ class user_login(public.prop):
|
|||||||
api.register(user_login)
|
api.register(user_login)
|
||||||
|
|
||||||
class user_initials(public.prop):
|
class user_initials(public.prop):
|
||||||
def get_doc(self, _):
|
'user initials'
|
||||||
return _('user initials')
|
|
||||||
def default(self, **kw):
|
def default(self, **kw):
|
||||||
givenname = kw.get('givenname', None)
|
givenname = kw.get('givenname', None)
|
||||||
sn = kw.get('sn', None)
|
sn = kw.get('sn', None)
|
||||||
@ -96,61 +86,50 @@ api.register(user_initials)
|
|||||||
|
|
||||||
# Register some methods for the 'group' object:
|
# Register some methods for the 'group' object:
|
||||||
class group_add(public.mthd):
|
class group_add(public.mthd):
|
||||||
def get_doc(self, _):
|
'add new group'
|
||||||
return _('add new group')
|
|
||||||
api.register(group_add)
|
api.register(group_add)
|
||||||
|
|
||||||
class group_del(public.mthd):
|
class group_del(public.mthd):
|
||||||
def get_doc(self, _):
|
'delete existing group'
|
||||||
return _('delete existing group')
|
|
||||||
api.register(group_del)
|
api.register(group_del)
|
||||||
|
|
||||||
class group_mod(public.mthd):
|
class group_mod(public.mthd):
|
||||||
def get_doc(self, _):
|
'edit existing group'
|
||||||
return _('edit existing group')
|
|
||||||
api.register(group_mod)
|
api.register(group_mod)
|
||||||
|
|
||||||
class group_find(public.mthd):
|
class group_find(public.mthd):
|
||||||
def get_doc(self, _):
|
'search for groups'
|
||||||
return _('search for groups')
|
|
||||||
api.register(group_find)
|
api.register(group_find)
|
||||||
|
|
||||||
|
|
||||||
# Register some methods for the 'service' object
|
# Register some methods for the 'service' object
|
||||||
class service_add(public.mthd):
|
class service_add(public.mthd):
|
||||||
def get_doc(self, _):
|
'add new service'
|
||||||
return _('add new service')
|
|
||||||
api.register(service_add)
|
api.register(service_add)
|
||||||
|
|
||||||
class service_del(public.mthd):
|
class service_del(public.mthd):
|
||||||
def get_doc(self, _):
|
'delete existing service'
|
||||||
return _('delete existing service')
|
|
||||||
api.register(service_del)
|
api.register(service_del)
|
||||||
|
|
||||||
class service_mod(public.mthd):
|
class service_mod(public.mthd):
|
||||||
def get_doc(self, _):
|
'edit existing service'
|
||||||
return _('edit existing service')
|
|
||||||
api.register(service_mod)
|
api.register(service_mod)
|
||||||
|
|
||||||
class service_find(public.mthd):
|
class service_find(public.mthd):
|
||||||
def get_doc(self, _):
|
'search for services'
|
||||||
return _('search for services')
|
|
||||||
api.register(service_find)
|
api.register(service_find)
|
||||||
|
|
||||||
|
|
||||||
# And to emphasis that the registration order doesn't matter,
|
# And to emphasis that the registration order doesn't matter,
|
||||||
# we'll register the objects last:
|
# we'll register the objects last:
|
||||||
class group(public.obj):
|
class group(public.obj):
|
||||||
def get_doc(self, _):
|
'group object'
|
||||||
return _('')
|
|
||||||
api.register(group)
|
api.register(group)
|
||||||
|
|
||||||
class service(public.obj):
|
class service(public.obj):
|
||||||
def get_doc(self, _):
|
'service object'
|
||||||
return _('')
|
|
||||||
api.register(service)
|
api.register(service)
|
||||||
|
|
||||||
class user(public.obj):
|
class user(public.obj):
|
||||||
def get_doc(self, _):
|
'user object'
|
||||||
return _('')
|
|
||||||
api.register(user)
|
api.register(user)
|
||||||
|
@ -45,7 +45,6 @@ class option(plugable.Plugin):
|
|||||||
"""
|
"""
|
||||||
|
|
||||||
__public__ = frozenset((
|
__public__ = frozenset((
|
||||||
'get_doc',
|
|
||||||
'normalize',
|
'normalize',
|
||||||
'default',
|
'default',
|
||||||
'validate',
|
'validate',
|
||||||
|
@ -126,7 +126,7 @@ class test_ProxyTarget(ClassChecker):
|
|||||||
|
|
||||||
def test_name(self):
|
def test_name(self):
|
||||||
"""
|
"""
|
||||||
Test the `name` property.
|
Tests the `name` property.
|
||||||
"""
|
"""
|
||||||
assert read_only(self.cls(), 'name') == 'ProxyTarget'
|
assert read_only(self.cls(), 'name') == 'ProxyTarget'
|
||||||
|
|
||||||
@ -134,9 +134,17 @@ class test_ProxyTarget(ClassChecker):
|
|||||||
pass
|
pass
|
||||||
assert read_only(some_subclass(), 'name') == 'some_subclass'
|
assert read_only(some_subclass(), 'name') == 'some_subclass'
|
||||||
|
|
||||||
|
def test_doc(self):
|
||||||
|
"""
|
||||||
|
Tests the `doc` property.
|
||||||
|
"""
|
||||||
|
class some_subclass(self.cls):
|
||||||
|
'here is the doc string'
|
||||||
|
assert read_only(some_subclass(), 'doc') == 'here is the doc string'
|
||||||
|
|
||||||
def test_implements(self):
|
def test_implements(self):
|
||||||
"""
|
"""
|
||||||
Test the `implements` classmethod.
|
Tests the `implements` classmethod.
|
||||||
"""
|
"""
|
||||||
class example(self.cls):
|
class example(self.cls):
|
||||||
__public__ = frozenset((
|
__public__ = frozenset((
|
||||||
@ -263,6 +271,7 @@ class test_Proxy(ClassChecker):
|
|||||||
class plugin(base):
|
class plugin(base):
|
||||||
name = 'user_add'
|
name = 'user_add'
|
||||||
attr_name = 'add'
|
attr_name = 'add'
|
||||||
|
doc = 'add a new user'
|
||||||
|
|
||||||
# Test that TypeError is raised when base is not a class:
|
# Test that TypeError is raised when base is not a class:
|
||||||
raises(TypeError, self.cls, base(), None)
|
raises(TypeError, self.cls, base(), None)
|
||||||
@ -273,7 +282,8 @@ class test_Proxy(ClassChecker):
|
|||||||
# Test with correct arguments:
|
# Test with correct arguments:
|
||||||
i = plugin()
|
i = plugin()
|
||||||
p = self.cls(base, i)
|
p = self.cls(base, i)
|
||||||
assert read_only(p, 'name') == 'user_add'
|
assert read_only(p, 'name') is plugin.name
|
||||||
|
assert read_only(p, 'doc') == plugin.doc
|
||||||
assert list(p) == sorted(base.__public__)
|
assert list(p) == sorted(base.__public__)
|
||||||
|
|
||||||
# Test normal methods:
|
# Test normal methods:
|
||||||
@ -304,6 +314,7 @@ class test_Proxy(ClassChecker):
|
|||||||
class base(object):
|
class base(object):
|
||||||
__public__ = frozenset()
|
__public__ = frozenset()
|
||||||
name = 'base'
|
name = 'base'
|
||||||
|
doc = 'doc'
|
||||||
@classmethod
|
@classmethod
|
||||||
def implements(cls, arg):
|
def implements(cls, arg):
|
||||||
return arg + 7
|
return arg + 7
|
||||||
@ -329,6 +340,7 @@ class test_Proxy(ClassChecker):
|
|||||||
__public__ = frozenset()
|
__public__ = frozenset()
|
||||||
class sub(base):
|
class sub(base):
|
||||||
name = 'some_name'
|
name = 'some_name'
|
||||||
|
doc = 'doc'
|
||||||
label = 'another_name'
|
label = 'another_name'
|
||||||
|
|
||||||
p = self.cls(base, sub())
|
p = self.cls(base, sub())
|
||||||
@ -389,6 +401,7 @@ class test_NameSpace(ClassChecker):
|
|||||||
__public__ = frozenset((
|
__public__ = frozenset((
|
||||||
'plusplus',
|
'plusplus',
|
||||||
))
|
))
|
||||||
|
doc = 'doc'
|
||||||
|
|
||||||
def plusplus(self, n):
|
def plusplus(self, n):
|
||||||
return n + 1
|
return n + 1
|
||||||
|
Loading…
Reference in New Issue
Block a user