Commit 2ea71a07 authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

bpo-36670: regrtest bug fixes (GH-16537)

* Fix TestWorkerProcess.__repr__(): start_time is only valid
  if _popen is not None.
* Fix _kill(): don't set _killed to True if _popen is None.
* _run_process(): only set _killed to False after calling
  run_test_in_subprocess().
parent b9a8b829
...@@ -120,27 +120,28 @@ class TestWorkerProcess(threading.Thread): ...@@ -120,27 +120,28 @@ class TestWorkerProcess(threading.Thread):
def __repr__(self): def __repr__(self):
info = [f'TestWorkerProcess #{self.worker_id}'] info = [f'TestWorkerProcess #{self.worker_id}']
if self.is_alive(): if self.is_alive():
dt = time.monotonic() - self.start_time info.append("running")
info.append("running for %s" % format_duration(dt))
else: else:
info.append('stopped') info.append('stopped')
test = self.current_test_name test = self.current_test_name
if test: if test:
info.append(f'test={test}') info.append(f'test={test}')
popen = self._popen popen = self._popen
if popen: if popen is not None:
info.append(f'pid={popen.pid}') dt = time.monotonic() - self.start_time
info.extend((f'pid={self._popen.pid}',
f'time={format_duration(dt)}'))
return '<%s>' % ' '.join(info) return '<%s>' % ' '.join(info)
def _kill(self): def _kill(self):
if self._killed:
return
self._killed = True
popen = self._popen popen = self._popen
if popen is None: if popen is None:
return return
if self._killed:
return
self._killed = True
print(f"Kill {self}", file=sys.stderr, flush=True) print(f"Kill {self}", file=sys.stderr, flush=True)
try: try:
popen.kill() popen.kill()
...@@ -177,9 +178,10 @@ class TestWorkerProcess(threading.Thread): ...@@ -177,9 +178,10 @@ class TestWorkerProcess(threading.Thread):
self.current_test_name = test_name self.current_test_name = test_name
try: try:
popen = run_test_in_subprocess(test_name, self.ns)
self._killed = False self._killed = False
self._popen = run_test_in_subprocess(test_name, self.ns) self._popen = popen
popen = self._popen
except: except:
self.current_test_name = None self.current_test_name = None
raise raise
......
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