blob: 5c0b0c839bfbc3825dbec19529cad37cf13a9ddf [file] [log] [blame]
Fred Drake38c2ef02001-07-17 20:52:51 +00001# As a test suite for the os module, this is woefully inadequate, but this
2# does add tests for a few functions which have been determined to be more
Walter Dörwaldf0dfc7a2003-10-20 14:01:56 +00003# portable than they had been thought to be.
Fred Drake38c2ef02001-07-17 20:52:51 +00004
5import os
Benjamin Peterson5c6d7872009-02-06 02:40:07 +00006import errno
Fred Drake38c2ef02001-07-17 20:52:51 +00007import unittest
Jeremy Hyltona7fc21b2001-08-20 20:10:01 +00008import warnings
Thomas Wouters477c8d52006-05-27 19:21:47 +00009import sys
Brian Curtineb24d742010-04-12 17:16:38 +000010import signal
11import subprocess
12import time
Martin v. Löwis011e8422009-05-05 04:43:17 +000013import shutil
Benjamin Petersonee8712c2008-05-20 21:35:26 +000014from test import support
Victor Stinnerc2d095f2010-05-17 00:14:53 +000015import contextlib
Hirokazu Yamamoto54c950f2010-10-08 08:38:15 +000016import mmap
Benjamin Peterson799bd802011-08-31 22:15:17 -040017import platform
18import re
Hirokazu Yamamoto54c950f2010-10-08 08:38:15 +000019import uuid
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +000020import asyncore
21import asynchat
22import socket
Charles-François Natali7372b062012-02-05 15:15:38 +010023import itertools
24import stat
Brett Cannonefb00c02012-02-29 18:31:31 -050025import locale
26import codecs
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +000027try:
28 import threading
29except ImportError:
30 threading = None
Georg Brandl2daf6ae2012-02-20 19:54:16 +010031from test.script_helper import assert_python_ok
Fred Drake38c2ef02001-07-17 20:52:51 +000032
Victor Stinner034d0aa2012-06-05 01:22:15 +020033with warnings.catch_warnings():
34 warnings.simplefilter("ignore", DeprecationWarning)
35 os.stat_float_times(True)
Victor Stinner1aa54a42012-02-08 04:09:37 +010036st = os.stat(__file__)
37stat_supports_subsecond = (
38 # check if float and int timestamps are different
39 (st.st_atime != st[7])
40 or (st.st_mtime != st[8])
41 or (st.st_ctime != st[9]))
42
Mark Dickinson7cf03892010-04-16 13:45:35 +000043# Detect whether we're on a Linux system that uses the (now outdated
44# and unmaintained) linuxthreads threading library. There's an issue
45# when combining linuxthreads with a failed execv call: see
46# http://bugs.python.org/issue4970.
Victor Stinnerd5c355c2011-04-30 14:53:09 +020047if hasattr(sys, 'thread_info') and sys.thread_info.version:
48 USING_LINUXTHREADS = sys.thread_info.version.startswith("linuxthreads")
49else:
50 USING_LINUXTHREADS = False
Brian Curtineb24d742010-04-12 17:16:38 +000051
Thomas Wouters0e3f5912006-08-11 14:57:12 +000052# Tests creating TESTFN
53class FileTests(unittest.TestCase):
54 def setUp(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +000055 if os.path.exists(support.TESTFN):
56 os.unlink(support.TESTFN)
Thomas Wouters0e3f5912006-08-11 14:57:12 +000057 tearDown = setUp
58
59 def test_access(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +000060 f = os.open(support.TESTFN, os.O_CREAT|os.O_RDWR)
Thomas Wouters0e3f5912006-08-11 14:57:12 +000061 os.close(f)
Benjamin Petersonc9c0f202009-06-30 23:06:06 +000062 self.assertTrue(os.access(support.TESTFN, os.W_OK))
Thomas Wouters0e3f5912006-08-11 14:57:12 +000063
Christian Heimesfdab48e2008-01-20 09:06:41 +000064 def test_closerange(self):
Antoine Pitroub9ee06c2008-08-16 22:03:17 +000065 first = os.open(support.TESTFN, os.O_CREAT|os.O_RDWR)
66 # We must allocate two consecutive file descriptors, otherwise
67 # it will mess up other file descriptors (perhaps even the three
68 # standard ones).
69 second = os.dup(first)
70 try:
71 retries = 0
72 while second != first + 1:
73 os.close(first)
74 retries += 1
75 if retries > 10:
76 # XXX test skipped
Benjamin Petersonfa0d7032009-06-01 22:42:33 +000077 self.skipTest("couldn't allocate two consecutive fds")
Antoine Pitroub9ee06c2008-08-16 22:03:17 +000078 first, second = second, os.dup(second)
79 finally:
80 os.close(second)
Christian Heimesfdab48e2008-01-20 09:06:41 +000081 # close a fd that is open, and one that isn't
Antoine Pitroub9ee06c2008-08-16 22:03:17 +000082 os.closerange(first, first + 2)
Antoine Pitrou9cadb1b2008-09-15 23:02:56 +000083 self.assertRaises(OSError, os.write, first, b"a")
Thomas Wouters0e3f5912006-08-11 14:57:12 +000084
Benjamin Peterson1cc6df92010-06-30 17:39:45 +000085 @support.cpython_only
Hirokazu Yamamoto4c19e6e2008-09-08 23:41:21 +000086 def test_rename(self):
87 path = support.TESTFN
88 old = sys.getrefcount(path)
89 self.assertRaises(TypeError, os.rename, path, 0)
90 new = sys.getrefcount(path)
91 self.assertEqual(old, new)
92
Antoine Pitrou9cadb1b2008-09-15 23:02:56 +000093 def test_read(self):
94 with open(support.TESTFN, "w+b") as fobj:
95 fobj.write(b"spam")
96 fobj.flush()
97 fd = fobj.fileno()
98 os.lseek(fd, 0, 0)
99 s = os.read(fd, 4)
100 self.assertEqual(type(s), bytes)
101 self.assertEqual(s, b"spam")
102
103 def test_write(self):
104 # os.write() accepts bytes- and buffer-like objects but not strings
105 fd = os.open(support.TESTFN, os.O_CREAT | os.O_WRONLY)
106 self.assertRaises(TypeError, os.write, fd, "beans")
107 os.write(fd, b"bacon\n")
108 os.write(fd, bytearray(b"eggs\n"))
109 os.write(fd, memoryview(b"spam\n"))
110 os.close(fd)
111 with open(support.TESTFN, "rb") as fobj:
Antoine Pitroud62269f2008-09-15 23:54:52 +0000112 self.assertEqual(fobj.read().splitlines(),
113 [b"bacon", b"eggs", b"spam"])
Antoine Pitrou9cadb1b2008-09-15 23:02:56 +0000114
Victor Stinnere0daff12011-03-20 23:36:35 +0100115 def write_windows_console(self, *args):
116 retcode = subprocess.call(args,
117 # use a new console to not flood the test output
118 creationflags=subprocess.CREATE_NEW_CONSOLE,
119 # use a shell to hide the console window (SW_HIDE)
120 shell=True)
121 self.assertEqual(retcode, 0)
122
123 @unittest.skipUnless(sys.platform == 'win32',
124 'test specific to the Windows console')
125 def test_write_windows_console(self):
126 # Issue #11395: the Windows console returns an error (12: not enough
127 # space error) on writing into stdout if stdout mode is binary and the
128 # length is greater than 66,000 bytes (or less, depending on heap
129 # usage).
130 code = "print('x' * 100000)"
131 self.write_windows_console(sys.executable, "-c", code)
132 self.write_windows_console(sys.executable, "-u", "-c", code)
133
Amaury Forgeot d'Arce2e36ba2008-08-01 00:14:22 +0000134 def fdopen_helper(self, *args):
135 fd = os.open(support.TESTFN, os.O_RDONLY)
Victor Stinnerbef7fdf2011-07-01 13:45:30 +0200136 f = os.fdopen(fd, *args)
137 f.close()
Amaury Forgeot d'Arce2e36ba2008-08-01 00:14:22 +0000138
139 def test_fdopen(self):
Victor Stinnerbef7fdf2011-07-01 13:45:30 +0200140 fd = os.open(support.TESTFN, os.O_CREAT|os.O_RDWR)
141 os.close(fd)
142
Amaury Forgeot d'Arce2e36ba2008-08-01 00:14:22 +0000143 self.fdopen_helper()
144 self.fdopen_helper('r')
145 self.fdopen_helper('r', 100)
146
Antoine Pitrouf3b2d882012-01-30 22:08:52 +0100147 def test_replace(self):
148 TESTFN2 = support.TESTFN + ".2"
149 with open(support.TESTFN, 'w') as f:
150 f.write("1")
151 with open(TESTFN2, 'w') as f:
152 f.write("2")
153 self.addCleanup(os.unlink, TESTFN2)
154 os.replace(support.TESTFN, TESTFN2)
155 self.assertRaises(FileNotFoundError, os.stat, support.TESTFN)
156 with open(TESTFN2, 'r') as f:
157 self.assertEqual(f.read(), "1")
158
Victor Stinnerbef7fdf2011-07-01 13:45:30 +0200159
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000160# Test attributes on return values from os.*stat* family.
161class StatAttributeTests(unittest.TestCase):
162 def setUp(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000163 os.mkdir(support.TESTFN)
164 self.fname = os.path.join(support.TESTFN, "f1")
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000165 f = open(self.fname, 'wb')
Guido van Rossum26d95c32007-08-27 23:18:54 +0000166 f.write(b"ABC")
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000167 f.close()
Tim Peterse0c446b2001-10-18 21:57:37 +0000168
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000169 def tearDown(self):
170 os.unlink(self.fname)
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000171 os.rmdir(support.TESTFN)
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000172
Antoine Pitrou38425292010-09-21 18:19:07 +0000173 def check_stat_attributes(self, fname):
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000174 if not hasattr(os, "stat"):
175 return
176
Antoine Pitrou38425292010-09-21 18:19:07 +0000177 result = os.stat(fname)
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000178
179 # Make sure direct access works
Ezio Melottib3aedd42010-11-20 19:04:17 +0000180 self.assertEqual(result[stat.ST_SIZE], 3)
181 self.assertEqual(result.st_size, 3)
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000182
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000183 # Make sure all the attributes are there
184 members = dir(result)
185 for name in dir(stat):
186 if name[:3] == 'ST_':
187 attr = name.lower()
Martin v. Löwis4d394df2005-01-23 09:19:22 +0000188 if name.endswith("TIME"):
189 def trunc(x): return int(x)
190 else:
191 def trunc(x): return x
Ezio Melottib3aedd42010-11-20 19:04:17 +0000192 self.assertEqual(trunc(getattr(result, attr)),
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000193 result[getattr(stat, name)])
Benjamin Peterson577473f2010-01-19 00:09:57 +0000194 self.assertIn(attr, members)
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000195
Larry Hastings6fe20b32012-04-19 15:07:49 -0700196 # Make sure that the st_?time and st_?time_ns fields roughly agree
Larry Hastings76ad59b2012-05-03 00:30:07 -0700197 # (they should always agree up to around tens-of-microseconds)
Larry Hastings6fe20b32012-04-19 15:07:49 -0700198 for name in 'st_atime st_mtime st_ctime'.split():
199 floaty = int(getattr(result, name) * 100000)
200 nanosecondy = getattr(result, name + "_ns") // 10000
Larry Hastings76ad59b2012-05-03 00:30:07 -0700201 self.assertAlmostEqual(floaty, nanosecondy, delta=2)
Larry Hastings6fe20b32012-04-19 15:07:49 -0700202
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000203 try:
204 result[200]
205 self.fail("No exception thrown")
206 except IndexError:
207 pass
208
209 # Make sure that assignment fails
210 try:
211 result.st_mode = 1
212 self.fail("No exception thrown")
Collin Winter42dae6a2007-03-28 21:44:53 +0000213 except AttributeError:
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000214 pass
215
216 try:
217 result.st_rdev = 1
218 self.fail("No exception thrown")
Guido van Rossum1fff8782001-10-18 21:19:31 +0000219 except (AttributeError, TypeError):
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000220 pass
221
222 try:
223 result.parrot = 1
224 self.fail("No exception thrown")
225 except AttributeError:
226 pass
227
228 # Use the stat_result constructor with a too-short tuple.
229 try:
230 result2 = os.stat_result((10,))
231 self.fail("No exception thrown")
232 except TypeError:
233 pass
234
Ezio Melotti42da6632011-03-15 05:18:48 +0200235 # Use the constructor with a too-long tuple.
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000236 try:
237 result2 = os.stat_result((0,1,2,3,4,5,6,7,8,9,10,11,12,13,14))
238 except TypeError:
239 pass
240
Antoine Pitrou38425292010-09-21 18:19:07 +0000241 def test_stat_attributes(self):
242 self.check_stat_attributes(self.fname)
243
244 def test_stat_attributes_bytes(self):
245 try:
246 fname = self.fname.encode(sys.getfilesystemencoding())
247 except UnicodeEncodeError:
248 self.skipTest("cannot encode %a for the filesystem" % self.fname)
Victor Stinner1ab6c2d2011-11-15 22:27:41 +0100249 with warnings.catch_warnings():
250 warnings.simplefilter("ignore", DeprecationWarning)
251 self.check_stat_attributes(fname)
Tim Peterse0c446b2001-10-18 21:57:37 +0000252
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000253 def test_statvfs_attributes(self):
254 if not hasattr(os, "statvfs"):
255 return
256
Martin v. Löwisf90ae202002-06-11 06:22:31 +0000257 try:
258 result = os.statvfs(self.fname)
Guido van Rossumb940e112007-01-10 16:19:56 +0000259 except OSError as e:
Martin v. Löwisf90ae202002-06-11 06:22:31 +0000260 # On AtheOS, glibc always returns ENOSYS
Martin v. Löwisf90ae202002-06-11 06:22:31 +0000261 if e.errno == errno.ENOSYS:
262 return
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000263
264 # Make sure direct access works
Ezio Melottib3aedd42010-11-20 19:04:17 +0000265 self.assertEqual(result.f_bfree, result[3])
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000266
Brett Cannoncfaf10c2008-05-16 00:45:35 +0000267 # Make sure all the attributes are there.
268 members = ('bsize', 'frsize', 'blocks', 'bfree', 'bavail', 'files',
269 'ffree', 'favail', 'flag', 'namemax')
270 for value, member in enumerate(members):
Ezio Melottib3aedd42010-11-20 19:04:17 +0000271 self.assertEqual(getattr(result, 'f_' + member), result[value])
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000272
273 # Make sure that assignment really fails
274 try:
275 result.f_bfree = 1
276 self.fail("No exception thrown")
Collin Winter42dae6a2007-03-28 21:44:53 +0000277 except AttributeError:
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000278 pass
279
280 try:
281 result.parrot = 1
282 self.fail("No exception thrown")
283 except AttributeError:
284 pass
285
286 # Use the constructor with a too-short tuple.
287 try:
288 result2 = os.statvfs_result((10,))
289 self.fail("No exception thrown")
290 except TypeError:
291 pass
292
Ezio Melotti42da6632011-03-15 05:18:48 +0200293 # Use the constructor with a too-long tuple.
Guido van Rossum98bf58f2001-10-18 20:34:25 +0000294 try:
295 result2 = os.statvfs_result((0,1,2,3,4,5,6,7,8,9,10,11,12,13,14))
296 except TypeError:
297 pass
Fred Drake38c2ef02001-07-17 20:52:51 +0000298
Thomas Wouters89f507f2006-12-13 04:49:30 +0000299 def test_utime_dir(self):
300 delta = 1000000
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000301 st = os.stat(support.TESTFN)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000302 # round to int, because some systems may support sub-second
303 # time stamps in stat, but not in utime.
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000304 os.utime(support.TESTFN, (st.st_atime, int(st.st_mtime-delta)))
305 st2 = os.stat(support.TESTFN)
Ezio Melottib3aedd42010-11-20 19:04:17 +0000306 self.assertEqual(st2.st_mtime, int(st.st_mtime-delta))
Thomas Wouters89f507f2006-12-13 04:49:30 +0000307
Larry Hastings76ad59b2012-05-03 00:30:07 -0700308 def _test_utime(self, filename, attr, utime, delta):
Brian Curtin0277aa32011-11-06 13:50:15 -0600309 # Issue #13327 removed the requirement to pass None as the
Brian Curtin52fbea12011-11-06 13:41:17 -0600310 # second argument. Check that the previous methods of passing
311 # a time tuple or None work in addition to no argument.
Larry Hastings76ad59b2012-05-03 00:30:07 -0700312 st0 = os.stat(filename)
Brian Curtin52fbea12011-11-06 13:41:17 -0600313 # Doesn't set anything new, but sets the time tuple way
Larry Hastings76ad59b2012-05-03 00:30:07 -0700314 utime(filename, (attr(st0, "st_atime"), attr(st0, "st_mtime")))
315 # Setting the time to the time you just read, then reading again,
316 # should always return exactly the same times.
317 st1 = os.stat(filename)
318 self.assertEqual(attr(st0, "st_mtime"), attr(st1, "st_mtime"))
319 self.assertEqual(attr(st0, "st_atime"), attr(st1, "st_atime"))
Brian Curtin52fbea12011-11-06 13:41:17 -0600320 # Set to the current time in the old explicit way.
Larry Hastings76ad59b2012-05-03 00:30:07 -0700321 os.utime(filename, None)
Brian Curtin52fbea12011-11-06 13:41:17 -0600322 st2 = os.stat(support.TESTFN)
Larry Hastings76ad59b2012-05-03 00:30:07 -0700323 # Set to the current time in the new way
324 os.utime(filename)
325 st3 = os.stat(filename)
326 self.assertAlmostEqual(attr(st2, "st_mtime"), attr(st3, "st_mtime"), delta=delta)
327
328 def test_utime(self):
329 def utime(file, times):
330 return os.utime(file, times)
331 self._test_utime(self.fname, getattr, utime, 10)
332 self._test_utime(support.TESTFN, getattr, utime, 10)
333
334
335 def _test_utime_ns(self, set_times_ns, test_dir=True):
336 def getattr_ns(o, attr):
337 return getattr(o, attr + "_ns")
338 ten_s = 10 * 1000 * 1000 * 1000
339 self._test_utime(self.fname, getattr_ns, set_times_ns, ten_s)
340 if test_dir:
341 self._test_utime(support.TESTFN, getattr_ns, set_times_ns, ten_s)
342
343 def test_utime_ns(self):
344 def utime_ns(file, times):
345 return os.utime(file, ns=times)
346 self._test_utime_ns(utime_ns)
347
Larry Hastings9cf065c2012-06-22 16:30:09 -0700348 requires_utime_dir_fd = unittest.skipUnless(
349 os.utime in os.supports_dir_fd,
350 "dir_fd support for utime required for this test.")
351 requires_utime_fd = unittest.skipUnless(
352 os.utime in os.supports_fd,
353 "fd support for utime required for this test.")
354 requires_utime_nofollow_symlinks = unittest.skipUnless(
355 os.utime in os.supports_follow_symlinks,
356 "follow_symlinks support for utime required for this test.")
Larry Hastings76ad59b2012-05-03 00:30:07 -0700357
Larry Hastings9cf065c2012-06-22 16:30:09 -0700358 @requires_utime_nofollow_symlinks
Larry Hastings76ad59b2012-05-03 00:30:07 -0700359 def test_lutimes_ns(self):
360 def lutimes_ns(file, times):
Larry Hastings9cf065c2012-06-22 16:30:09 -0700361 return os.utime(file, ns=times, follow_symlinks=False)
Larry Hastings76ad59b2012-05-03 00:30:07 -0700362 self._test_utime_ns(lutimes_ns)
363
Larry Hastings9cf065c2012-06-22 16:30:09 -0700364 @requires_utime_fd
Larry Hastings76ad59b2012-05-03 00:30:07 -0700365 def test_futimes_ns(self):
366 def futimes_ns(file, times):
367 with open(file, "wb") as f:
Larry Hastings9cf065c2012-06-22 16:30:09 -0700368 os.utime(f.fileno(), ns=times)
Larry Hastings76ad59b2012-05-03 00:30:07 -0700369 self._test_utime_ns(futimes_ns, test_dir=False)
370
371 def _utime_invalid_arguments(self, name, arg):
Larry Hastings9cf065c2012-06-22 16:30:09 -0700372 with self.assertRaises(ValueError):
Larry Hastings76ad59b2012-05-03 00:30:07 -0700373 getattr(os, name)(arg, (5, 5), ns=(5, 5))
374
375 def test_utime_invalid_arguments(self):
376 self._utime_invalid_arguments('utime', self.fname)
377
Brian Curtin52fbea12011-11-06 13:41:17 -0600378
Victor Stinner1aa54a42012-02-08 04:09:37 +0100379 @unittest.skipUnless(stat_supports_subsecond,
380 "os.stat() doesn't has a subsecond resolution")
Victor Stinnera2f7c002012-02-08 03:36:25 +0100381 def _test_utime_subsecond(self, set_time_func):
Victor Stinnerbe557de2012-02-08 03:01:11 +0100382 asec, amsec = 1, 901
383 atime = asec + amsec * 1e-3
Victor Stinnera2f7c002012-02-08 03:36:25 +0100384 msec, mmsec = 2, 901
Victor Stinnerbe557de2012-02-08 03:01:11 +0100385 mtime = msec + mmsec * 1e-3
386 filename = self.fname
Victor Stinnera2f7c002012-02-08 03:36:25 +0100387 os.utime(filename, (0, 0))
388 set_time_func(filename, atime, mtime)
Victor Stinner034d0aa2012-06-05 01:22:15 +0200389 with warnings.catch_warnings():
390 warnings.simplefilter("ignore", DeprecationWarning)
391 os.stat_float_times(True)
Victor Stinnera2f7c002012-02-08 03:36:25 +0100392 st = os.stat(filename)
393 self.assertAlmostEqual(st.st_atime, atime, places=3)
394 self.assertAlmostEqual(st.st_mtime, mtime, places=3)
Victor Stinnerbe557de2012-02-08 03:01:11 +0100395
Victor Stinnera2f7c002012-02-08 03:36:25 +0100396 def test_utime_subsecond(self):
397 def set_time(filename, atime, mtime):
398 os.utime(filename, (atime, mtime))
399 self._test_utime_subsecond(set_time)
400
Larry Hastings9cf065c2012-06-22 16:30:09 -0700401 @requires_utime_fd
Victor Stinnera2f7c002012-02-08 03:36:25 +0100402 def test_futimes_subsecond(self):
403 def set_time(filename, atime, mtime):
404 with open(filename, "wb") as f:
Larry Hastings9cf065c2012-06-22 16:30:09 -0700405 os.utime(f.fileno(), times=(atime, mtime))
Victor Stinnera2f7c002012-02-08 03:36:25 +0100406 self._test_utime_subsecond(set_time)
407
Larry Hastings9cf065c2012-06-22 16:30:09 -0700408 @requires_utime_fd
Victor Stinnera2f7c002012-02-08 03:36:25 +0100409 def test_futimens_subsecond(self):
410 def set_time(filename, atime, mtime):
411 with open(filename, "wb") as f:
Larry Hastings9cf065c2012-06-22 16:30:09 -0700412 os.utime(f.fileno(), times=(atime, mtime))
Victor Stinnera2f7c002012-02-08 03:36:25 +0100413 self._test_utime_subsecond(set_time)
414
Larry Hastings9cf065c2012-06-22 16:30:09 -0700415 @requires_utime_dir_fd
Victor Stinnera2f7c002012-02-08 03:36:25 +0100416 def test_futimesat_subsecond(self):
417 def set_time(filename, atime, mtime):
418 dirname = os.path.dirname(filename)
419 dirfd = os.open(dirname, os.O_RDONLY)
420 try:
Larry Hastings9cf065c2012-06-22 16:30:09 -0700421 os.utime(os.path.basename(filename), dir_fd=dirfd,
422 times=(atime, mtime))
Victor Stinnera2f7c002012-02-08 03:36:25 +0100423 finally:
424 os.close(dirfd)
425 self._test_utime_subsecond(set_time)
426
Larry Hastings9cf065c2012-06-22 16:30:09 -0700427 @requires_utime_nofollow_symlinks
Victor Stinnera2f7c002012-02-08 03:36:25 +0100428 def test_lutimes_subsecond(self):
429 def set_time(filename, atime, mtime):
Larry Hastings9cf065c2012-06-22 16:30:09 -0700430 os.utime(filename, (atime, mtime), follow_symlinks=False)
Victor Stinnera2f7c002012-02-08 03:36:25 +0100431 self._test_utime_subsecond(set_time)
432
Larry Hastings9cf065c2012-06-22 16:30:09 -0700433 @requires_utime_dir_fd
Victor Stinnera2f7c002012-02-08 03:36:25 +0100434 def test_utimensat_subsecond(self):
435 def set_time(filename, atime, mtime):
436 dirname = os.path.dirname(filename)
437 dirfd = os.open(dirname, os.O_RDONLY)
438 try:
Larry Hastings9cf065c2012-06-22 16:30:09 -0700439 os.utime(os.path.basename(filename), dir_fd=dirfd,
440 times=(atime, mtime))
Victor Stinnera2f7c002012-02-08 03:36:25 +0100441 finally:
442 os.close(dirfd)
443 self._test_utime_subsecond(set_time)
Victor Stinnerbe557de2012-02-08 03:01:11 +0100444
Thomas Wouters89f507f2006-12-13 04:49:30 +0000445 # Restrict test to Win32, since there is no guarantee other
446 # systems support centiseconds
447 if sys.platform == 'win32':
Thomas Wouters47b49bf2007-08-30 22:15:33 +0000448 def get_file_system(path):
Hirokazu Yamamoto5ef6d182008-08-20 04:17:24 +0000449 root = os.path.splitdrive(os.path.abspath(path))[0] + '\\'
Thomas Wouters47b49bf2007-08-30 22:15:33 +0000450 import ctypes
Hirokazu Yamamotoca765d52008-08-20 16:18:19 +0000451 kernel32 = ctypes.windll.kernel32
Hirokazu Yamamoto5ef6d182008-08-20 04:17:24 +0000452 buf = ctypes.create_unicode_buffer("", 100)
Hirokazu Yamamotoca765d52008-08-20 16:18:19 +0000453 if kernel32.GetVolumeInformationW(root, None, 0, None, None, None, buf, len(buf)):
Thomas Wouters47b49bf2007-08-30 22:15:33 +0000454 return buf.value
455
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000456 if get_file_system(support.TESTFN) == "NTFS":
Thomas Wouters47b49bf2007-08-30 22:15:33 +0000457 def test_1565150(self):
458 t1 = 1159195039.25
459 os.utime(self.fname, (t1, t1))
Ezio Melottib3aedd42010-11-20 19:04:17 +0000460 self.assertEqual(os.stat(self.fname).st_mtime, t1)
Thomas Wouters89f507f2006-12-13 04:49:30 +0000461
Amaury Forgeot d'Arca251a852011-01-03 00:19:11 +0000462 def test_large_time(self):
463 t1 = 5000000000 # some day in 2128
464 os.utime(self.fname, (t1, t1))
465 self.assertEqual(os.stat(self.fname).st_mtime, t1)
466
Guido van Rossumd8faa362007-04-27 19:54:29 +0000467 def test_1686475(self):
468 # Verify that an open file can be stat'ed
469 try:
470 os.stat(r"c:\pagefile.sys")
471 except WindowsError as e:
Benjamin Petersonc4fe6f32008-08-19 18:57:56 +0000472 if e.errno == 2: # file does not exist; cannot run test
Guido van Rossumd8faa362007-04-27 19:54:29 +0000473 return
474 self.fail("Could not stat pagefile.sys")
475
Richard Oudkerk2240ac12012-07-06 12:05:32 +0100476 @unittest.skipUnless(hasattr(os, "pipe"), "requires os.pipe()")
477 def test_15261(self):
478 # Verify that stat'ing a closed fd does not cause crash
479 r, w = os.pipe()
480 try:
481 os.stat(r) # should not raise error
482 finally:
483 os.close(r)
484 os.close(w)
485 with self.assertRaises(OSError) as ctx:
486 os.stat(r)
487 self.assertEqual(ctx.exception.errno, errno.EBADF)
488
Walter Dörwald0a6d0ff2004-05-31 16:29:04 +0000489from test import mapping_tests
Raymond Hettinger2c2d3222003-03-09 07:05:43 +0000490
Walter Dörwald0a6d0ff2004-05-31 16:29:04 +0000491class EnvironTests(mapping_tests.BasicTestMappingProtocol):
Raymond Hettinger2c2d3222003-03-09 07:05:43 +0000492 """check that os.environ object conform to mapping protocol"""
Walter Dörwald118f9312004-06-02 18:42:25 +0000493 type2test = None
Christian Heimes90333392007-11-01 19:08:42 +0000494
Raymond Hettinger2c2d3222003-03-09 07:05:43 +0000495 def setUp(self):
496 self.__save = dict(os.environ)
Victor Stinnerb745a742010-05-18 17:17:23 +0000497 if os.supports_bytes_environ:
Victor Stinner208d28c2010-05-07 00:54:14 +0000498 self.__saveb = dict(os.environb)
Christian Heimes90333392007-11-01 19:08:42 +0000499 for key, value in self._reference().items():
500 os.environ[key] = value
501
Raymond Hettinger2c2d3222003-03-09 07:05:43 +0000502 def tearDown(self):
503 os.environ.clear()
504 os.environ.update(self.__save)
Victor Stinnerb745a742010-05-18 17:17:23 +0000505 if os.supports_bytes_environ:
Victor Stinner208d28c2010-05-07 00:54:14 +0000506 os.environb.clear()
507 os.environb.update(self.__saveb)
Raymond Hettinger2c2d3222003-03-09 07:05:43 +0000508
Christian Heimes90333392007-11-01 19:08:42 +0000509 def _reference(self):
510 return {"KEY1":"VALUE1", "KEY2":"VALUE2", "KEY3":"VALUE3"}
511
512 def _empty_mapping(self):
513 os.environ.clear()
514 return os.environ
515
Martin v. Löwis1d11de62005-01-29 13:29:23 +0000516 # Bug 1110478
Martin v. Löwis5510f652005-02-17 21:23:20 +0000517 def test_update2(self):
Christian Heimes90333392007-11-01 19:08:42 +0000518 os.environ.clear()
Martin v. Löwis1d11de62005-01-29 13:29:23 +0000519 if os.path.exists("/bin/sh"):
520 os.environ.update(HELLO="World")
Brian Curtin810921b2010-10-30 21:24:21 +0000521 with os.popen("/bin/sh -c 'echo $HELLO'") as popen:
522 value = popen.read().strip()
Ezio Melottib3aedd42010-11-20 19:04:17 +0000523 self.assertEqual(value, "World")
Martin v. Löwis1d11de62005-01-29 13:29:23 +0000524
Christian Heimes1a13d592007-11-08 14:16:55 +0000525 def test_os_popen_iter(self):
526 if os.path.exists("/bin/sh"):
Brian Curtin810921b2010-10-30 21:24:21 +0000527 with os.popen(
528 "/bin/sh -c 'echo \"line1\nline2\nline3\"'") as popen:
529 it = iter(popen)
Ezio Melottib3aedd42010-11-20 19:04:17 +0000530 self.assertEqual(next(it), "line1\n")
531 self.assertEqual(next(it), "line2\n")
532 self.assertEqual(next(it), "line3\n")
Brian Curtin810921b2010-10-30 21:24:21 +0000533 self.assertRaises(StopIteration, next, it)
Christian Heimes1a13d592007-11-08 14:16:55 +0000534
Guido van Rossum67aca9e2007-06-13 21:51:27 +0000535 # Verify environ keys and values from the OS are of the
536 # correct str type.
537 def test_keyvalue_types(self):
538 for key, val in os.environ.items():
Ezio Melottib3aedd42010-11-20 19:04:17 +0000539 self.assertEqual(type(key), str)
540 self.assertEqual(type(val), str)
Guido van Rossum67aca9e2007-06-13 21:51:27 +0000541
Christian Heimes90333392007-11-01 19:08:42 +0000542 def test_items(self):
543 for key, value in self._reference().items():
544 self.assertEqual(os.environ.get(key), value)
545
Ezio Melotti19e4acf2010-02-22 15:59:01 +0000546 # Issue 7310
547 def test___repr__(self):
548 """Check that the repr() of os.environ looks like environ({...})."""
549 env = os.environ
Victor Stinner96f0de92010-07-29 00:29:00 +0000550 self.assertEqual(repr(env), 'environ({{{}}})'.format(', '.join(
551 '{!r}: {!r}'.format(key, value)
552 for key, value in env.items())))
Ezio Melotti19e4acf2010-02-22 15:59:01 +0000553
Gregory P. Smithb6e8c7e2010-02-27 07:22:22 +0000554 def test_get_exec_path(self):
555 defpath_list = os.defpath.split(os.pathsep)
556 test_path = ['/monty', '/python', '', '/flying/circus']
557 test_env = {'PATH': os.pathsep.join(test_path)}
558
559 saved_environ = os.environ
560 try:
561 os.environ = dict(test_env)
562 # Test that defaulting to os.environ works.
563 self.assertSequenceEqual(test_path, os.get_exec_path())
564 self.assertSequenceEqual(test_path, os.get_exec_path(env=None))
565 finally:
566 os.environ = saved_environ
567
568 # No PATH environment variable
569 self.assertSequenceEqual(defpath_list, os.get_exec_path({}))
570 # Empty PATH environment variable
571 self.assertSequenceEqual(('',), os.get_exec_path({'PATH':''}))
572 # Supplied PATH environment variable
573 self.assertSequenceEqual(test_path, os.get_exec_path(test_env))
574
Victor Stinnerb745a742010-05-18 17:17:23 +0000575 if os.supports_bytes_environ:
576 # env cannot contain 'PATH' and b'PATH' keys
Victor Stinner38430e22010-08-19 17:10:18 +0000577 try:
Victor Stinner6f35eda2010-10-29 00:38:58 +0000578 # ignore BytesWarning warning
579 with warnings.catch_warnings(record=True):
580 mixed_env = {'PATH': '1', b'PATH': b'2'}
Victor Stinner38430e22010-08-19 17:10:18 +0000581 except BytesWarning:
Victor Stinner6f35eda2010-10-29 00:38:58 +0000582 # mixed_env cannot be created with python -bb
Victor Stinner38430e22010-08-19 17:10:18 +0000583 pass
584 else:
585 self.assertRaises(ValueError, os.get_exec_path, mixed_env)
Victor Stinnerb745a742010-05-18 17:17:23 +0000586
587 # bytes key and/or value
588 self.assertSequenceEqual(os.get_exec_path({b'PATH': b'abc'}),
589 ['abc'])
590 self.assertSequenceEqual(os.get_exec_path({b'PATH': 'abc'}),
591 ['abc'])
592 self.assertSequenceEqual(os.get_exec_path({'PATH': b'abc'}),
593 ['abc'])
594
595 @unittest.skipUnless(os.supports_bytes_environ,
596 "os.environb required for this test.")
Victor Stinner84ae1182010-05-06 22:05:07 +0000597 def test_environb(self):
598 # os.environ -> os.environb
599 value = 'euro\u20ac'
600 try:
Benjamin Peterson180799d2010-05-06 22:25:42 +0000601 value_bytes = value.encode(sys.getfilesystemencoding(),
602 'surrogateescape')
Victor Stinner84ae1182010-05-06 22:05:07 +0000603 except UnicodeEncodeError:
Benjamin Peterson180799d2010-05-06 22:25:42 +0000604 msg = "U+20AC character is not encodable to %s" % (
605 sys.getfilesystemencoding(),)
Benjamin Peterson932d3f42010-05-06 22:26:31 +0000606 self.skipTest(msg)
Victor Stinner84ae1182010-05-06 22:05:07 +0000607 os.environ['unicode'] = value
Ezio Melottib3aedd42010-11-20 19:04:17 +0000608 self.assertEqual(os.environ['unicode'], value)
609 self.assertEqual(os.environb[b'unicode'], value_bytes)
Victor Stinner84ae1182010-05-06 22:05:07 +0000610
611 # os.environb -> os.environ
612 value = b'\xff'
613 os.environb[b'bytes'] = value
Ezio Melottib3aedd42010-11-20 19:04:17 +0000614 self.assertEqual(os.environb[b'bytes'], value)
Victor Stinner84ae1182010-05-06 22:05:07 +0000615 value_str = value.decode(sys.getfilesystemencoding(), 'surrogateescape')
Ezio Melottib3aedd42010-11-20 19:04:17 +0000616 self.assertEqual(os.environ['bytes'], value_str)
Ezio Melotti19e4acf2010-02-22 15:59:01 +0000617
Charles-François Natali2966f102011-11-26 11:32:46 +0100618 # On FreeBSD < 7 and OS X < 10.6, unsetenv() doesn't return a value (issue
619 # #13415).
620 @support.requires_freebsd_version(7)
621 @support.requires_mac_ver(10, 6)
Victor Stinner60b385e2011-11-22 22:01:28 +0100622 def test_unset_error(self):
623 if sys.platform == "win32":
624 # an environment variable is limited to 32,767 characters
625 key = 'x' * 50000
Victor Stinnerb3f82682011-11-22 22:30:19 +0100626 self.assertRaises(ValueError, os.environ.__delitem__, key)
Victor Stinner60b385e2011-11-22 22:01:28 +0100627 else:
628 # "=" is not allowed in a variable name
629 key = 'key='
Victor Stinnerb3f82682011-11-22 22:30:19 +0100630 self.assertRaises(OSError, os.environ.__delitem__, key)
Victor Stinner60b385e2011-11-22 22:01:28 +0100631
Tim Petersc4e09402003-04-25 07:11:48 +0000632class WalkTests(unittest.TestCase):
633 """Tests for os.walk()."""
634
Charles-François Natali7372b062012-02-05 15:15:38 +0100635 def setUp(self):
Tim Petersc4e09402003-04-25 07:11:48 +0000636 import os
637 from os.path import join
638
639 # Build:
Guido van Rossumd8faa362007-04-27 19:54:29 +0000640 # TESTFN/
641 # TEST1/ a file kid and two directory kids
Tim Petersc4e09402003-04-25 07:11:48 +0000642 # tmp1
643 # SUB1/ a file kid and a directory kid
Guido van Rossumd8faa362007-04-27 19:54:29 +0000644 # tmp2
645 # SUB11/ no kids
646 # SUB2/ a file kid and a dirsymlink kid
647 # tmp3
648 # link/ a symlink to TESTFN.2
Hynek Schlawack66bfcc12012-05-15 16:32:21 +0200649 # broken_link
Guido van Rossumd8faa362007-04-27 19:54:29 +0000650 # TEST2/
651 # tmp4 a lone file
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000652 walk_path = join(support.TESTFN, "TEST1")
Guido van Rossumd8faa362007-04-27 19:54:29 +0000653 sub1_path = join(walk_path, "SUB1")
Tim Petersc4e09402003-04-25 07:11:48 +0000654 sub11_path = join(sub1_path, "SUB11")
Guido van Rossumd8faa362007-04-27 19:54:29 +0000655 sub2_path = join(walk_path, "SUB2")
656 tmp1_path = join(walk_path, "tmp1")
Tim Petersc4e09402003-04-25 07:11:48 +0000657 tmp2_path = join(sub1_path, "tmp2")
658 tmp3_path = join(sub2_path, "tmp3")
Guido van Rossumd8faa362007-04-27 19:54:29 +0000659 link_path = join(sub2_path, "link")
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000660 t2_path = join(support.TESTFN, "TEST2")
661 tmp4_path = join(support.TESTFN, "TEST2", "tmp4")
Hynek Schlawack66bfcc12012-05-15 16:32:21 +0200662 link_path = join(sub2_path, "link")
663 broken_link_path = join(sub2_path, "broken_link")
Tim Petersc4e09402003-04-25 07:11:48 +0000664
665 # Create stuff.
666 os.makedirs(sub11_path)
667 os.makedirs(sub2_path)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000668 os.makedirs(t2_path)
669 for path in tmp1_path, tmp2_path, tmp3_path, tmp4_path:
Alex Martelli01c77c62006-08-24 02:58:11 +0000670 f = open(path, "w")
Tim Petersc4e09402003-04-25 07:11:48 +0000671 f.write("I'm " + path + " and proud of it. Blame test_os.\n")
672 f.close()
Brian Curtin3b4499c2010-12-28 14:31:47 +0000673 if support.can_symlink():
Antoine Pitrou5311c1d2012-01-24 08:59:28 +0100674 if os.name == 'nt':
675 def symlink_to_dir(src, dest):
676 os.symlink(src, dest, True)
677 else:
678 symlink_to_dir = os.symlink
679 symlink_to_dir(os.path.abspath(t2_path), link_path)
Hynek Schlawack66bfcc12012-05-15 16:32:21 +0200680 symlink_to_dir('broken', broken_link_path)
681 sub2_tree = (sub2_path, ["link"], ["broken_link", "tmp3"])
Guido van Rossumd8faa362007-04-27 19:54:29 +0000682 else:
683 sub2_tree = (sub2_path, [], ["tmp3"])
Tim Petersc4e09402003-04-25 07:11:48 +0000684
685 # Walk top-down.
Guido van Rossumd8faa362007-04-27 19:54:29 +0000686 all = list(os.walk(walk_path))
Tim Petersc4e09402003-04-25 07:11:48 +0000687 self.assertEqual(len(all), 4)
688 # We can't know which order SUB1 and SUB2 will appear in.
689 # Not flipped: TESTFN, SUB1, SUB11, SUB2
690 # flipped: TESTFN, SUB2, SUB1, SUB11
691 flipped = all[0][1][0] != "SUB1"
692 all[0][1].sort()
Hynek Schlawackc96f5a02012-05-15 17:55:38 +0200693 all[3 - 2 * flipped][-1].sort()
Guido van Rossumd8faa362007-04-27 19:54:29 +0000694 self.assertEqual(all[0], (walk_path, ["SUB1", "SUB2"], ["tmp1"]))
Tim Petersc4e09402003-04-25 07:11:48 +0000695 self.assertEqual(all[1 + flipped], (sub1_path, ["SUB11"], ["tmp2"]))
696 self.assertEqual(all[2 + flipped], (sub11_path, [], []))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000697 self.assertEqual(all[3 - 2 * flipped], sub2_tree)
Tim Petersc4e09402003-04-25 07:11:48 +0000698
699 # Prune the search.
700 all = []
Guido van Rossumd8faa362007-04-27 19:54:29 +0000701 for root, dirs, files in os.walk(walk_path):
Tim Petersc4e09402003-04-25 07:11:48 +0000702 all.append((root, dirs, files))
703 # Don't descend into SUB1.
704 if 'SUB1' in dirs:
705 # Note that this also mutates the dirs we appended to all!
706 dirs.remove('SUB1')
707 self.assertEqual(len(all), 2)
Guido van Rossumd8faa362007-04-27 19:54:29 +0000708 self.assertEqual(all[0], (walk_path, ["SUB2"], ["tmp1"]))
Hynek Schlawack39bf90d2012-05-15 18:40:17 +0200709 all[1][-1].sort()
Guido van Rossumd8faa362007-04-27 19:54:29 +0000710 self.assertEqual(all[1], sub2_tree)
Tim Petersc4e09402003-04-25 07:11:48 +0000711
712 # Walk bottom-up.
Guido van Rossumd8faa362007-04-27 19:54:29 +0000713 all = list(os.walk(walk_path, topdown=False))
Tim Petersc4e09402003-04-25 07:11:48 +0000714 self.assertEqual(len(all), 4)
715 # We can't know which order SUB1 and SUB2 will appear in.
716 # Not flipped: SUB11, SUB1, SUB2, TESTFN
717 # flipped: SUB2, SUB11, SUB1, TESTFN
718 flipped = all[3][1][0] != "SUB1"
719 all[3][1].sort()
Hynek Schlawack39bf90d2012-05-15 18:40:17 +0200720 all[2 - 2 * flipped][-1].sort()
Guido van Rossumd8faa362007-04-27 19:54:29 +0000721 self.assertEqual(all[3], (walk_path, ["SUB1", "SUB2"], ["tmp1"]))
Tim Petersc4e09402003-04-25 07:11:48 +0000722 self.assertEqual(all[flipped], (sub11_path, [], []))
723 self.assertEqual(all[flipped + 1], (sub1_path, ["SUB11"], ["tmp2"]))
Guido van Rossumd8faa362007-04-27 19:54:29 +0000724 self.assertEqual(all[2 - 2 * flipped], sub2_tree)
Tim Petersc4e09402003-04-25 07:11:48 +0000725
Brian Curtin3b4499c2010-12-28 14:31:47 +0000726 if support.can_symlink():
Guido van Rossumd8faa362007-04-27 19:54:29 +0000727 # Walk, following symlinks.
728 for root, dirs, files in os.walk(walk_path, followlinks=True):
729 if root == link_path:
730 self.assertEqual(dirs, [])
731 self.assertEqual(files, ["tmp4"])
732 break
733 else:
734 self.fail("Didn't follow symlink with followlinks=True")
735
736 def tearDown(self):
Tim Petersc4e09402003-04-25 07:11:48 +0000737 # Tear everything down. This is a decent use for bottom-up on
738 # Windows, which doesn't have a recursive delete command. The
739 # (not so) subtlety is that rmdir will fail unless the dir's
740 # kids are removed first, so bottom up is essential.
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000741 for root, dirs, files in os.walk(support.TESTFN, topdown=False):
Tim Petersc4e09402003-04-25 07:11:48 +0000742 for name in files:
Guido van Rossumd8faa362007-04-27 19:54:29 +0000743 os.remove(os.path.join(root, name))
Tim Petersc4e09402003-04-25 07:11:48 +0000744 for name in dirs:
Guido van Rossumd8faa362007-04-27 19:54:29 +0000745 dirname = os.path.join(root, name)
746 if not os.path.islink(dirname):
747 os.rmdir(dirname)
748 else:
749 os.remove(dirname)
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000750 os.rmdir(support.TESTFN)
Tim Petersc4e09402003-04-25 07:11:48 +0000751
Charles-François Natali7372b062012-02-05 15:15:38 +0100752
753@unittest.skipUnless(hasattr(os, 'fwalk'), "Test needs os.fwalk()")
754class FwalkTests(WalkTests):
755 """Tests for os.fwalk()."""
756
Larry Hastingsc48fe982012-06-25 04:49:05 -0700757 def _compare_to_walk(self, walk_kwargs, fwalk_kwargs):
758 """
759 compare with walk() results.
760 """
Larry Hastingsb4038062012-07-15 10:57:38 -0700761 walk_kwargs = walk_kwargs.copy()
762 fwalk_kwargs = fwalk_kwargs.copy()
763 for topdown, follow_symlinks in itertools.product((True, False), repeat=2):
764 walk_kwargs.update(topdown=topdown, followlinks=follow_symlinks)
765 fwalk_kwargs.update(topdown=topdown, follow_symlinks=follow_symlinks)
Larry Hastingsc48fe982012-06-25 04:49:05 -0700766
Charles-François Natali7372b062012-02-05 15:15:38 +0100767 expected = {}
Larry Hastingsc48fe982012-06-25 04:49:05 -0700768 for root, dirs, files in os.walk(**walk_kwargs):
Charles-François Natali7372b062012-02-05 15:15:38 +0100769 expected[root] = (set(dirs), set(files))
770
Larry Hastingsc48fe982012-06-25 04:49:05 -0700771 for root, dirs, files, rootfd in os.fwalk(**fwalk_kwargs):
Charles-François Natali7372b062012-02-05 15:15:38 +0100772 self.assertIn(root, expected)
773 self.assertEqual(expected[root], (set(dirs), set(files)))
774
Larry Hastingsc48fe982012-06-25 04:49:05 -0700775 def test_compare_to_walk(self):
776 kwargs = {'top': support.TESTFN}
777 self._compare_to_walk(kwargs, kwargs)
778
Charles-François Natali7372b062012-02-05 15:15:38 +0100779 def test_dir_fd(self):
Larry Hastingsc48fe982012-06-25 04:49:05 -0700780 try:
781 fd = os.open(".", os.O_RDONLY)
782 walk_kwargs = {'top': support.TESTFN}
783 fwalk_kwargs = walk_kwargs.copy()
784 fwalk_kwargs['dir_fd'] = fd
785 self._compare_to_walk(walk_kwargs, fwalk_kwargs)
786 finally:
787 os.close(fd)
788
789 def test_yields_correct_dir_fd(self):
Charles-François Natali7372b062012-02-05 15:15:38 +0100790 # check returned file descriptors
Larry Hastingsb4038062012-07-15 10:57:38 -0700791 for topdown, follow_symlinks in itertools.product((True, False), repeat=2):
792 args = support.TESTFN, topdown, None
793 for root, dirs, files, rootfd in os.fwalk(*args, follow_symlinks=follow_symlinks):
Charles-François Natali7372b062012-02-05 15:15:38 +0100794 # check that the FD is valid
795 os.fstat(rootfd)
Larry Hastings9cf065c2012-06-22 16:30:09 -0700796 # redundant check
797 os.stat(rootfd)
798 # check that listdir() returns consistent information
799 self.assertEqual(set(os.listdir(rootfd)), set(dirs) | set(files))
Charles-François Natali7372b062012-02-05 15:15:38 +0100800
801 def test_fd_leak(self):
802 # Since we're opening a lot of FDs, we must be careful to avoid leaks:
803 # we both check that calling fwalk() a large number of times doesn't
804 # yield EMFILE, and that the minimum allocated FD hasn't changed.
805 minfd = os.dup(1)
806 os.close(minfd)
807 for i in range(256):
808 for x in os.fwalk(support.TESTFN):
809 pass
810 newfd = os.dup(1)
811 self.addCleanup(os.close, newfd)
812 self.assertEqual(newfd, minfd)
813
814 def tearDown(self):
815 # cleanup
816 for root, dirs, files, rootfd in os.fwalk(support.TESTFN, topdown=False):
817 for name in files:
Larry Hastings9cf065c2012-06-22 16:30:09 -0700818 os.unlink(name, dir_fd=rootfd)
Charles-François Natali7372b062012-02-05 15:15:38 +0100819 for name in dirs:
Larry Hastings9cf065c2012-06-22 16:30:09 -0700820 st = os.stat(name, dir_fd=rootfd, follow_symlinks=False)
Larry Hastingsb698d8e2012-06-23 16:55:07 -0700821 if stat.S_ISDIR(st.st_mode):
822 os.rmdir(name, dir_fd=rootfd)
823 else:
824 os.unlink(name, dir_fd=rootfd)
Charles-François Natali7372b062012-02-05 15:15:38 +0100825 os.rmdir(support.TESTFN)
826
827
Guido van Rossume7ba4952007-06-06 23:52:48 +0000828class MakedirTests(unittest.TestCase):
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +0000829 def setUp(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000830 os.mkdir(support.TESTFN)
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +0000831
832 def test_makedir(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000833 base = support.TESTFN
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +0000834 path = os.path.join(base, 'dir1', 'dir2', 'dir3')
835 os.makedirs(path) # Should work
836 path = os.path.join(base, 'dir1', 'dir2', 'dir3', 'dir4')
837 os.makedirs(path)
838
839 # Try paths with a '.' in them
Benjamin Petersonc9c0f202009-06-30 23:06:06 +0000840 self.assertRaises(OSError, os.makedirs, os.curdir)
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +0000841 path = os.path.join(base, 'dir1', 'dir2', 'dir3', 'dir4', 'dir5', os.curdir)
842 os.makedirs(path)
843 path = os.path.join(base, 'dir1', os.curdir, 'dir2', 'dir3', 'dir4',
844 'dir5', 'dir6')
845 os.makedirs(path)
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +0000846
Terry Reedy5a22b652010-12-02 07:05:56 +0000847 def test_exist_ok_existing_directory(self):
848 path = os.path.join(support.TESTFN, 'dir1')
849 mode = 0o777
850 old_mask = os.umask(0o022)
851 os.makedirs(path, mode)
852 self.assertRaises(OSError, os.makedirs, path, mode)
853 self.assertRaises(OSError, os.makedirs, path, mode, exist_ok=False)
854 self.assertRaises(OSError, os.makedirs, path, 0o776, exist_ok=True)
855 os.makedirs(path, mode=mode, exist_ok=True)
856 os.umask(old_mask)
857
Gregory P. Smitha81c8562012-06-03 14:30:44 -0700858 def test_exist_ok_s_isgid_directory(self):
859 path = os.path.join(support.TESTFN, 'dir1')
860 S_ISGID = stat.S_ISGID
861 mode = 0o777
862 old_mask = os.umask(0o022)
863 try:
864 existing_testfn_mode = stat.S_IMODE(
865 os.lstat(support.TESTFN).st_mode)
866 os.chmod(support.TESTFN, existing_testfn_mode | S_ISGID)
867 if (os.lstat(support.TESTFN).st_mode & S_ISGID != S_ISGID):
868 raise unittest.SkipTest('No support for S_ISGID dir mode.')
869 # The os should apply S_ISGID from the parent dir for us, but
870 # this test need not depend on that behavior. Be explicit.
871 os.makedirs(path, mode | S_ISGID)
872 # http://bugs.python.org/issue14992
873 # Should not fail when the bit is already set.
874 os.makedirs(path, mode, exist_ok=True)
875 # remove the bit.
876 os.chmod(path, stat.S_IMODE(os.lstat(path).st_mode) & ~S_ISGID)
877 with self.assertRaises(OSError):
878 # Should fail when the bit is not already set when demanded.
879 os.makedirs(path, mode | S_ISGID, exist_ok=True)
880 finally:
881 os.umask(old_mask)
Terry Reedy5a22b652010-12-02 07:05:56 +0000882
883 def test_exist_ok_existing_regular_file(self):
884 base = support.TESTFN
885 path = os.path.join(support.TESTFN, 'dir1')
886 f = open(path, 'w')
887 f.write('abc')
888 f.close()
889 self.assertRaises(OSError, os.makedirs, path)
890 self.assertRaises(OSError, os.makedirs, path, exist_ok=False)
891 self.assertRaises(OSError, os.makedirs, path, exist_ok=True)
892 os.remove(path)
893
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +0000894 def tearDown(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000895 path = os.path.join(support.TESTFN, 'dir1', 'dir2', 'dir3',
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +0000896 'dir4', 'dir5', 'dir6')
897 # If the tests failed, the bottom-most directory ('../dir6')
898 # may not have been created, so we look for the outermost directory
899 # that exists.
Benjamin Petersonee8712c2008-05-20 21:35:26 +0000900 while not os.path.exists(path) and path != support.TESTFN:
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +0000901 path = os.path.dirname(path)
902
903 os.removedirs(path)
904
Guido van Rossume7ba4952007-06-06 23:52:48 +0000905class DevNullTests(unittest.TestCase):
Martin v. Löwisbdec50f2004-06-08 08:29:33 +0000906 def test_devnull(self):
Victor Stinnera6d2c762011-06-30 18:20:11 +0200907 with open(os.devnull, 'wb') as f:
908 f.write(b'hello')
909 f.close()
910 with open(os.devnull, 'rb') as f:
911 self.assertEqual(f.read(), b'')
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +0000912
Guido van Rossume7ba4952007-06-06 23:52:48 +0000913class URandomTests(unittest.TestCase):
Georg Brandl2daf6ae2012-02-20 19:54:16 +0100914 def test_urandom_length(self):
915 self.assertEqual(len(os.urandom(0)), 0)
916 self.assertEqual(len(os.urandom(1)), 1)
917 self.assertEqual(len(os.urandom(10)), 10)
918 self.assertEqual(len(os.urandom(100)), 100)
919 self.assertEqual(len(os.urandom(1000)), 1000)
920
921 def test_urandom_value(self):
922 data1 = os.urandom(16)
923 data2 = os.urandom(16)
924 self.assertNotEqual(data1, data2)
925
926 def get_urandom_subprocess(self, count):
927 code = '\n'.join((
928 'import os, sys',
929 'data = os.urandom(%s)' % count,
930 'sys.stdout.buffer.write(data)',
931 'sys.stdout.buffer.flush()'))
932 out = assert_python_ok('-c', code)
933 stdout = out[1]
934 self.assertEqual(len(stdout), 16)
935 return stdout
936
937 def test_urandom_subprocess(self):
938 data1 = self.get_urandom_subprocess(16)
939 data2 = self.get_urandom_subprocess(16)
940 self.assertNotEqual(data1, data2)
Martin v. Löwisdc3883f2004-08-29 15:46:35 +0000941
Victor Stinnerc2d095f2010-05-17 00:14:53 +0000942@contextlib.contextmanager
943def _execvpe_mockup(defpath=None):
944 """
945 Stubs out execv and execve functions when used as context manager.
946 Records exec calls. The mock execv and execve functions always raise an
947 exception as they would normally never return.
948 """
949 # A list of tuples containing (function name, first arg, args)
950 # of calls to execv or execve that have been made.
951 calls = []
952
953 def mock_execv(name, *args):
954 calls.append(('execv', name, args))
955 raise RuntimeError("execv called")
956
957 def mock_execve(name, *args):
958 calls.append(('execve', name, args))
959 raise OSError(errno.ENOTDIR, "execve called")
960
961 try:
962 orig_execv = os.execv
963 orig_execve = os.execve
964 orig_defpath = os.defpath
965 os.execv = mock_execv
966 os.execve = mock_execve
967 if defpath is not None:
968 os.defpath = defpath
969 yield calls
970 finally:
971 os.execv = orig_execv
972 os.execve = orig_execve
973 os.defpath = orig_defpath
974
Guido van Rossume7ba4952007-06-06 23:52:48 +0000975class ExecTests(unittest.TestCase):
Mark Dickinson7cf03892010-04-16 13:45:35 +0000976 @unittest.skipIf(USING_LINUXTHREADS,
977 "avoid triggering a linuxthreads bug: see issue #4970")
Guido van Rossume7ba4952007-06-06 23:52:48 +0000978 def test_execvpe_with_bad_program(self):
Mark Dickinson7cf03892010-04-16 13:45:35 +0000979 self.assertRaises(OSError, os.execvpe, 'no such app-',
980 ['no such app-'], None)
Guido van Rossume7ba4952007-06-06 23:52:48 +0000981
Thomas Heller6790d602007-08-30 17:15:14 +0000982 def test_execvpe_with_bad_arglist(self):
983 self.assertRaises(ValueError, os.execvpe, 'notepad', [], None)
984
Gregory P. Smith4ae37772010-05-08 18:05:46 +0000985 @unittest.skipUnless(hasattr(os, '_execvpe'),
986 "No internal os._execvpe function to test.")
Victor Stinnerb745a742010-05-18 17:17:23 +0000987 def _test_internal_execvpe(self, test_type):
988 program_path = os.sep + 'absolutepath'
989 if test_type is bytes:
990 program = b'executable'
991 fullpath = os.path.join(os.fsencode(program_path), program)
992 native_fullpath = fullpath
993 arguments = [b'progname', 'arg1', 'arg2']
994 else:
995 program = 'executable'
996 arguments = ['progname', 'arg1', 'arg2']
997 fullpath = os.path.join(program_path, program)
998 if os.name != "nt":
999 native_fullpath = os.fsencode(fullpath)
1000 else:
1001 native_fullpath = fullpath
Victor Stinnerc2d095f2010-05-17 00:14:53 +00001002 env = {'spam': 'beans'}
1003
Victor Stinnerb745a742010-05-18 17:17:23 +00001004 # test os._execvpe() with an absolute path
Victor Stinnerc2d095f2010-05-17 00:14:53 +00001005 with _execvpe_mockup() as calls:
Victor Stinnerb745a742010-05-18 17:17:23 +00001006 self.assertRaises(RuntimeError,
1007 os._execvpe, fullpath, arguments)
Victor Stinnerc2d095f2010-05-17 00:14:53 +00001008 self.assertEqual(len(calls), 1)
1009 self.assertEqual(calls[0], ('execv', fullpath, (arguments,)))
1010
Victor Stinnerb745a742010-05-18 17:17:23 +00001011 # test os._execvpe() with a relative path:
1012 # os.get_exec_path() returns defpath
Victor Stinnerc2d095f2010-05-17 00:14:53 +00001013 with _execvpe_mockup(defpath=program_path) as calls:
Victor Stinnerb745a742010-05-18 17:17:23 +00001014 self.assertRaises(OSError,
1015 os._execvpe, program, arguments, env=env)
Victor Stinnerc2d095f2010-05-17 00:14:53 +00001016 self.assertEqual(len(calls), 1)
Victor Stinnerb745a742010-05-18 17:17:23 +00001017 self.assertSequenceEqual(calls[0],
1018 ('execve', native_fullpath, (arguments, env)))
1019
1020 # test os._execvpe() with a relative path:
1021 # os.get_exec_path() reads the 'PATH' variable
1022 with _execvpe_mockup() as calls:
1023 env_path = env.copy()
Victor Stinner38430e22010-08-19 17:10:18 +00001024 if test_type is bytes:
1025 env_path[b'PATH'] = program_path
1026 else:
1027 env_path['PATH'] = program_path
Victor Stinnerb745a742010-05-18 17:17:23 +00001028 self.assertRaises(OSError,
1029 os._execvpe, program, arguments, env=env_path)
1030 self.assertEqual(len(calls), 1)
1031 self.assertSequenceEqual(calls[0],
1032 ('execve', native_fullpath, (arguments, env_path)))
1033
1034 def test_internal_execvpe_str(self):
1035 self._test_internal_execvpe(str)
1036 if os.name != "nt":
1037 self._test_internal_execvpe(bytes)
Victor Stinnerc2d095f2010-05-17 00:14:53 +00001038
Gregory P. Smith4ae37772010-05-08 18:05:46 +00001039
Thomas Wouters477c8d52006-05-27 19:21:47 +00001040class Win32ErrorTests(unittest.TestCase):
1041 def test_rename(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +00001042 self.assertRaises(WindowsError, os.rename, support.TESTFN, support.TESTFN+".bak")
Thomas Wouters477c8d52006-05-27 19:21:47 +00001043
1044 def test_remove(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +00001045 self.assertRaises(WindowsError, os.remove, support.TESTFN)
Thomas Wouters477c8d52006-05-27 19:21:47 +00001046
1047 def test_chdir(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +00001048 self.assertRaises(WindowsError, os.chdir, support.TESTFN)
Thomas Wouters477c8d52006-05-27 19:21:47 +00001049
1050 def test_mkdir(self):
Amaury Forgeot d'Arc2fc224f2009-02-19 23:23:47 +00001051 f = open(support.TESTFN, "w")
Benjamin Petersonf91df042009-02-13 02:50:59 +00001052 try:
1053 self.assertRaises(WindowsError, os.mkdir, support.TESTFN)
1054 finally:
1055 f.close()
Amaury Forgeot d'Arc2fc224f2009-02-19 23:23:47 +00001056 os.unlink(support.TESTFN)
Thomas Wouters477c8d52006-05-27 19:21:47 +00001057
1058 def test_utime(self):
Benjamin Petersonee8712c2008-05-20 21:35:26 +00001059 self.assertRaises(WindowsError, os.utime, support.TESTFN, None)
Thomas Wouters477c8d52006-05-27 19:21:47 +00001060
Thomas Wouters477c8d52006-05-27 19:21:47 +00001061 def test_chmod(self):
Benjamin Petersonf91df042009-02-13 02:50:59 +00001062 self.assertRaises(WindowsError, os.chmod, support.TESTFN, 0)
Thomas Wouters477c8d52006-05-27 19:21:47 +00001063
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001064class TestInvalidFD(unittest.TestCase):
Benjamin Peterson05e782f2009-01-19 15:15:02 +00001065 singles = ["fchdir", "dup", "fdopen", "fdatasync", "fstat",
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001066 "fstatvfs", "fsync", "tcgetpgrp", "ttyname"]
1067 #singles.append("close")
1068 #We omit close because it doesn'r raise an exception on some platforms
1069 def get_single(f):
1070 def helper(self):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001071 if hasattr(os, f):
1072 self.check(getattr(os, f))
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001073 return helper
1074 for f in singles:
1075 locals()["test_"+f] = get_single(f)
1076
Benjamin Peterson7522c742009-01-19 21:00:09 +00001077 def check(self, f, *args):
Benjamin Peterson5c6d7872009-02-06 02:40:07 +00001078 try:
1079 f(support.make_bad_fd(), *args)
1080 except OSError as e:
1081 self.assertEqual(e.errno, errno.EBADF)
1082 else:
1083 self.fail("%r didn't raise a OSError with a bad file descriptor"
1084 % f)
Benjamin Peterson7522c742009-01-19 21:00:09 +00001085
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001086 def test_isatty(self):
1087 if hasattr(os, "isatty"):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001088 self.assertEqual(os.isatty(support.make_bad_fd()), False)
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001089
1090 def test_closerange(self):
1091 if hasattr(os, "closerange"):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001092 fd = support.make_bad_fd()
R. David Murray630cc482009-07-22 15:20:27 +00001093 # Make sure none of the descriptors we are about to close are
1094 # currently valid (issue 6542).
1095 for i in range(10):
1096 try: os.fstat(fd+i)
1097 except OSError:
1098 pass
1099 else:
1100 break
1101 if i < 2:
1102 raise unittest.SkipTest(
1103 "Unable to acquire a range of invalid file descriptors")
1104 self.assertEqual(os.closerange(fd, fd + i-1), None)
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001105
1106 def test_dup2(self):
1107 if hasattr(os, "dup2"):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001108 self.check(os.dup2, 20)
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001109
1110 def test_fchmod(self):
1111 if hasattr(os, "fchmod"):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001112 self.check(os.fchmod, 0)
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001113
1114 def test_fchown(self):
1115 if hasattr(os, "fchown"):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001116 self.check(os.fchown, -1, -1)
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001117
1118 def test_fpathconf(self):
1119 if hasattr(os, "fpathconf"):
Georg Brandl306336b2012-06-24 12:55:33 +02001120 self.check(os.pathconf, "PC_NAME_MAX")
Benjamin Peterson7522c742009-01-19 21:00:09 +00001121 self.check(os.fpathconf, "PC_NAME_MAX")
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001122
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001123 def test_ftruncate(self):
1124 if hasattr(os, "ftruncate"):
Georg Brandl306336b2012-06-24 12:55:33 +02001125 self.check(os.truncate, 0)
Benjamin Peterson7522c742009-01-19 21:00:09 +00001126 self.check(os.ftruncate, 0)
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001127
1128 def test_lseek(self):
1129 if hasattr(os, "lseek"):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001130 self.check(os.lseek, 0, 0)
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001131
1132 def test_read(self):
1133 if hasattr(os, "read"):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001134 self.check(os.read, 1)
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001135
1136 def test_tcsetpgrpt(self):
1137 if hasattr(os, "tcsetpgrp"):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001138 self.check(os.tcsetpgrp, 0)
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001139
1140 def test_write(self):
1141 if hasattr(os, "write"):
Benjamin Peterson7522c742009-01-19 21:00:09 +00001142 self.check(os.write, b" ")
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00001143
Brian Curtin1b9df392010-11-24 20:24:31 +00001144
1145class LinkTests(unittest.TestCase):
1146 def setUp(self):
1147 self.file1 = support.TESTFN
1148 self.file2 = os.path.join(support.TESTFN + "2")
1149
Brian Curtinc0abc4e2010-11-30 23:46:54 +00001150 def tearDown(self):
Brian Curtin1b9df392010-11-24 20:24:31 +00001151 for file in (self.file1, self.file2):
1152 if os.path.exists(file):
1153 os.unlink(file)
1154
Brian Curtin1b9df392010-11-24 20:24:31 +00001155 def _test_link(self, file1, file2):
1156 with open(file1, "w") as f1:
1157 f1.write("test")
1158
Victor Stinner1ab6c2d2011-11-15 22:27:41 +01001159 with warnings.catch_warnings():
1160 warnings.simplefilter("ignore", DeprecationWarning)
1161 os.link(file1, file2)
Brian Curtin1b9df392010-11-24 20:24:31 +00001162 with open(file1, "r") as f1, open(file2, "r") as f2:
1163 self.assertTrue(os.path.sameopenfile(f1.fileno(), f2.fileno()))
1164
1165 def test_link(self):
1166 self._test_link(self.file1, self.file2)
1167
1168 def test_link_bytes(self):
1169 self._test_link(bytes(self.file1, sys.getfilesystemencoding()),
1170 bytes(self.file2, sys.getfilesystemencoding()))
1171
Brian Curtinf498b752010-11-30 15:54:04 +00001172 def test_unicode_name(self):
Brian Curtin43f0c272010-11-30 15:40:04 +00001173 try:
Brian Curtinf498b752010-11-30 15:54:04 +00001174 os.fsencode("\xf1")
Brian Curtin43f0c272010-11-30 15:40:04 +00001175 except UnicodeError:
1176 raise unittest.SkipTest("Unable to encode for this platform.")
1177
Brian Curtinf498b752010-11-30 15:54:04 +00001178 self.file1 += "\xf1"
Brian Curtinfc889c42010-11-28 23:59:46 +00001179 self.file2 = self.file1 + "2"
1180 self._test_link(self.file1, self.file2)
1181
Thomas Wouters477c8d52006-05-27 19:21:47 +00001182if sys.platform != 'win32':
1183 class Win32ErrorTests(unittest.TestCase):
1184 pass
1185
Benjamin Petersonef3e4c22009-04-11 19:48:14 +00001186 class PosixUidGidTests(unittest.TestCase):
1187 if hasattr(os, 'setuid'):
1188 def test_setuid(self):
1189 if os.getuid() != 0:
1190 self.assertRaises(os.error, os.setuid, 0)
1191 self.assertRaises(OverflowError, os.setuid, 1<<32)
1192
1193 if hasattr(os, 'setgid'):
1194 def test_setgid(self):
1195 if os.getuid() != 0:
1196 self.assertRaises(os.error, os.setgid, 0)
1197 self.assertRaises(OverflowError, os.setgid, 1<<32)
1198
1199 if hasattr(os, 'seteuid'):
1200 def test_seteuid(self):
1201 if os.getuid() != 0:
1202 self.assertRaises(os.error, os.seteuid, 0)
1203 self.assertRaises(OverflowError, os.seteuid, 1<<32)
1204
1205 if hasattr(os, 'setegid'):
1206 def test_setegid(self):
1207 if os.getuid() != 0:
1208 self.assertRaises(os.error, os.setegid, 0)
1209 self.assertRaises(OverflowError, os.setegid, 1<<32)
1210
1211 if hasattr(os, 'setreuid'):
1212 def test_setreuid(self):
1213 if os.getuid() != 0:
1214 self.assertRaises(os.error, os.setreuid, 0, 0)
1215 self.assertRaises(OverflowError, os.setreuid, 1<<32, 0)
1216 self.assertRaises(OverflowError, os.setreuid, 0, 1<<32)
Benjamin Petersonebe87ba2010-03-06 20:34:24 +00001217
1218 def test_setreuid_neg1(self):
1219 # Needs to accept -1. We run this in a subprocess to avoid
1220 # altering the test runner's process state (issue8045).
Benjamin Petersonebe87ba2010-03-06 20:34:24 +00001221 subprocess.check_call([
1222 sys.executable, '-c',
1223 'import os,sys;os.setreuid(-1,-1);sys.exit(0)'])
Benjamin Petersonef3e4c22009-04-11 19:48:14 +00001224
1225 if hasattr(os, 'setregid'):
1226 def test_setregid(self):
1227 if os.getuid() != 0:
1228 self.assertRaises(os.error, os.setregid, 0, 0)
1229 self.assertRaises(OverflowError, os.setregid, 1<<32, 0)
1230 self.assertRaises(OverflowError, os.setregid, 0, 1<<32)
Benjamin Petersonebe87ba2010-03-06 20:34:24 +00001231
1232 def test_setregid_neg1(self):
1233 # Needs to accept -1. We run this in a subprocess to avoid
1234 # altering the test runner's process state (issue8045).
Benjamin Petersonebe87ba2010-03-06 20:34:24 +00001235 subprocess.check_call([
1236 sys.executable, '-c',
1237 'import os,sys;os.setregid(-1,-1);sys.exit(0)'])
Martin v. Löwis011e8422009-05-05 04:43:17 +00001238
1239 class Pep383Tests(unittest.TestCase):
Martin v. Löwis011e8422009-05-05 04:43:17 +00001240 def setUp(self):
Victor Stinnerd91df1a2010-08-18 10:56:19 +00001241 if support.TESTFN_UNENCODABLE:
1242 self.dir = support.TESTFN_UNENCODABLE
1243 else:
1244 self.dir = support.TESTFN
1245 self.bdir = os.fsencode(self.dir)
1246
1247 bytesfn = []
1248 def add_filename(fn):
1249 try:
1250 fn = os.fsencode(fn)
1251 except UnicodeEncodeError:
1252 return
1253 bytesfn.append(fn)
1254 add_filename(support.TESTFN_UNICODE)
1255 if support.TESTFN_UNENCODABLE:
1256 add_filename(support.TESTFN_UNENCODABLE)
1257 if not bytesfn:
1258 self.skipTest("couldn't create any non-ascii filename")
1259
1260 self.unicodefn = set()
Martin v. Löwis011e8422009-05-05 04:43:17 +00001261 os.mkdir(self.dir)
Victor Stinnerd91df1a2010-08-18 10:56:19 +00001262 try:
1263 for fn in bytesfn:
Victor Stinnerbf816222011-06-30 23:25:47 +02001264 support.create_empty_file(os.path.join(self.bdir, fn))
Victor Stinnere8d51452010-08-19 01:05:19 +00001265 fn = os.fsdecode(fn)
Victor Stinnerd91df1a2010-08-18 10:56:19 +00001266 if fn in self.unicodefn:
1267 raise ValueError("duplicate filename")
1268 self.unicodefn.add(fn)
1269 except:
1270 shutil.rmtree(self.dir)
1271 raise
Martin v. Löwis011e8422009-05-05 04:43:17 +00001272
1273 def tearDown(self):
1274 shutil.rmtree(self.dir)
Martin v. Löwis011e8422009-05-05 04:43:17 +00001275
1276 def test_listdir(self):
Victor Stinnerd91df1a2010-08-18 10:56:19 +00001277 expected = self.unicodefn
1278 found = set(os.listdir(self.dir))
Ezio Melottib3aedd42010-11-20 19:04:17 +00001279 self.assertEqual(found, expected)
Larry Hastings9cf065c2012-06-22 16:30:09 -07001280 # test listdir without arguments
1281 current_directory = os.getcwd()
1282 try:
1283 os.chdir(os.sep)
1284 self.assertEqual(set(os.listdir()), set(os.listdir(os.sep)))
1285 finally:
1286 os.chdir(current_directory)
Martin v. Löwis011e8422009-05-05 04:43:17 +00001287
1288 def test_open(self):
1289 for fn in self.unicodefn:
Victor Stinnera6d2c762011-06-30 18:20:11 +02001290 f = open(os.path.join(self.dir, fn), 'rb')
Martin v. Löwis011e8422009-05-05 04:43:17 +00001291 f.close()
1292
1293 def test_stat(self):
1294 for fn in self.unicodefn:
1295 os.stat(os.path.join(self.dir, fn))
Benjamin Petersonef3e4c22009-04-11 19:48:14 +00001296else:
1297 class PosixUidGidTests(unittest.TestCase):
1298 pass
Martin v. Löwis011e8422009-05-05 04:43:17 +00001299 class Pep383Tests(unittest.TestCase):
1300 pass
Benjamin Petersonef3e4c22009-04-11 19:48:14 +00001301
Brian Curtineb24d742010-04-12 17:16:38 +00001302@unittest.skipUnless(sys.platform == "win32", "Win32 specific tests")
1303class Win32KillTests(unittest.TestCase):
Brian Curtinc3acbc32010-05-28 16:08:40 +00001304 def _kill(self, sig):
1305 # Start sys.executable as a subprocess and communicate from the
1306 # subprocess to the parent that the interpreter is ready. When it
1307 # becomes ready, send *sig* via os.kill to the subprocess and check
1308 # that the return code is equal to *sig*.
1309 import ctypes
1310 from ctypes import wintypes
1311 import msvcrt
1312
1313 # Since we can't access the contents of the process' stdout until the
1314 # process has exited, use PeekNamedPipe to see what's inside stdout
1315 # without waiting. This is done so we can tell that the interpreter
1316 # is started and running at a point where it could handle a signal.
1317 PeekNamedPipe = ctypes.windll.kernel32.PeekNamedPipe
1318 PeekNamedPipe.restype = wintypes.BOOL
1319 PeekNamedPipe.argtypes = (wintypes.HANDLE, # Pipe handle
1320 ctypes.POINTER(ctypes.c_char), # stdout buf
1321 wintypes.DWORD, # Buffer size
1322 ctypes.POINTER(wintypes.DWORD), # bytes read
1323 ctypes.POINTER(wintypes.DWORD), # bytes avail
1324 ctypes.POINTER(wintypes.DWORD)) # bytes left
1325 msg = "running"
1326 proc = subprocess.Popen([sys.executable, "-c",
1327 "import sys;"
1328 "sys.stdout.write('{}');"
1329 "sys.stdout.flush();"
1330 "input()".format(msg)],
1331 stdout=subprocess.PIPE,
1332 stderr=subprocess.PIPE,
1333 stdin=subprocess.PIPE)
Brian Curtin43ec5772010-11-05 15:17:11 +00001334 self.addCleanup(proc.stdout.close)
1335 self.addCleanup(proc.stderr.close)
1336 self.addCleanup(proc.stdin.close)
Brian Curtinc3acbc32010-05-28 16:08:40 +00001337
1338 count, max = 0, 100
1339 while count < max and proc.poll() is None:
1340 # Create a string buffer to store the result of stdout from the pipe
1341 buf = ctypes.create_string_buffer(len(msg))
1342 # Obtain the text currently in proc.stdout
1343 # Bytes read/avail/left are left as NULL and unused
1344 rslt = PeekNamedPipe(msvcrt.get_osfhandle(proc.stdout.fileno()),
1345 buf, ctypes.sizeof(buf), None, None, None)
1346 self.assertNotEqual(rslt, 0, "PeekNamedPipe failed")
1347 if buf.value:
1348 self.assertEqual(msg, buf.value.decode())
1349 break
1350 time.sleep(0.1)
1351 count += 1
1352 else:
1353 self.fail("Did not receive communication from the subprocess")
1354
Brian Curtineb24d742010-04-12 17:16:38 +00001355 os.kill(proc.pid, sig)
1356 self.assertEqual(proc.wait(), sig)
1357
1358 def test_kill_sigterm(self):
1359 # SIGTERM doesn't mean anything special, but make sure it works
Brian Curtinc3acbc32010-05-28 16:08:40 +00001360 self._kill(signal.SIGTERM)
Brian Curtineb24d742010-04-12 17:16:38 +00001361
1362 def test_kill_int(self):
1363 # os.kill on Windows can take an int which gets set as the exit code
Brian Curtinc3acbc32010-05-28 16:08:40 +00001364 self._kill(100)
Brian Curtineb24d742010-04-12 17:16:38 +00001365
1366 def _kill_with_event(self, event, name):
Hirokazu Yamamoto54c950f2010-10-08 08:38:15 +00001367 tagname = "test_os_%s" % uuid.uuid1()
1368 m = mmap.mmap(-1, 1, tagname)
1369 m[0] = 0
Brian Curtineb24d742010-04-12 17:16:38 +00001370 # Run a script which has console control handling enabled.
1371 proc = subprocess.Popen([sys.executable,
1372 os.path.join(os.path.dirname(__file__),
Hirokazu Yamamoto54c950f2010-10-08 08:38:15 +00001373 "win_console_handler.py"), tagname],
Brian Curtineb24d742010-04-12 17:16:38 +00001374 creationflags=subprocess.CREATE_NEW_PROCESS_GROUP)
1375 # Let the interpreter startup before we send signals. See #3137.
Hirokazu Yamamoto8e9fe9f2010-12-05 02:41:46 +00001376 count, max = 0, 100
Hirokazu Yamamoto54c950f2010-10-08 08:38:15 +00001377 while count < max and proc.poll() is None:
Brian Curtinf668df52010-10-15 14:21:06 +00001378 if m[0] == 1:
Hirokazu Yamamoto54c950f2010-10-08 08:38:15 +00001379 break
Hirokazu Yamamoto8e9fe9f2010-12-05 02:41:46 +00001380 time.sleep(0.1)
Hirokazu Yamamoto54c950f2010-10-08 08:38:15 +00001381 count += 1
1382 else:
Hirokazu Yamamoto8e9fe9f2010-12-05 02:41:46 +00001383 # Forcefully kill the process if we weren't able to signal it.
1384 os.kill(proc.pid, signal.SIGINT)
Hirokazu Yamamoto54c950f2010-10-08 08:38:15 +00001385 self.fail("Subprocess didn't finish initialization")
Brian Curtineb24d742010-04-12 17:16:38 +00001386 os.kill(proc.pid, event)
1387 # proc.send_signal(event) could also be done here.
1388 # Allow time for the signal to be passed and the process to exit.
1389 time.sleep(0.5)
1390 if not proc.poll():
1391 # Forcefully kill the process if we weren't able to signal it.
1392 os.kill(proc.pid, signal.SIGINT)
1393 self.fail("subprocess did not stop on {}".format(name))
1394
1395 @unittest.skip("subprocesses aren't inheriting CTRL+C property")
1396 def test_CTRL_C_EVENT(self):
1397 from ctypes import wintypes
1398 import ctypes
1399
1400 # Make a NULL value by creating a pointer with no argument.
1401 NULL = ctypes.POINTER(ctypes.c_int)()
1402 SetConsoleCtrlHandler = ctypes.windll.kernel32.SetConsoleCtrlHandler
1403 SetConsoleCtrlHandler.argtypes = (ctypes.POINTER(ctypes.c_int),
1404 wintypes.BOOL)
1405 SetConsoleCtrlHandler.restype = wintypes.BOOL
1406
1407 # Calling this with NULL and FALSE causes the calling process to
1408 # handle CTRL+C, rather than ignore it. This property is inherited
1409 # by subprocesses.
1410 SetConsoleCtrlHandler(NULL, 0)
1411
1412 self._kill_with_event(signal.CTRL_C_EVENT, "CTRL_C_EVENT")
1413
1414 def test_CTRL_BREAK_EVENT(self):
1415 self._kill_with_event(signal.CTRL_BREAK_EVENT, "CTRL_BREAK_EVENT")
1416
1417
Brian Curtind40e6f72010-07-08 21:39:08 +00001418@unittest.skipUnless(sys.platform == "win32", "Win32 specific tests")
Brian Curtin3b4499c2010-12-28 14:31:47 +00001419@support.skip_unless_symlink
Brian Curtind40e6f72010-07-08 21:39:08 +00001420class Win32SymlinkTests(unittest.TestCase):
1421 filelink = 'filelinktest'
1422 filelink_target = os.path.abspath(__file__)
1423 dirlink = 'dirlinktest'
1424 dirlink_target = os.path.dirname(filelink_target)
1425 missing_link = 'missing link'
1426
1427 def setUp(self):
1428 assert os.path.exists(self.dirlink_target)
1429 assert os.path.exists(self.filelink_target)
1430 assert not os.path.exists(self.dirlink)
1431 assert not os.path.exists(self.filelink)
1432 assert not os.path.exists(self.missing_link)
1433
1434 def tearDown(self):
1435 if os.path.exists(self.filelink):
1436 os.remove(self.filelink)
1437 if os.path.exists(self.dirlink):
1438 os.rmdir(self.dirlink)
1439 if os.path.lexists(self.missing_link):
1440 os.remove(self.missing_link)
1441
1442 def test_directory_link(self):
Antoine Pitrou5311c1d2012-01-24 08:59:28 +01001443 os.symlink(self.dirlink_target, self.dirlink, True)
Brian Curtind40e6f72010-07-08 21:39:08 +00001444 self.assertTrue(os.path.exists(self.dirlink))
1445 self.assertTrue(os.path.isdir(self.dirlink))
1446 self.assertTrue(os.path.islink(self.dirlink))
1447 self.check_stat(self.dirlink, self.dirlink_target)
1448
1449 def test_file_link(self):
1450 os.symlink(self.filelink_target, self.filelink)
1451 self.assertTrue(os.path.exists(self.filelink))
1452 self.assertTrue(os.path.isfile(self.filelink))
1453 self.assertTrue(os.path.islink(self.filelink))
1454 self.check_stat(self.filelink, self.filelink_target)
1455
1456 def _create_missing_dir_link(self):
1457 'Create a "directory" link to a non-existent target'
1458 linkname = self.missing_link
1459 if os.path.lexists(linkname):
1460 os.remove(linkname)
1461 target = r'c:\\target does not exist.29r3c740'
1462 assert not os.path.exists(target)
1463 target_is_dir = True
1464 os.symlink(target, linkname, target_is_dir)
1465
1466 def test_remove_directory_link_to_missing_target(self):
1467 self._create_missing_dir_link()
1468 # For compatibility with Unix, os.remove will check the
1469 # directory status and call RemoveDirectory if the symlink
1470 # was created with target_is_dir==True.
1471 os.remove(self.missing_link)
1472
1473 @unittest.skip("currently fails; consider for improvement")
1474 def test_isdir_on_directory_link_to_missing_target(self):
1475 self._create_missing_dir_link()
1476 # consider having isdir return true for directory links
1477 self.assertTrue(os.path.isdir(self.missing_link))
1478
1479 @unittest.skip("currently fails; consider for improvement")
1480 def test_rmdir_on_directory_link_to_missing_target(self):
1481 self._create_missing_dir_link()
1482 # consider allowing rmdir to remove directory links
1483 os.rmdir(self.missing_link)
1484
1485 def check_stat(self, link, target):
1486 self.assertEqual(os.stat(link), os.stat(target))
1487 self.assertNotEqual(os.lstat(link), os.stat(link))
1488
Brian Curtind25aef52011-06-13 15:16:04 -05001489 bytes_link = os.fsencode(link)
Victor Stinner1ab6c2d2011-11-15 22:27:41 +01001490 with warnings.catch_warnings():
1491 warnings.simplefilter("ignore", DeprecationWarning)
1492 self.assertEqual(os.stat(bytes_link), os.stat(target))
1493 self.assertNotEqual(os.lstat(bytes_link), os.stat(bytes_link))
Brian Curtind25aef52011-06-13 15:16:04 -05001494
1495 def test_12084(self):
1496 level1 = os.path.abspath(support.TESTFN)
1497 level2 = os.path.join(level1, "level2")
1498 level3 = os.path.join(level2, "level3")
1499 try:
1500 os.mkdir(level1)
1501 os.mkdir(level2)
1502 os.mkdir(level3)
1503
1504 file1 = os.path.abspath(os.path.join(level1, "file1"))
1505
1506 with open(file1, "w") as f:
1507 f.write("file1")
1508
1509 orig_dir = os.getcwd()
1510 try:
1511 os.chdir(level2)
1512 link = os.path.join(level2, "link")
1513 os.symlink(os.path.relpath(file1), "link")
1514 self.assertIn("link", os.listdir(os.getcwd()))
1515
1516 # Check os.stat calls from the same dir as the link
1517 self.assertEqual(os.stat(file1), os.stat("link"))
1518
1519 # Check os.stat calls from a dir below the link
1520 os.chdir(level1)
1521 self.assertEqual(os.stat(file1),
1522 os.stat(os.path.relpath(link)))
1523
1524 # Check os.stat calls from a dir above the link
1525 os.chdir(level3)
1526 self.assertEqual(os.stat(file1),
1527 os.stat(os.path.relpath(link)))
1528 finally:
1529 os.chdir(orig_dir)
1530 except OSError as err:
1531 self.fail(err)
1532 finally:
1533 os.remove(file1)
1534 shutil.rmtree(level1)
1535
Brian Curtind40e6f72010-07-08 21:39:08 +00001536
Victor Stinnere8d51452010-08-19 01:05:19 +00001537class FSEncodingTests(unittest.TestCase):
1538 def test_nop(self):
Ezio Melottib3aedd42010-11-20 19:04:17 +00001539 self.assertEqual(os.fsencode(b'abc\xff'), b'abc\xff')
1540 self.assertEqual(os.fsdecode('abc\u0141'), 'abc\u0141')
Benjamin Peterson31191a92010-05-09 03:22:58 +00001541
Victor Stinnere8d51452010-08-19 01:05:19 +00001542 def test_identity(self):
1543 # assert fsdecode(fsencode(x)) == x
1544 for fn in ('unicode\u0141', 'latin\xe9', 'ascii'):
1545 try:
1546 bytesfn = os.fsencode(fn)
1547 except UnicodeEncodeError:
1548 continue
Ezio Melottib3aedd42010-11-20 19:04:17 +00001549 self.assertEqual(os.fsdecode(bytesfn), fn)
Victor Stinnere8d51452010-08-19 01:05:19 +00001550
Victor Stinnerbf9bcab2010-05-09 03:15:33 +00001551
Brett Cannonefb00c02012-02-29 18:31:31 -05001552
1553class DeviceEncodingTests(unittest.TestCase):
1554
1555 def test_bad_fd(self):
1556 # Return None when an fd doesn't actually exist.
1557 self.assertIsNone(os.device_encoding(123456))
1558
Philip Jenveye308b7c2012-02-29 16:16:15 -08001559 @unittest.skipUnless(os.isatty(0) and (sys.platform.startswith('win') or
1560 (hasattr(locale, 'nl_langinfo') and hasattr(locale, 'CODESET'))),
Philip Jenveyd7aff2d2012-02-29 16:21:25 -08001561 'test requires a tty and either Windows or nl_langinfo(CODESET)')
Brett Cannonefb00c02012-02-29 18:31:31 -05001562 def test_device_encoding(self):
1563 encoding = os.device_encoding(0)
1564 self.assertIsNotNone(encoding)
1565 self.assertTrue(codecs.lookup(encoding))
1566
1567
Amaury Forgeot d'Arc4b6fdf32010-09-07 21:31:17 +00001568class PidTests(unittest.TestCase):
1569 @unittest.skipUnless(hasattr(os, 'getppid'), "test needs os.getppid")
1570 def test_getppid(self):
1571 p = subprocess.Popen([sys.executable, '-c',
1572 'import os; print(os.getppid())'],
1573 stdout=subprocess.PIPE)
1574 stdout, _ = p.communicate()
1575 # We are the parent of our subprocess
1576 self.assertEqual(int(stdout), os.getpid())
1577
1578
Brian Curtin0151b8e2010-09-24 13:43:43 +00001579# The introduction of this TestCase caused at least two different errors on
1580# *nix buildbots. Temporarily skip this to let the buildbots move along.
1581@unittest.skip("Skip due to platform/environment differences on *NIX buildbots")
Brian Curtine8e4b3b2010-09-23 20:04:14 +00001582@unittest.skipUnless(hasattr(os, 'getlogin'), "test needs os.getlogin")
1583class LoginTests(unittest.TestCase):
1584 def test_getlogin(self):
1585 user_name = os.getlogin()
1586 self.assertNotEqual(len(user_name), 0)
1587
1588
Giampaolo Rodolà18e8bcb2011-02-25 20:57:54 +00001589@unittest.skipUnless(hasattr(os, 'getpriority') and hasattr(os, 'setpriority'),
1590 "needs os.getpriority and os.setpriority")
1591class ProgramPriorityTests(unittest.TestCase):
1592 """Tests for os.getpriority() and os.setpriority()."""
1593
1594 def test_set_get_priority(self):
Giampaolo Rodolàcfbcec32011-02-28 19:27:16 +00001595
Giampaolo Rodolà18e8bcb2011-02-25 20:57:54 +00001596 base = os.getpriority(os.PRIO_PROCESS, os.getpid())
1597 os.setpriority(os.PRIO_PROCESS, os.getpid(), base + 1)
1598 try:
Giampaolo Rodolàcfbcec32011-02-28 19:27:16 +00001599 new_prio = os.getpriority(os.PRIO_PROCESS, os.getpid())
1600 if base >= 19 and new_prio <= 19:
1601 raise unittest.SkipTest(
1602 "unable to reliably test setpriority at current nice level of %s" % base)
1603 else:
1604 self.assertEqual(new_prio, base + 1)
Giampaolo Rodolà18e8bcb2011-02-25 20:57:54 +00001605 finally:
1606 try:
1607 os.setpriority(os.PRIO_PROCESS, os.getpid(), base)
1608 except OSError as err:
Antoine Pitrou692f0382011-02-26 00:22:25 +00001609 if err.errno != errno.EACCES:
Giampaolo Rodolà18e8bcb2011-02-25 20:57:54 +00001610 raise
1611
1612
Giampaolo Rodola'566f8a62011-05-18 21:28:39 +02001613if threading is not None:
1614 class SendfileTestServer(asyncore.dispatcher, threading.Thread):
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001615
Giampaolo Rodola'566f8a62011-05-18 21:28:39 +02001616 class Handler(asynchat.async_chat):
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001617
Giampaolo Rodola'566f8a62011-05-18 21:28:39 +02001618 def __init__(self, conn):
1619 asynchat.async_chat.__init__(self, conn)
1620 self.in_buffer = []
1621 self.closed = False
1622 self.push(b"220 ready\r\n")
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001623
Giampaolo Rodola'566f8a62011-05-18 21:28:39 +02001624 def handle_read(self):
1625 data = self.recv(4096)
1626 self.in_buffer.append(data)
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001627
Giampaolo Rodola'566f8a62011-05-18 21:28:39 +02001628 def get_data(self):
1629 return b''.join(self.in_buffer)
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001630
Giampaolo Rodola'566f8a62011-05-18 21:28:39 +02001631 def handle_close(self):
1632 self.close()
1633 self.closed = True
1634
1635 def handle_error(self):
1636 raise
1637
1638 def __init__(self, address):
1639 threading.Thread.__init__(self)
1640 asyncore.dispatcher.__init__(self)
1641 self.create_socket(socket.AF_INET, socket.SOCK_STREAM)
1642 self.bind(address)
1643 self.listen(5)
1644 self.host, self.port = self.socket.getsockname()[:2]
1645 self.handler_instance = None
1646 self._active = False
1647 self._active_lock = threading.Lock()
1648
1649 # --- public API
1650
1651 @property
1652 def running(self):
1653 return self._active
1654
1655 def start(self):
1656 assert not self.running
1657 self.__flag = threading.Event()
1658 threading.Thread.start(self)
1659 self.__flag.wait()
1660
1661 def stop(self):
1662 assert self.running
1663 self._active = False
1664 self.join()
1665
1666 def wait(self):
1667 # wait for handler connection to be closed, then stop the server
1668 while not getattr(self.handler_instance, "closed", False):
1669 time.sleep(0.001)
1670 self.stop()
1671
1672 # --- internals
1673
1674 def run(self):
1675 self._active = True
1676 self.__flag.set()
1677 while self._active and asyncore.socket_map:
1678 self._active_lock.acquire()
1679 asyncore.loop(timeout=0.001, count=1)
1680 self._active_lock.release()
1681 asyncore.close_all()
1682
1683 def handle_accept(self):
1684 conn, addr = self.accept()
1685 self.handler_instance = self.Handler(conn)
1686
1687 def handle_connect(self):
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001688 self.close()
Giampaolo Rodola'566f8a62011-05-18 21:28:39 +02001689 handle_read = handle_connect
1690
1691 def writable(self):
1692 return 0
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001693
1694 def handle_error(self):
1695 raise
1696
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001697
Giampaolo Rodolà46134642011-02-25 20:01:05 +00001698@unittest.skipUnless(threading is not None, "test needs threading module")
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001699@unittest.skipUnless(hasattr(os, 'sendfile'), "test needs os.sendfile()")
1700class TestSendfile(unittest.TestCase):
1701
Antoine Pitrou18dd0df2011-02-26 14:29:24 +00001702 DATA = b"12345abcde" * 16 * 1024 # 160 KB
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001703 SUPPORT_HEADERS_TRAILERS = not sys.platform.startswith("linux") and \
Giampaolo Rodolà4bc68572011-02-25 21:46:01 +00001704 not sys.platform.startswith("solaris") and \
1705 not sys.platform.startswith("sunos")
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001706
1707 @classmethod
1708 def setUpClass(cls):
1709 with open(support.TESTFN, "wb") as f:
1710 f.write(cls.DATA)
1711
1712 @classmethod
1713 def tearDownClass(cls):
1714 support.unlink(support.TESTFN)
1715
1716 def setUp(self):
1717 self.server = SendfileTestServer((support.HOST, 0))
1718 self.server.start()
1719 self.client = socket.socket()
1720 self.client.connect((self.server.host, self.server.port))
1721 self.client.settimeout(1)
1722 # synchronize by waiting for "220 ready" response
1723 self.client.recv(1024)
1724 self.sockno = self.client.fileno()
1725 self.file = open(support.TESTFN, 'rb')
1726 self.fileno = self.file.fileno()
1727
1728 def tearDown(self):
1729 self.file.close()
1730 self.client.close()
1731 if self.server.running:
1732 self.server.stop()
1733
1734 def sendfile_wrapper(self, sock, file, offset, nbytes, headers=[], trailers=[]):
1735 """A higher level wrapper representing how an application is
1736 supposed to use sendfile().
1737 """
1738 while 1:
1739 try:
1740 if self.SUPPORT_HEADERS_TRAILERS:
1741 return os.sendfile(sock, file, offset, nbytes, headers,
1742 trailers)
1743 else:
1744 return os.sendfile(sock, file, offset, nbytes)
1745 except OSError as err:
1746 if err.errno == errno.ECONNRESET:
1747 # disconnected
1748 raise
1749 elif err.errno in (errno.EAGAIN, errno.EBUSY):
1750 # we have to retry send data
1751 continue
1752 else:
1753 raise
1754
1755 def test_send_whole_file(self):
1756 # normal send
1757 total_sent = 0
1758 offset = 0
1759 nbytes = 4096
Antoine Pitrou18dd0df2011-02-26 14:29:24 +00001760 while total_sent < len(self.DATA):
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001761 sent = self.sendfile_wrapper(self.sockno, self.fileno, offset, nbytes)
1762 if sent == 0:
1763 break
1764 offset += sent
1765 total_sent += sent
1766 self.assertTrue(sent <= nbytes)
1767 self.assertEqual(offset, total_sent)
1768
1769 self.assertEqual(total_sent, len(self.DATA))
Antoine Pitrou2de51ff2011-02-26 17:52:50 +00001770 self.client.shutdown(socket.SHUT_RDWR)
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001771 self.client.close()
1772 self.server.wait()
1773 data = self.server.handler_instance.get_data()
Antoine Pitrou2de51ff2011-02-26 17:52:50 +00001774 self.assertEqual(len(data), len(self.DATA))
Antoine Pitrou18dd0df2011-02-26 14:29:24 +00001775 self.assertEqual(data, self.DATA)
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001776
1777 def test_send_at_certain_offset(self):
1778 # start sending a file at a certain offset
1779 total_sent = 0
Antoine Pitrou18dd0df2011-02-26 14:29:24 +00001780 offset = len(self.DATA) // 2
1781 must_send = len(self.DATA) - offset
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001782 nbytes = 4096
Antoine Pitrou18dd0df2011-02-26 14:29:24 +00001783 while total_sent < must_send:
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001784 sent = self.sendfile_wrapper(self.sockno, self.fileno, offset, nbytes)
1785 if sent == 0:
1786 break
1787 offset += sent
1788 total_sent += sent
1789 self.assertTrue(sent <= nbytes)
1790
Antoine Pitrou2de51ff2011-02-26 17:52:50 +00001791 self.client.shutdown(socket.SHUT_RDWR)
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001792 self.client.close()
1793 self.server.wait()
1794 data = self.server.handler_instance.get_data()
Antoine Pitrou18dd0df2011-02-26 14:29:24 +00001795 expected = self.DATA[len(self.DATA) // 2:]
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001796 self.assertEqual(total_sent, len(expected))
Antoine Pitrou2de51ff2011-02-26 17:52:50 +00001797 self.assertEqual(len(data), len(expected))
Antoine Pitrou18dd0df2011-02-26 14:29:24 +00001798 self.assertEqual(data, expected)
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001799
1800 def test_offset_overflow(self):
1801 # specify an offset > file size
1802 offset = len(self.DATA) + 4096
Antoine Pitrou18dd0df2011-02-26 14:29:24 +00001803 try:
1804 sent = os.sendfile(self.sockno, self.fileno, offset, 4096)
1805 except OSError as e:
1806 # Solaris can raise EINVAL if offset >= file length, ignore.
1807 if e.errno != errno.EINVAL:
1808 raise
1809 else:
1810 self.assertEqual(sent, 0)
Antoine Pitrou2de51ff2011-02-26 17:52:50 +00001811 self.client.shutdown(socket.SHUT_RDWR)
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001812 self.client.close()
1813 self.server.wait()
1814 data = self.server.handler_instance.get_data()
1815 self.assertEqual(data, b'')
1816
1817 def test_invalid_offset(self):
1818 with self.assertRaises(OSError) as cm:
1819 os.sendfile(self.sockno, self.fileno, -1, 4096)
1820 self.assertEqual(cm.exception.errno, errno.EINVAL)
1821
1822 # --- headers / trailers tests
1823
1824 if SUPPORT_HEADERS_TRAILERS:
1825
1826 def test_headers(self):
1827 total_sent = 0
1828 sent = os.sendfile(self.sockno, self.fileno, 0, 4096,
1829 headers=[b"x" * 512])
1830 total_sent += sent
1831 offset = 4096
1832 nbytes = 4096
1833 while 1:
1834 sent = self.sendfile_wrapper(self.sockno, self.fileno,
1835 offset, nbytes)
1836 if sent == 0:
1837 break
1838 total_sent += sent
1839 offset += sent
1840
1841 expected_data = b"x" * 512 + self.DATA
1842 self.assertEqual(total_sent, len(expected_data))
1843 self.client.close()
1844 self.server.wait()
1845 data = self.server.handler_instance.get_data()
1846 self.assertEqual(hash(data), hash(expected_data))
1847
1848 def test_trailers(self):
1849 TESTFN2 = support.TESTFN + "2"
Brett Cannonb6376802011-03-15 17:38:22 -04001850 with open(TESTFN2, 'wb') as f:
1851 f.write(b"abcde")
1852 with open(TESTFN2, 'rb')as f:
1853 self.addCleanup(os.remove, TESTFN2)
1854 os.sendfile(self.sockno, f.fileno(), 0, 4096,
1855 trailers=[b"12345"])
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001856 self.client.close()
1857 self.server.wait()
1858 data = self.server.handler_instance.get_data()
1859 self.assertEqual(data, b"abcde12345")
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00001860
1861 if hasattr(os, "SF_NODISKIO"):
1862 def test_flags(self):
1863 try:
1864 os.sendfile(self.sockno, self.fileno, 0, 4096,
1865 flags=os.SF_NODISKIO)
1866 except OSError as err:
1867 if err.errno not in (errno.EBUSY, errno.EAGAIN):
1868 raise
1869
1870
Larry Hastings9cf065c2012-06-22 16:30:09 -07001871def supports_extended_attributes():
1872 if not hasattr(os, "setxattr"):
1873 return False
1874 try:
1875 with open(support.TESTFN, "wb") as fp:
1876 try:
1877 os.setxattr(fp.fileno(), b"user.test", b"")
1878 except OSError:
1879 return False
1880 finally:
1881 support.unlink(support.TESTFN)
1882 # Kernels < 2.6.39 don't respect setxattr flags.
1883 kernel_version = platform.release()
1884 m = re.match("2.6.(\d{1,2})", kernel_version)
1885 return m is None or int(m.group(1)) >= 39
1886
1887
1888@unittest.skipUnless(supports_extended_attributes(),
1889 "no non-broken extended attribute support")
Benjamin Peterson799bd802011-08-31 22:15:17 -04001890class ExtendedAttributeTests(unittest.TestCase):
1891
1892 def tearDown(self):
1893 support.unlink(support.TESTFN)
1894
Larry Hastings9cf065c2012-06-22 16:30:09 -07001895 def _check_xattrs_str(self, s, getxattr, setxattr, removexattr, listxattr, **kwargs):
Benjamin Peterson799bd802011-08-31 22:15:17 -04001896 fn = support.TESTFN
1897 open(fn, "wb").close()
1898 with self.assertRaises(OSError) as cm:
Larry Hastings9cf065c2012-06-22 16:30:09 -07001899 getxattr(fn, s("user.test"), **kwargs)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001900 self.assertEqual(cm.exception.errno, errno.ENODATA)
Victor Stinnerf12e5062011-10-16 22:12:03 +02001901 init_xattr = listxattr(fn)
1902 self.assertIsInstance(init_xattr, list)
Larry Hastings9cf065c2012-06-22 16:30:09 -07001903 setxattr(fn, s("user.test"), b"", **kwargs)
Victor Stinnerf12e5062011-10-16 22:12:03 +02001904 xattr = set(init_xattr)
1905 xattr.add("user.test")
1906 self.assertEqual(set(listxattr(fn)), xattr)
Larry Hastings9cf065c2012-06-22 16:30:09 -07001907 self.assertEqual(getxattr(fn, b"user.test", **kwargs), b"")
1908 setxattr(fn, s("user.test"), b"hello", os.XATTR_REPLACE, **kwargs)
1909 self.assertEqual(getxattr(fn, b"user.test", **kwargs), b"hello")
Benjamin Peterson799bd802011-08-31 22:15:17 -04001910 with self.assertRaises(OSError) as cm:
Larry Hastings9cf065c2012-06-22 16:30:09 -07001911 setxattr(fn, s("user.test"), b"bye", os.XATTR_CREATE, **kwargs)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001912 self.assertEqual(cm.exception.errno, errno.EEXIST)
1913 with self.assertRaises(OSError) as cm:
Larry Hastings9cf065c2012-06-22 16:30:09 -07001914 setxattr(fn, s("user.test2"), b"bye", os.XATTR_REPLACE, **kwargs)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001915 self.assertEqual(cm.exception.errno, errno.ENODATA)
Larry Hastings9cf065c2012-06-22 16:30:09 -07001916 setxattr(fn, s("user.test2"), b"foo", os.XATTR_CREATE, **kwargs)
Victor Stinnerf12e5062011-10-16 22:12:03 +02001917 xattr.add("user.test2")
1918 self.assertEqual(set(listxattr(fn)), xattr)
Larry Hastings9cf065c2012-06-22 16:30:09 -07001919 removexattr(fn, s("user.test"), **kwargs)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001920 with self.assertRaises(OSError) as cm:
Larry Hastings9cf065c2012-06-22 16:30:09 -07001921 getxattr(fn, s("user.test"), **kwargs)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001922 self.assertEqual(cm.exception.errno, errno.ENODATA)
Victor Stinnerf12e5062011-10-16 22:12:03 +02001923 xattr.remove("user.test")
1924 self.assertEqual(set(listxattr(fn)), xattr)
Larry Hastings9cf065c2012-06-22 16:30:09 -07001925 self.assertEqual(getxattr(fn, s("user.test2"), **kwargs), b"foo")
1926 setxattr(fn, s("user.test"), b"a"*1024, **kwargs)
1927 self.assertEqual(getxattr(fn, s("user.test"), **kwargs), b"a"*1024)
1928 removexattr(fn, s("user.test"), **kwargs)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001929 many = sorted("user.test{}".format(i) for i in range(100))
1930 for thing in many:
Larry Hastings9cf065c2012-06-22 16:30:09 -07001931 setxattr(fn, thing, b"x", **kwargs)
Victor Stinnerf12e5062011-10-16 22:12:03 +02001932 self.assertEqual(set(listxattr(fn)), set(init_xattr) | set(many))
Benjamin Peterson799bd802011-08-31 22:15:17 -04001933
Larry Hastings9cf065c2012-06-22 16:30:09 -07001934 def _check_xattrs(self, *args, **kwargs):
Benjamin Peterson799bd802011-08-31 22:15:17 -04001935 def make_bytes(s):
1936 return bytes(s, "ascii")
Larry Hastings9cf065c2012-06-22 16:30:09 -07001937 self._check_xattrs_str(str, *args, **kwargs)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001938 support.unlink(support.TESTFN)
Larry Hastings9cf065c2012-06-22 16:30:09 -07001939 self._check_xattrs_str(make_bytes, *args, **kwargs)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001940
1941 def test_simple(self):
1942 self._check_xattrs(os.getxattr, os.setxattr, os.removexattr,
1943 os.listxattr)
1944
1945 def test_lpath(self):
Larry Hastings9cf065c2012-06-22 16:30:09 -07001946 self._check_xattrs(os.getxattr, os.setxattr, os.removexattr,
1947 os.listxattr, follow_symlinks=False)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001948
1949 def test_fds(self):
1950 def getxattr(path, *args):
1951 with open(path, "rb") as fp:
Larry Hastings9cf065c2012-06-22 16:30:09 -07001952 return os.getxattr(fp.fileno(), *args)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001953 def setxattr(path, *args):
1954 with open(path, "wb") as fp:
Larry Hastings9cf065c2012-06-22 16:30:09 -07001955 os.setxattr(fp.fileno(), *args)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001956 def removexattr(path, *args):
1957 with open(path, "wb") as fp:
Larry Hastings9cf065c2012-06-22 16:30:09 -07001958 os.removexattr(fp.fileno(), *args)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001959 def listxattr(path, *args):
1960 with open(path, "rb") as fp:
Larry Hastings9cf065c2012-06-22 16:30:09 -07001961 return os.listxattr(fp.fileno(), *args)
Benjamin Peterson799bd802011-08-31 22:15:17 -04001962 self._check_xattrs(getxattr, setxattr, removexattr, listxattr)
1963
1964
Victor Stinner1ab6c2d2011-11-15 22:27:41 +01001965@unittest.skipUnless(sys.platform == "win32", "Win32 specific tests")
1966class Win32DeprecatedBytesAPI(unittest.TestCase):
1967 def test_deprecated(self):
1968 import nt
1969 filename = os.fsencode(support.TESTFN)
1970 with warnings.catch_warnings():
1971 warnings.simplefilter("error", DeprecationWarning)
1972 for func, *args in (
1973 (nt._getfullpathname, filename),
1974 (nt._isdir, filename),
1975 (os.access, filename, os.R_OK),
1976 (os.chdir, filename),
1977 (os.chmod, filename, 0o777),
Victor Stinnerf7c5ae22011-11-16 23:43:07 +01001978 (os.getcwdb,),
Victor Stinner1ab6c2d2011-11-15 22:27:41 +01001979 (os.link, filename, filename),
1980 (os.listdir, filename),
1981 (os.lstat, filename),
1982 (os.mkdir, filename),
1983 (os.open, filename, os.O_RDONLY),
1984 (os.rename, filename, filename),
1985 (os.rmdir, filename),
1986 (os.startfile, filename),
1987 (os.stat, filename),
Victor Stinner1ab6c2d2011-11-15 22:27:41 +01001988 (os.unlink, filename),
1989 (os.utime, filename),
1990 ):
1991 self.assertRaises(DeprecationWarning, func, *args)
1992
Victor Stinner28216442011-11-16 00:34:44 +01001993 @support.skip_unless_symlink
1994 def test_symlink(self):
1995 filename = os.fsencode(support.TESTFN)
1996 with warnings.catch_warnings():
1997 warnings.simplefilter("error", DeprecationWarning)
1998 self.assertRaises(DeprecationWarning,
1999 os.symlink, filename, filename)
2000
Victor Stinner1ab6c2d2011-11-15 22:27:41 +01002001
Antoine Pitroubcf2b592012-02-08 23:28:36 +01002002@unittest.skipUnless(hasattr(os, 'get_terminal_size'), "requires os.get_terminal_size")
2003class TermsizeTests(unittest.TestCase):
2004 def test_does_not_crash(self):
2005 """Check if get_terminal_size() returns a meaningful value.
2006
2007 There's no easy portable way to actually check the size of the
2008 terminal, so let's check if it returns something sensible instead.
2009 """
2010 try:
2011 size = os.get_terminal_size()
2012 except OSError as e:
Antoine Pitrou81a1fa52012-02-09 00:11:00 +01002013 if sys.platform == "win32" or e.errno in (errno.EINVAL, errno.ENOTTY):
Antoine Pitroubcf2b592012-02-08 23:28:36 +01002014 # Under win32 a generic OSError can be thrown if the
2015 # handle cannot be retrieved
2016 self.skipTest("failed to query terminal size")
2017 raise
2018
Antoine Pitroucfade362012-02-08 23:48:59 +01002019 self.assertGreaterEqual(size.columns, 0)
2020 self.assertGreaterEqual(size.lines, 0)
Antoine Pitroubcf2b592012-02-08 23:28:36 +01002021
2022 def test_stty_match(self):
2023 """Check if stty returns the same results
2024
2025 stty actually tests stdin, so get_terminal_size is invoked on
2026 stdin explicitly. If stty succeeded, then get_terminal_size()
2027 should work too.
2028 """
2029 try:
2030 size = subprocess.check_output(['stty', 'size']).decode().split()
2031 except (FileNotFoundError, subprocess.CalledProcessError):
2032 self.skipTest("stty invocation failed")
2033 expected = (int(size[1]), int(size[0])) # reversed order
2034
Antoine Pitrou81a1fa52012-02-09 00:11:00 +01002035 try:
2036 actual = os.get_terminal_size(sys.__stdin__.fileno())
2037 except OSError as e:
2038 if sys.platform == "win32" or e.errno in (errno.EINVAL, errno.ENOTTY):
2039 # Under win32 a generic OSError can be thrown if the
2040 # handle cannot be retrieved
2041 self.skipTest("failed to query terminal size")
2042 raise
Antoine Pitroubcf2b592012-02-08 23:28:36 +01002043 self.assertEqual(expected, actual)
2044
2045
Antoine Pitrouf26ad712011-07-15 23:00:56 +02002046@support.reap_threads
Fred Drake2e2be372001-09-20 21:33:42 +00002047def test_main():
Benjamin Petersonee8712c2008-05-20 21:35:26 +00002048 support.run_unittest(
Thomas Wouters0e3f5912006-08-11 14:57:12 +00002049 FileTests,
Walter Dörwald21d3a322003-05-01 17:45:56 +00002050 StatAttributeTests,
2051 EnvironTests,
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +00002052 WalkTests,
Charles-François Natali7372b062012-02-05 15:15:38 +01002053 FwalkTests,
Andrew M. Kuchlingb386f6a2003-12-23 16:36:11 +00002054 MakedirTests,
Martin v. Löwisbdec50f2004-06-08 08:29:33 +00002055 DevNullTests,
Thomas Wouters477c8d52006-05-27 19:21:47 +00002056 URandomTests,
Guido van Rossume7ba4952007-06-06 23:52:48 +00002057 ExecTests,
Benjamin Petersone1cdfd72009-01-18 21:02:37 +00002058 Win32ErrorTests,
Benjamin Petersonef3e4c22009-04-11 19:48:14 +00002059 TestInvalidFD,
Martin v. Löwis011e8422009-05-05 04:43:17 +00002060 PosixUidGidTests,
Brian Curtineb24d742010-04-12 17:16:38 +00002061 Pep383Tests,
Victor Stinnerbf9bcab2010-05-09 03:15:33 +00002062 Win32KillTests,
Brian Curtind40e6f72010-07-08 21:39:08 +00002063 Win32SymlinkTests,
Victor Stinnere8d51452010-08-19 01:05:19 +00002064 FSEncodingTests,
Brett Cannonefb00c02012-02-29 18:31:31 -05002065 DeviceEncodingTests,
Amaury Forgeot d'Arc4b6fdf32010-09-07 21:31:17 +00002066 PidTests,
Brian Curtine8e4b3b2010-09-23 20:04:14 +00002067 LoginTests,
Brian Curtin1b9df392010-11-24 20:24:31 +00002068 LinkTests,
Giampaolo Rodolàc9c2c8b2011-02-25 14:39:16 +00002069 TestSendfile,
Giampaolo Rodolà18e8bcb2011-02-25 20:57:54 +00002070 ProgramPriorityTests,
Benjamin Peterson799bd802011-08-31 22:15:17 -04002071 ExtendedAttributeTests,
Victor Stinner1ab6c2d2011-11-15 22:27:41 +01002072 Win32DeprecatedBytesAPI,
Antoine Pitroubcf2b592012-02-08 23:28:36 +01002073 TermsizeTests,
Walter Dörwald21d3a322003-05-01 17:45:56 +00002074 )
Fred Drake2e2be372001-09-20 21:33:42 +00002075
2076if __name__ == "__main__":
2077 test_main()