summaryrefslogtreecommitdiff
path: root/test/base/test_utils.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2013-08-18 16:05:38 -0400
committerMike Bayer <mike_mp@zzzcomputing.com>2013-08-18 16:05:38 -0400
commit9769628ac1c080dc69b3812bc546ff6df3318cbb (patch)
treed56f3d66e1e134d74e7fa0a092b9413247e094dd /test/base/test_utils.py
parent76e1a76e175ec4acf91e533ce815883316ee5307 (diff)
downloadsqlalchemy-9769628ac1c080dc69b3812bc546ff6df3318cbb.tar.gz
- add WeakSequence.append()
- fix and test weakref cleanout for WeakSequence, [ticket:2794]
Diffstat (limited to 'test/base/test_utils.py')
-rw-r--r--test/base/test_utils.py36
1 files changed, 33 insertions, 3 deletions
diff --git a/test/base/test_utils.py b/test/base/test_utils.py
index aefc6d421..2fd1edbb5 100644
--- a/test/base/test_utils.py
+++ b/test/base/test_utils.py
@@ -1,10 +1,10 @@
import copy
-from sqlalchemy import util, sql, exc
+from sqlalchemy import util, sql, exc, testing
from sqlalchemy.testing import assert_raises, assert_raises_message, fixtures
from sqlalchemy.testing import eq_, is_, ne_, fails_if
-from sqlalchemy.testing.util import picklers
-from sqlalchemy.util import classproperty
+from sqlalchemy.testing.util import picklers, gc_collect
+from sqlalchemy.util import classproperty, WeakSequence
class KeyedTupleTest():
@@ -115,6 +115,36 @@ class KeyedTupleTest():
keyed_tuple[0] = 100
assert_raises(TypeError, should_raise)
+class WeakSequenceTest(fixtures.TestBase):
+ @testing.requires.predictable_gc
+ def test_cleanout_elements(self):
+ class Foo(object):
+ pass
+ f1, f2, f3 = Foo(), Foo(), Foo()
+ w = WeakSequence([f1, f2, f3])
+ eq_(len(w), 3)
+ eq_(len(w._storage), 3)
+ del f2
+ gc_collect()
+ eq_(len(w), 2)
+ eq_(len(w._storage), 2)
+
+ @testing.requires.predictable_gc
+ def test_cleanout_appended(self):
+ class Foo(object):
+ pass
+ f1, f2, f3 = Foo(), Foo(), Foo()
+ w = WeakSequence()
+ w.append(f1)
+ w.append(f2)
+ w.append(f3)
+ eq_(len(w), 3)
+ eq_(len(w._storage), 3)
+ del f2
+ gc_collect()
+ eq_(len(w), 2)
+ eq_(len(w._storage), 2)
+
class OrderedDictTest(fixtures.TestBase):