Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
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
Boxiang Sun
cython
Commits
2b1c04d9
Commit
2b1c04d9
authored
Nov 21, 2010
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
test runner: safer shutdown even if threads were kept alive by failing tests
parent
2e333d31
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
36 additions
and
7 deletions
+36
-7
runtests.py
runtests.py
+36
-7
No files found.
runtests.py
View file @
2b1c04d9
...
@@ -10,6 +10,7 @@ import unittest
...
@@ -10,6 +10,7 @@ import unittest
import
doctest
import
doctest
import
operator
import
operator
import
tempfile
import
tempfile
import
traceback
try
:
try
:
from
StringIO
import
StringIO
from
StringIO
import
StringIO
except
ImportError
:
except
ImportError
:
...
@@ -484,7 +485,6 @@ class CythonRunTestCase(CythonCompileTestCase):
...
@@ -484,7 +485,6 @@ class CythonRunTestCase(CythonCompileTestCase):
output
=
open
(
result_file
,
'wb'
)
output
=
open
(
result_file
,
'wb'
)
pickle
.
dump
(
partial_result
.
data
(),
output
)
pickle
.
dump
(
partial_result
.
data
(),
output
)
except
:
except
:
import
traceback
traceback
.
print_exc
()
traceback
.
print_exc
()
finally
:
finally
:
try
:
output
.
close
()
try
:
output
.
close
()
...
@@ -848,7 +848,12 @@ def refactor_for_py3(distdir, cy3_dir):
...
@@ -848,7 +848,12 @@ def refactor_for_py3(distdir, cy3_dir):
'''
)
'''
)
sys
.
path
.
insert
(
0
,
cy3_dir
)
sys
.
path
.
insert
(
0
,
cy3_dir
)
def
check_thread_termination
():
class
PendingThreadsError
(
RuntimeError
):
pass
threads_seen
=
[]
def
check_thread_termination
(
ignore_seen
=
True
):
if
threading
is
None
:
# no threading enabled in CPython
if
threading
is
None
:
# no threading enabled in CPython
return
return
current
=
threading
.
currentThread
()
current
=
threading
.
currentThread
()
...
@@ -858,15 +863,20 @@ def check_thread_termination():
...
@@ -858,15 +863,20 @@ def check_thread_termination():
continue
continue
t
.
join
(
timeout
=
2
)
t
.
join
(
timeout
=
2
)
if
t
.
isAlive
():
if
t
.
isAlive
():
for
seen
in
threads_seen
:
if
t
is
seen
:
break
else
:
threads_seen
.
append
(
t
)
blocking_threads
.
append
(
t
)
blocking_threads
.
append
(
t
)
if
not
blocking_threads
:
if
not
blocking_threads
:
return
return
sys
.
stderr
.
write
(
"warning: left-over threads found after running test:
\
n
"
)
sys
.
stderr
.
write
(
"warning: left-over threads found after running test:
\
n
"
)
for
t
in
blocking_threads
:
for
t
in
blocking_threads
:
sys
.
stderr
.
write
(
'...%s
\
n
'
%
repr
(
t
))
sys
.
stderr
.
write
(
'...%s
\
n
'
%
repr
(
t
))
raise
Runtime
Error
(
"left-over threads found after running test"
)
raise
PendingThreads
Error
(
"left-over threads found after running test"
)
if
__name__
==
'__main__'
:
def
main
()
:
from
optparse
import
OptionParser
from
optparse
import
OptionParser
parser
=
OptionParser
()
parser
=
OptionParser
()
parser
.
add_option
(
"--no-cleanup"
,
dest
=
"cleanup_workdir"
,
parser
.
add_option
(
"--no-cleanup"
,
dest
=
"cleanup_workdir"
,
...
@@ -978,6 +988,7 @@ if __name__ == '__main__':
...
@@ -978,6 +988,7 @@ if __name__ == '__main__':
coverage
.
start
()
coverage
.
start
()
if
WITH_CYTHON
:
if
WITH_CYTHON
:
global
CompilationOptions
,
pyrex_default_options
,
cython_compile
from
Cython.Compiler.Main
import
\
from
Cython.Compiler.Main
import
\
CompilationOptions
,
\
CompilationOptions
,
\
default_options
as
pyrex_default_options
,
\
default_options
as
pyrex_default_options
,
\
...
@@ -1121,6 +1132,24 @@ if __name__ == '__main__':
...
@@ -1121,6 +1132,24 @@ if __name__ == '__main__':
sys
.
stderr
.
write
(
"
\
n
"
.
join
([
repr
(
x
)
for
x
in
refnanny
.
reflog
]))
sys
.
stderr
.
write
(
"
\
n
"
.
join
([
repr
(
x
)
for
x
in
refnanny
.
reflog
]))
if
options
.
exit_ok
:
if
options
.
exit_ok
:
sys
.
exit
(
0
)
return_code
=
0
else
:
else
:
sys
.
exit
(
not
result
.
wasSuccessful
())
return_code
=
not
result
.
wasSuccessful
()
try
:
check_thread_termination
(
ignore_seen
=
False
)
sys
.
exit
(
return_code
)
except
PendingThreadsError
:
# normal program exit won't kill the threads, do it the hard way here
os
.
_exit
(
return_code
)
if
__name__
==
'__main__'
:
try
:
main
()
except
Exception
:
traceback
.
print_exc
()
try
:
check_thread_termination
(
ignore_seen
=
False
)
except
PendingThreadsError
:
# normal program exit won't kill the threads, do it the hard way here
os
.
_exit
(
1
)
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