mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-11 08:41:55 -06:00
165: Added unit tests for plugable.lock() function; replaced occurances of 'self.__lock__()' with 'lock(self)' in plugable.py
This commit is contained in:
parent
887667caa7
commit
d229a76474
@ -18,7 +18,7 @@
|
|||||||
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Implementation of the plugin framework.
|
Plugin framework.
|
||||||
|
|
||||||
The classes in this module make heavy use of Python container emulation. If
|
The classes in this module make heavy use of Python container emulation. If
|
||||||
you are unfamiliar with this Python feature, see
|
you are unfamiliar with this Python feature, see
|
||||||
@ -50,7 +50,7 @@ class ReadOnly(object):
|
|||||||
>>> class givenname(ReadOnly):
|
>>> class givenname(ReadOnly):
|
||||||
>>> def __init__(self):
|
>>> def __init__(self):
|
||||||
>>> self.whatever = 'some value' # Hasn't been locked yet
|
>>> self.whatever = 'some value' # Hasn't been locked yet
|
||||||
>>> self.__lock__()
|
>>> lock(self)
|
||||||
>>>
|
>>>
|
||||||
>>> def finalize(self, api):
|
>>> def finalize(self, api):
|
||||||
>>> # After the instance has been locked, attributes can still be
|
>>> # After the instance has been locked, attributes can still be
|
||||||
@ -106,14 +106,20 @@ class ReadOnly(object):
|
|||||||
return object.__delattr__(self, name)
|
return object.__delattr__(self, name)
|
||||||
|
|
||||||
|
|
||||||
def lock(obj):
|
def lock(readonly):
|
||||||
"""
|
"""
|
||||||
Convenience function to lock a `ReadOnly` instance.
|
Locks a `ReadOnly` instance.
|
||||||
|
|
||||||
|
This is mostly a convenience function to call `ReadOnly.__lock__()`. It
|
||||||
|
also verifies that the locking worked using `ReadOnly.__islocked__()`
|
||||||
|
|
||||||
|
:param readonly: An instance of the `ReadOnly` class.
|
||||||
"""
|
"""
|
||||||
assert isinstance(obj, ReadOnly)
|
if not isinstance(readonly, ReadOnly):
|
||||||
obj.__lock__()
|
raise ValueError('not a ReadOnly instance: %r' % readonly)
|
||||||
assert obj.__islocked__()
|
readonly.__lock__()
|
||||||
return obj
|
assert readonly.__islocked__(), 'Ouch! The locking failed?'
|
||||||
|
return readonly
|
||||||
|
|
||||||
|
|
||||||
class Plugin(ReadOnly):
|
class Plugin(ReadOnly):
|
||||||
@ -282,7 +288,7 @@ class Proxy(ReadOnly):
|
|||||||
self.__public__ = base.__public__
|
self.__public__ = base.__public__
|
||||||
self.name = getattr(target, name_attr)
|
self.name = getattr(target, name_attr)
|
||||||
self.doc = target.doc
|
self.doc = target.doc
|
||||||
self.__lock__()
|
lock(self)
|
||||||
assert type(self.__public__) is frozenset
|
assert type(self.__public__) is frozenset
|
||||||
|
|
||||||
def implements(self, arg):
|
def implements(self, arg):
|
||||||
@ -414,7 +420,7 @@ class NameSpace(ReadOnly):
|
|||||||
"""
|
"""
|
||||||
self.__d = dict()
|
self.__d = dict()
|
||||||
self.__names = tuple(self.__member_iter(members))
|
self.__names = tuple(self.__member_iter(members))
|
||||||
self.__lock__()
|
lock(self)
|
||||||
assert set(self.__d) == set(self.__names)
|
assert set(self.__d) == set(self.__names)
|
||||||
|
|
||||||
def __member_iter(self, members):
|
def __member_iter(self, members):
|
||||||
@ -665,7 +671,7 @@ class API(ReadOnly):
|
|||||||
def __init__(self, *allowed):
|
def __init__(self, *allowed):
|
||||||
self.__keys = tuple(b.__name__ for b in allowed)
|
self.__keys = tuple(b.__name__ for b in allowed)
|
||||||
self.register = Registrar(*allowed)
|
self.register = Registrar(*allowed)
|
||||||
self.__lock__()
|
lock(self)
|
||||||
|
|
||||||
def finalize(self):
|
def finalize(self):
|
||||||
"""
|
"""
|
||||||
|
@ -88,6 +88,35 @@ class test_ReadOnly(ClassChecker):
|
|||||||
assert read_only(obj, 'an_attribute') == 'Hello world!'
|
assert read_only(obj, 'an_attribute') == 'Hello world!'
|
||||||
|
|
||||||
|
|
||||||
|
def test_lock():
|
||||||
|
"""
|
||||||
|
Tests the `plugable.lock` function.
|
||||||
|
"""
|
||||||
|
f = plugable.lock
|
||||||
|
|
||||||
|
# Test on a ReadOnly instance:
|
||||||
|
o = plugable.ReadOnly()
|
||||||
|
assert not o.__islocked__()
|
||||||
|
assert f(o) is o
|
||||||
|
assert o.__islocked__()
|
||||||
|
|
||||||
|
# Test on something not subclassed from ReadOnly:
|
||||||
|
class not_subclass(object):
|
||||||
|
def __lock__(self):
|
||||||
|
pass
|
||||||
|
def __islocked__(self):
|
||||||
|
return True
|
||||||
|
o = not_subclass()
|
||||||
|
raises(ValueError, f, o)
|
||||||
|
|
||||||
|
# Test that it checks __islocked__():
|
||||||
|
class subclass(plugable.ReadOnly):
|
||||||
|
def __islocked__(self):
|
||||||
|
return False
|
||||||
|
o = subclass()
|
||||||
|
raises(AssertionError, f, o)
|
||||||
|
|
||||||
|
|
||||||
class test_Plugin(ClassChecker):
|
class test_Plugin(ClassChecker):
|
||||||
"""
|
"""
|
||||||
Tests the `plugable.Plugin` class.
|
Tests the `plugable.Plugin` class.
|
||||||
|
Loading…
Reference in New Issue
Block a user