Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gevent
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
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gevent
Commits
454bced7
Commit
454bced7
authored
Jun 27, 2015
by
Jason Madden
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #592 from gevent/patch-subprocess-by-default
Patch subprocess by default. Fixes #466.
parents
65cb38de
90adf39b
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
30 additions
and
3 deletions
+30
-3
changelog.rst
changelog.rst
+1
-0
gevent/monkey.py
gevent/monkey.py
+1
-1
gevent/subprocess.py
gevent/subprocess.py
+2
-2
greentest/patched_tests_setup.py
greentest/patched_tests_setup.py
+25
-0
known_failures.py
known_failures.py
+1
-0
No files found.
changelog.rst
View file @
454bced7
...
@@ -41,6 +41,7 @@ Unreleased
...
@@ -41,6 +41,7 @@ Unreleased
return True, supporting its use-case as an "infinite" or unbounded
return True, supporting its use-case as an "infinite" or unbounded
semaphore providing no exclusing, and allowing the idiom ``if
semaphore providing no exclusing, and allowing the idiom ``if
sem.acquire(): ...``. PR #544 by Mouad Benchchaoui.
sem.acquire(): ...``. PR #544 by Mouad Benchchaoui.
- Patch ``subprocess`` by default in ``gevent.monkey.patch_all``. See #446.
Release 1.0.2
Release 1.0.2
-------------
-------------
...
...
gevent/monkey.py
View file @
454bced7
...
@@ -235,7 +235,7 @@ def patch_subprocess():
...
@@ -235,7 +235,7 @@ def patch_subprocess():
def
patch_all
(
socket
=
True
,
dns
=
True
,
time
=
True
,
select
=
True
,
thread
=
True
,
os
=
True
,
ssl
=
True
,
httplib
=
False
,
def
patch_all
(
socket
=
True
,
dns
=
True
,
time
=
True
,
select
=
True
,
thread
=
True
,
os
=
True
,
ssl
=
True
,
httplib
=
False
,
subprocess
=
Fals
e
,
sys
=
False
,
aggressive
=
True
,
Event
=
False
):
subprocess
=
Tru
e
,
sys
=
False
,
aggressive
=
True
,
Event
=
False
):
"""Do all of the default monkey patching (calls every other function in this module."""
"""Do all of the default monkey patching (calls every other function in this module."""
# order is important
# order is important
if
os
:
if
os
:
...
...
gevent/subprocess.py
View file @
454bced7
...
@@ -307,8 +307,8 @@ class Popen(object):
...
@@ -307,8 +307,8 @@ class Popen(object):
self
.
stderr
.
close
()
self
.
stderr
.
close
()
self
.
wait
()
self
.
wait
()
return
(
None
if
stdout
is
None
else
stdout
.
value
or
''
,
return
(
None
if
stdout
is
None
else
stdout
.
value
or
b
''
,
None
if
stderr
is
None
else
stderr
.
value
or
''
)
None
if
stderr
is
None
else
stderr
.
value
or
b
''
)
def
poll
(
self
):
def
poll
(
self
):
return
self
.
_internal_poll
()
return
self
.
_internal_poll
()
...
...
greentest/patched_tests_setup.py
View file @
454bced7
...
@@ -167,6 +167,31 @@ if sys.platform == 'darwin':
...
@@ -167,6 +167,31 @@ if sys.platform == 'darwin':
# causes Mac OS X to show "Python crashes" dialog box which is annoying
# causes Mac OS X to show "Python crashes" dialog box which is annoying
]
]
if
hasattr
(
sys
,
'pypy_version_info'
):
disabled_tests
+=
[
'test_subprocess.POSIXProcessTestCase.test_terminate_dead'
,
'test_subprocess.POSIXProcessTestCase.test_send_signal_dead'
,
'test_subprocess.POSIXProcessTestCase.test_kill_dead'
,
# Don't exist in the CPython test suite; with our monkey patch in place,
# they fail because the process they're looking for has been allowed to exit.
# Our monkey patch waits for the process with a watcher and so detects
# the exit before the normal polling mechanism would
'test_subprocess.POSIXProcessTestCase.test_preexec_errpipe_does_not_double_close_pipes'
,
# Does not exist in the CPython test suite. Subclasses Popen, and overrides
# _execute_child. But our version has a different parameter list than the
# version that comes with PyPy, so fails with a TypeError.
'test_subprocess.ProcessTestCase.test_failed_child_execute_fd_leak'
,
# Does not exist in the CPython test suite, tests for a specific bug
# in PyPy's forking. Only runs on linux and is specific to the PyPy
# implementation of subprocess (possibly explains the extra parameter to
# _execut_child)
'test_signal.InterProcessSignalTests.test_main'
,
# Fails to get the signal to the correct handler due to
# https://bitbucket.org/cffi/cffi/issue/152/handling-errors-from-signal-handlers-in
]
# if 'signalfd' in os.environ.get('GEVENT_BACKEND', ''):
# if 'signalfd' in os.environ.get('GEVENT_BACKEND', ''):
# # tests that don't interact well with signalfd
# # tests that don't interact well with signalfd
...
...
known_failures.py
View file @
454bced7
...
@@ -76,6 +76,7 @@ if PYPY:
...
@@ -76,6 +76,7 @@ if PYPY:
# check_sendall_interrupted and testInterruptedTimeout fail due to
# check_sendall_interrupted and testInterruptedTimeout fail due to
# https://bitbucket.org/cffi/cffi/issue/152/handling-errors-from-signal-handlers-in
# https://bitbucket.org/cffi/cffi/issue/152/handling-errors-from-signal-handlers-in
# See also patched_tests_setup and 'test_signal.InterProcessSignalTests.test_main'
'test_socket.py'
,
'test_socket.py'
,
]
]
...
...
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