2008-03-18 14:26:10 -03:00
|
|
|
import unittest
|
2008-03-19 14:37:43 -03:00
|
|
|
import sys
|
|
|
|
from test.test_support import (catch_warning, TestSkipped, run_unittest,
|
|
|
|
TestSkipped)
|
2008-03-18 14:26:10 -03:00
|
|
|
import warnings
|
|
|
|
|
2008-03-19 14:37:43 -03:00
|
|
|
if not sys.py3kwarning:
|
|
|
|
raise TestSkipped('%s must be run with the -3 flag' % __name__)
|
|
|
|
|
2008-03-18 14:26:10 -03:00
|
|
|
|
|
|
|
class TestPy3KWarnings(unittest.TestCase):
|
|
|
|
|
|
|
|
def test_type_inequality_comparisons(self):
|
2008-03-25 05:29:14 -03:00
|
|
|
expected = 'type inequality comparisons not supported in 3.x'
|
2008-03-18 14:26:10 -03:00
|
|
|
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):
|
2008-03-25 05:29:14 -03:00
|
|
|
expected = 'comparing unequal types not supported in 3.x'
|
2008-03-18 14:26:10 -03:00
|
|
|
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):
|
2008-03-25 05:29:14 -03:00
|
|
|
expected = 'dict inequality comparisons not supported in 3.x'
|
2008-03-18 14:26:10 -03:00
|
|
|
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):
|
2008-03-25 05:29:14 -03:00
|
|
|
expected = 'cell comparisons not supported in 3.x'
|
2008-03-18 14:26:10 -03:00
|
|
|
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)
|
|
|
|
|
2008-03-18 19:08:20 -03:00
|
|
|
def test_code_inequality_comparisons(self):
|
2008-03-25 05:29:14 -03:00
|
|
|
expected = 'code inequality comparisons not supported in 3.x'
|
2008-03-18 19:08:20 -03:00
|
|
|
def f(x):
|
|
|
|
pass
|
|
|
|
def g(x):
|
|
|
|
pass
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(f.func_code < g.func_code, w, expected)
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(f.func_code <= g.func_code, w, expected)
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(f.func_code >= g.func_code, w, expected)
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(f.func_code > g.func_code, w, expected)
|
|
|
|
|
|
|
|
def test_builtin_function_or_method_comparisons(self):
|
|
|
|
expected = ('builtin_function_or_method '
|
2008-03-25 05:29:14 -03:00
|
|
|
'inequality comparisons not supported in 3.x')
|
2008-03-18 19:08:20 -03:00
|
|
|
func = eval
|
|
|
|
meth = {}.get
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(func < meth, w, expected)
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(func > meth, w, expected)
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(meth <= func, w, expected)
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(meth >= func, w, expected)
|
|
|
|
|
2008-03-18 14:26:10 -03:00
|
|
|
def assertWarning(self, _, warning, expected_message):
|
|
|
|
self.assertEqual(str(warning.message), expected_message)
|
|
|
|
|
2008-03-19 14:45:19 -03:00
|
|
|
def test_sort_cmp_arg(self):
|
2008-03-25 05:29:14 -03:00
|
|
|
expected = "the cmp argument is not supported in 3.x"
|
2008-03-19 14:45:19 -03:00
|
|
|
lst = range(5)
|
|
|
|
cmp = lambda x,y: -1
|
|
|
|
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(lst.sort(cmp=cmp), w, expected)
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(sorted(lst, cmp=cmp), w, expected)
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(lst.sort(cmp), w, expected)
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(sorted(lst, cmp), w, expected)
|
|
|
|
|
2008-03-21 17:11:46 -03:00
|
|
|
def test_sys_exc_clear(self):
|
2008-03-25 05:29:14 -03:00
|
|
|
expected = 'sys.exc_clear() not supported in 3.x; use except clauses'
|
2008-03-21 17:11:46 -03:00
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(sys.exc_clear(), w, expected)
|
|
|
|
|
2008-03-21 17:21:46 -03:00
|
|
|
def test_methods_members(self):
|
|
|
|
expected = '__members__ and __methods__ not supported in 3.x'
|
|
|
|
class C:
|
|
|
|
__methods__ = ['a']
|
|
|
|
__members__ = ['b']
|
|
|
|
c = C()
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(dir(c), w, expected)
|
|
|
|
|
2008-03-21 17:38:24 -03:00
|
|
|
def test_softspace(self):
|
|
|
|
expected = 'file.softspace not supported in 3.x'
|
|
|
|
with file(__file__) as f:
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(f.softspace, w, expected)
|
|
|
|
def set():
|
|
|
|
f.softspace = 0
|
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(set(), w, expected)
|
|
|
|
|
2008-03-25 04:56:27 -03:00
|
|
|
def test_buffer(self):
|
2008-03-25 05:29:14 -03:00
|
|
|
expected = 'buffer() not supported in 3.x; use memoryview()'
|
2008-03-25 04:56:27 -03:00
|
|
|
with catch_warning() as w:
|
|
|
|
self.assertWarning(buffer('a'), w, expected)
|
|
|
|
|
2008-03-21 17:21:46 -03:00
|
|
|
|
2008-05-06 20:23:34 -03:00
|
|
|
class TestStdlibRemovals(unittest.TestCase):
|
|
|
|
|
2008-05-09 02:25:37 -03:00
|
|
|
# test.testall not tested as it executes all unit tests as an
|
|
|
|
# import side-effect.
|
2008-05-09 23:27:04 -03:00
|
|
|
all_platforms = ('audiodev', 'imputil', 'mutex', 'user', 'new', 'rexec',
|
2008-05-10 19:45:07 -03:00
|
|
|
'Bastion', 'compiler', 'dircache', 'fpformat',
|
|
|
|
'ihooks')
|
2008-05-09 19:51:58 -03:00
|
|
|
inclusive_platforms = {'irix':('pure',)}
|
2008-05-10 00:14:32 -03:00
|
|
|
# XXX Don't know if lib-tk is only installed if _tkinter is built.
|
2008-05-10 21:50:51 -03:00
|
|
|
optional_modules = ('bsddb185', 'Canvas', 'dl', 'linuxaudiodev')
|
2008-05-06 20:23:34 -03:00
|
|
|
|
2008-05-09 19:51:58 -03:00
|
|
|
def check_removal(self, module_name, optional=False):
|
2008-05-06 20:23:34 -03:00
|
|
|
"""Make sure the specified module, when imported, raises a
|
|
|
|
DeprecationWarning and specifies itself in the message."""
|
|
|
|
original_module = None
|
|
|
|
if module_name in sys.modules:
|
|
|
|
original_module = sys.modules[module_name]
|
|
|
|
del sys.modules[module_name]
|
|
|
|
try:
|
2008-05-10 00:16:38 -03:00
|
|
|
with catch_warning(record=False) as w:
|
2008-05-06 20:23:34 -03:00
|
|
|
warnings.filterwarnings("error", ".+ removed",
|
|
|
|
DeprecationWarning)
|
|
|
|
try:
|
|
|
|
__import__(module_name, level=0)
|
|
|
|
except DeprecationWarning as exc:
|
|
|
|
self.assert_(module_name in exc.args[0])
|
2008-05-09 19:51:58 -03:00
|
|
|
except ImportError:
|
|
|
|
if not optional:
|
|
|
|
raise
|
2008-05-06 20:23:34 -03:00
|
|
|
else:
|
|
|
|
self.fail("DeprecationWarning not raised for %s" %
|
|
|
|
module_name)
|
|
|
|
finally:
|
|
|
|
if original_module:
|
|
|
|
sys.modules[module_name] = original_module
|
|
|
|
|
|
|
|
|
|
|
|
def test_platform_independent_removals(self):
|
|
|
|
# Make sure that the modules that are available on all platforms raise
|
|
|
|
# the proper DeprecationWarning.
|
|
|
|
for module_name in self.all_platforms:
|
|
|
|
self.check_removal(module_name)
|
|
|
|
|
2008-05-09 19:51:58 -03:00
|
|
|
def test_platform_specific_removals(self):
|
|
|
|
# Test the removal of platform-specific modules.
|
|
|
|
for module_name in self.inclusive_platforms.get(sys.platform, []):
|
|
|
|
self.check_removal(module_name, optional=True)
|
|
|
|
|
2008-05-09 23:47:54 -03:00
|
|
|
def test_optional_module_removals(self):
|
|
|
|
# Test the removal of modules that may or may not be built.
|
|
|
|
for module_name in self.optional_modules:
|
|
|
|
self.check_removal(module_name, optional=True)
|
|
|
|
|
2008-05-08 21:27:01 -03:00
|
|
|
def test_os_path_walk(self):
|
|
|
|
msg = "In 3.x, os.path.walk is removed in favor of os.walk."
|
|
|
|
def dumbo(where, names, args): pass
|
|
|
|
for path_mod in ("ntpath", "macpath", "os2emxpath", "posixpath"):
|
|
|
|
mod = __import__(path_mod)
|
|
|
|
with catch_warning() as w:
|
|
|
|
# Since os3exmpath just imports it from ntpath
|
|
|
|
warnings.simplefilter("always")
|
|
|
|
mod.walk(".", dumbo, None)
|
|
|
|
self.assertEquals(str(w.message), msg)
|
|
|
|
|
2008-05-06 20:23:34 -03:00
|
|
|
|
2008-03-18 14:26:10 -03:00
|
|
|
def test_main():
|
2008-05-06 20:23:34 -03:00
|
|
|
run_unittest(TestPy3KWarnings, TestStdlibRemovals)
|
2008-03-18 14:26:10 -03:00
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
test_main()
|