From 7fb6fc15d88778f15a49ab1e63bdf550c2c7c981 Mon Sep 17 00:00:00 2001 From: Ned Batchelder Date: Mon, 23 Dec 2019 15:44:36 -0500 Subject: Catch and display expceptions during multiprocessing bootstrap. --- coverage/multiproc.py | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) (limited to 'coverage/multiproc.py') diff --git a/coverage/multiproc.py b/coverage/multiproc.py index bab81475..c466301f 100644 --- a/coverage/multiproc.py +++ b/coverage/multiproc.py @@ -6,6 +6,8 @@ import multiprocessing import multiprocessing.process import os +import sys +import traceback from coverage import env from coverage.misc import contract @@ -27,14 +29,20 @@ class ProcessWithCoverage(OriginalProcess): # pylint: disable=abstract-m def _bootstrap(self, *args, **kwargs): # pylint: disable=arguments-differ """Wrapper around _bootstrap to start coverage.""" - from coverage import Coverage # avoid circular import - cov = Coverage(data_suffix=True) - cov._warn_preimported_source = False - cov.start() - debug = cov._debug try: + from coverage import Coverage # avoid circular import + cov = Coverage(data_suffix=True) + cov._warn_preimported_source = False + cov.start() + debug = cov._debug if debug.should("multiproc"): debug.write("Calling multiprocessing bootstrap") + except Exception: + print("Exception during multiprocessing bootstrap init:") + traceback.print_exc(file=sys.stdout) + sys.stdout.flush() + raise + try: return original_bootstrap(self, *args, **kwargs) finally: if debug.should("multiproc"): -- cgit v1.2.1