aboutsummaryrefslogtreecommitdiff
path: root/python/run-tests.py
diff options
context:
space:
mode:
authorJosh Rosen <joshrosen@databricks.com>2015-06-29 23:08:51 -0700
committerJosh Rosen <joshrosen@databricks.com>2015-06-29 23:08:51 -0700
commit6c5a6db4d53d6db8aa3464ea6713cf0d3a3bdfb5 (patch)
tree75f54c7bba235535695596b364b7036e0c0164ce /python/run-tests.py
parente6c3f7462b3fde220ec0084b52388dd4dabb75b9 (diff)
downloadspark-6c5a6db4d53d6db8aa3464ea6713cf0d3a3bdfb5.tar.gz
spark-6c5a6db4d53d6db8aa3464ea6713cf0d3a3bdfb5.tar.bz2
spark-6c5a6db4d53d6db8aa3464ea6713cf0d3a3bdfb5.zip
[SPARK-5161] [HOTFIX] Fix bug in Python test failure reporting
This patch fixes a bug introduced in #7031 which can cause Jenkins to incorrectly report a build with failed Python tests as passing if an error occurred while printing the test failure message. Author: Josh Rosen <joshrosen@databricks.com> Closes #7112 from JoshRosen/python-tests-hotfix and squashes the following commits: c3f2961 [Josh Rosen] Hotfix for bug in Python test failure reporting
Diffstat (limited to 'python/run-tests.py')
-rwxr-xr-xpython/run-tests.py35
1 files changed, 23 insertions, 12 deletions
diff --git a/python/run-tests.py b/python/run-tests.py
index aaa35e936a..b7737650da 100755
--- a/python/run-tests.py
+++ b/python/run-tests.py
@@ -58,22 +58,33 @@ def run_individual_python_test(test_name, pyspark_python):
env = {'SPARK_TESTING': '1', 'PYSPARK_PYTHON': which(pyspark_python)}
LOGGER.debug("Starting test(%s): %s", pyspark_python, test_name)
start_time = time.time()
- per_test_output = tempfile.TemporaryFile()
- retcode = subprocess.Popen(
- [os.path.join(SPARK_HOME, "bin/pyspark"), test_name],
- stderr=per_test_output, stdout=per_test_output, env=env).wait()
+ try:
+ per_test_output = tempfile.TemporaryFile()
+ retcode = subprocess.Popen(
+ [os.path.join(SPARK_HOME, "bin/pyspark"), test_name],
+ stderr=per_test_output, stdout=per_test_output, env=env).wait()
+ except:
+ LOGGER.exception("Got exception while running %s with %s", test_name, pyspark_python)
+ # Here, we use os._exit() instead of sys.exit() in order to force Python to exit even if
+ # this code is invoked from a thread other than the main thread.
+ os._exit(1)
duration = time.time() - start_time
# Exit on the first failure.
if retcode != 0:
- with FAILURE_REPORTING_LOCK:
- with open(LOG_FILE, 'ab') as log_file:
+ try:
+ with FAILURE_REPORTING_LOCK:
+ with open(LOG_FILE, 'ab') as log_file:
+ per_test_output.seek(0)
+ log_file.writelines(per_test_output)
per_test_output.seek(0)
- log_file.writelines(per_test_output.readlines())
- per_test_output.seek(0)
- for line in per_test_output:
- if not re.match('[0-9]+', line):
- print(line, end='')
- per_test_output.close()
+ for line in per_test_output:
+ decoded_line = line.decode()
+ if not re.match('[0-9]+', decoded_line):
+ print(decoded_line, end='')
+ per_test_output.close()
+ except:
+ LOGGER.exception("Got an exception while trying to print failed test output")
+ finally:
print_red("\nHad test failures in %s with %s; see logs." % (test_name, pyspark_python))
# Here, we use os._exit() instead of sys.exit() in order to force Python to exit even if
# this code is invoked from a thread other than the main thread.