diff options
author | Guido van Rossum <guido@python.org> | 1999-03-26 15:32:05 (GMT) |
---|---|---|
committer | Guido van Rossum <guido@python.org> | 1999-03-26 15:32:05 (GMT) |
commit | 3eccc48b5b798c879533acb2611efebca5348bfe (patch) | |
tree | 3c59ee36c6b4b87abd6da4c4130402d9661da94f /Lib | |
parent | 1697b9cdf6b799cbe23c18396dbab3baa8056ce1 (diff) | |
download | cpython-3eccc48b5b798c879533acb2611efebca5348bfe.zip cpython-3eccc48b5b798c879533acb2611efebca5348bfe.tar.gz cpython-3eccc48b5b798c879533acb2611efebca5348bfe.tar.bz2 |
Test suite for UserDict
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/test/output/test_userdict | 1 | ||||
-rw-r--r-- | Lib/test/test_userdict.py | 101 |
2 files changed, 102 insertions, 0 deletions
diff --git a/Lib/test/output/test_userdict b/Lib/test/output/test_userdict new file mode 100644 index 0000000..8c04bd1 --- /dev/null +++ b/Lib/test/output/test_userdict @@ -0,0 +1 @@ +test_userdict diff --git a/Lib/test/test_userdict.py b/Lib/test/test_userdict.py new file mode 100644 index 0000000..63632f7 --- /dev/null +++ b/Lib/test/test_userdict.py @@ -0,0 +1,101 @@ +# Check every path through every method of UserDict + +from UserDict import UserDict + +d0 = {} +d1 = {"one": 1} +d2 = {"one": 1, "two": 2} + +# Test constructors + +u = UserDict() +u0 = UserDict(d0) +u1 = UserDict(d1) +u2 = UserDict(d2) + +uu = UserDict(u) +uu0 = UserDict(u0) +uu1 = UserDict(u1) +uu2 = UserDict(u2) + +# Test __repr__ + +assert str(u0) == str(d0) +assert repr(u1) == repr(d1) +assert `u2` == `d2` + +# Test __cmp__ and __len__ + +all = [d0, d1, d2, u, u0, u1, u2, uu, uu0, uu1, uu2] +for a in all: + for b in all: + assert cmp(a, b) == cmp(len(a), len(b)) + +# Test __getitem__ + +assert u2["one"] == 1 +try: + u1["two"] +except KeyError: + pass +else: + assert 0, "u1['two'] shouldn't exist" + +# Test __setitem__ + +u3 = UserDict(u2) +u3["two"] = 2 +u3["three"] = 3 + +# Test __delitem__ + +del u3["three"] +try: + del u3["three"] +except KeyError: + pass +else: + assert 0, "u3['three'] shouldn't exist" + +# Test clear + +u3.clear() +assert u3 == {} + +# Test copy() + +u2a = u2.copy() +assert u2a == u2 + +class MyUserDict(UserDict): + def display(self): print self + +m2 = MyUserDict(u2) +m2a = m2.copy() +assert m2a == m2 + +# Test keys, items, values + +assert u2.keys() == d2.keys() +assert u2.items() == d2.items() +assert u2.values() == d2.values() + +# Test has_key + +for i in u2.keys(): + assert u2.has_key(i) == 1 + assert u1.has_key(i) == d1.has_key(i) + assert u0.has_key(i) == d0.has_key(i) + +# Test update + +t = UserDict() +t.update(u2) +assert t == u2 + +# Test get + +for i in u2.keys(): + assert u2.get(i) == u2[i] + assert u1.get(i) == d1.get(i) + assert u0.get(i) == d0.get(i) |