diff options
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/test/test_py3kwarn.py | 60 | ||||
-rw-r--r-- | Lib/test/test_undocumented_details.py | 39 |
2 files changed, 99 insertions, 0 deletions
diff --git a/Lib/test/test_py3kwarn.py b/Lib/test/test_py3kwarn.py new file mode 100644 index 0000000000..61de7a22bd --- /dev/null +++ b/Lib/test/test_py3kwarn.py @@ -0,0 +1,60 @@ +import unittest +from test.test_support import catch_warning, TestSkipped, run_unittest +import warnings + +# TODO: This is a hack to raise TestSkipped if -3 is not enabled. Instead +# of relying on callable to have a warning, we should expose the -3 flag +# to Python code somehow +with catch_warning() as w: + callable(int) + if w.message is None: + raise TestSkipped('%s must be run with the -3 flag' % __name__) + +class TestPy3KWarnings(unittest.TestCase): + + def test_type_inequality_comparisons(self): + expected = 'type inequality comparisons not supported in 3.x.' + with catch_warning() as w: + self.assertWarning(int < str, w, expected) + with catch_warning() as w: + self.assertWarning(type < object, w, expected) + + def test_object_inequality_comparisons(self): + expected = 'comparing unequal types not supported in 3.x.' + with catch_warning() as w: + self.assertWarning(str < [], w, expected) + with catch_warning() as w: + self.assertWarning(object() < (1, 2), w, expected) + + def test_dict_inequality_comparisons(self): + expected = 'dict inequality comparisons not supported in 3.x.' + with catch_warning() as w: + self.assertWarning({} < {2:3}, w, expected) + with catch_warning() as w: + self.assertWarning({} <= {}, w, expected) + with catch_warning() as w: + self.assertWarning({} > {2:3}, w, expected) + with catch_warning() as w: + self.assertWarning({2:3} >= {}, w, expected) + + def test_cell_inequality_comparisons(self): + expected = 'cell comparisons not supported in 3.x.' + def f(x): + def g(): + return x + return g + cell0, = f(0).func_closure + cell1, = f(1).func_closure + with catch_warning() as w: + self.assertWarning(cell0 == cell1, w, expected) + with catch_warning() as w: + self.assertWarning(cell0 < cell1, w, expected) + + def assertWarning(self, _, warning, expected_message): + self.assertEqual(str(warning.message), expected_message) + +def test_main(): + run_unittest(TestPy3KWarnings) + +if __name__ == '__main__': + test_main() diff --git a/Lib/test/test_undocumented_details.py b/Lib/test/test_undocumented_details.py new file mode 100644 index 0000000000..ca66c19f65 --- /dev/null +++ b/Lib/test/test_undocumented_details.py @@ -0,0 +1,39 @@ +from test.test_support import run_unittest, have_unicode +import unittest +import sys + +class TestImplementationComparisons(unittest.TestCase): + + def test_type_comparisons(self): + self.assertTrue(str < int or str > int) + self.assertTrue(int <= str or int >= str) + self.assertTrue(cmp(int, str) != 0) + self.assertTrue(int is int) + self.assertTrue(str == str) + self.assertTrue(int != str) + + def test_cell_comparisons(self): + def f(x): + if x: + y = 1 + def g(): + return x + def h(): + return y + return g, h + g, h = f(0) + g_cell, = g.func_closure + h_cell, = h.func_closure + self.assertTrue(h_cell < g_cell) + self.assertTrue(g_cell >= h_cell) + self.assertEqual(cmp(g_cell, h_cell), 1) + self.assertTrue(g_cell is g_cell) + self.assertTrue(g_cell == g_cell) + self.assertTrue(h_cell == h_cell) + self.assertTrue(g_cell != h_cell) + +def test_main(): + run_unittest(TestImplementationComparisons) + +if __name__ == '__main__': + test_main() |