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
3718930b
Commit
3718930b
authored
Mar 04, 2014
by
Denis Bilenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
testrunner.py: do not depend on gevent
parent
b4d1a6cc
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
66 additions
and
46 deletions
+66
-46
greentest/test__example_portforwarder.py
greentest/test__example_portforwarder.py
+1
-1
greentest/test__example_udp_client.py
greentest/test__example_udp_client.py
+1
-1
greentest/testrunner.py
greentest/testrunner.py
+42
-25
greentest/util.py
greentest/util.py
+22
-19
No files found.
greentest/test__example_portforwarder.py
View file @
3718930b
from
__future__
import
print_function
from
__future__
import
print_function
from
gevent
import
monkey
;
monkey
.
patch_all
()
from
gevent
import
monkey
;
monkey
.
patch_all
(
subprocess
=
True
)
import
sys
import
sys
import
socket
import
socket
from
time
import
sleep
from
time
import
sleep
...
...
greentest/test__example_udp_client.py
View file @
3718930b
from
gevent
import
monkey
;
monkey
.
patch_all
()
from
gevent
import
monkey
;
monkey
.
patch_all
(
subprocess
=
True
)
import
sys
import
sys
from
gevent.server
import
DatagramServer
from
gevent.server
import
DatagramServer
from
unittest
import
TestCase
,
main
from
unittest
import
TestCase
,
main
...
...
greentest/testrunner.py
View file @
3718930b
#!/usr/bin/env python
#!/usr/bin/env python
from
__future__
import
print_function
from
__future__
import
print_function
import
gevent
gevent
.
get_hub
(
'select'
)
# this is just to make sure we don't pass any fds to children
from
gevent
import
monkey
;
monkey
.
patch_all
()
import
six
import
six
import
sys
import
sys
import
os
import
os
import
glob
import
glob
import
traceback
import
traceback
from
time
import
time
import
time
from
gevent.pool
import
Pool
from
multiprocessing.pool
import
Thread
Pool
import
util
import
util
TIMEOUT
=
180
TIMEOUT
=
180
NWORKERS
=
int
(
os
.
environ
.
get
(
'NWORKERS'
)
or
8
)
NWORKERS
=
int
(
os
.
environ
.
get
(
'NWORKERS'
)
or
8
)
pool
=
None
def
spawn
(
*
args
,
**
kwargs
):
g
=
pool
.
spawn
(
*
args
,
**
kwargs
)
g
.
link_exception
(
lambda
*
args
:
sys
.
exit
(
'Internal error in testrunner.py: %s %s'
%
(
g
,
g
.
exception
)))
return
g
def
run_many
(
tests
,
expected
=
None
,
failfast
=
False
):
def
run_many
(
tests
,
expected
=
None
,
failfast
=
False
):
global
NWORKERS
,
pool
global
NWORKERS
start
=
time
()
start
=
time
.
time
()
total
=
0
total
=
0
failed
=
{}
failed
=
{}
NWORKERS
=
min
(
len
(
tests
),
NWORKERS
)
NWORKERS
=
min
(
len
(
tests
),
NWORKERS
)
pool
=
Pool
(
NWORKERS
)
pool
=
Thread
Pool
(
NWORKERS
)
util
.
BUFFER_OUTPUT
=
NWORKERS
>
1
util
.
BUFFER_OUTPUT
=
NWORKERS
>
1
def
run_one
(
cmd
,
**
kwargs
):
def
run_one
(
cmd
,
**
kwargs
):
...
@@ -45,26 +35,55 @@ def run_many(tests, expected=None, failfast=False):
...
@@ -45,26 +35,55 @@ def run_many(tests, expected=None, failfast=False):
# we therefore will retry them sequentially
# we therefore will retry them sequentially
failed
[
result
.
name
]
=
[
cmd
,
kwargs
,
'AssertionError'
in
(
result
.
output
or
''
)]
failed
[
result
.
name
]
=
[
cmd
,
kwargs
,
'AssertionError'
in
(
result
.
output
or
''
)]
results
=
[]
def
reap
():
for
r
in
results
[:]:
if
not
r
.
ready
():
continue
if
r
.
successful
():
results
.
remove
(
r
)
else
:
r
.
get
()
sys
.
exit
(
'Internal error in testrunner.py: %r'
%
(
r
,
))
return
len
(
results
)
def
reap_all
():
while
reap
()
>
0
:
time
.
sleep
(
0.1
)
def
spawn
(
args
,
kwargs
):
while
True
:
if
reap
()
<
NWORKERS
:
r
=
pool
.
apply_async
(
run_one
,
(
cmd
,
),
options
or
{})
results
.
append
(
r
)
return
else
:
time
.
sleep
(
0.1
)
try
:
try
:
try
:
try
:
for
cmd
,
options
in
tests
:
for
cmd
,
options
in
tests
:
total
+=
1
total
+=
1
spawn
(
run_one
,
cmd
,
**
(
options
or
{}))
spawn
((
cmd
,
),
options
or
{})
gevent
.
wait
()
pool
.
close
()
pool
.
join
()
except
KeyboardInterrupt
:
except
KeyboardInterrupt
:
try
:
try
:
if
pool
:
util
.
log
(
'Waiting for currently running to finish...'
)
util
.
log
(
'Waiting for currently running to finish...'
)
reap_all
()
pool
.
join
()
except
KeyboardInterrupt
:
except
KeyboardInterrupt
:
util
.
report
(
total
,
failed
,
exit
=
False
,
took
=
time
()
-
start
,
expected
=
expected
)
pool
.
terminate
()
util
.
report
(
total
,
failed
,
exit
=
False
,
took
=
time
.
time
()
-
start
,
expected
=
expected
)
util
.
log
(
'(partial results)
\
n
'
)
util
.
log
(
'(partial results)
\
n
'
)
raise
raise
except
:
except
:
traceback
.
print_exc
()
traceback
.
print_exc
()
pool
.
kill
()
# this needed to kill the processes
pool
.
terminate
()
raise
raise
reap_all
()
toretry
=
[
key
for
(
key
,
(
cmd
,
kwargs
,
can_retry
))
in
failed
.
items
()
if
can_retry
]
toretry
=
[
key
for
(
key
,
(
cmd
,
kwargs
,
can_retry
))
in
failed
.
items
()
if
can_retry
]
failed_then_succeeded
=
[]
failed_then_succeeded
=
[]
...
@@ -79,9 +98,7 @@ def run_many(tests, expected=None, failfast=False):
...
@@ -79,9 +98,7 @@ def run_many(tests, expected=None, failfast=False):
util
.
log
(
'
\
n
%s tests failed during concurrent run but succeeded when ran sequentially:'
,
len
(
failed_then_succeeded
))
util
.
log
(
'
\
n
%s tests failed during concurrent run but succeeded when ran sequentially:'
,
len
(
failed_then_succeeded
))
util
.
log
(
'- '
+
'
\
n
- '
.
join
(
failed_then_succeeded
))
util
.
log
(
'- '
+
'
\
n
- '
.
join
(
failed_then_succeeded
))
util
.
log
(
'gevent version %s from %s'
,
gevent
.
__version__
,
gevent
.
__file__
)
util
.
report
(
total
,
failed
,
took
=
time
.
time
()
-
start
,
expected
=
expected
)
util
.
report
(
total
,
failed
,
took
=
time
()
-
start
,
expected
=
expected
)
assert
not
pool
,
pool
def
discover
(
tests
=
None
,
ignore
=
None
):
def
discover
(
tests
=
None
,
ignore
=
None
):
...
...
greentest/util.py
View file @
3718930b
...
@@ -5,9 +5,9 @@ import six
...
@@ -5,9 +5,9 @@ import six
import
traceback
import
traceback
import
unittest
import
unittest
import
threading
import
threading
import
subprocess
import
time
import
time
from
datetime
import
timedelta
from
datetime
import
timedelta
from
gevent
import
subprocess
,
sleep
,
spawn_later
SLEEP
=
0.1
SLEEP
=
0.1
...
@@ -82,6 +82,8 @@ def _kill(popen):
...
@@ -82,6 +82,8 @@ def _kill(popen):
def
kill
(
popen
):
def
kill
(
popen
):
if
popen
.
poll
()
is
not
None
:
return
try
:
try
:
if
getattr
(
popen
,
'setpgrp_enabled'
,
None
):
if
getattr
(
popen
,
'setpgrp_enabled'
,
None
):
killpg
(
popen
.
pid
)
killpg
(
popen
.
pid
)
...
@@ -139,10 +141,9 @@ def start(command, **kwargs):
...
@@ -139,10 +141,9 @@ def start(command, **kwargs):
popen
.
name
=
name
popen
.
name
=
name
popen
.
setpgrp_enabled
=
preexec_fn
is
not
None
popen
.
setpgrp_enabled
=
preexec_fn
is
not
None
if
timeout
is
not
None
:
if
timeout
is
not
None
:
popen
.
_killer
=
spawn_later
(
timeout
,
kill
,
popen
)
t
=
threading
.
Timer
(
timeout
,
kill
,
args
=
(
popen
,
))
popen
.
_killer
.
_start_event
.
ref
=
False
# XXX add 'ref' property to greenlet
t
.
setDaemon
(
True
)
else
:
t
.
start
()
popen
.
_killer
=
None
return
popen
return
popen
...
@@ -164,6 +165,9 @@ class RunResult(object):
...
@@ -164,6 +165,9 @@ class RunResult(object):
return
self
.
code
return
self
.
code
lock
=
threading
.
Lock
()
def
run
(
command
,
**
kwargs
):
def
run
(
command
,
**
kwargs
):
buffer_output
=
kwargs
.
pop
(
'buffer_output'
,
BUFFER_OUTPUT
)
buffer_output
=
kwargs
.
pop
(
'buffer_output'
,
BUFFER_OUTPUT
)
if
buffer_output
:
if
buffer_output
:
...
@@ -181,21 +185,20 @@ def run(command, **kwargs):
...
@@ -181,21 +185,20 @@ def run(command, **kwargs):
else
:
else
:
result
=
popen
.
poll
()
result
=
popen
.
poll
()
finally
:
finally
:
if
popen
.
_killer
is
not
None
:
popen
.
_killer
.
kill
(
block
=
False
)
kill
(
popen
)
kill
(
popen
)
assert
not
err
assert
not
err
if
out
:
with
lock
:
out
=
out
.
strip
()
if
out
:
if
out
:
out
=
' '
+
out
.
replace
(
'
\
n
'
,
'
\
n
'
)
out
=
out
.
strip
().
decode
()
out
=
out
.
rstrip
()
if
out
:
out
+=
'
\
n
'
out
=
' '
+
out
.
replace
(
'
\
n
'
,
'
\
n
'
)
log
(
'| %s
\
n
%s'
,
name
,
out
)
out
=
out
.
rstrip
()
if
result
:
out
+=
'
\
n
'
log
(
'! %s [code %s] [took %.1fs]'
,
name
,
result
,
took
)
log
(
'| %s
\
n
%s'
,
name
,
out
)
else
:
if
result
:
log
(
'- %s [took %.1fs]'
,
name
,
took
)
log
(
'! %s [code %s] [took %.1fs]'
,
name
,
result
,
took
)
else
:
log
(
'- %s [took %.1fs]'
,
name
,
took
)
if
took
>=
MIN_RUNTIME
:
if
took
>=
MIN_RUNTIME
:
runtimelog
.
append
((
-
took
,
name
))
runtimelog
.
append
((
-
took
,
name
))
return
RunResult
(
result
,
out
,
name
)
return
RunResult
(
result
,
out
,
name
)
...
@@ -380,12 +383,12 @@ class TestServer(unittest.TestCase):
...
@@ -380,12 +383,12 @@ class TestServer(unittest.TestCase):
def
before
(
self
):
def
before
(
self
):
if
self
.
before_delay
is
not
None
:
if
self
.
before_delay
is
not
None
:
sleep
(
self
.
before_delay
)
time
.
sleep
(
self
.
before_delay
)
assert
self
.
popen
.
poll
()
is
None
,
'%s died with code %s'
%
(
self
.
server
,
self
.
popen
.
poll
(),
)
assert
self
.
popen
.
poll
()
is
None
,
'%s died with code %s'
%
(
self
.
server
,
self
.
popen
.
poll
(),
)
def
after
(
self
):
def
after
(
self
):
if
self
.
after_delay
is
not
None
:
if
self
.
after_delay
is
not
None
:
sleep
(
self
.
after_delay
)
time
.
sleep
(
self
.
after_delay
)
assert
self
.
popen
.
poll
()
is
None
,
'%s died with code %s'
%
(
self
.
server
,
self
.
popen
.
poll
(),
)
assert
self
.
popen
.
poll
()
is
None
,
'%s died with code %s'
%
(
self
.
server
,
self
.
popen
.
poll
(),
)
def
_run_all_tests
(
self
):
def
_run_all_tests
(
self
):
...
...
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