PageRenderTime 46ms CodeModel.GetById 14ms RepoModel.GetById 1ms app.codeStats 0ms

/lib-python/2.7/test/test_tempfile.py

https://bitbucket.org/yrttyr/pypy
Python | 892 lines | 817 code | 52 blank | 23 comment | 20 complexity | 23ca7a8dccea0b310ee8ba6f92875831 MD5 | raw file
  1. # tempfile.py unit tests.
  2. import tempfile
  3. import os
  4. import signal
  5. import sys
  6. import re
  7. import warnings
  8. import unittest
  9. from test import test_support
  10. warnings.filterwarnings("ignore",
  11. category=RuntimeWarning,
  12. message="mktemp", module=__name__)
  13. if hasattr(os, 'stat'):
  14. import stat
  15. has_stat = 1
  16. else:
  17. has_stat = 0
  18. has_textmode = (tempfile._text_openflags != tempfile._bin_openflags)
  19. has_spawnl = hasattr(os, 'spawnl')
  20. # TEST_FILES may need to be tweaked for systems depending on the maximum
  21. # number of files that can be opened at one time (see ulimit -n)
  22. if sys.platform.startswith("openbsd"):
  23. TEST_FILES = 64 # ulimit -n defaults to 128 for normal users
  24. else:
  25. TEST_FILES = 100
  26. # This is organized as one test for each chunk of code in tempfile.py,
  27. # in order of their appearance in the file. Testing which requires
  28. # threads is not done here.
  29. # Common functionality.
  30. class TC(unittest.TestCase):
  31. str_check = re.compile(r"[a-zA-Z0-9_-]{6}$")
  32. def failOnException(self, what, ei=None):
  33. if ei is None:
  34. ei = sys.exc_info()
  35. self.fail("%s raised %s: %s" % (what, ei[0], ei[1]))
  36. def nameCheck(self, name, dir, pre, suf):
  37. (ndir, nbase) = os.path.split(name)
  38. npre = nbase[:len(pre)]
  39. nsuf = nbase[len(nbase)-len(suf):]
  40. # check for equality of the absolute paths!
  41. self.assertEqual(os.path.abspath(ndir), os.path.abspath(dir),
  42. "file '%s' not in directory '%s'" % (name, dir))
  43. self.assertEqual(npre, pre,
  44. "file '%s' does not begin with '%s'" % (nbase, pre))
  45. self.assertEqual(nsuf, suf,
  46. "file '%s' does not end with '%s'" % (nbase, suf))
  47. nbase = nbase[len(pre):len(nbase)-len(suf)]
  48. self.assertTrue(self.str_check.match(nbase),
  49. "random string '%s' does not match /^[a-zA-Z0-9_-]{6}$/"
  50. % nbase)
  51. test_classes = []
  52. class test_exports(TC):
  53. def test_exports(self):
  54. # There are no surprising symbols in the tempfile module
  55. dict = tempfile.__dict__
  56. expected = {
  57. "NamedTemporaryFile" : 1,
  58. "TemporaryFile" : 1,
  59. "mkstemp" : 1,
  60. "mkdtemp" : 1,
  61. "mktemp" : 1,
  62. "TMP_MAX" : 1,
  63. "gettempprefix" : 1,
  64. "gettempdir" : 1,
  65. "tempdir" : 1,
  66. "template" : 1,
  67. "SpooledTemporaryFile" : 1
  68. }
  69. unexp = []
  70. for key in dict:
  71. if key[0] != '_' and key not in expected:
  72. unexp.append(key)
  73. self.assertTrue(len(unexp) == 0,
  74. "unexpected keys: %s" % unexp)
  75. test_classes.append(test_exports)
  76. class test__RandomNameSequence(TC):
  77. """Test the internal iterator object _RandomNameSequence."""
  78. def setUp(self):
  79. self.r = tempfile._RandomNameSequence()
  80. def test_get_six_char_str(self):
  81. # _RandomNameSequence returns a six-character string
  82. s = self.r.next()
  83. self.nameCheck(s, '', '', '')
  84. def test_many(self):
  85. # _RandomNameSequence returns no duplicate strings (stochastic)
  86. dict = {}
  87. r = self.r
  88. for i in xrange(TEST_FILES):
  89. s = r.next()
  90. self.nameCheck(s, '', '', '')
  91. self.assertNotIn(s, dict)
  92. dict[s] = 1
  93. def test_supports_iter(self):
  94. # _RandomNameSequence supports the iterator protocol
  95. i = 0
  96. r = self.r
  97. try:
  98. for s in r:
  99. i += 1
  100. if i == 20:
  101. break
  102. except:
  103. self.failOnException("iteration")
  104. @unittest.skipUnless(hasattr(os, 'fork'),
  105. "os.fork is required for this test")
  106. def test_process_awareness(self):
  107. # ensure that the random source differs between
  108. # child and parent.
  109. read_fd, write_fd = os.pipe()
  110. pid = None
  111. try:
  112. pid = os.fork()
  113. if not pid:
  114. os.close(read_fd)
  115. os.write(write_fd, next(self.r).encode("ascii"))
  116. os.close(write_fd)
  117. # bypass the normal exit handlers- leave those to
  118. # the parent.
  119. os._exit(0)
  120. parent_value = next(self.r)
  121. child_value = os.read(read_fd, len(parent_value)).decode("ascii")
  122. finally:
  123. if pid:
  124. # best effort to ensure the process can't bleed out
  125. # via any bugs above
  126. try:
  127. os.kill(pid, signal.SIGKILL)
  128. except EnvironmentError:
  129. pass
  130. os.close(read_fd)
  131. os.close(write_fd)
  132. self.assertNotEqual(child_value, parent_value)
  133. test_classes.append(test__RandomNameSequence)
  134. class test__candidate_tempdir_list(TC):
  135. """Test the internal function _candidate_tempdir_list."""
  136. def test_nonempty_list(self):
  137. # _candidate_tempdir_list returns a nonempty list of strings
  138. cand = tempfile._candidate_tempdir_list()
  139. self.assertFalse(len(cand) == 0)
  140. for c in cand:
  141. self.assertIsInstance(c, basestring)
  142. def test_wanted_dirs(self):
  143. # _candidate_tempdir_list contains the expected directories
  144. # Make sure the interesting environment variables are all set.
  145. with test_support.EnvironmentVarGuard() as env:
  146. for envname in 'TMPDIR', 'TEMP', 'TMP':
  147. dirname = os.getenv(envname)
  148. if not dirname:
  149. env[envname] = os.path.abspath(envname)
  150. cand = tempfile._candidate_tempdir_list()
  151. for envname in 'TMPDIR', 'TEMP', 'TMP':
  152. dirname = os.getenv(envname)
  153. if not dirname: raise ValueError
  154. self.assertIn(dirname, cand)
  155. try:
  156. dirname = os.getcwd()
  157. except (AttributeError, os.error):
  158. dirname = os.curdir
  159. self.assertIn(dirname, cand)
  160. # Not practical to try to verify the presence of OS-specific
  161. # paths in this list.
  162. test_classes.append(test__candidate_tempdir_list)
  163. # We test _get_default_tempdir by testing gettempdir.
  164. class test__get_candidate_names(TC):
  165. """Test the internal function _get_candidate_names."""
  166. def test_retval(self):
  167. # _get_candidate_names returns a _RandomNameSequence object
  168. obj = tempfile._get_candidate_names()
  169. self.assertIsInstance(obj, tempfile._RandomNameSequence)
  170. def test_same_thing(self):
  171. # _get_candidate_names always returns the same object
  172. a = tempfile._get_candidate_names()
  173. b = tempfile._get_candidate_names()
  174. self.assertTrue(a is b)
  175. test_classes.append(test__get_candidate_names)
  176. class test__mkstemp_inner(TC):
  177. """Test the internal function _mkstemp_inner."""
  178. class mkstemped:
  179. _bflags = tempfile._bin_openflags
  180. _tflags = tempfile._text_openflags
  181. _close = os.close
  182. _unlink = os.unlink
  183. def __init__(self, dir, pre, suf, bin):
  184. if bin: flags = self._bflags
  185. else: flags = self._tflags
  186. (self.fd, self.name) = tempfile._mkstemp_inner(dir, pre, suf, flags)
  187. def write(self, str):
  188. os.write(self.fd, str)
  189. def __del__(self):
  190. self._close(self.fd)
  191. self._unlink(self.name)
  192. def do_create(self, dir=None, pre="", suf="", bin=1):
  193. if dir is None:
  194. dir = tempfile.gettempdir()
  195. try:
  196. file = self.mkstemped(dir, pre, suf, bin)
  197. except:
  198. self.failOnException("_mkstemp_inner")
  199. self.nameCheck(file.name, dir, pre, suf)
  200. return file
  201. def test_basic(self):
  202. # _mkstemp_inner can create files
  203. self.do_create().write("blat")
  204. self.do_create(pre="a").write("blat")
  205. self.do_create(suf="b").write("blat")
  206. self.do_create(pre="a", suf="b").write("blat")
  207. self.do_create(pre="aa", suf=".txt").write("blat")
  208. def test_basic_many(self):
  209. # _mkstemp_inner can create many files (stochastic)
  210. extant = range(TEST_FILES)
  211. for i in extant:
  212. extant[i] = self.do_create(pre="aa")
  213. def test_choose_directory(self):
  214. # _mkstemp_inner can create files in a user-selected directory
  215. dir = tempfile.mkdtemp()
  216. try:
  217. self.do_create(dir=dir).write("blat")
  218. test_support.gc_collect()
  219. finally:
  220. os.rmdir(dir)
  221. def test_file_mode(self):
  222. # _mkstemp_inner creates files with the proper mode
  223. if not has_stat:
  224. return # ugh, can't use SkipTest.
  225. file = self.do_create()
  226. mode = stat.S_IMODE(os.stat(file.name).st_mode)
  227. expected = 0600
  228. if sys.platform in ('win32', 'os2emx'):
  229. # There's no distinction among 'user', 'group' and 'world';
  230. # replicate the 'user' bits.
  231. user = expected >> 6
  232. expected = user * (1 + 8 + 64)
  233. self.assertEqual(mode, expected)
  234. def test_noinherit(self):
  235. # _mkstemp_inner file handles are not inherited by child processes
  236. if not has_spawnl:
  237. return # ugh, can't use SkipTest.
  238. if test_support.verbose:
  239. v="v"
  240. else:
  241. v="q"
  242. file = self.do_create()
  243. fd = "%d" % file.fd
  244. try:
  245. me = __file__
  246. except NameError:
  247. me = sys.argv[0]
  248. # We have to exec something, so that FD_CLOEXEC will take
  249. # effect. The core of this test is therefore in
  250. # tf_inherit_check.py, which see.
  251. tester = os.path.join(os.path.dirname(os.path.abspath(me)),
  252. "tf_inherit_check.py")
  253. # On Windows a spawn* /path/ with embedded spaces shouldn't be quoted,
  254. # but an arg with embedded spaces should be decorated with double
  255. # quotes on each end
  256. if sys.platform in ('win32',):
  257. decorated = '"%s"' % sys.executable
  258. tester = '"%s"' % tester
  259. else:
  260. decorated = sys.executable
  261. retval = os.spawnl(os.P_WAIT, sys.executable, decorated, tester, v, fd)
  262. self.assertFalse(retval < 0,
  263. "child process caught fatal signal %d" % -retval)
  264. self.assertFalse(retval > 0, "child process reports failure %d"%retval)
  265. def test_textmode(self):
  266. # _mkstemp_inner can create files in text mode
  267. if not has_textmode:
  268. return # ugh, can't use SkipTest.
  269. self.do_create(bin=0).write("blat\n")
  270. # XXX should test that the file really is a text file
  271. test_classes.append(test__mkstemp_inner)
  272. class test_gettempprefix(TC):
  273. """Test gettempprefix()."""
  274. def test_sane_template(self):
  275. # gettempprefix returns a nonempty prefix string
  276. p = tempfile.gettempprefix()
  277. self.assertIsInstance(p, basestring)
  278. self.assertTrue(len(p) > 0)
  279. def test_usable_template(self):
  280. # gettempprefix returns a usable prefix string
  281. # Create a temp directory, avoiding use of the prefix.
  282. # Then attempt to create a file whose name is
  283. # prefix + 'xxxxxx.xxx' in that directory.
  284. p = tempfile.gettempprefix() + "xxxxxx.xxx"
  285. d = tempfile.mkdtemp(prefix="")
  286. try:
  287. p = os.path.join(d, p)
  288. try:
  289. fd = os.open(p, os.O_RDWR | os.O_CREAT)
  290. except:
  291. self.failOnException("os.open")
  292. os.close(fd)
  293. os.unlink(p)
  294. finally:
  295. os.rmdir(d)
  296. test_classes.append(test_gettempprefix)
  297. class test_gettempdir(TC):
  298. """Test gettempdir()."""
  299. def test_directory_exists(self):
  300. # gettempdir returns a directory which exists
  301. dir = tempfile.gettempdir()
  302. self.assertTrue(os.path.isabs(dir) or dir == os.curdir,
  303. "%s is not an absolute path" % dir)
  304. self.assertTrue(os.path.isdir(dir),
  305. "%s is not a directory" % dir)
  306. def test_directory_writable(self):
  307. # gettempdir returns a directory writable by the user
  308. # sneaky: just instantiate a NamedTemporaryFile, which
  309. # defaults to writing into the directory returned by
  310. # gettempdir.
  311. try:
  312. file = tempfile.NamedTemporaryFile()
  313. file.write("blat")
  314. file.close()
  315. except:
  316. self.failOnException("create file in %s" % tempfile.gettempdir())
  317. def test_same_thing(self):
  318. # gettempdir always returns the same object
  319. a = tempfile.gettempdir()
  320. b = tempfile.gettempdir()
  321. self.assertTrue(a is b)
  322. test_classes.append(test_gettempdir)
  323. class test_mkstemp(TC):
  324. """Test mkstemp()."""
  325. def do_create(self, dir=None, pre="", suf=""):
  326. if dir is None:
  327. dir = tempfile.gettempdir()
  328. try:
  329. (fd, name) = tempfile.mkstemp(dir=dir, prefix=pre, suffix=suf)
  330. (ndir, nbase) = os.path.split(name)
  331. adir = os.path.abspath(dir)
  332. self.assertEqual(adir, ndir,
  333. "Directory '%s' incorrectly returned as '%s'" % (adir, ndir))
  334. except:
  335. self.failOnException("mkstemp")
  336. try:
  337. self.nameCheck(name, dir, pre, suf)
  338. finally:
  339. os.close(fd)
  340. os.unlink(name)
  341. def test_basic(self):
  342. # mkstemp can create files
  343. self.do_create()
  344. self.do_create(pre="a")
  345. self.do_create(suf="b")
  346. self.do_create(pre="a", suf="b")
  347. self.do_create(pre="aa", suf=".txt")
  348. self.do_create(dir=".")
  349. def test_choose_directory(self):
  350. # mkstemp can create directories in a user-selected directory
  351. dir = tempfile.mkdtemp()
  352. try:
  353. self.do_create(dir=dir)
  354. finally:
  355. os.rmdir(dir)
  356. test_classes.append(test_mkstemp)
  357. class test_mkdtemp(TC):
  358. """Test mkdtemp()."""
  359. def do_create(self, dir=None, pre="", suf=""):
  360. if dir is None:
  361. dir = tempfile.gettempdir()
  362. try:
  363. name = tempfile.mkdtemp(dir=dir, prefix=pre, suffix=suf)
  364. except:
  365. self.failOnException("mkdtemp")
  366. try:
  367. self.nameCheck(name, dir, pre, suf)
  368. return name
  369. except:
  370. os.rmdir(name)
  371. raise
  372. def test_basic(self):
  373. # mkdtemp can create directories
  374. os.rmdir(self.do_create())
  375. os.rmdir(self.do_create(pre="a"))
  376. os.rmdir(self.do_create(suf="b"))
  377. os.rmdir(self.do_create(pre="a", suf="b"))
  378. os.rmdir(self.do_create(pre="aa", suf=".txt"))
  379. def test_basic_many(self):
  380. # mkdtemp can create many directories (stochastic)
  381. extant = range(TEST_FILES)
  382. try:
  383. for i in extant:
  384. extant[i] = self.do_create(pre="aa")
  385. finally:
  386. for i in extant:
  387. if(isinstance(i, basestring)):
  388. os.rmdir(i)
  389. def test_choose_directory(self):
  390. # mkdtemp can create directories in a user-selected directory
  391. dir = tempfile.mkdtemp()
  392. try:
  393. os.rmdir(self.do_create(dir=dir))
  394. finally:
  395. os.rmdir(dir)
  396. def test_mode(self):
  397. # mkdtemp creates directories with the proper mode
  398. if not has_stat:
  399. return # ugh, can't use SkipTest.
  400. dir = self.do_create()
  401. try:
  402. mode = stat.S_IMODE(os.stat(dir).st_mode)
  403. mode &= 0777 # Mask off sticky bits inherited from /tmp
  404. expected = 0700
  405. if sys.platform in ('win32', 'os2emx'):
  406. # There's no distinction among 'user', 'group' and 'world';
  407. # replicate the 'user' bits.
  408. user = expected >> 6
  409. expected = user * (1 + 8 + 64)
  410. self.assertEqual(mode, expected)
  411. finally:
  412. os.rmdir(dir)
  413. test_classes.append(test_mkdtemp)
  414. class test_mktemp(TC):
  415. """Test mktemp()."""
  416. # For safety, all use of mktemp must occur in a private directory.
  417. # We must also suppress the RuntimeWarning it generates.
  418. def setUp(self):
  419. self.dir = tempfile.mkdtemp()
  420. def tearDown(self):
  421. if self.dir:
  422. os.rmdir(self.dir)
  423. self.dir = None
  424. class mktemped:
  425. _unlink = os.unlink
  426. _bflags = tempfile._bin_openflags
  427. def __init__(self, dir, pre, suf):
  428. self.name = tempfile.mktemp(dir=dir, prefix=pre, suffix=suf)
  429. # Create the file. This will raise an exception if it's
  430. # mysteriously appeared in the meanwhile.
  431. os.close(os.open(self.name, self._bflags, 0600))
  432. def __del__(self):
  433. self._unlink(self.name)
  434. def do_create(self, pre="", suf=""):
  435. try:
  436. file = self.mktemped(self.dir, pre, suf)
  437. except:
  438. self.failOnException("mktemp")
  439. self.nameCheck(file.name, self.dir, pre, suf)
  440. return file
  441. def test_basic(self):
  442. # mktemp can choose usable file names
  443. self.do_create()
  444. self.do_create(pre="a")
  445. self.do_create(suf="b")
  446. self.do_create(pre="a", suf="b")
  447. self.do_create(pre="aa", suf=".txt")
  448. test_support.gc_collect()
  449. def test_many(self):
  450. # mktemp can choose many usable file names (stochastic)
  451. extant = range(TEST_FILES)
  452. for i in extant:
  453. extant[i] = self.do_create(pre="aa")
  454. del extant
  455. test_support.gc_collect()
  456. ## def test_warning(self):
  457. ## # mktemp issues a warning when used
  458. ## warnings.filterwarnings("error",
  459. ## category=RuntimeWarning,
  460. ## message="mktemp")
  461. ## self.assertRaises(RuntimeWarning,
  462. ## tempfile.mktemp, dir=self.dir)
  463. test_classes.append(test_mktemp)
  464. # We test _TemporaryFileWrapper by testing NamedTemporaryFile.
  465. class test_NamedTemporaryFile(TC):
  466. """Test NamedTemporaryFile()."""
  467. def do_create(self, dir=None, pre="", suf="", delete=True):
  468. if dir is None:
  469. dir = tempfile.gettempdir()
  470. try:
  471. file = tempfile.NamedTemporaryFile(dir=dir, prefix=pre, suffix=suf,
  472. delete=delete)
  473. except:
  474. self.failOnException("NamedTemporaryFile")
  475. self.nameCheck(file.name, dir, pre, suf)
  476. return file
  477. def test_basic(self):
  478. # NamedTemporaryFile can create files
  479. self.do_create()
  480. self.do_create(pre="a")
  481. self.do_create(suf="b")
  482. self.do_create(pre="a", suf="b")
  483. self.do_create(pre="aa", suf=".txt")
  484. def test_creates_named(self):
  485. # NamedTemporaryFile creates files with names
  486. f = tempfile.NamedTemporaryFile()
  487. self.assertTrue(os.path.exists(f.name),
  488. "NamedTemporaryFile %s does not exist" % f.name)
  489. def test_del_on_close(self):
  490. # A NamedTemporaryFile is deleted when closed
  491. dir = tempfile.mkdtemp()
  492. try:
  493. f = tempfile.NamedTemporaryFile(dir=dir)
  494. f.write('blat')
  495. f.close()
  496. self.assertFalse(os.path.exists(f.name),
  497. "NamedTemporaryFile %s exists after close" % f.name)
  498. finally:
  499. os.rmdir(dir)
  500. def test_dis_del_on_close(self):
  501. # Tests that delete-on-close can be disabled
  502. dir = tempfile.mkdtemp()
  503. tmp = None
  504. try:
  505. f = tempfile.NamedTemporaryFile(dir=dir, delete=False)
  506. tmp = f.name
  507. f.write('blat')
  508. f.close()
  509. self.assertTrue(os.path.exists(f.name),
  510. "NamedTemporaryFile %s missing after close" % f.name)
  511. finally:
  512. if tmp is not None:
  513. os.unlink(tmp)
  514. os.rmdir(dir)
  515. def test_multiple_close(self):
  516. # A NamedTemporaryFile can be closed many times without error
  517. f = tempfile.NamedTemporaryFile()
  518. f.write('abc\n')
  519. f.close()
  520. try:
  521. f.close()
  522. f.close()
  523. except:
  524. self.failOnException("close")
  525. def test_context_manager(self):
  526. # A NamedTemporaryFile can be used as a context manager
  527. with tempfile.NamedTemporaryFile() as f:
  528. self.assertTrue(os.path.exists(f.name))
  529. self.assertFalse(os.path.exists(f.name))
  530. def use_closed():
  531. with f:
  532. pass
  533. self.assertRaises(ValueError, use_closed)
  534. # How to test the mode and bufsize parameters?
  535. test_classes.append(test_NamedTemporaryFile)
  536. class test_SpooledTemporaryFile(TC):
  537. """Test SpooledTemporaryFile()."""
  538. def do_create(self, max_size=0, dir=None, pre="", suf=""):
  539. if dir is None:
  540. dir = tempfile.gettempdir()
  541. try:
  542. file = tempfile.SpooledTemporaryFile(max_size=max_size, dir=dir, prefix=pre, suffix=suf)
  543. except:
  544. self.failOnException("SpooledTemporaryFile")
  545. return file
  546. def test_basic(self):
  547. # SpooledTemporaryFile can create files
  548. f = self.do_create()
  549. self.assertFalse(f._rolled)
  550. f = self.do_create(max_size=100, pre="a", suf=".txt")
  551. self.assertFalse(f._rolled)
  552. def test_del_on_close(self):
  553. # A SpooledTemporaryFile is deleted when closed
  554. dir = tempfile.mkdtemp()
  555. try:
  556. f = tempfile.SpooledTemporaryFile(max_size=10, dir=dir)
  557. self.assertFalse(f._rolled)
  558. f.write('blat ' * 5)
  559. self.assertTrue(f._rolled)
  560. filename = f.name
  561. f.close()
  562. self.assertFalse(os.path.exists(filename),
  563. "SpooledTemporaryFile %s exists after close" % filename)
  564. finally:
  565. os.rmdir(dir)
  566. def test_rewrite_small(self):
  567. # A SpooledTemporaryFile can be written to multiple within the max_size
  568. f = self.do_create(max_size=30)
  569. self.assertFalse(f._rolled)
  570. for i in range(5):
  571. f.seek(0, 0)
  572. f.write('x' * 20)
  573. self.assertFalse(f._rolled)
  574. def test_write_sequential(self):
  575. # A SpooledTemporaryFile should hold exactly max_size bytes, and roll
  576. # over afterward
  577. f = self.do_create(max_size=30)
  578. self.assertFalse(f._rolled)
  579. f.write('x' * 20)
  580. self.assertFalse(f._rolled)
  581. f.write('x' * 10)
  582. self.assertFalse(f._rolled)
  583. f.write('x')
  584. self.assertTrue(f._rolled)
  585. def test_writelines(self):
  586. # Verify writelines with a SpooledTemporaryFile
  587. f = self.do_create()
  588. f.writelines((b'x', b'y', b'z'))
  589. f.seek(0)
  590. buf = f.read()
  591. self.assertEqual(buf, b'xyz')
  592. def test_writelines_sequential(self):
  593. # A SpooledTemporaryFile should hold exactly max_size bytes, and roll
  594. # over afterward
  595. f = self.do_create(max_size=35)
  596. f.writelines((b'x' * 20, b'x' * 10, b'x' * 5))
  597. self.assertFalse(f._rolled)
  598. f.write(b'x')
  599. self.assertTrue(f._rolled)
  600. def test_sparse(self):
  601. # A SpooledTemporaryFile that is written late in the file will extend
  602. # when that occurs
  603. f = self.do_create(max_size=30)
  604. self.assertFalse(f._rolled)
  605. f.seek(100, 0)
  606. self.assertFalse(f._rolled)
  607. f.write('x')
  608. self.assertTrue(f._rolled)
  609. def test_fileno(self):
  610. # A SpooledTemporaryFile should roll over to a real file on fileno()
  611. f = self.do_create(max_size=30)
  612. self.assertFalse(f._rolled)
  613. self.assertTrue(f.fileno() > 0)
  614. self.assertTrue(f._rolled)
  615. def test_multiple_close_before_rollover(self):
  616. # A SpooledTemporaryFile can be closed many times without error
  617. f = tempfile.SpooledTemporaryFile()
  618. f.write('abc\n')
  619. self.assertFalse(f._rolled)
  620. f.close()
  621. try:
  622. f.close()
  623. f.close()
  624. except:
  625. self.failOnException("close")
  626. def test_multiple_close_after_rollover(self):
  627. # A SpooledTemporaryFile can be closed many times without error
  628. f = tempfile.SpooledTemporaryFile(max_size=1)
  629. f.write('abc\n')
  630. self.assertTrue(f._rolled)
  631. f.close()
  632. try:
  633. f.close()
  634. f.close()
  635. except:
  636. self.failOnException("close")
  637. def test_bound_methods(self):
  638. # It should be OK to steal a bound method from a SpooledTemporaryFile
  639. # and use it independently; when the file rolls over, those bound
  640. # methods should continue to function
  641. f = self.do_create(max_size=30)
  642. read = f.read
  643. write = f.write
  644. seek = f.seek
  645. write("a" * 35)
  646. write("b" * 35)
  647. seek(0, 0)
  648. self.assertTrue(read(70) == 'a'*35 + 'b'*35)
  649. def test_context_manager_before_rollover(self):
  650. # A SpooledTemporaryFile can be used as a context manager
  651. with tempfile.SpooledTemporaryFile(max_size=1) as f:
  652. self.assertFalse(f._rolled)
  653. self.assertFalse(f.closed)
  654. self.assertTrue(f.closed)
  655. def use_closed():
  656. with f:
  657. pass
  658. self.assertRaises(ValueError, use_closed)
  659. def test_context_manager_during_rollover(self):
  660. # A SpooledTemporaryFile can be used as a context manager
  661. with tempfile.SpooledTemporaryFile(max_size=1) as f:
  662. self.assertFalse(f._rolled)
  663. f.write('abc\n')
  664. f.flush()
  665. self.assertTrue(f._rolled)
  666. self.assertFalse(f.closed)
  667. self.assertTrue(f.closed)
  668. def use_closed():
  669. with f:
  670. pass
  671. self.assertRaises(ValueError, use_closed)
  672. def test_context_manager_after_rollover(self):
  673. # A SpooledTemporaryFile can be used as a context manager
  674. f = tempfile.SpooledTemporaryFile(max_size=1)
  675. f.write('abc\n')
  676. f.flush()
  677. self.assertTrue(f._rolled)
  678. with f:
  679. self.assertFalse(f.closed)
  680. self.assertTrue(f.closed)
  681. def use_closed():
  682. with f:
  683. pass
  684. self.assertRaises(ValueError, use_closed)
  685. test_classes.append(test_SpooledTemporaryFile)
  686. class test_TemporaryFile(TC):
  687. """Test TemporaryFile()."""
  688. def test_basic(self):
  689. # TemporaryFile can create files
  690. # No point in testing the name params - the file has no name.
  691. try:
  692. tempfile.TemporaryFile()
  693. except:
  694. self.failOnException("TemporaryFile")
  695. def test_has_no_name(self):
  696. # TemporaryFile creates files with no names (on this system)
  697. dir = tempfile.mkdtemp()
  698. f = tempfile.TemporaryFile(dir=dir)
  699. f.write('blat')
  700. # Sneaky: because this file has no name, it should not prevent
  701. # us from removing the directory it was created in.
  702. try:
  703. os.rmdir(dir)
  704. except:
  705. ei = sys.exc_info()
  706. # cleanup
  707. f.close()
  708. os.rmdir(dir)
  709. self.failOnException("rmdir", ei)
  710. def test_multiple_close(self):
  711. # A TemporaryFile can be closed many times without error
  712. f = tempfile.TemporaryFile()
  713. f.write('abc\n')
  714. f.close()
  715. try:
  716. f.close()
  717. f.close()
  718. except:
  719. self.failOnException("close")
  720. # How to test the mode and bufsize parameters?
  721. if tempfile.NamedTemporaryFile is not tempfile.TemporaryFile:
  722. test_classes.append(test_TemporaryFile)
  723. def test_main():
  724. test_support.run_unittest(*test_classes)
  725. if __name__ == "__main__":
  726. test_main()