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

Fixes T6637, "closing by commit" should update task status and specify responsible commit, but drop the artificial comment.

Summary: When updating the status of a task via commit, transaction should show responsible commit and status update if it was changed.

Test Plan: Push a commit "Fixes Txx", transaction should include status update and commit number.

Reviewers: #blessed_reviewers, epriestley

Reviewed By: #blessed_reviewers, epriestley

Subscribers: Korvin, epriestley

Maniphest Tasks: T6637

Differential Revision: https://secure.phabricator.com/D11230
This commit is contained in:
lkassianik 2015-01-05 16:22:07 -08:00 committed by epriestley
parent ad1da6ec5e
commit 204ae221d2
2 changed files with 121 additions and 41 deletions

View file

@ -114,6 +114,12 @@ final class ManiphestTransaction
$phids[] = $phid; $phids[] = $phid;
} }
break; break;
case self::TYPE_STATUS:
$commit_phid = $this->getMetadataValue('commitPHID');
if ($commit_phid) {
$phids[] = $commit_phid;
}
break;
} }
return $phids; return $phids;
@ -121,6 +127,16 @@ final class ManiphestTransaction
public function shouldHide() { public function shouldHide() {
switch ($this->getTransactionType()) { switch ($this->getTransactionType()) {
case PhabricatorTransactions::TYPE_EDGE:
$commit_phid = $this->getMetadataValue('commitPHID');
$edge_type = $this->getMetadataValue('edge:type');
if ($edge_type == ManiphestTaskHasCommitEdgeType::EDGECONST) {
if ($commit_phid) {
return true;
}
}
break;
case self::TYPE_DESCRIPTION: case self::TYPE_DESCRIPTION:
case self::TYPE_PRIORITY: case self::TYPE_PRIORITY:
case self::TYPE_STATUS: case self::TYPE_STATUS:
@ -385,28 +401,62 @@ final class ManiphestTransaction
$old_name = ManiphestTaskStatus::getTaskStatusName($old); $old_name = ManiphestTaskStatus::getTaskStatusName($old);
$new_name = ManiphestTaskStatus::getTaskStatusName($new); $new_name = ManiphestTaskStatus::getTaskStatusName($new);
$commit_phid = $this->getMetadataValue('commitPHID');
if ($new_closed && !$old_closed) { if ($new_closed && !$old_closed) {
if ($new == ManiphestTaskStatus::getDuplicateStatus()) { if ($new == ManiphestTaskStatus::getDuplicateStatus()) {
if ($commit_phid) {
return pht(
'%s closed this task as a duplicate by committing %s.',
$this->renderHandleLink($author_phid),
$this->renderHandleLink($commit_phid));
} else {
return pht(
'%s closed this task as a duplicate.',
$this->renderHandleLink($author_phid));
}
} else {
if ($commit_phid) {
return pht(
'%s closed this task as "%s" by committing %s.',
$this->renderHandleLink($author_phid),
$new_name,
$this->renderHandleLink($commit_phid));
} else {
return pht(
'%s closed this task as "%s".',
$this->renderHandleLink($author_phid),
$new_name);
}
}
} else if (!$new_closed && $old_closed) {
if ($commit_phid) {
return pht( return pht(
'%s closed this task as a duplicate.', '%s reopened this task as "%s" by committing %s.',
$this->renderHandleLink($author_phid)); $this->renderHandleLink($author_phid),
$new_name,
$this->renderHandleLink($commit_phid));
} else { } else {
return pht( return pht(
'%s closed this task as "%s".', '%s reopened this task as "%s".',
$this->renderHandleLink($author_phid), $this->renderHandleLink($author_phid),
$new_name); $new_name);
} }
} else if (!$new_closed && $old_closed) {
return pht(
'%s reopened this task as "%s".',
$this->renderHandleLink($author_phid),
$new_name);
} else { } else {
return pht( if ($commit_phid) {
'%s changed the task status from "%s" to "%s".', return pht(
$this->renderHandleLink($author_phid), '%s changed the task status from "%s" to "%s" by committing %s.',
$old_name, $this->renderHandleLink($author_phid),
$new_name); $old_name,
$new_name,
$this->renderHandleLink($commit_phid));
} else {
return pht(
'%s changed the task status from "%s" to "%s".',
$this->renderHandleLink($author_phid),
$old_name,
$new_name);
}
} }
case self::TYPE_UNBLOCK: case self::TYPE_UNBLOCK:
@ -590,32 +640,70 @@ final class ManiphestTransaction
$old_name = ManiphestTaskStatus::getTaskStatusName($old); $old_name = ManiphestTaskStatus::getTaskStatusName($old);
$new_name = ManiphestTaskStatus::getTaskStatusName($new); $new_name = ManiphestTaskStatus::getTaskStatusName($new);
$commit_phid = $this->getMetadataValue('commitPHID');
if ($new_closed && !$old_closed) { if ($new_closed && !$old_closed) {
if ($new == ManiphestTaskStatus::getDuplicateStatus()) { if ($new == ManiphestTaskStatus::getDuplicateStatus()) {
if ($commit_phid) {
return pht(
'%s closed %s as a duplicate by committing %s.',
$this->renderHandleLink($author_phid),
$this->renderHandleLink($object_phid),
$this->renderHandleLink($commit_phid));
} else {
return pht(
'%s closed %s as a duplicate.',
$this->renderHandleLink($author_phid),
$this->renderHandleLink($object_phid));
}
} else {
if ($commit_phid) {
return pht(
'%s closed %s as "%s" by committing %s.',
$this->renderHandleLink($author_phid),
$this->renderHandleLink($object_phid),
$new_name,
$this->renderHandleLink($commit_phid));
} else {
return pht(
'%s closed %s as "%s".',
$this->renderHandleLink($author_phid),
$this->renderHandleLink($object_phid),
$new_name);
}
}
} else if (!$new_closed && $old_closed) {
if ($commit_phid) {
return pht( return pht(
'%s closed %s as a duplicate.', '%s reopened %s as "%s" by committing %s.',
$this->renderHandleLink($author_phid), $this->renderHandleLink($author_phid),
$this->renderHandleLink($object_phid)); $this->renderHandleLink($object_phid),
$new_name,
$this->renderHandleLink($commit_phid));
} else { } else {
return pht( return pht(
'%s closed %s as "%s".', '%s reopened %s as "%s".',
$this->renderHandleLink($author_phid), $this->renderHandleLink($author_phid),
$this->renderHandleLink($object_phid), $this->renderHandleLink($object_phid),
$new_name); $new_name);
} }
} else if (!$new_closed && $old_closed) {
return pht(
'%s reopened %s as "%s".',
$this->renderHandleLink($author_phid),
$this->renderHandleLink($object_phid),
$new_name);
} else { } else {
return pht( if ($commit_phid) {
'%s changed the status of %s from "%s" to "%s".', return pht(
$this->renderHandleLink($author_phid), '%s changed the status of %s from "%s" to "%s" by committing %s.',
$this->renderHandleLink($object_phid), $this->renderHandleLink($author_phid),
$old_name, $this->renderHandleLink($object_phid),
$new_name); $old_name,
$new_name,
$this->renderHandleLink($commit_phid));
} else {
return pht(
'%s changed the status of %s from "%s" to "%s".',
$this->renderHandleLink($author_phid),
$this->renderHandleLink($object_phid),
$old_name,
$new_name);
}
} }
case self::TYPE_UNBLOCK: case self::TYPE_UNBLOCK:

View file

@ -466,7 +466,7 @@ abstract class PhabricatorRepositoryCommitMessageParserWorker
$xactions = array(); $xactions = array();
$edge_type = ManiphestTaskHasCommitEdgeType::EDGECONST; $edge_type = ManiphestTaskHasCommitEdgeType::EDGECONST;
$xactions[] = id(new ManiphestTransaction()) $edge_xaction = id(new ManiphestTransaction())
->setTransactionType(PhabricatorTransactions::TYPE_EDGE) ->setTransactionType(PhabricatorTransactions::TYPE_EDGE)
->setMetadataValue('edge:type', $edge_type) ->setMetadataValue('edge:type', $edge_type)
->setNewValue( ->setNewValue(
@ -481,23 +481,15 @@ abstract class PhabricatorRepositoryCommitMessageParserWorker
if ($task->getStatus() != $status) { if ($task->getStatus() != $status) {
$xactions[] = id(new ManiphestTransaction()) $xactions[] = id(new ManiphestTransaction())
->setTransactionType(ManiphestTransaction::TYPE_STATUS) ->setTransactionType(ManiphestTransaction::TYPE_STATUS)
->setMetadataValue('commitPHID', $commit->getPHID())
->setNewValue($status); ->setNewValue($status);
$commit_name = $repository->formatCommitName( $edge_xaction->setMetadataValue('commitPHID', $commit->getPHID());
$commit->getCommitIdentifier());
$status_message = pht(
'Closed by commit %s.',
$commit_name);
$xactions[] = id(new ManiphestTransaction())
->setTransactionType(PhabricatorTransactions::TYPE_COMMENT)
->attachComment(
id(new ManiphestTransactionComment())
->setContent($status_message));
} }
} }
$xactions[] = $edge_xaction;
$content_source = PhabricatorContentSource::newForSource( $content_source = PhabricatorContentSource::newForSource(
PhabricatorContentSource::SOURCE_DAEMON, PhabricatorContentSource::SOURCE_DAEMON,
array()); array());