Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
8e36812e
Commit
8e36812e
authored
Feb 10, 2015
by
Victor Stinner
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
asyncio: BaseSubprocessTransport.close() doesn't try to kill the process if it
already finished
parent
832dd5f0
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
61 additions
and
1 deletion
+61
-1
Lib/asyncio/base_subprocess.py
Lib/asyncio/base_subprocess.py
+6
-1
Lib/test/test_asyncio/test_subprocess.py
Lib/test/test_asyncio/test_subprocess.py
+55
-0
No files found.
Lib/asyncio/base_subprocess.py
View file @
8e36812e
...
...
@@ -93,7 +93,12 @@ class BaseSubprocessTransport(transports.SubprocessTransport):
continue
proto
.
pipe
.
close
()
if
self
.
_proc
is
not
None
and
self
.
_returncode
is
None
:
if
(
self
.
_proc
is
not
None
# the child process finished?
and
self
.
_returncode
is
None
# the child process finished but the transport was not notified yet?
and
self
.
_proc
.
poll
()
is
None
):
if
self
.
_loop
.
get_debug
():
logger
.
warning
(
'Close running child process: kill %r'
,
self
)
...
...
Lib/test/test_asyncio/test_subprocess.py
View file @
8e36812e
...
...
@@ -349,6 +349,61 @@ class SubprocessMixin:
self
.
loop
.
run_until_complete
(
cancel_make_transport
())
test_utils
.
run_briefly
(
self
.
loop
)
def
test_close_kill_running
(
self
):
@
asyncio
.
coroutine
def
kill_running
():
create
=
self
.
loop
.
subprocess_exec
(
asyncio
.
SubprocessProtocol
,
*
PROGRAM_BLOCKED
)
transport
,
protocol
=
yield
from
create
proc
=
transport
.
get_extra_info
(
'subprocess'
)
proc
.
kill
=
mock
.
Mock
()
returncode
=
transport
.
get_returncode
()
transport
.
close
()
return
(
returncode
,
proc
.
kill
.
called
)
# Ignore "Close running child process: kill ..." log
with
test_utils
.
disable_logger
():
returncode
,
killed
=
self
.
loop
.
run_until_complete
(
kill_running
())
self
.
assertIsNone
(
returncode
)
# transport.close() must kill the process if it is still running
self
.
assertTrue
(
killed
)
test_utils
.
run_briefly
(
self
.
loop
)
def
test_close_dont_kill_finished
(
self
):
@
asyncio
.
coroutine
def
kill_running
():
create
=
self
.
loop
.
subprocess_exec
(
asyncio
.
SubprocessProtocol
,
*
PROGRAM_BLOCKED
)
transport
,
protocol
=
yield
from
create
proc
=
transport
.
get_extra_info
(
'subprocess'
)
# kill the process (but asyncio is not notified immediatly)
proc
.
kill
()
proc
.
wait
()
proc
.
kill
=
mock
.
Mock
()
proc_returncode
=
proc
.
poll
()
transport_returncode
=
transport
.
get_returncode
()
transport
.
close
()
return
(
proc_returncode
,
transport_returncode
,
proc
.
kill
.
called
)
# Ignore "Unknown child process pid ..." log of SafeChildWatcher,
# emitted because the test already consumes the exit status:
# proc.wait()
with
test_utils
.
disable_logger
():
result
=
self
.
loop
.
run_until_complete
(
kill_running
())
test_utils
.
run_briefly
(
self
.
loop
)
proc_returncode
,
transport_return_code
,
killed
=
result
self
.
assertIsNotNone
(
proc_returncode
)
self
.
assertIsNone
(
transport_return_code
)
# transport.close() must not kill the process if it finished, even if
# the transport was not notified yet
self
.
assertFalse
(
killed
)
if
sys
.
platform
!=
'win32'
:
# Unix
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment