mirror of
https://we.phorge.it/source/arcanist.git
synced 2024-11-25 08:12:40 +01:00
Ship unresolved unit test information to Differential.
Summary: Test Plan: Reviewers: CC:
This commit is contained in:
parent
bb7e649fa5
commit
7d36705215
5 changed files with 92 additions and 11 deletions
|
@ -63,6 +63,7 @@ phutil_register_library_map(array(
|
||||||
'PhutilLintEngine' => 'lint/engine/phutil',
|
'PhutilLintEngine' => 'lint/engine/phutil',
|
||||||
'PhutilModuleRequirements' => 'staticanalysis/parsers/phutilmodule',
|
'PhutilModuleRequirements' => 'staticanalysis/parsers/phutilmodule',
|
||||||
'PhutilUnitTestEngine' => 'unit/engine/phutil',
|
'PhutilUnitTestEngine' => 'unit/engine/phutil',
|
||||||
|
'PhutilUnitTestEngineTestCase' => 'unit/engine/phutil/__tests__',
|
||||||
'UnitTestableArcanistLintEngine' => 'lint/engine/test',
|
'UnitTestableArcanistLintEngine' => 'lint/engine/test',
|
||||||
),
|
),
|
||||||
'function' =>
|
'function' =>
|
||||||
|
@ -98,6 +99,7 @@ phutil_register_library_map(array(
|
||||||
'ArcanistXHPASTLinterTestCase' => 'ArcanistPhutilTestCase',
|
'ArcanistXHPASTLinterTestCase' => 'ArcanistPhutilTestCase',
|
||||||
'PhutilLintEngine' => 'ArcanistLintEngine',
|
'PhutilLintEngine' => 'ArcanistLintEngine',
|
||||||
'PhutilUnitTestEngine' => 'ArcanistBaseUnitTestEngine',
|
'PhutilUnitTestEngine' => 'ArcanistBaseUnitTestEngine',
|
||||||
|
'PhutilUnitTestEngineTestCase' => 'ArcanistPhutilTestCase',
|
||||||
'UnitTestableArcanistLintEngine' => 'ArcanistLintEngine',
|
'UnitTestableArcanistLintEngine' => 'ArcanistLintEngine',
|
||||||
),
|
),
|
||||||
'requires_interface' =>
|
'requires_interface' =>
|
||||||
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright 2011 Facebook, Inc.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
class PhutilUnitTestEngineTestCase extends ArcanistPhutilTestCase {
|
||||||
|
|
||||||
|
public function testPass() {
|
||||||
|
$this->assertEqual(1, 1, 'This test is expected to pass.');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testFail() {
|
||||||
|
$this->assertEqual(1, 2, 'This test is expected to fail.');
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
12
src/unit/engine/phutil/__tests__/__init__.php
Normal file
12
src/unit/engine/phutil/__tests__/__init__.php
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* This file is automatically generated. Lint this module to rebuild it.
|
||||||
|
* @generated
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_module('arcanist', 'unit/engine/phutil/testcase');
|
||||||
|
|
||||||
|
|
||||||
|
phutil_require_source('PhutilUnitTestEngineTestCase.php');
|
|
@ -212,8 +212,10 @@ EOTEXT
|
||||||
|
|
||||||
if ($lint_result === ArcanistLintWorkflow::RESULT_OKAY) {
|
if ($lint_result === ArcanistLintWorkflow::RESULT_OKAY) {
|
||||||
$lint = 'okay';
|
$lint = 'okay';
|
||||||
} else if ($lint_result === ArcanistLintWorkflow::RESULT_WARNINGS) {
|
} else if ($lint_result === ArcanistLintWorkflow::RESULT_ERRORS) {
|
||||||
$lint = 'fail';
|
$lint = 'fail';
|
||||||
|
} else if ($lint_result === ArcanistLintWorkflow::RESULT_WARNINGS) {
|
||||||
|
$lint = 'warn';
|
||||||
} else if ($lint_result === ArcanistLintWorkflow::RESULT_SKIP) {
|
} else if ($lint_result === ArcanistLintWorkflow::RESULT_SKIP) {
|
||||||
$lint = 'skip';
|
$lint = 'skip';
|
||||||
} else {
|
} else {
|
||||||
|
@ -222,9 +224,10 @@ EOTEXT
|
||||||
|
|
||||||
if ($unit_result === ArcanistUnitWorkflow::RESULT_OKAY) {
|
if ($unit_result === ArcanistUnitWorkflow::RESULT_OKAY) {
|
||||||
$unit = 'okay';
|
$unit = 'okay';
|
||||||
} else if ($unit_result === ArcanistUnitWorkflow::RESULT_UNSOUND ||
|
} else if ($unit_result === ArcanistUnitWorkflow::RESULT_FAIL) {
|
||||||
$unit_result === ArcanistUnitWorkflow::RESULT_FAIL) {
|
|
||||||
$unit = 'fail';
|
$unit = 'fail';
|
||||||
|
} else if ($unit_result === ArcanistUnitWorkflow::RESULT_UNSOUND) {
|
||||||
|
$unit = 'warn';
|
||||||
} else if ($unit_result === ArcanistUnitWorkflow::RESULT_SKIP) {
|
} else if ($unit_result === ArcanistUnitWorkflow::RESULT_SKIP) {
|
||||||
$unit = 'skip';
|
$unit = 'skip';
|
||||||
} else {
|
} else {
|
||||||
|
@ -271,6 +274,24 @@ EOTEXT
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->unresolvedTests) {
|
||||||
|
$data = array();
|
||||||
|
foreach ($this->unresolvedTests as $test) {
|
||||||
|
$data[] = array(
|
||||||
|
'name' => $test->getName(),
|
||||||
|
'result' => $test->getResult(),
|
||||||
|
'userdata' => $test->getUserData(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
$conduit->callMethodSynchronous(
|
||||||
|
'differential.setdiffproperty',
|
||||||
|
array(
|
||||||
|
'diff_id' => $diff_info['diffid'],
|
||||||
|
'name' => 'arc:unit',
|
||||||
|
'data' => json_encode($data),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
if ($this->shouldOnlyCreateDiff()) {
|
if ($this->shouldOnlyCreateDiff()) {
|
||||||
echo phutil_console_format(
|
echo phutil_console_format(
|
||||||
"Created a new Differential diff:\n".
|
"Created a new Differential diff:\n".
|
||||||
|
@ -840,16 +861,20 @@ EOTEXT
|
||||||
if (!$continue) {
|
if (!$continue) {
|
||||||
throw new ArcanistUserAbortException();
|
throw new ArcanistUserAbortException();
|
||||||
}
|
}
|
||||||
$this->unresolvedLint = $lint_workflow->getUnresolvedMessages();
|
|
||||||
break;
|
break;
|
||||||
case ArcanistLintWorkflow::RESULT_ERRORS:
|
case ArcanistLintWorkflow::RESULT_ERRORS:
|
||||||
echo phutil_console_format(
|
echo phutil_console_format(
|
||||||
"<bg:red>** LINT ERRORS **</bg> Lint raised errors!\n");
|
"<bg:red>** LINT ERRORS **</bg> Lint raised errors!\n");
|
||||||
throw new ArcanistUsageException(
|
$continue = phutil_console_confirm(
|
||||||
"Resolve lint errors or run with --nolint.");
|
"Lint issued unresolved errors! Ignore lint errors?");
|
||||||
|
if (!$continue) {
|
||||||
|
throw new ArcanistUserAbortException();
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->unresolvedLint = $lint_workflow->getUnresolvedMessages();
|
||||||
|
|
||||||
return $lint_result;
|
return $lint_result;
|
||||||
} catch (ArcanistNoEngineException $ex) {
|
} catch (ArcanistNoEngineException $ex) {
|
||||||
echo "No lint engine configured for this project.\n";
|
echo "No lint engine configured for this project.\n";
|
||||||
|
@ -892,11 +917,16 @@ EOTEXT
|
||||||
case ArcanistUnitWorkflow::RESULT_FAIL:
|
case ArcanistUnitWorkflow::RESULT_FAIL:
|
||||||
echo phutil_console_format(
|
echo phutil_console_format(
|
||||||
"<bg:red>** UNIT ERRORS **</bg> Unit testing raised errors!\n");
|
"<bg:red>** UNIT ERRORS **</bg> Unit testing raised errors!\n");
|
||||||
throw new ArcanistUsageException(
|
$continue = phutil_console_confirm(
|
||||||
"Resolve unit test errors or run with --nounit.");
|
"Unit test results include failures! Ignore test failures?");
|
||||||
|
if (!$continue) {
|
||||||
|
throw new ArcanistUserAbortException();
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->unresolvedTests = $unit_workflow->getUnresolvedTests();
|
||||||
|
|
||||||
return $unit_result;
|
return $unit_result;
|
||||||
} catch (ArcanistNoEngineException $ex) {
|
} catch (ArcanistNoEngineException $ex) {
|
||||||
echo "No unit test engine is configured for this project.\n";
|
echo "No unit test engine is configured for this project.\n";
|
||||||
|
|
|
@ -23,6 +23,8 @@ class ArcanistUnitWorkflow extends ArcanistBaseWorkflow {
|
||||||
const RESULT_FAIL = 2;
|
const RESULT_FAIL = 2;
|
||||||
const RESULT_SKIP = 3;
|
const RESULT_SKIP = 3;
|
||||||
|
|
||||||
|
private $unresolvedTests;
|
||||||
|
|
||||||
public function getCommandHelp() {
|
public function getCommandHelp() {
|
||||||
return phutil_console_format(<<<EOTEXT
|
return phutil_console_format(<<<EOTEXT
|
||||||
**unit**
|
**unit**
|
||||||
|
@ -96,13 +98,16 @@ EOTEXT
|
||||||
' <bg:yellow>** UNSOUND **</bg>'),
|
' <bg:yellow>** UNSOUND **</bg>'),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
$unresolved = array();
|
||||||
foreach ($results as $result) {
|
foreach ($results as $result) {
|
||||||
$result_code = $result->getResult();
|
$result_code = $result->getResult();
|
||||||
echo $status_codes[$result_code].' '.$result->getName()."\n";
|
echo $status_codes[$result_code].' '.$result->getName()."\n";
|
||||||
if ($result_code != ArcanistUnitTestResult::RESULT_PASS) {
|
if ($result_code != ArcanistUnitTestResult::RESULT_PASS) {
|
||||||
echo $result->getUserData()."\n";
|
echo $result->getUserData()."\n";
|
||||||
|
$unresolved[] = $result;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
$this->unresolvedTests = $unresolved;
|
||||||
|
|
||||||
$overall_result = self::RESULT_OKAY;
|
$overall_result = self::RESULT_OKAY;
|
||||||
foreach ($results as $result) {
|
foreach ($results as $result) {
|
||||||
|
@ -111,13 +116,16 @@ EOTEXT
|
||||||
$result_code == ArcanistUnitTestResult::RESULT_BROKEN) {
|
$result_code == ArcanistUnitTestResult::RESULT_BROKEN) {
|
||||||
$overall_result = self::RESULT_FAIL;
|
$overall_result = self::RESULT_FAIL;
|
||||||
break;
|
break;
|
||||||
}
|
} else if ($result_code == ArcanistUnitTestResult::RESULT_UNSOUND) {
|
||||||
if ($result_code == ArcanistUnitTestResult::RESULT_UNSOUND) {
|
|
||||||
$overall_result = self::RESULT_UNSOUND;
|
$overall_result = self::RESULT_UNSOUND;
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $overall_result;
|
return $overall_result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getUnresolvedTests() {
|
||||||
|
return $this->unresolvedTests;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue