Commit 061eca59 authored by machenbach's avatar machenbach Committed by Commit bot

[test runner] Handle missing files gracefully.

This returns a proper test result (failure) when files are
missing for setting up the command.

Review URL: https://codereview.chromium.org/1696713002

Cr-Commit-Position: refs/heads/master@{#33946}
parent eb6d46de
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
import collections import collections
import os import os
import re
import shutil import shutil
import sys import sys
import time import time
...@@ -38,6 +39,7 @@ from . import perfdata ...@@ -38,6 +39,7 @@ from . import perfdata
from . import statusfile from . import statusfile
from . import testsuite from . import testsuite
from . import utils from . import utils
from ..objects import output
# Base dir of the v8 checkout. # Base dir of the v8 checkout.
...@@ -134,15 +136,28 @@ class Job(object): ...@@ -134,15 +136,28 @@ class Job(object):
raise NotImplementedError() raise NotImplementedError()
def SetupProblem(exception, test):
stderr = ">>> EXCEPTION: %s\n" % exception
match = re.match(r"^.*No such file or directory: '(.*)'$", str(exception))
if match:
# Extra debuging information when files are claimed missing.
f = match.group(1)
stderr += ">>> File %s exists? -> %s\n" % (f, os.path.exists(f))
return test.id, output.Output(1, False, "", stderr), 0
class TestJob(Job): class TestJob(Job):
def __init__(self, test): def __init__(self, test):
self.test = test self.test = test
def Run(self, process_context): def Run(self, process_context):
# Retrieve a new suite object on the worker-process side. The original try:
# suite object isn't pickled. # Retrieve a new suite object on the worker-process side. The original
self.test.SetSuiteObject(process_context.suites) # suite object isn't pickled.
instr = _GetInstructions(self.test, process_context.context) self.test.SetSuiteObject(process_context.suites)
instr = _GetInstructions(self.test, process_context.context)
except Exception, e:
return SetupProblem(e, self.test)
start_time = time.time() start_time = time.time()
if instr.dep_command is not None: if instr.dep_command is not None:
......
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