]> granicus.if.org Git - python/commitdiff
Issue #15526: try to fix test_startfile's inability to clean up after itself in time.
authorAntoine Pitrou <solipsis@pitrou.net>
Sat, 15 Sep 2012 22:12:50 +0000 (00:12 +0200)
committerAntoine Pitrou <solipsis@pitrou.net>
Sat, 15 Sep 2012 22:12:50 +0000 (00:12 +0200)
Patch by Jeremy Kloth.

Lib/test/test_startfile.py

index dd505bf8cedc13bdfacbfc0e8c4906093a7a4cb7..ae9aeb9b6ce605fe49ed367a868d6eddb83949e0 100644 (file)
@@ -10,8 +10,8 @@
 import unittest
 from test import support
 import os
+import sys
 from os import path
-from time import sleep
 
 startfile = support.get_attribute(os, 'startfile')
 
@@ -21,13 +21,12 @@ class TestCase(unittest.TestCase):
         self.assertRaises(OSError, startfile, "nonexisting.vbs")
 
     def test_empty(self):
-        empty = path.join(path.dirname(__file__), "empty.vbs")
-        startfile(empty)
-        startfile(empty, "open")
-        # Give the child process some time to exit before we finish.
-        # Otherwise the cleanup code will not be able to delete the cwd,
-        # because it is still in use.
-        sleep(0.1)
+        # Switch to an existing, but safe, working directory to let the
+        # cleanup code do its thing without permission errors.
+        with support.temp_cwd(path=path.dirname(sys.executable)):
+            empty = path.join(path.dirname(__file__), "empty.vbs")
+            startfile(empty)
+            startfile(empty, "open")
 
 def test_main():
     support.run_unittest(TestCase)