From 60a6ba2b2501a83f40d9d7403a0acc28569604a9 Mon Sep 17 00:00:00 2001 From: Peng Li Date: Mon, 13 Jan 2014 18:18:26 -0800 Subject: [PATCH] Add dependencies to releeph Summary: Add the 'Depends On' field to releeph requests. This will help the release engineers to be aware of the dependencies and make sure pick them altogether. Test Plan: Check sandbox. This field shows up when a revision has some dependencies. Reviewers: JoelB, lifeihuang, epriestley, #blessed_reviewers Reviewed By: epriestley CC: Korvin, epriestley, aran Differential Revision: https://secure.phabricator.com/D7946 --- src/__phutil_library_map__.php | 2 + .../selector/ReleephDefaultFieldSelector.php | 2 + .../ReleephDependsOnFieldSpecification.php | 46 +++++++++++++++++++ 3 files changed, 50 insertions(+) create mode 100644 src/applications/releeph/field/specification/ReleephDependsOnFieldSpecification.php diff --git a/src/__phutil_library_map__.php b/src/__phutil_library_map__.php index ec59c86015..16b800ccb8 100644 --- a/src/__phutil_library_map__.php +++ b/src/__phutil_library_map__.php @@ -2359,6 +2359,7 @@ phutil_register_library_map(array( 'ReleephDAO' => 'applications/releeph/storage/ReleephDAO.php', 'ReleephDefaultFieldSelector' => 'applications/releeph/field/selector/ReleephDefaultFieldSelector.php', 'ReleephDefaultUserView' => 'applications/releeph/view/user/ReleephDefaultUserView.php', + 'ReleephDependsOnFieldSpecification' => 'applications/releeph/field/specification/ReleephDependsOnFieldSpecification.php', 'ReleephDiffChurnFieldSpecification' => 'applications/releeph/field/specification/ReleephDiffChurnFieldSpecification.php', 'ReleephDiffMessageFieldSpecification' => 'applications/releeph/field/specification/ReleephDiffMessageFieldSpecification.php', 'ReleephDiffSizeFieldSpecification' => 'applications/releeph/field/specification/ReleephDiffSizeFieldSpecification.php', @@ -5109,6 +5110,7 @@ phutil_register_library_map(array( 'ReleephDAO' => 'PhabricatorLiskDAO', 'ReleephDefaultFieldSelector' => 'ReleephFieldSelector', 'ReleephDefaultUserView' => 'ReleephUserView', + 'ReleephDependsOnFieldSpecification' => 'ReleephFieldSpecification', 'ReleephDiffChurnFieldSpecification' => 'ReleephFieldSpecification', 'ReleephDiffMessageFieldSpecification' => 'ReleephFieldSpecification', 'ReleephDiffSizeFieldSpecification' => 'ReleephFieldSpecification', diff --git a/src/applications/releeph/field/selector/ReleephDefaultFieldSelector.php b/src/applications/releeph/field/selector/ReleephDefaultFieldSelector.php index 0801203b89..24ec931bd1 100644 --- a/src/applications/releeph/field/selector/ReleephDefaultFieldSelector.php +++ b/src/applications/releeph/field/selector/ReleephDefaultFieldSelector.php @@ -42,6 +42,7 @@ final class ReleephDefaultFieldSelector extends ReleephFieldSelector { new ReleephBranchCommitFieldSpecification(), new ReleephDiffSizeFieldSpecification(), new ReleephDiffChurnFieldSpecification(), + new ReleephDependsOnFieldSpecification(), new ReleephFacebookTagFieldSpecification(), new ReleephFacebookTasksFieldSpecification(), ); @@ -76,6 +77,7 @@ final class ReleephDefaultFieldSelector extends ReleephFieldSelector { 'ReleephOriginalCommitFieldSpecification', 'ReleephDiffSizeFieldSpecification', 'ReleephDiffChurnFieldSpecification', + 'ReleephDependsOnFieldSpecification', 'ReleephFacebookTasksFieldSpecification', )), 'right' => self::selectFields($fields, array( diff --git a/src/applications/releeph/field/specification/ReleephDependsOnFieldSpecification.php b/src/applications/releeph/field/specification/ReleephDependsOnFieldSpecification.php new file mode 100644 index 0000000000..8af68bd444 --- /dev/null +++ b/src/applications/releeph/field/specification/ReleephDependsOnFieldSpecification.php @@ -0,0 +1,46 @@ +getDependentRevisionPHIDs(); + if (!$revision_phids) { + return null; + } + + $links = array(); + $handles = id(new PhabricatorHandleQuery()) + ->setViewer($this->getUser()) + ->withPHIDs($revision_phids) + ->execute(); + foreach ($revision_phids as $revision_phid) { + $links[] = id(clone $handles[$revision_phid]) + // Hack to remove the strike-through rendering of diff links + ->setStatus(null) + ->renderLink(); + } + + return phutil_implode_html(phutil_tag('br'), $links); + } + + private function getDependentRevisionPHIDs() { + $revision = $this + ->getReleephRequest() + ->loadDifferentialRevision(); + if (!$revision) { + return null; + } + + return PhabricatorEdgeQuery::loadDestinationPHIDs( + $revision->getPHID(), + PhabricatorEdgeConfig::TYPE_DREV_DEPENDS_ON_DREV); + } +}