summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2000-03-06 21:00:29 (GMT)
committerGuido van Rossum <guido@python.org>2000-03-06 21:00:29 (GMT)
commit24512e6a355a8adcdc46d1b78cf92aa4b8aad38a (patch)
treefa66ff1c2c7be49bfd61e47ffdeec9091810f071
parente85c93f52109711f415e860ba41609ae22984d92 (diff)
downloadcpython-24512e6a355a8adcdc46d1b78cf92aa4b8aad38a.zip
cpython-24512e6a355a8adcdc46d1b78cf92aa4b8aad38a.tar.gz
cpython-24512e6a355a8adcdc46d1b78cf92aa4b8aad38a.tar.bz2
Test cases for __contains__ code, by Moshe Zadka.
-rw-r--r--Lib/test/test_contains.py41
1 files changed, 41 insertions, 0 deletions
diff --git a/Lib/test/test_contains.py b/Lib/test/test_contains.py
new file mode 100644
index 0000000..a7ad574
--- /dev/null
+++ b/Lib/test/test_contains.py
@@ -0,0 +1,41 @@
+from test_support import TestFailed
+
+class base_set:
+
+ def __init__(self, el):
+ self.el = el
+
+class set(base_set):
+
+ def __contains__(self, el):
+ return self.el == el
+
+class seq(base_set):
+
+ def __getitem__(self, n):
+ return [self.el][n]
+
+def check(ok, *args):
+ if not ok:
+ raise TestFailed, join(map(str, args), " ")
+
+a = base_set(1)
+b = set(1)
+c = seq(1)
+
+check(1 in b, "1 not in set(1)")
+check(0 not in b, "0 in set(1)")
+check(1 in c, "1 not in seq(1)")
+check(0 not in c, "0 in seq(1)")
+
+try:
+ 1 in a
+ check(0, "in base_set did not raise error")
+except AttributeError:
+ pass
+
+try:
+ 1 not in a
+ check(0, "not in base_set did not raise error")
+except AttributeError:
+ pass