1
0
Fork 0
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:
epriestley 2012-10-02 11:01:49 -07:00
parent f0a91a30c8
commit b880dfd4c8

View file

@ -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()) {