- improved behavior of add_property() etc., fixed [ticket:831] involving
synonym/deferred
+
+- fixed clear_mappers() behavior to better clean up after itself
- Made access dao dection more reliable [ticket:828]
for mapper in mapper_registry.values():
mapper.dispose()
mapper_registry.clear()
- mapperlib.ClassKey.dispose()
+ mapperlib.ClassKey.dispose(mapperlib.ClassKey)
finally:
mapperlib._COMPILE_MUTEX.release()
instances = {}
def dispose(cls):
- for key in ArgSingleton.instances:
+ for key in list(ArgSingleton.instances):
if key[0] is cls:
del ArgSingleton.instances[key]
- dispose = classmethod(dispose)
+ dispose = staticmethod(dispose)
def __call__(self, *args):
hashkey = (self, args)
import testbase
+import unittest
from sqlalchemy import util, sql, exceptions
from testlib import *
cc3.add(c3)
assert (cc1==cc2).compare(c1 == c2)
assert not (cc1==cc3).compare(c2 == c3)
+
+class ArgSingletonTest(unittest.TestCase):
+ def test_cleanout(self):
+ util.ArgSingleton.instances.clear()
+
+ class MyClass(object):
+ __metaclass__ = util.ArgSingleton
+ def __init__(self, x, y):
+ self.x = x
+ self.y = y
+
+ m1 = MyClass(3, 4)
+ m2 = MyClass(1, 5)
+ m3 = MyClass(3, 4)
+ assert m1 is m3
+ assert m2 is not m3
+ assert len(util.ArgSingleton.instances) == 2
+
+ m1 = m2 = m3 = None
+ MyClass.dispose(MyClass)
+ assert len(util.ArgSingleton.instances) == 0
if __name__ == "__main__":