mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-19 19:21:10 +01:00
Normalize the definition of "closed" revision statuses
Summary: Currently, "Closed" and "Abandoned" are treated as "closed". I want to add a flag which treats "Accepted" as "Closed", too, for Asana and other companies who use an Asana-like workflow. The background here is that their workflow is a bit weird. They basically do audits, but have a lot of things which Diffusion doesn't do well right now. This one change makes Differential fit their workflow fairly well, even though it's an audit workflow. To prepare for this, normalize the definition of "closed" better. We have a few callsites which explicitly check for "ABANDONED || CLOSED", and normalizing this is cleaner anyway. Also delete the very old COMMITTED status, which has been obsolete for over a year. Test Plan: Browsed around most/all of the affected interfaces. Reviewers: btrahan Reviewed By: btrahan CC: aran Differential Revision: https://secure.phabricator.com/D7653
This commit is contained in:
parent
e4920cdf86
commit
1da691113a
8 changed files with 39 additions and 40 deletions
|
@ -68,8 +68,7 @@ final class ConduitAPI_differential_creatediff_Method extends ConduitAPIMethod {
|
||||||
->execute();
|
->execute();
|
||||||
if ($parent_rev) {
|
if ($parent_rev) {
|
||||||
$parent_rev = head($parent_rev);
|
$parent_rev = head($parent_rev);
|
||||||
if ($parent_rev->getStatus() !=
|
if (!$parent_rev->isClosed()) {
|
||||||
ArcanistDifferentialRevisionStatus::CLOSED) {
|
|
||||||
$diff->setParentRevisionID($parent_id);
|
$diff->setParentRevisionID($parent_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,4 +70,30 @@ final class DifferentialRevisionStatus {
|
||||||
|
|
||||||
return $tag;
|
return $tag;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static function getClosedStatuses() {
|
||||||
|
return array(
|
||||||
|
ArcanistDifferentialRevisionStatus::CLOSED,
|
||||||
|
ArcanistDifferentialRevisionStatus::ABANDONED,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function getOpenStatuses() {
|
||||||
|
return array_diff(self::getAllStatuses(), self::getClosedStatuses());
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function getAllStatuses() {
|
||||||
|
return array(
|
||||||
|
ArcanistDifferentialRevisionStatus::NEEDS_REVIEW,
|
||||||
|
ArcanistDifferentialRevisionStatus::NEEDS_REVISION,
|
||||||
|
ArcanistDifferentialRevisionStatus::ACCEPTED,
|
||||||
|
ArcanistDifferentialRevisionStatus::CLOSED,
|
||||||
|
ArcanistDifferentialRevisionStatus::ABANDONED,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function isClosedStatus($status) {
|
||||||
|
return in_array($status, self::getClosedStatuses());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,13 +78,7 @@ final class DifferentialDoorkeeperRevisionFeedStoryPublisher
|
||||||
}
|
}
|
||||||
|
|
||||||
public function isObjectClosed($object) {
|
public function isObjectClosed($object) {
|
||||||
switch ($object->getStatus()) {
|
return $object->isClosed();
|
||||||
case ArcanistDifferentialRevisionStatus::CLOSED:
|
|
||||||
case ArcanistDifferentialRevisionStatus::ABANDONED:
|
|
||||||
return true;
|
|
||||||
default:
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getResponsibilityTitle($object) {
|
public function getResponsibilityTitle($object) {
|
||||||
|
|
|
@ -29,11 +29,6 @@ final class DifferentialPHIDTypeRevision extends PhabricatorPHIDType {
|
||||||
array $handles,
|
array $handles,
|
||||||
array $objects) {
|
array $objects) {
|
||||||
|
|
||||||
static $closed_statuses = array(
|
|
||||||
ArcanistDifferentialRevisionStatus::CLOSED => true,
|
|
||||||
ArcanistDifferentialRevisionStatus::ABANDONED => true,
|
|
||||||
);
|
|
||||||
|
|
||||||
foreach ($handles as $phid => $handle) {
|
foreach ($handles as $phid => $handle) {
|
||||||
$revision = $objects[$phid];
|
$revision = $objects[$phid];
|
||||||
|
|
||||||
|
@ -45,7 +40,7 @@ final class DifferentialPHIDTypeRevision extends PhabricatorPHIDType {
|
||||||
$handle->setURI("/D{$id}");
|
$handle->setURI("/D{$id}");
|
||||||
$handle->setFullName("D{$id}: {$title}");
|
$handle->setFullName("D{$id}: {$title}");
|
||||||
|
|
||||||
if (isset($closed_statuses[$status])) {
|
if ($revision->isClosed()) {
|
||||||
$handle->setStatus(PhabricatorObjectHandleStatus::STATUS_CLOSED);
|
$handle->setStatus(PhabricatorObjectHandleStatus::STATUS_CLOSED);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,8 +23,7 @@ final class DifferentialRevisionQuery
|
||||||
const STATUS_ACCEPTED = 'status-accepted';
|
const STATUS_ACCEPTED = 'status-accepted';
|
||||||
const STATUS_NEEDS_REVIEW = 'status-needs-review';
|
const STATUS_NEEDS_REVIEW = 'status-needs-review';
|
||||||
const STATUS_NEEDS_REVISION = 'status-needs-revision';
|
const STATUS_NEEDS_REVISION = 'status-needs-revision';
|
||||||
const STATUS_CLOSED = 'status-closed'; // NOTE: Same as 'committed'
|
const STATUS_CLOSED = 'status-closed';
|
||||||
const STATUS_COMMITTED = 'status-committed'; // TODO: Remove.
|
|
||||||
const STATUS_ABANDONED = 'status-abandoned';
|
const STATUS_ABANDONED = 'status-abandoned';
|
||||||
|
|
||||||
private $authors = array();
|
private $authors = array();
|
||||||
|
@ -772,11 +771,7 @@ final class DifferentialRevisionQuery
|
||||||
$where[] = qsprintf(
|
$where[] = qsprintf(
|
||||||
$conn_r,
|
$conn_r,
|
||||||
'r.status IN (%Ld)',
|
'r.status IN (%Ld)',
|
||||||
array(
|
DifferentialRevisionStatus::getOpenStatuses());
|
||||||
ArcanistDifferentialRevisionStatus::NEEDS_REVIEW,
|
|
||||||
ArcanistDifferentialRevisionStatus::NEEDS_REVISION,
|
|
||||||
ArcanistDifferentialRevisionStatus::ACCEPTED,
|
|
||||||
));
|
|
||||||
break;
|
break;
|
||||||
case self::STATUS_NEEDS_REVIEW:
|
case self::STATUS_NEEDS_REVIEW:
|
||||||
$where[] = qsprintf(
|
$where[] = qsprintf(
|
||||||
|
@ -802,19 +797,11 @@ final class DifferentialRevisionQuery
|
||||||
ArcanistDifferentialRevisionStatus::ACCEPTED,
|
ArcanistDifferentialRevisionStatus::ACCEPTED,
|
||||||
));
|
));
|
||||||
break;
|
break;
|
||||||
case self::STATUS_COMMITTED:
|
|
||||||
phlog(
|
|
||||||
"WARNING: DifferentialRevisionQuery using deprecated ".
|
|
||||||
"STATUS_COMMITTED constant. This will be removed soon. ".
|
|
||||||
"Use STATUS_CLOSED.");
|
|
||||||
// fallthrough
|
|
||||||
case self::STATUS_CLOSED:
|
case self::STATUS_CLOSED:
|
||||||
$where[] = qsprintf(
|
$where[] = qsprintf(
|
||||||
$conn_r,
|
$conn_r,
|
||||||
'r.status IN (%Ld)',
|
'r.status IN (%Ld)',
|
||||||
array(
|
DifferentialRevisionStatus::getClosedStatuses());
|
||||||
ArcanistDifferentialRevisionStatus::CLOSED,
|
|
||||||
));
|
|
||||||
break;
|
break;
|
||||||
case self::STATUS_ABANDONED:
|
case self::STATUS_ABANDONED:
|
||||||
$where[] = qsprintf(
|
$where[] = qsprintf(
|
||||||
|
|
|
@ -44,8 +44,7 @@ final class DifferentialSearchIndexer
|
||||||
PhabricatorPeoplePHIDTypeUser::TYPECONST,
|
PhabricatorPeoplePHIDTypeUser::TYPECONST,
|
||||||
$rev->getDateCreated());
|
$rev->getDateCreated());
|
||||||
|
|
||||||
if ($rev->getStatus() != ArcanistDifferentialRevisionStatus::CLOSED &&
|
if (!$rev->isClosed()) {
|
||||||
$rev->getStatus() != ArcanistDifferentialRevisionStatus::ABANDONED) {
|
|
||||||
$doc->addRelationship(
|
$doc->addRelationship(
|
||||||
PhabricatorSearchRelationship::RELATIONSHIP_OPEN,
|
PhabricatorSearchRelationship::RELATIONSHIP_OPEN,
|
||||||
$rev->getPHID(),
|
$rev->getPHID(),
|
||||||
|
|
|
@ -407,4 +407,9 @@ final class DifferentialRevision extends DifferentialDAO
|
||||||
$this->repository = $repository;
|
$this->repository = $repository;
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function isClosed() {
|
||||||
|
return DifferentialRevisionStatus::isClosedStatus($this->getStatus());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -114,11 +114,6 @@ final class DifferentialRevisionListView extends AphrontView {
|
||||||
$list = new PHUIObjectItemListView();
|
$list = new PHUIObjectItemListView();
|
||||||
$list->setCards(true);
|
$list->setCards(true);
|
||||||
|
|
||||||
$do_not_display_age = array(
|
|
||||||
ArcanistDifferentialRevisionStatus::CLOSED => true,
|
|
||||||
ArcanistDifferentialRevisionStatus::ABANDONED => true,
|
|
||||||
);
|
|
||||||
|
|
||||||
foreach ($this->revisions as $revision) {
|
foreach ($this->revisions as $revision) {
|
||||||
$item = id(new PHUIObjectItemView())
|
$item = id(new PHUIObjectItemView())
|
||||||
->setUser($user);
|
->setUser($user);
|
||||||
|
@ -146,8 +141,7 @@ final class DifferentialRevisionListView extends AphrontView {
|
||||||
$status = $revision->getStatus();
|
$status = $revision->getStatus();
|
||||||
$show_age = ($fresh || $stale) &&
|
$show_age = ($fresh || $stale) &&
|
||||||
$this->highlightAge &&
|
$this->highlightAge &&
|
||||||
empty($do_not_display_age[$status]);
|
!$revision->isClosed();
|
||||||
|
|
||||||
|
|
||||||
$object_age = PHUIObjectItemView::AGE_FRESH;
|
$object_age = PHUIObjectItemView::AGE_FRESH;
|
||||||
foreach ($this->fields as $field) {
|
foreach ($this->fields as $field) {
|
||||||
|
|
Loading…
Reference in a new issue