1
0
Fork 0
mirror of https://we.phorge.it/source/arcanist.git synced 2025-01-25 14:08:18 +01:00

Catch exceptions in didRunLinters()

Test Plan: Threw in `didRunLinters()` of one linter, still saw the result of other linters and "Some linters failed" at the end.

Reviewers: epriestley

Reviewed By: epriestley

CC: aran, Korvin

Differential Revision: https://secure.phabricator.com/D5124
This commit is contained in:
vrana 2013-02-26 11:35:58 -08:00
parent 2464f54ecf
commit 266a4f4c75

View file

@ -232,7 +232,7 @@ abstract class ArcanistLintEngine {
$profiler = PhutilServiceProfiler::getInstance(); $profiler = PhutilServiceProfiler::getInstance();
$call_id = $profiler->beginServiceCall(array( $call_id = $profiler->beginServiceCall(array(
'type' => 'lint', 'type' => 'lint',
'linter' => get_class($linter), 'linter' => $linter_name,
'paths' => $paths, 'paths' => $paths,
)); ));
@ -257,7 +257,7 @@ abstract class ArcanistLintEngine {
} }
} }
$this->didRunLinters($linters); $exceptions += $this->didRunLinters($linters);
foreach ($linters as $linter) { foreach ($linters as $linter) {
foreach ($linter->getLintMessages() as $message) { foreach ($linter->getLintMessages() as $message) {
@ -358,15 +358,28 @@ abstract class ArcanistLintEngine {
protected function didRunLinters(array $linters) { protected function didRunLinters(array $linters) {
assert_instances_of($linters, 'ArcanistLinter'); assert_instances_of($linters, 'ArcanistLinter');
$exceptions = array();
$profiler = PhutilServiceProfiler::getInstance(); $profiler = PhutilServiceProfiler::getInstance();
foreach ($linters as $linter) {
foreach ($linters as $linter_name => $linter) {
if (!is_string($linter_name)) {
$linter_name = get_class($linter);
}
$call_id = $profiler->beginServiceCall(array( $call_id = $profiler->beginServiceCall(array(
'type' => 'lint', 'type' => 'lint',
'linter' => get_class($linter), 'linter' => $linter_name,
)); ));
$linter->didRunLinters();
try {
$linter->didRunLinters();
} catch (Exception $ex) {
$exceptions[$linter_name] = $ex;
}
$profiler->endServiceCall($call_id, array()); $profiler->endServiceCall($call_id, array());
} }
return $exceptions;
} }
public function setRepositoryVersion($version) { public function setRepositoryVersion($version) {