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

Stop using loadRelationships in differential related herald adapters

Summary:
Used `DifferentialRevisionQuery` with the relevant `need*()` calls in the test controller.
And started assuming the revision has reviewers and CC phids in `HeraldDifferentialRevisionAdapter`.

Test Plan:
Added herald rules that use revisions (one for revisions another for commit) and reviewers.
Created, accepted and landed a revision that matched the rules and checked all rules were applied.

Reviewers: epriestley

Reviewed By: epriestley

CC: aran, Korvin

Maniphest Tasks: T1279

Differential Revision: https://secure.phabricator.com/D6468

Conflicts:
	src/applications/herald/adapter/HeraldCommitAdapter.php
	src/applications/herald/adapter/HeraldDifferentialRevisionAdapter.php
	src/applications/herald/controller/HeraldTestConsoleController.php
This commit is contained in:
Juan Pablo Civile 2013-10-04 16:30:43 -07:00 committed by epriestley
parent c35b93d9b6
commit 562da7e98b
2 changed files with 21 additions and 5 deletions

View file

@ -221,10 +221,20 @@ final class HeraldCommitAdapter extends HeraldAdapter {
$data = $this->commitData; $data = $this->commitData;
$revision_id = $data->getCommitDetail('differential.revisionID'); $revision_id = $data->getCommitDetail('differential.revisionID');
if ($revision_id) { if ($revision_id) {
// TODO: (T603) Herald policy stuff. // NOTE: The Herald rule owner might not actually have access to
$revision = id(new DifferentialRevision())->load($revision_id); // the revision, and can control which revision a commit is
// associated with by putting text in the commit message. However,
// the rules they can write against revisions don't actually expose
// anything interesting, so it seems reasonable to load unconditionally
// here.
$revision = id(new DifferentialRevisionQuery())
->withIDs(array($revision_id))
->setViewer(PhabricatorUser::getOmnipotentUser())
->needRelationships(true)
->needReviewerStatus(true)
->executeOne();
if ($revision) { if ($revision) {
$revision->loadRelationships();
$this->affectedRevision = $revision; $this->affectedRevision = $revision;
} }
} }

View file

@ -62,10 +62,16 @@ final class HeraldDifferentialRevisionAdapter extends HeraldAdapter {
public static function newLegacyAdapter( public static function newLegacyAdapter(
DifferentialRevision $revision, DifferentialRevision $revision,
DifferentialDiff $diff) { DifferentialDiff $diff) {
$object = new HeraldDifferentialRevisionAdapter(); $object = new HeraldDifferentialRevisionAdapter();
$revision->loadRelationships(); // Reload the revision to pick up relationship information.
$revision = id(new DifferentialRevisionQuery())
->withIDs(array($revision->getID()))
->setViewer(PhabricatorUser::getOmnipotentUser())
->needRelationships(true)
->needReviewerStatus(true)
->executeOne();
$object->revision = $revision; $object->revision = $revision;
$object->diff = $diff; $object->diff = $diff;