Commit 109630f3 authored by Stefan Behnel's avatar Stefan Behnel

Merge branch '0.29.x'

parents 2722c00f c3be8ff4
...@@ -1309,7 +1309,6 @@ def run_forked_test(result, run_func, test_name, fork=True): ...@@ -1309,7 +1309,6 @@ def run_forked_test(result, run_func, test_name, fork=True):
child_id = os.fork() child_id = os.fork()
if not child_id: if not child_id:
result_code = 0 result_code = 0
output = None
try: try:
try: try:
tests = partial_result = None tests = partial_result = None
...@@ -1329,7 +1328,8 @@ def run_forked_test(result, run_func, test_name, fork=True): ...@@ -1329,7 +1328,8 @@ def run_forked_test(result, run_func, test_name, fork=True):
_shortDescription=test_name, _shortDescription=test_name,
module_name=None) module_name=None)
partial_result.addError(tests, sys.exc_info()) partial_result.addError(tests, sys.exc_info())
output = open(result_file, 'wb') if partial_result is not None:
with open(result_file, 'wb') as output:
pickle.dump(partial_result.data(), output) pickle.dump(partial_result.data(), output)
except: except:
traceback.print_exc() traceback.print_exc()
...@@ -1338,11 +1338,6 @@ def run_forked_test(result, run_func, test_name, fork=True): ...@@ -1338,11 +1338,6 @@ def run_forked_test(result, run_func, test_name, fork=True):
except: pass except: pass
try: sys.stdout.flush() try: sys.stdout.flush()
except: pass except: pass
try:
if output is not None:
output.close()
except:
pass
os._exit(result_code) os._exit(result_code)
try: try:
...@@ -1352,18 +1347,22 @@ def run_forked_test(result, run_func, test_name, fork=True): ...@@ -1352,18 +1347,22 @@ def run_forked_test(result, run_func, test_name, fork=True):
# upper byte of result_code, and the signal it was # upper byte of result_code, and the signal it was
# killed by in the lower byte # killed by in the lower byte
if result_code & 255: if result_code & 255:
raise Exception("Tests in module '%s' were unexpectedly killed by signal %d"% raise Exception(
(module_name, result_code & 255)) "Tests in module '%s' were unexpectedly killed by signal %d, see test output for details." % (
module_name, result_code & 255))
result_code >>= 8 result_code >>= 8
if result_code in (0,1): if result_code in (0,1):
input = open(result_file, 'rb')
try: try:
PartialTestResult.join_results(result, pickle.load(input)) with open(result_file, 'rb') as f:
finally: PartialTestResult.join_results(result, pickle.load(f))
input.close() except Exception:
raise Exception(
"Failed to load test result from test in module '%s' after exit status %d,"
" see test output for details." % (module_name, result_code))
if result_code: if result_code:
raise Exception("Tests in module '%s' exited with status %d" % raise Exception(
(module_name, result_code)) "Tests in module '%s' exited with status %d, see test output for details." % (
module_name, result_code))
finally: finally:
try: try:
os.unlink(result_file) os.unlink(result_file)
......
...@@ -60,7 +60,7 @@ def test_prange_matches_range(int start, int stop, int step): ...@@ -60,7 +60,7 @@ def test_prange_matches_range(int start, int stop, int step):
>>> test_prange_matches_range(2, -10, -3) >>> test_prange_matches_range(2, -10, -3)
>>> test_prange_matches_range(3, -10, -3) >>> test_prange_matches_range(3, -10, -3)
""" """
cdef int i, range_last, prange_last cdef int i = -765432, range_last = -876543, prange_last = -987654
prange_set = set() prange_set = set()
for i in prange(start, stop, step, nogil=True, num_threads=3): for i in prange(start, stop, step, nogil=True, num_threads=3):
prange_last = i prange_last = i
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment