gh-146202: Create tmp_dir in regrtest worker (GH-146347)
Create tmp_dir in libregrtest.worker since the directory can be
different than the --tempdir directory.
(cherry picked from commit
bcff99cb3f3b887a08c4f0ace1279ced38dd9e62)
Co-authored-by: Victor Stinner <vstinner@python.org>
f"unexpectedly returned {tmp_dir!r} on WASI"
)
tmp_dir = os.path.join(tmp_dir, 'build')
-
- # When get_temp_dir() is called in a worker process,
- # get_temp_dir() path is different than in the parent process
- # which is not a WASI process. So the parent does not create
- # the same "tmp_dir" than the test worker process.
- os.makedirs(tmp_dir, exist_ok=True)
else:
tmp_dir = tempfile.gettempdir()
worker_json = sys.argv[1]
tmp_dir = get_temp_dir()
+ # get_temp_dir() can be different in the worker and the parent process.
+ # For example, if --tempdir option is used.
+ os.makedirs(tmp_dir, exist_ok=True)
work_dir = get_work_dir(tmp_dir, worker=True)
with exit_timeout():
--- /dev/null
+Fix a race condition in regrtest: make sure that the temporary directory is
+created in the worker process. Previously, temp_cwd() could fail on Windows if
+the "build" directory was not created. Patch by Victor Stinner.