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
8e2c01fc
Commit
8e2c01fc
authored
Oct 20, 2015
by
Jason Madden
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Rework test__core_fork to run on Windows; however it shows that fork watchers aren't called there
parent
f6cf7deb
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
29 additions
and
17 deletions
+29
-17
changelog.rst
changelog.rst
+1
-1
doc/whatsnew_1_1.rst
doc/whatsnew_1_1.rst
+2
-1
greentest/test__core_fork.py
greentest/test__core_fork.py
+24
-15
known_failures.py
known_failures.py
+2
-0
No files found.
changelog.rst
View file @
8e2c01fc
...
@@ -296,7 +296,7 @@
...
@@ -296,7 +296,7 @@
Previously the child process would hang indefinitely. Reported in
Previously the child process would hang indefinitely. Reported in
:issue:`230` by Lx Yu.
:issue:`230` by Lx Yu.
- Fork watchers are more likely to (eventually) get called in a
- Fork watchers are more likely to (eventually) get called in a
multi-threaded program. See :issue:`154`.
multi-threaded program
(except on Windows)
. See :issue:`154`.
- ``gevent.killall`` accepts an arbitrary iterable for the greenlets
- ``gevent.killall`` accepts an arbitrary iterable for the greenlets
to kill. Reported in :issue:`404` by Martin Bachwerk; seen in
to kill. Reported in :issue:`404` by Martin Bachwerk; seen in
combination with older versions of simple-requests.
combination with older versions of simple-requests.
...
...
doc/whatsnew_1_1.rst
View file @
8e2c01fc
...
@@ -80,7 +80,8 @@ downstream libraries, notably `gunicorn`_.
...
@@ -80,7 +80,8 @@ downstream libraries, notably `gunicorn`_.
:func:`gevent.os.waitpid` (again monkey patched by default) and
:func:`gevent.os.waitpid` (again monkey patched by default) and
:func:`gevent.signal.signal` (which is monkey patched only for the
:func:`gevent.signal.signal` (which is monkey patched only for the
:data:`signal.SIGCHLD` case). The latter two patches are new in 1.1.
:data:`signal.SIGCHLD` case). The latter two patches are new in 1.1.
- Fork-watchers will be called, even in multi-threaded programs.
- Fork-watchers will be called, even in multi-threaded programs
(except on Windows).
- The default threadpool and threaded resolver work in child
- The default threadpool and threaded resolver work in child
processes.
processes.
- File descriptors are no longer leaked if
- File descriptors are no longer leaked if
...
...
greentest/test__core_fork.py
View file @
8e2c01fc
...
@@ -2,6 +2,7 @@ from __future__ import print_function
...
@@ -2,6 +2,7 @@ from __future__ import print_function
import
gevent.monkey
;
gevent
.
monkey
.
patch_all
()
import
gevent.monkey
;
gevent
.
monkey
.
patch_all
()
import
gevent
import
gevent
import
os
import
os
import
multiprocessing
hub
=
gevent
.
get_hub
()
hub
=
gevent
.
get_hub
()
pid
=
os
.
getpid
()
pid
=
os
.
getpid
()
...
@@ -15,10 +16,8 @@ def on_fork():
...
@@ -15,10 +16,8 @@ def on_fork():
fork_watcher
=
hub
.
loop
.
fork
(
ref
=
False
)
fork_watcher
=
hub
.
loop
.
fork
(
ref
=
False
)
fork_watcher
.
start
(
on_fork
)
fork_watcher
.
start
(
on_fork
)
# fork watchers weren't firing in multi-threading processes.
def
run
():
def
run
(
q
):
# libev only calls fork callbacks at the beginning of
# libev only calls fork callbacks at the beginning of
# the loop; we use callbacks extensively so it takes *two*
# the loop; we use callbacks extensively so it takes *two*
# calls to sleep (with a timer) to actually get wrapped
# calls to sleep (with a timer) to actually get wrapped
...
@@ -28,15 +27,25 @@ def run():
...
@@ -28,15 +27,25 @@ def run():
q
.
put
(
newpid
)
q
.
put
(
newpid
)
import
multiprocessing
def
test
():
# Use a thread to make us multi-threaded
# Use a thread to make us multi-threaded
hub
.
threadpool
.
apply
(
lambda
:
None
)
hub
.
threadpool
.
apply
(
lambda
:
None
)
# If the Queue is global, q.get() hangs on Windows; must pass as
q
=
multiprocessing
.
Queue
()
# an argument.
p
=
multiprocessing
.
Process
(
target
=
run
)
q
=
multiprocessing
.
Queue
()
p
.
start
()
p
=
multiprocessing
.
Process
(
target
=
run
,
args
=
(
q
,))
p_val
=
q
.
get
()
p
.
start
()
p
.
join
()
p
.
join
()
p_val
=
q
.
get
()
assert
p_val
is
not
None
assert
p_val
!=
pid
assert
p_val
is
not
None
,
"The fork watcher didn't run"
assert
p_val
!=
pid
if
__name__
==
'__main__'
:
# Must call for Windows to fork properly; the fork can't be in the top-level
multiprocessing
.
freeze_support
()
# fork watchers weren't firing in multi-threading processes.
# This test is designed to prove that they are.
# However, it fails on Windows: The fork watcher never runs!
test
()
known_failures.py
View file @
8e2c01fc
...
@@ -56,6 +56,8 @@ if sys.platform == 'win32':
...
@@ -56,6 +56,8 @@ if sys.platform == 'win32':
# other Windows-related issues (need investigating)
# other Windows-related issues (need investigating)
FAILING_TESTS
+=
[
FAILING_TESTS
+=
[
'test__all__.py'
,
'test__all__.py'
,
# fork watchers don't get called in multithreaded programs on windows
# No idea why.
'test__core_fork.py'
,
'test__core_fork.py'
,
'test__issues461_471.py'
,
'test__issues461_471.py'
,
'test__execmodules.py'
,
'test__execmodules.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