1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-04 11:51:02 +01:00

Add a "branches" rule for Herald commit rules

Summary:
Fixes T4195. Allows you to write a rule against a commit's branches.

This completes outstanding work on T4195.

Test Plan: Pushed to Git and Mercurial repositories and verified branches were selected correctly by examining transcripts.

Reviewers: btrahan

Reviewed By: btrahan

CC: aran

Maniphest Tasks: T4195

Differential Revision: https://secure.phabricator.com/D7820
This commit is contained in:
epriestley 2013-12-26 10:40:16 -08:00
parent 44c9a94abe
commit adcc4ee1db
3 changed files with 39 additions and 0 deletions

View file

@ -26,6 +26,7 @@ final class DiffusionCommitHookEngine extends Phobject {
private $transactionKey; private $transactionKey;
private $mercurialHook; private $mercurialHook;
private $mercurialCommits = array(); private $mercurialCommits = array();
private $gitCommits = array();
private $heraldViewerProjects; private $heraldViewerProjects;
@ -427,6 +428,7 @@ final class DiffusionCommitHookEngine extends Phobject {
$merge_base = rtrim($stdout, "\n"); $merge_base = rtrim($stdout, "\n");
} }
$ref_update = $ref_updates[$key];
$ref_update->setMergeBase($merge_base); $ref_update->setMergeBase($merge_base);
} }
@ -525,7 +527,20 @@ final class DiffusionCommitHookEngine extends Phobject {
$commits = phutil_split_lines($stdout, $retain_newlines = false); $commits = phutil_split_lines($stdout, $retain_newlines = false);
// If we're looking at a branch, mark all of the new commits as on that
// branch. It's only possible for these commits to be on updated branches,
// since any other branch heads are necessarily behind them.
$branch_name = null;
$ref_update = $ref_updates[$key];
$type_branch = PhabricatorRepositoryPushLog::REFTYPE_BRANCH;
if ($ref_update->getRefType() == $type_branch) {
$branch_name = $ref_update->getRefName();
}
foreach ($commits as $commit) { foreach ($commits as $commit) {
if ($branch_name) {
$this->gitCommits[$commit][] = $branch_name;
}
$content_updates[$commit] = $this->newPushLog() $content_updates[$commit] = $this->newPushLog()
->setRefType(PhabricatorRepositoryPushLog::REFTYPE_COMMIT) ->setRefType(PhabricatorRepositoryPushLog::REFTYPE_COMMIT)
->setRefNew($commit) ->setRefNew($commit)
@ -973,5 +988,19 @@ final class DiffusionCommitHookEngine extends Phobject {
} }
} }
public function loadBranches($identifier) {
$repository = $this->getRepository();
$vcs = $repository->getVersionControlSystem();
switch ($vcs) {
case PhabricatorRepositoryType::REPOSITORY_TYPE_GIT:
return idx($this->gitCommits, $identifier, array());
case PhabricatorRepositoryType::REPOSITORY_TYPE_MERCURIAL:
return idx($this->mercurialCommits, $identifier, array());
case PhabricatorRepositoryType::REPOSITORY_TYPE_SVN:
// Subversion doesn't have branches.
return array();
}
}
} }

View file

@ -42,6 +42,7 @@ final class HeraldPreCommitContentAdapter extends HeraldAdapter {
self::FIELD_BODY, self::FIELD_BODY,
self::FIELD_AUTHOR, self::FIELD_AUTHOR,
self::FIELD_COMMITTER, self::FIELD_COMMITTER,
self::FIELD_BRANCHES,
self::FIELD_DIFF_FILE, self::FIELD_DIFF_FILE,
self::FIELD_DIFF_CONTENT, self::FIELD_DIFF_CONTENT,
self::FIELD_DIFF_ADDED_CONTENT, self::FIELD_DIFF_ADDED_CONTENT,
@ -100,6 +101,8 @@ final class HeraldPreCommitContentAdapter extends HeraldAdapter {
return $this->getAuthorPHID(); return $this->getAuthorPHID();
case self::FIELD_COMMITTER: case self::FIELD_COMMITTER:
return $this->getCommitterPHID(); return $this->getCommitterPHID();
case self::FIELD_BRANCHES:
return $this->getBranches();
case self::FIELD_DIFF_FILE: case self::FIELD_DIFF_FILE:
return $this->getDiffContent('name'); return $this->getDiffContent('name');
case self::FIELD_DIFF_CONTENT: case self::FIELD_DIFF_CONTENT:
@ -329,4 +332,8 @@ final class HeraldPreCommitContentAdapter extends HeraldAdapter {
} }
} }
private function getBranches() {
return $this->hookEngine->loadBranches($this->log->getRefNew());
}
} }

View file

@ -33,6 +33,7 @@ abstract class HeraldAdapter {
const FIELD_DIFFERENTIAL_CCS = 'differential-ccs'; const FIELD_DIFFERENTIAL_CCS = 'differential-ccs';
const FIELD_DIFFERENTIAL_ACCEPTED = 'differential-accepted'; const FIELD_DIFFERENTIAL_ACCEPTED = 'differential-accepted';
const FIELD_IS_MERGE_COMMIT = 'is-merge-commit'; const FIELD_IS_MERGE_COMMIT = 'is-merge-commit';
const FIELD_BRANCHES = 'branches';
const CONDITION_CONTAINS = 'contains'; const CONDITION_CONTAINS = 'contains';
const CONDITION_NOT_CONTAINS = '!contains'; const CONDITION_NOT_CONTAINS = '!contains';
@ -178,6 +179,7 @@ abstract class HeraldAdapter {
self::FIELD_DIFFERENTIAL_ACCEPTED self::FIELD_DIFFERENTIAL_ACCEPTED
=> pht('Accepted Differential revision'), => pht('Accepted Differential revision'),
self::FIELD_IS_MERGE_COMMIT => pht('Commit is a merge'), self::FIELD_IS_MERGE_COMMIT => pht('Commit is a merge'),
self::FIELD_BRANCHES => pht('Commit\'s branches'),
); );
} }
@ -255,6 +257,7 @@ abstract class HeraldAdapter {
self::CONDITION_NOT_EXISTS, self::CONDITION_NOT_EXISTS,
); );
case self::FIELD_DIFF_FILE: case self::FIELD_DIFF_FILE:
case self::FIELD_BRANCHES:
return array( return array(
self::CONDITION_CONTAINS, self::CONDITION_CONTAINS,
self::CONDITION_REGEXP, self::CONDITION_REGEXP,