[Zodb-checkins] CVS: Zope/lib/python/BTrees/tests - testSetOps.py:1.8

Tim Peters tim.one@comcast.net
Mon, 24 Jun 2002 22:00:56 -0400


Update of /cvs-repository/Zope/lib/python/BTrees/tests
In directory cvs.zope.org:/tmp/cvs-serv10293/lib/python/BTrees/tests

Modified Files:
	testSetOps.py 
Log Message:
Enabled multiunion() for the IOBTree package too.  There isn't a good
reason for it not being enabled before.


=== Zope/lib/python/BTrees/tests/testSetOps.py 1.7 => 1.8 ===
 from BTrees.OIBTree import OIBTree, OIBucket, OISet, OITreeSet
 
-from BTrees.IIBTree import multiunion
-
 # XXX TODO Needs more tests.
 # This file was created when multiunion was added.  The other set operations
 # don't appear to be tested anywhere yet.
@@ -195,10 +193,14 @@
     from BTrees.OIBTree import union, intersection, difference
     builders = OISet, OITreeSet, makeBuilder(OIBTree), makeBuilder(OIBucket)
 
-class TestMultiUnion(TestCase):
+# Subclasses must set up (as class variables):
+#     multiunion, union
+#     mkset, mktreeset
+#     mkbucket, mkbtree
+class MultiUnion(TestCase):
 
     def testEmpty(self):
-        self.assertEqual(len(multiunion([])), 0)
+        self.assertEqual(len(self.multiunion([])), 0)
 
     def testOne(self):
         for sequence in [3], range(20), range(-10, 0, 2) + range(1, 10, 2):
@@ -208,22 +210,22 @@
             seqsorted = sequence[:]
             seqsorted.sort()
             for seq in seq1, seq2, seqsorted:
-                for builder in IISet, IITreeSet:
+                for builder in self.mkset, self.mktreeset:
                     input = builder(seq)
-                    output = multiunion([input])
+                    output = self.multiunion([input])
                     self.assertEqual(len(seq), len(output))
                     self.assertEqual(seqsorted, list(output))
 
     def testValuesIgnored(self):
-        for builder in IIBucket, IIBTree:
+        for builder in self.mkbucket, self.mkbtree:
             input = builder([(1, 2), (3, 4), (5, 6)])
-            output = multiunion([input])
+            output = self.multiunion([input])
             self.assertEqual([1, 3, 5], list(output))
 
     def testBigInput(self):
         N = 100000
-        input = IISet(range(N))
-        output = multiunion([input] * 10)
+        input = self.mkset(range(N))
+        output = self.multiunion([input] * 10)
         self.assertEqual(len(output), N)
         self.assertEqual(output.minKey(), 0)
         self.assertEqual(output.maxKey(), N-1)
@@ -233,32 +235,43 @@
         from random import shuffle
         N = 5000
         inputs = []
+        mkset, mktreeset = self.mkset, self.mktreeset
         for i in range(N):
             base = i * 4 - N
-            inputs.append(IISet([base, base+1]))
-            inputs.append(IITreeSet([base+2, base+3]))
+            inputs.append(mkset([base, base+1]))
+            inputs.append(mktreeset([base+2, base+3]))
         shuffle(inputs)
-        output = multiunion(inputs)
+        output = self.multiunion(inputs)
         self.assertEqual(len(output), N*4)
         self.assertEqual(list(output), range(-N, 3*N))
 
     def testFunkyKeyIteration(self):
         # The internal set iteration protocol allows "iterating over" a
         # a single key as if it were a set.
-        from BTrees.IIBTree import union
         N = 100
-        slow = IISet()
+        union, mkset = self.union, self.mkset
+        slow = mkset()
         for i in range(N):
-            slow = union(slow, IISet([i]))
-        fast = multiunion(range(N))  # acts like N distinct singleton sets
+            slow = union(slow, mkset([i]))
+        fast = self.multiunion(range(N))  # acts like N distinct singleton sets
         self.assertEqual(len(slow), N)
         self.assertEqual(len(fast), N)
         self.assertEqual(list(slow.keys()), list(fast.keys()))
         self.assertEqual(list(fast.keys()), range(N))
 
+class TestIIMultiUnion(MultiUnion):
+    from BTrees.IIBTree import multiunion, union
+    from BTrees.IIBTree import IISet as mkset, IITreeSet as mktreeset
+    from BTrees.IIBTree import IIBucket as mkbucket, IIBTree as mkbtree
+
+class TestIOMultiUnion(MultiUnion):
+    from BTrees.IOBTree import multiunion, union
+    from BTrees.IOBTree import IOSet as mkset, IOTreeSet as mktreeset
+    from BTrees.IOBTree import IOBucket as mkbucket, IOBTree as mkbtree
+
 def test_suite():
     s = TestSuite()
-    for klass in (TestMultiUnion,
+    for klass in (TestIIMultiUnion, TestIOMultiUnion,
                   PureII, PureIO, PureOI, PureOO):
         s.addTest(makeSuite(klass))
     return s