1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-01 18:30:59 +01:00

Restore some minor state behaviors to Differential on EditEngine

Summary:
Ref T11114. This restores:

  - Commandeering should exeucte Herald.
  - Commandeering should swap reviewers.
  - "Request Review" on an "Accepted" revision should downgrade reviewers so they have to accept again.

Test Plan:
  - Commandeered, saw Herald run and reviewers swap.
  - Requested review of an accepted revision, saw it drop down to "Needs Review" with "Accepted Prior" on the reviewer.

Reviewers: chad

Reviewed By: chad

Maniphest Tasks: T11114

Differential Revision: https://secure.phabricator.com/D17118
This commit is contained in:
epriestley 2016-12-31 09:17:58 -08:00
parent 9b4090af55
commit b373dcef74
2 changed files with 63 additions and 39 deletions

View file

@ -288,16 +288,26 @@ final class DifferentialTransactionEditor
$downgrade_accepts = true; $downgrade_accepts = true;
} }
break; break;
case DifferentialRevisionRequestReviewTransaction::TRANSACTIONTYPE:
$downgrade_rejects = true;
if ((!$is_sticky_accept) ||
($object->getStatus() != $status_plan)) {
// If the old state isn't "changes planned", downgrade the accepts.
// This exception allows an accepted revision to go through
// "Plan Changes" -> "Request Review" and return to "accepted" if
// the author didn't update the revision, essentially undoing the
// "Plan Changes".
$downgrade_accepts = true;
}
break;
// TODO: Remove this, obsoleted by ModularTransactions above.
case DifferentialTransaction::TYPE_ACTION: case DifferentialTransaction::TYPE_ACTION:
switch ($xaction->getNewValue()) { switch ($xaction->getNewValue()) {
case DifferentialAction::ACTION_REQUEST: case DifferentialAction::ACTION_REQUEST:
$downgrade_rejects = true; $downgrade_rejects = true;
if ((!$is_sticky_accept) || if ((!$is_sticky_accept) ||
($object->getStatus() != $status_plan)) { ($object->getStatus() != $status_plan)) {
// If the old state isn't "changes planned", downgrade the
// accepts. This exception allows an accepted revision to
// go through Plan Changes -> Request Review to return to
// "accepted" if the author didn't update the revision.
$downgrade_accepts = true; $downgrade_accepts = true;
} }
break; break;
@ -353,6 +363,7 @@ final class DifferentialTransactionEditor
} }
} }
$is_commandeer = false;
switch ($xaction->getTransactionType()) { switch ($xaction->getTransactionType()) {
case DifferentialTransaction::TYPE_UPDATE: case DifferentialTransaction::TYPE_UPDATE:
if ($this->getIsCloseByCommit()) { if ($this->getIsCloseByCommit()) {
@ -424,6 +435,10 @@ final class DifferentialTransactionEditor
} }
break; break;
case DifferentialRevisionCommandeerTransaction::TRANSACTIONTYPE:
$is_commandeer = true;
break;
case DifferentialTransaction::TYPE_ACTION: case DifferentialTransaction::TYPE_ACTION:
$action_type = $xaction->getNewValue(); $action_type = $xaction->getNewValue();
@ -463,41 +478,7 @@ final class DifferentialTransactionEditor
break; break;
case DifferentialAction::ACTION_CLAIM: case DifferentialAction::ACTION_CLAIM:
// If the user is commandeering, add the previous owner as a $is_commandeer = true;
// reviewer and remove the actor.
$edits = array(
'-' => array(
$actor_phid => $actor_phid,
),
);
$owner_phid = $object->getAuthorPHID();
if ($owner_phid) {
$reviewer = new DifferentialReviewerProxy(
$owner_phid,
array(
'status' => DifferentialReviewerStatus::STATUS_ADDED,
));
$edits['+'] = array(
$owner_phid => array(
'data' => $reviewer->getEdgeData(),
),
);
}
// NOTE: We're setting setIsCommandeerSideEffect() on this because
// normally you can't add a revision's author as a reviewer, but
// this action swaps them after validation executes.
$results[] = id(new DifferentialTransaction())
->setTransactionType($type_edge)
->setMetadataValue('edge:type', $edge_reviewer)
->setIgnoreOnNoEffect(true)
->setIsCommandeerSideEffect(true)
->setNewValue($edits);
break; break;
case DifferentialAction::ACTION_RESIGN: case DifferentialAction::ACTION_RESIGN:
// If the user is resigning, add a separate reviewer edit // If the user is resigning, add a separate reviewer edit
@ -519,6 +500,10 @@ final class DifferentialTransactionEditor
break; break;
} }
if ($is_commandeer) {
$results[] = $this->newCommandeerReviewerTransaction($object);
}
if (!$this->didExpandInlineState) { if (!$this->didExpandInlineState) {
switch ($xaction->getTransactionType()) { switch ($xaction->getTransactionType()) {
case PhabricatorTransactions::TYPE_COMMENT: case PhabricatorTransactions::TYPE_COMMENT:
@ -1499,6 +1484,10 @@ final class DifferentialTransactionEditor
return true; return true;
} }
break; break;
case DifferentialRevisionCommandeerTransaction::TRANSACTIONTYPE:
// When users commandeer revisions, we may need to trigger
// signatures or author-based rules.
return true;
case DifferentialTransaction::TYPE_ACTION: case DifferentialTransaction::TYPE_ACTION:
switch ($xaction->getNewValue()) { switch ($xaction->getNewValue()) {
case DifferentialAction::ACTION_CLAIM: case DifferentialAction::ACTION_CLAIM:
@ -1922,4 +1911,35 @@ final class DifferentialTransactionEditor
return $this; return $this;
} }
private function newCommandeerReviewerTransaction(
DifferentialRevision $revision) {
$actor_phid = $this->getActingAsPHID();
$owner_phid = $revision->getAuthorPHID();
// If the user is commandeering, add the previous owner as a
// reviewer and remove the actor.
$edits = array(
'-' => array(
$actor_phid,
),
'+' => array(
$owner_phid,
),
);
// NOTE: We're setting setIsCommandeerSideEffect() on this because normally
// you can't add a revision's author as a reviewer, but this action swaps
// them after validation executes.
$xaction_type = DifferentialRevisionReviewersTransaction::TRANSACTIONTYPE;
return id(new DifferentialTransaction())
->setTransactionType($xaction_type)
->setIgnoreOnNoEffect(true)
->setIsCommandeerSideEffect(true)
->setNewValue($edits);
}
} }

View file

@ -1805,6 +1805,10 @@ abstract class PhabricatorEditEngine
try { try {
$xactions = $editor->applyTransactions($object, $xactions); $xactions = $editor->applyTransactions($object, $xactions);
} catch (PhabricatorApplicationTransactionValidationException $ex) {
return id(new PhabricatorApplicationTransactionValidationResponse())
->setCancelURI($view_uri)
->setException($ex);
} catch (PhabricatorApplicationTransactionNoEffectException $ex) { } catch (PhabricatorApplicationTransactionNoEffectException $ex) {
return id(new PhabricatorApplicationTransactionNoEffectResponse()) return id(new PhabricatorApplicationTransactionNoEffectResponse())
->setCancelURI($view_uri) ->setCancelURI($view_uri)