From 4710c53dcad1ebf3755f3efb9e80ac24bd72a9b2 Mon Sep 17 00:00:00 2001 From: darylm503 Date: Mon, 16 Apr 2012 22:12:42 +0000 Subject: AppPkg/Applications/Python: Add Python 2.7.2 sources since the release of Python 2.7.3 made them unavailable from the python.org web site. These files are a subset of the python-2.7.2.tgz distribution from python.org. Changed files from PyMod-2.7.2 have been copied into the corresponding directories of this tree, replacing the original files in the distribution. Signed-off-by: daryl.mcdaniel@intel.com git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@13197 6f19259b-4bc3-4df7-8a09-765794883524 --- .../Python/Python-2.7.2/Lib/test/test_contains.py | 111 +++++++++++++++++++++ 1 file changed, 111 insertions(+) create mode 100644 AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_contains.py (limited to 'AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_contains.py') diff --git a/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_contains.py b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_contains.py new file mode 100644 index 0000000000..960b6c2682 --- /dev/null +++ b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_contains.py @@ -0,0 +1,111 @@ +from test.test_support import have_unicode, run_unittest +import unittest + + +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] + + +class TestContains(unittest.TestCase): + def test_common_tests(self): + a = base_set(1) + b = set(1) + c = seq(1) + self.assertIn(1, b) + self.assertNotIn(0, b) + self.assertIn(1, c) + self.assertNotIn(0, c) + self.assertRaises(TypeError, lambda: 1 in a) + self.assertRaises(TypeError, lambda: 1 not in a) + + # test char in string + self.assertIn('c', 'abc') + self.assertNotIn('d', 'abc') + + self.assertIn('', '') + self.assertIn('', 'abc') + + self.assertRaises(TypeError, lambda: None in 'abc') + + if have_unicode: + def test_char_in_unicode(self): + self.assertIn('c', unicode('abc')) + self.assertNotIn('d', unicode('abc')) + + self.assertIn('', unicode('')) + self.assertIn(unicode(''), '') + self.assertIn(unicode(''), unicode('')) + self.assertIn('', unicode('abc')) + self.assertIn(unicode(''), 'abc') + self.assertIn(unicode(''), unicode('abc')) + + self.assertRaises(TypeError, lambda: None in unicode('abc')) + + # test Unicode char in Unicode + self.assertIn(unicode('c'), unicode('abc')) + self.assertNotIn(unicode('d'), unicode('abc')) + + # test Unicode char in string + self.assertIn(unicode('c'), 'abc') + self.assertNotIn(unicode('d'), 'abc') + + def test_builtin_sequence_types(self): + # a collection of tests on builtin sequence types + a = range(10) + for i in a: + self.assertIn(i, a) + self.assertNotIn(16, a) + self.assertNotIn(a, a) + + a = tuple(a) + for i in a: + self.assertIn(i, a) + self.assertNotIn(16, a) + self.assertNotIn(a, a) + + class Deviant1: + """Behaves strangely when compared + + This class is designed to make sure that the contains code + works when the list is modified during the check. + """ + aList = range(15) + def __cmp__(self, other): + if other == 12: + self.aList.remove(12) + self.aList.remove(13) + self.aList.remove(14) + return 1 + + self.assertNotIn(Deviant1(), Deviant1.aList) + + class Deviant2: + """Behaves strangely when compared + + This class raises an exception during comparison. That in + turn causes the comparison to fail with a TypeError. + """ + def __cmp__(self, other): + if other == 4: + raise RuntimeError, "gotcha" + + try: + self.assertNotIn(Deviant2(), a) + except TypeError: + pass + + +def test_main(): + run_unittest(TestContains) + +if __name__ == '__main__': + test_main() -- cgit v1.2.3