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

Add a "branches" rule for commits

Summary:
Fixes T1353. Also some minor unrelated cleanup:

  - `openTransaction()` / `saveTransaction()` exist now, fix TODOs.
  - Fix some instructions.
  - Make `diffusion.branchquery` return empty for SVN rather than fataling.

Test Plan:
  - Added a branches rule.
  - Ran a dry run against commits in different VCSes.

{F105574}

Reviewers: btrahan

Reviewed By: btrahan

CC: aran, Nopik

Maniphest Tasks: T1353

Differential Revision: https://secure.phabricator.com/D8086
This commit is contained in:
epriestley 2014-01-28 14:43:13 -08:00
parent e293d39b5f
commit e9be9ecfbc
4 changed files with 30 additions and 12 deletions

View file

@ -100,6 +100,12 @@ final class ConduitAPI_diffusion_branchquery_Method
return $this->processBranchRefs($request, $refs); return $this->processBranchRefs($request, $refs);
} }
protected function getSVNResult() {
// Since SVN doesn't have meaningful branches, just return nothing for all
// queries.
return array();
}
private function processBranchRefs(ConduitAPIRequest $request, array $refs) { private function processBranchRefs(ConduitAPIRequest $request, array $refs) {
$drequest = $this->getDiffusionRequest(); $drequest = $this->getDiffusionRequest();
$repository = $drequest->getRepository(); $repository = $drequest->getRepository();
@ -125,4 +131,5 @@ final class ConduitAPI_diffusion_branchquery_Method
return mpull($refs, 'toDictionary'); return mpull($refs, 'toDictionary');
} }
} }

View file

@ -88,7 +88,8 @@ final class HeraldCommitAdapter extends HeraldAdapter {
return array( return array(
self::FIELD_NEED_AUDIT_FOR_PACKAGE => self::FIELD_NEED_AUDIT_FOR_PACKAGE =>
pht('Affected packages that need audit'), pht('Affected packages that need audit'),
self::FIELD_REPOSITORY_AUTOCLOSE_BRANCH => pht('On autoclose branch'), self::FIELD_REPOSITORY_AUTOCLOSE_BRANCH
=> pht('Commit is on closing branch'),
) + parent::getFieldNameMap(); ) + parent::getFieldNameMap();
} }
@ -114,6 +115,7 @@ final class HeraldCommitAdapter extends HeraldAdapter {
self::FIELD_DIFFERENTIAL_ACCEPTED, self::FIELD_DIFFERENTIAL_ACCEPTED,
self::FIELD_DIFFERENTIAL_REVIEWERS, self::FIELD_DIFFERENTIAL_REVIEWERS,
self::FIELD_DIFFERENTIAL_CCS, self::FIELD_DIFFERENTIAL_CCS,
self::FIELD_BRANCHES,
self::FIELD_REPOSITORY_AUTOCLOSE_BRANCH, self::FIELD_REPOSITORY_AUTOCLOSE_BRANCH,
), ),
parent::getFields()); parent::getFields());
@ -461,6 +463,18 @@ final class HeraldCommitAdapter extends HeraldAdapter {
return array(); return array();
} }
return $revision->getCCPHIDs(); return $revision->getCCPHIDs();
case self::FIELD_BRANCHES:
$params = array(
'callsign' => $this->repository->getCallsign(),
'contains' => $this->commit->getCommitIdentifier(),
);
$result = id(new ConduitCall('diffusion.branchquery', $params))
->setUser(PhabricatorUser::getOmnipotentUser())
->execute();
$refs = DiffusionRepositoryRef::loadAllFromDictionaries($result);
return mpull($refs, 'getShortName');
case self::FIELD_REPOSITORY_AUTOCLOSE_BRANCH: case self::FIELD_REPOSITORY_AUTOCLOSE_BRANCH:
return $this->repository->shouldAutocloseCommit( return $this->repository->shouldAutocloseCommit(
$this->commit, $this->commit,

View file

@ -74,15 +74,13 @@ final class HeraldTestConsoleController extends HeraldController {
} }
} }
$text = pht(
'Enter an object to test rules for, like a Diffusion commit (e.g., '.
'rX123) or a Differential revision (e.g., D123). You will be shown '.
'the results of a dry run on the object.');
$form = id(new AphrontFormView()) $form = id(new AphrontFormView())
->setUser($user) ->setUser($user)
->appendChild( ->appendRemarkupInstructions(
phutil_tag('p', array('class' => 'aphront-form-instructions'), $text)) pht(
'Enter an object to test rules for, like a Diffusion commit (e.g., '.
'`rX123`) or a Differential revision (e.g., `D123`). You will be '.
'shown the results of a dry run on the object.'))
->appendChild( ->appendChild(
id(new AphrontFormTextControl()) id(new AphrontFormTextControl())
->setLabel(pht('Object Name')) ->setLabel(pht('Object Name'))

View file

@ -17,7 +17,7 @@ final class HeraldRule extends HeraldDAO
protected $isDisabled = 0; protected $isDisabled = 0;
protected $triggerObjectPHID; protected $triggerObjectPHID;
protected $configVersion = 27; protected $configVersion = 28;
// phids for which this rule has been applied // phids for which this rule has been applied
private $ruleApplied = self::ATTACHABLE; private $ruleApplied = self::ATTACHABLE;
@ -134,8 +134,7 @@ final class HeraldRule extends HeraldDAO
$child->setRuleID($this->getID()); $child->setRuleID($this->getID());
} }
// TODO: $this->openTransaction();
// $this->openTransaction();
queryfx( queryfx(
$this->establishConnection('w'), $this->establishConnection('w'),
'DELETE FROM %T WHERE ruleID = %d', 'DELETE FROM %T WHERE ruleID = %d',
@ -144,7 +143,7 @@ final class HeraldRule extends HeraldDAO
foreach ($children as $child) { foreach ($children as $child) {
$child->save(); $child->save();
} }
// $this->saveTransaction(); $this->saveTransaction();
} }
public function delete() { public function delete() {