1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-11 15:21:03 +01:00

When voiding "Accept" reviews, also void "Reject" reviews

Summary: Ref T10967. This change is similar to D17566, but for rejects.

Test Plan:
  - Create a revision as A, with reviewer B.
  - Reject as B.
  - Request review as A.
  - Before patch: stuck in "rejected".
  - After patch: transitions back to "needs review".

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T10967

Differential Revision: https://secure.phabricator.com/D17568
This commit is contained in:
epriestley 2017-03-28 06:22:19 -07:00
parent 415ad78484
commit ddc02ce420
4 changed files with 56 additions and 16 deletions

View file

@ -339,7 +339,7 @@ final class DifferentialTransactionEditor
}
}
if ($downgrade_accepts) {
if ($downgrade_accepts || $downgrade_rejects) {
$void_type = DifferentialRevisionVoidTransaction::TRANSACTIONTYPE;
$results[] = id(new DifferentialTransaction())
->setTransactionType($void_type)
@ -659,11 +659,8 @@ final class DifferentialTransactionEditor
$reviewer_status = $reviewer->getReviewerStatus();
switch ($reviewer_status) {
case DifferentialReviewerStatus::STATUS_REJECTED:
$action_phid = $reviewer->getLastActionDiffPHID();
$active_phid = $active_diff->getPHID();
$is_current = ($action_phid == $active_phid);
if ($is_current) {
if ($reviewer->isRejected($active_phid)) {
$has_rejecting_reviewer = true;
}
break;

View file

@ -54,6 +54,25 @@ final class DifferentialReviewer
return ($this->getReviewerStatus() == $status_resigned);
}
public function isRejected($diff_phid) {
$status_rejected = DifferentialReviewerStatus::STATUS_REJECTED;
if ($this->getReviewerStatus() != $status_rejected) {
return false;
}
if ($this->getVoidedPHID()) {
return false;
}
if ($this->isCurrentAction($diff_phid)) {
return true;
}
return false;
}
public function isAccepted($diff_phid) {
$status_accepted = DifferentialReviewerStatus::STATUS_ACCEPTED;
@ -68,6 +87,21 @@ final class DifferentialReviewer
return false;
}
if ($this->isCurrentAction($diff_phid)) {
return true;
}
$sticky_key = 'differential.sticky-accept';
$is_sticky = PhabricatorEnv::getEnvConfig($sticky_key);
if ($is_sticky) {
return true;
}
return false;
}
private function isCurrentAction($diff_phid) {
if (!$diff_phid) {
return true;
}
@ -82,13 +116,6 @@ final class DifferentialReviewer
return true;
}
$sticky_key = 'differential.sticky-accept';
$is_sticky = PhabricatorEnv::getEnvConfig($sticky_key);
if ($is_sticky) {
return true;
}
return false;
}

View file

@ -100,7 +100,10 @@ abstract class DifferentialRevisionReviewTransaction
$active_phid = $this->getActiveDiffPHID($revision);
$status_accepted = DifferentialReviewerStatus::STATUS_ACCEPTED;
$status_rejected = DifferentialReviewerStatus::STATUS_REJECTED;
$is_accepted = ($require_status == $status_accepted);
$is_rejected = ($require_status == $status_rejected);
// Otherwise, check that all reviews they have authority over are in
// the desired set of states.
@ -121,6 +124,12 @@ abstract class DifferentialRevisionReviewTransaction
}
}
if ($is_rejected) {
if (!$reviewer->isRejected($active_phid)) {
return false;
}
}
// This is a broader check to see if we can update the diff where the
// last action occurred.
if ($reviewer->getLastActionDiffPHID() != $active_phid) {

View file

@ -25,10 +25,10 @@ final class DifferentialRevisionVoidTransaction
'SELECT reviewerPHID FROM %T
WHERE revisionPHID = %s
AND voidedPHID IS NULL
AND reviewerStatus = %s',
AND reviewerStatus IN (%Ls)',
$table_name,
$object->getPHID(),
DifferentialReviewerStatus::STATUS_ACCEPTED);
$this->getVoidableStatuses());
return ipull($rows, 'reviewerPHID');
}
@ -47,11 +47,11 @@ final class DifferentialRevisionVoidTransaction
'UPDATE %T SET voidedPHID = %s
WHERE revisionPHID = %s
AND voidedPHID IS NULL
AND reviewerStatus = %s',
AND reviewerStatus IN (%Ls)',
$table_name,
$this->getActingAsPHID(),
$object->getPHID(),
DifferentialReviewerStatus::STATUS_ACCEPTED);
$this->getVoidableStatuses());
}
public function shouldHide() {
@ -60,4 +60,11 @@ final class DifferentialRevisionVoidTransaction
return true;
}
private function getVoidableStatuses() {
return array(
DifferentialReviewerStatus::STATUS_ACCEPTED,
DifferentialReviewerStatus::STATUS_REJECTED,
);
}
}