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:
parent
e293d39b5f
commit
e9be9ecfbc
4 changed files with 30 additions and 12 deletions
|
@ -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');
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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'))
|
||||||
|
|
|
@ -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() {
|
||||||
|
|
Loading…
Reference in a new issue