mirror of
https://we.phorge.it/source/arcanist.git
synced 2025-01-25 22:18:18 +01:00
Improve handling of --background
with --base
Summary: Currently, we run `runDiffSetupBasics()` //after// splitting off background lint and unit tests. However, this means `--base` and any explicit revision name (like "HEAD^") will not be parsed, so the call to `getRelativeCommit()` in order to generate `arc lint --rev XXX` will fail or not work as expected, because it will ignore any arguments. Instead, parse `--base`, explicit revisions, and other repository API arguments before doing lint and unit tests. Test Plan: - Set global config for `base` to `arc:amended, git:branch-unique(origin/master)`. - Created a commit on master. - Ran `arc diff HEAD^`. - Before this change, the command fails with "Usage Exception: None of the rules in your 'base' configuration matched a valid commit. Adjust rules or specify which commit you want to use explicitly." when it attempts to run lint, because the `HEAD^` argument is never parsed. After - After this change, the command succeeds. Reviewers: vrana Reviewed By: vrana CC: aran Differential Revision: https://secure.phabricator.com/D3574
This commit is contained in:
parent
f0a91a30c8
commit
b880dfd4c8
1 changed files with 29 additions and 21 deletions
|
@ -368,6 +368,8 @@ EOTEXT
|
||||||
public function run() {
|
public function run() {
|
||||||
$this->console = PhutilConsole::getConsole();
|
$this->console = PhutilConsole::getConsole();
|
||||||
|
|
||||||
|
$this->runRepositoryAPISetup();
|
||||||
|
|
||||||
if ($this->getArgument('no-diff')) {
|
if ($this->getArgument('no-diff')) {
|
||||||
$this->removeScratchFile('diff-result.json');
|
$this->removeScratchFile('diff-result.json');
|
||||||
$data = $this->runLintUnit();
|
$data = $this->runLintUnit();
|
||||||
|
@ -387,6 +389,7 @@ EOTEXT
|
||||||
if (!PhutilConsoleFormatter::getDisableANSI()) {
|
if (!PhutilConsoleFormatter::getDisableANSI()) {
|
||||||
array_unshift($argv, '--ansi');
|
array_unshift($argv, '--ansi');
|
||||||
}
|
}
|
||||||
|
|
||||||
$lint_unit = new ExecFuture(
|
$lint_unit = new ExecFuture(
|
||||||
'php %s --recon diff --no-diff %Ls',
|
'php %s --recon diff --no-diff %Ls',
|
||||||
phutil_get_library_root('arcanist').'/../scripts/arcanist.php',
|
phutil_get_library_root('arcanist').'/../scripts/arcanist.php',
|
||||||
|
@ -541,8 +544,11 @@ EOTEXT
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function runDiffSetupBasics() {
|
private function runRepositoryAPISetup() {
|
||||||
if ($this->requiresRepositoryAPI()) {
|
if (!$this->requiresRepositoryAPI()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
$repository_api = $this->getRepositoryAPI();
|
$repository_api = $this->getRepositoryAPI();
|
||||||
if ($this->getArgument('less-context')) {
|
if ($this->getArgument('less-context')) {
|
||||||
$repository_api->setDiffLinesOfContext(3);
|
$repository_api->setDiffLinesOfContext(3);
|
||||||
|
@ -564,6 +570,7 @@ EOTEXT
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function runDiffSetupBasics() {
|
||||||
$output_json = $this->getArgument('json');
|
$output_json = $this->getArgument('json');
|
||||||
if ($output_json) {
|
if ($output_json) {
|
||||||
// TODO: We should move this to a higher-level and put an indirection
|
// TODO: We should move this to a higher-level and put an indirection
|
||||||
|
@ -1230,6 +1237,7 @@ EOTEXT
|
||||||
$argv[] = '--rev';
|
$argv[] = '--rev';
|
||||||
$argv[] = $repository_api->getRelativeCommit();
|
$argv[] = $repository_api->getRelativeCommit();
|
||||||
}
|
}
|
||||||
|
|
||||||
$lint_workflow = $this->buildChildWorkflow('lint', $argv);
|
$lint_workflow = $this->buildChildWorkflow('lint', $argv);
|
||||||
|
|
||||||
if ($this->shouldAmend()) {
|
if ($this->shouldAmend()) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue