-
-
Notifications
You must be signed in to change notification settings - Fork 30.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
bpo-30028: make test.support.temp_cwd() fork-safe #1066
Changes from 3 commits
22e032a
7b96cf7
9ca9665
1a0364d
0f480d9
8cebac8
1b78826
ee34a5b
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -161,6 +161,20 @@ def test_temp_dir__existing_dir__quiet_true(self): | |
f'temporary directory {path!r}: '), | ||
warn) | ||
|
||
@unittest.skipUnless(hasattr(os, "fork"), "test requires os.fork") | ||
def test_temp_dir__forked_child(self): | ||
"""Test that a forked child process does not remove the directory.""" | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please add a reference to the issue: bpo-30028 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. No other doc string in this file contains a reference to bpo. Therefore I added the reference as a comment. |
||
with support.temp_cwd() as temp_path: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hum, please don't use fork in a test process. Write a short script run with test.support.script_helper. Otherwise, I expect too many issues like bad handling of KeyboardInterrupt. Use textwrap.dedent() to include the script directly here. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Done (1a0364d). Is the patch now OK? |
||
pid = os.fork() | ||
if pid != 0: | ||
# parent process | ||
os.waitpid(pid, 0) # wait for the child to terminate | ||
# make sure that temp_path is still present | ||
self.assertTrue(os.path.isdir(temp_path)) | ||
if pid == 0: | ||
# terminate the child in order to not confuse the test runner | ||
os._exit(0) | ||
|
||
# Tests for change_cwd() | ||
|
||
def test_change_cwd(self): | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The test is non obvious, can you please add a short comment explaining why you test the pid?
I guess that it's test to avoid that two processes try to remove the directory if the parent uses fork()?
Add bpo-30028 in the comment.