diff options
author | Guido van Rossum <guido@python.org> | 2000-03-06 21:00:29 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 2000-03-06 21:00:29 (GMT) |
commit | 24512e6a355a8adcdc46d1b78cf92aa4b8aad38a (patch) | |
tree | fa66ff1c2c7be49bfd61e47ffdeec9091810f071 | |
parent | e85c93f52109711f415e860ba41609ae22984d92 (diff) | |
download | cpython-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.py | 41 |
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 |