blob: eb28b891a1d93147aa99446e185fcbf0014144cf [file] [log] [blame]
Steven Bethardae42f332008-03-18 17:26:10 +00001import unittest
Brett Cannon977eb022008-03-19 17:37:43 +00002import sys
Alexandre Vassalottieb83f702008-05-11 07:06:04 +00003from test.test_support import (catch_warning, CleanImport,
4 TestSkipped, run_unittest)
Steven Bethardae42f332008-03-18 17:26:10 +00005import warnings
6
Brett Cannon977eb022008-03-19 17:37:43 +00007if not sys.py3kwarning:
8 raise TestSkipped('%s must be run with the -3 flag' % __name__)
9
Steven Bethardae42f332008-03-18 17:26:10 +000010
11class TestPy3KWarnings(unittest.TestCase):
12
13 def test_type_inequality_comparisons(self):
Georg Brandld5b635f2008-03-25 08:29:14 +000014 expected = 'type inequality comparisons not supported in 3.x'
Steven Bethardae42f332008-03-18 17:26:10 +000015 with catch_warning() as w:
16 self.assertWarning(int < str, w, expected)
17 with catch_warning() as w:
18 self.assertWarning(type < object, w, expected)
19
20 def test_object_inequality_comparisons(self):
Georg Brandld5b635f2008-03-25 08:29:14 +000021 expected = 'comparing unequal types not supported in 3.x'
Steven Bethardae42f332008-03-18 17:26:10 +000022 with catch_warning() as w:
23 self.assertWarning(str < [], w, expected)
24 with catch_warning() as w:
25 self.assertWarning(object() < (1, 2), w, expected)
26
27 def test_dict_inequality_comparisons(self):
Georg Brandld5b635f2008-03-25 08:29:14 +000028 expected = 'dict inequality comparisons not supported in 3.x'
Steven Bethardae42f332008-03-18 17:26:10 +000029 with catch_warning() as w:
30 self.assertWarning({} < {2:3}, w, expected)
31 with catch_warning() as w:
32 self.assertWarning({} <= {}, w, expected)
33 with catch_warning() as w:
34 self.assertWarning({} > {2:3}, w, expected)
35 with catch_warning() as w:
36 self.assertWarning({2:3} >= {}, w, expected)
37
38 def test_cell_inequality_comparisons(self):
Georg Brandld5b635f2008-03-25 08:29:14 +000039 expected = 'cell comparisons not supported in 3.x'
Steven Bethardae42f332008-03-18 17:26:10 +000040 def f(x):
41 def g():
42 return x
43 return g
44 cell0, = f(0).func_closure
45 cell1, = f(1).func_closure
46 with catch_warning() as w:
47 self.assertWarning(cell0 == cell1, w, expected)
48 with catch_warning() as w:
49 self.assertWarning(cell0 < cell1, w, expected)
50
Steven Bethard6a644f92008-03-18 22:08:20 +000051 def test_code_inequality_comparisons(self):
Georg Brandld5b635f2008-03-25 08:29:14 +000052 expected = 'code inequality comparisons not supported in 3.x'
Steven Bethard6a644f92008-03-18 22:08:20 +000053 def f(x):
54 pass
55 def g(x):
56 pass
57 with catch_warning() as w:
58 self.assertWarning(f.func_code < g.func_code, w, expected)
59 with catch_warning() as w:
60 self.assertWarning(f.func_code <= g.func_code, w, expected)
61 with catch_warning() as w:
62 self.assertWarning(f.func_code >= g.func_code, w, expected)
63 with catch_warning() as w:
64 self.assertWarning(f.func_code > g.func_code, w, expected)
65
66 def test_builtin_function_or_method_comparisons(self):
67 expected = ('builtin_function_or_method '
Georg Brandld5b635f2008-03-25 08:29:14 +000068 'inequality comparisons not supported in 3.x')
Steven Bethard6a644f92008-03-18 22:08:20 +000069 func = eval
70 meth = {}.get
71 with catch_warning() as w:
72 self.assertWarning(func < meth, w, expected)
73 with catch_warning() as w:
74 self.assertWarning(func > meth, w, expected)
75 with catch_warning() as w:
76 self.assertWarning(meth <= func, w, expected)
77 with catch_warning() as w:
78 self.assertWarning(meth >= func, w, expected)
79
Steven Bethardae42f332008-03-18 17:26:10 +000080 def assertWarning(self, _, warning, expected_message):
81 self.assertEqual(str(warning.message), expected_message)
82
Raymond Hettinger05387862008-03-19 17:45:19 +000083 def test_sort_cmp_arg(self):
Georg Brandld5b635f2008-03-25 08:29:14 +000084 expected = "the cmp argument is not supported in 3.x"
Raymond Hettinger05387862008-03-19 17:45:19 +000085 lst = range(5)
86 cmp = lambda x,y: -1
87
88 with catch_warning() as w:
89 self.assertWarning(lst.sort(cmp=cmp), w, expected)
90 with catch_warning() as w:
91 self.assertWarning(sorted(lst, cmp=cmp), w, expected)
92 with catch_warning() as w:
93 self.assertWarning(lst.sort(cmp), w, expected)
94 with catch_warning() as w:
95 self.assertWarning(sorted(lst, cmp), w, expected)
96
Georg Brandl5a444242008-03-21 20:11:46 +000097 def test_sys_exc_clear(self):
Georg Brandld5b635f2008-03-25 08:29:14 +000098 expected = 'sys.exc_clear() not supported in 3.x; use except clauses'
Georg Brandl5a444242008-03-21 20:11:46 +000099 with catch_warning() as w:
100 self.assertWarning(sys.exc_clear(), w, expected)
101
Georg Brandl07e56812008-03-21 20:21:46 +0000102 def test_methods_members(self):
103 expected = '__members__ and __methods__ not supported in 3.x'
104 class C:
105 __methods__ = ['a']
106 __members__ = ['b']
107 c = C()
108 with catch_warning() as w:
109 self.assertWarning(dir(c), w, expected)
110
Georg Brandl65bb42d2008-03-21 20:38:24 +0000111 def test_softspace(self):
112 expected = 'file.softspace not supported in 3.x'
113 with file(__file__) as f:
114 with catch_warning() as w:
115 self.assertWarning(f.softspace, w, expected)
116 def set():
117 f.softspace = 0
118 with catch_warning() as w:
119 self.assertWarning(set(), w, expected)
120
Georg Brandl80055f62008-03-25 07:56:27 +0000121 def test_buffer(self):
Georg Brandld5b635f2008-03-25 08:29:14 +0000122 expected = 'buffer() not supported in 3.x; use memoryview()'
Georg Brandl80055f62008-03-25 07:56:27 +0000123 with catch_warning() as w:
124 self.assertWarning(buffer('a'), w, expected)
125
Georg Brandla9916b52008-05-17 22:11:54 +0000126 def test_file_xreadlines(self):
127 expected = ("f.xreadlines() not supported in 3.x, "
128 "try 'for line in f' instead")
129 with file(__file__) as f:
130 with catch_warning() as w:
131 self.assertWarning(f.xreadlines(), w, expected)
132
Georg Brandl07e56812008-03-21 20:21:46 +0000133
Brett Cannone5d2cba2008-05-06 23:23:34 +0000134class TestStdlibRemovals(unittest.TestCase):
135
Brett Cannon3c759142008-05-09 05:25:37 +0000136 # test.testall not tested as it executes all unit tests as an
137 # import side-effect.
Brett Cannon4c1f8812008-05-10 02:27:04 +0000138 all_platforms = ('audiodev', 'imputil', 'mutex', 'user', 'new', 'rexec',
Brett Cannon27508d42008-05-10 22:45:07 +0000139 'Bastion', 'compiler', 'dircache', 'fpformat',
Brett Cannonfa40bbf2008-05-16 00:50:02 +0000140 'ihooks', 'mhlib', 'statvfs')
Brett Cannon54c77aa2008-05-14 21:08:41 +0000141 inclusive_platforms = {'irix' : ('pure', 'AL', 'al', 'CD', 'cd', 'cddb',
Brett Cannon044616a2008-05-15 02:33:55 +0000142 'cdplayer', 'CL', 'cl', 'DEVICE', 'GL',
Brett Cannon75ba4652008-05-15 03:23:17 +0000143 'gl', 'ERRNO', 'FILE', 'FL', 'flp', 'fl',
Brett Cannond8c41ec2008-05-15 03:41:55 +0000144 'fm', 'GET', 'GLWS', 'imgfile', 'IN',
Brett Cannoncd2de082008-05-15 03:51:21 +0000145 'IOCTL', 'jpeg', 'panel', 'panelparser',
Brett Cannon74a596c2008-05-15 04:17:35 +0000146 'readcd', 'SV', 'torgb', 'WAIT'),
Benjamin Peterson23681932008-05-12 21:42:13 +0000147 'darwin' : ('autoGIL', 'Carbon', 'OSATerminology',
Brett Cannonea785fb2008-05-14 01:09:40 +0000148 'icglue', 'Nav', 'MacOS', 'aepack',
149 'aetools', 'aetypes', 'applesingle',
150 'appletrawmain', 'appletrunner',
151 'argvemulator', 'bgenlocations',
Benjamin Peterson23681932008-05-12 21:42:13 +0000152 'EasyDialogs', 'macerrors', 'macostools',
153 'findertools', 'FrameWork', 'ic',
154 'gensuitemodule', 'icopen', 'macresource',
155 'MiniAEFrame', 'pimp', 'PixMapWrapper',
Brett Cannonea785fb2008-05-14 01:09:40 +0000156 'terminalcommand', 'videoreader',
157 '_builtinSuites', 'CodeWarrior',
158 'Explorer', 'Finder', 'Netscape',
159 'StdSuites', 'SystemEvents', 'Terminal',
160 'cfmfile', 'bundlebuilder', 'buildtools',
Brett Cannon22248172008-05-16 00:10:24 +0000161 'ColorPicker'),
162 'sunos5' : ('sunaudiodev', 'SUNAUDIODEV'),
163 }
Brett Cannonac861b52008-05-12 03:45:59 +0000164 optional_modules = ('bsddb185', 'Canvas', 'dl', 'linuxaudiodev', 'imageop',
Alexandre Vassalotti3c4971c2008-05-16 19:14:31 +0000165 'sv', 'cPickle')
Brett Cannone5d2cba2008-05-06 23:23:34 +0000166
Brett Cannon9ac39742008-05-09 22:51:58 +0000167 def check_removal(self, module_name, optional=False):
Brett Cannone5d2cba2008-05-06 23:23:34 +0000168 """Make sure the specified module, when imported, raises a
169 DeprecationWarning and specifies itself in the message."""
Alexandre Vassalottieb83f702008-05-11 07:06:04 +0000170 with CleanImport(module_name):
Brett Cannonddf7a422008-05-10 03:16:38 +0000171 with catch_warning(record=False) as w:
Brett Cannone5d2cba2008-05-06 23:23:34 +0000172 warnings.filterwarnings("error", ".+ removed",
173 DeprecationWarning)
174 try:
175 __import__(module_name, level=0)
176 except DeprecationWarning as exc:
Benjamin Petersonab1fb9f2008-05-12 22:26:05 +0000177 self.assert_(module_name in exc.args[0],
178 "%s warning didn't contain module name"
179 % module_name)
Brett Cannon9ac39742008-05-09 22:51:58 +0000180 except ImportError:
181 if not optional:
Benjamin Petersonbbb09372008-05-13 00:09:46 +0000182 self.fail("Non-optional module {0} raised an "
183 "ImportError.".format(module_name))
Brett Cannone5d2cba2008-05-06 23:23:34 +0000184 else:
Benjamin Petersonbbb09372008-05-13 00:09:46 +0000185 self.fail("DeprecationWarning not raised for {0}"
186 .format(module_name))
Brett Cannone5d2cba2008-05-06 23:23:34 +0000187
188 def test_platform_independent_removals(self):
189 # Make sure that the modules that are available on all platforms raise
190 # the proper DeprecationWarning.
191 for module_name in self.all_platforms:
192 self.check_removal(module_name)
193
Brett Cannon9ac39742008-05-09 22:51:58 +0000194 def test_platform_specific_removals(self):
195 # Test the removal of platform-specific modules.
196 for module_name in self.inclusive_platforms.get(sys.platform, []):
197 self.check_removal(module_name, optional=True)
198
Brett Cannon768d44f2008-05-10 02:47:54 +0000199 def test_optional_module_removals(self):
200 # Test the removal of modules that may or may not be built.
201 for module_name in self.optional_modules:
202 self.check_removal(module_name, optional=True)
203
Benjamin Peterson0893a0a2008-05-09 00:27:01 +0000204 def test_os_path_walk(self):
205 msg = "In 3.x, os.path.walk is removed in favor of os.walk."
206 def dumbo(where, names, args): pass
207 for path_mod in ("ntpath", "macpath", "os2emxpath", "posixpath"):
208 mod = __import__(path_mod)
209 with catch_warning() as w:
210 # Since os3exmpath just imports it from ntpath
211 warnings.simplefilter("always")
212 mod.walk(".", dumbo, None)
213 self.assertEquals(str(w.message), msg)
214
Brett Cannone5d2cba2008-05-06 23:23:34 +0000215
Alexandre Vassalottieb83f702008-05-11 07:06:04 +0000216class TestStdlibRenames(unittest.TestCase):
217
Alexandre Vassalottifb9ce652008-05-12 01:37:10 +0000218 renames = {'copy_reg': 'copyreg', 'Queue': 'queue',
Alexandre Vassalottie3a23c02008-05-14 22:07:07 +0000219 'SocketServer': 'socketserver',
Alexandre Vassalotti95d97c72008-05-16 06:37:57 +0000220 'ConfigParser': 'configparser',
221 'repr': 'reprlib',
Georg Brandlad9afeb2008-05-16 15:48:15 +0000222 'FileDialog': 'tkinter.filedialog',
223 'FixTk': 'tkinter._fix',
224 'ScrolledText': 'tkinter.scrolledtext',
225 'SimpleDialog': 'tkinter.simpledialog',
226 'Tix': 'tkinter.tix',
227 'tkColorChooser': 'tkinter.colorchooser',
228 'tkCommonDialog': 'tkinter.commondialog',
229 'Tkconstants': 'tkinter.constants',
230 'Tkdnd': 'tkinter.dnd',
231 'tkFileDialog': 'tkinter.filedialog',
232 'tkFont': 'tkinter.font',
233 'Tkinter': 'tkinter',
234 'tkMessageBox': 'tkinter.messagebox',
235 'tkSimpleDialog': 'tkinter.simpledialog',
236 'turtle': 'tkinter.turtle'
Alexandre Vassalotti95d97c72008-05-16 06:37:57 +0000237 }
Alexandre Vassalottieb83f702008-05-11 07:06:04 +0000238
Alexandre Vassalotti1fcaa772008-05-11 23:12:38 +0000239 def check_rename(self, module_name, new_module_name):
Alexandre Vassalottieb83f702008-05-11 07:06:04 +0000240 """Make sure that:
241 - A DeprecationWarning is raised when importing using the
242 old 2.x module name.
243 - The module can be imported using the new 3.x name.
244 - The warning message specify both names.
245 """
Alexandre Vassalottieb83f702008-05-11 07:06:04 +0000246 with CleanImport(module_name):
247 with catch_warning(record=False) as w:
248 warnings.filterwarnings("error", ".+ renamed to",
249 DeprecationWarning)
250 try:
251 __import__(module_name, level=0)
252 except DeprecationWarning as exc:
253 self.assert_(module_name in exc.args[0])
254 self.assert_(new_module_name in exc.args[0])
255 else:
256 self.fail("DeprecationWarning not raised for %s" %
257 module_name)
258 with CleanImport(new_module_name):
259 try:
260 __import__(new_module_name, level=0)
Alexandre Vassalotti1fcaa772008-05-11 23:12:38 +0000261 except ImportError:
262 self.fail("cannot import %s with its 3.x name, %s" %
263 module_name, new_module_name)
Alexandre Vassalottieb83f702008-05-11 07:06:04 +0000264 except DeprecationWarning:
265 self.fail("unexpected DeprecationWarning raised for %s" %
266 module_name)
267
Alexandre Vassalotti1fcaa772008-05-11 23:12:38 +0000268 def test_module_renames(self):
269 for module_name, new_module_name in self.renames.items():
Alexandre Vassalottieb83f702008-05-11 07:06:04 +0000270 self.check_rename(module_name, new_module_name)
271
272
Steven Bethardae42f332008-03-18 17:26:10 +0000273def test_main():
Alexandre Vassalottieb83f702008-05-11 07:06:04 +0000274 run_unittest(TestPy3KWarnings,
275 TestStdlibRemovals,
276 TestStdlibRenames)
Steven Bethardae42f332008-03-18 17:26:10 +0000277
278if __name__ == '__main__':
279 test_main()