From bb05ddfb5a6e04168fdeb4d28020e148e2516947 Mon Sep 17 00:00:00 2001 From: Marek Sapota Date: Tue, 25 Oct 2011 20:03:41 -0700 Subject: [PATCH] Allow anyone to run `arc commit` on an accepted revision Test Plan: Using SVN make some changes to the repo, run `arc diff`. As other user accept the revision, add the changes to your repo using `arc patch` and then run `arc commit --revision revisionID` to commit them. Arcanist should ask if you are sure that you want to commit this revision and if you answer `Y` it should commit to SNV repo. Reviewers: epriestley, jungejason Reviewed By: epriestley CC: aran, mareksapota, epriestley Differential Revision: 1055 --- .../commit/ArcanistCommitWorkflow.php | 98 +++++++++++++------ .../ArcanistMarkCommittedWorkflow.php | 2 +- 2 files changed, 71 insertions(+), 29 deletions(-) diff --git a/src/workflow/commit/ArcanistCommitWorkflow.php b/src/workflow/commit/ArcanistCommitWorkflow.php index 27b29aa5..d40a837d 100644 --- a/src/workflow/commit/ArcanistCommitWorkflow.php +++ b/src/workflow/commit/ArcanistCommitWorkflow.php @@ -68,33 +68,63 @@ EOTEXT $repository_api = $this->getRepositoryAPI(); $conduit = $this->getConduit(); - $revision_data = $conduit->callMethodSynchronous( - 'differential.find', - array( - 'query' => 'committable', - 'guids' => array( - $this->getUserPHID(), - ), - )); + $revision_id = $this->getArgument('revision'); - try { - $revision_id = $this->getArgument('revision'); - $revision = $this->chooseRevision( - $revision_data, - $revision_id, - 'Which revision do you want to commit?'); - } catch (ArcanistChooseInvalidRevisionException $ex) { - throw new ArcanistUsageException( - "Revision D{$revision_id} is not committable. You can only commit ". - "revisions you own which have been 'accepted'."); - } catch (ArcanistChooseNoRevisionsException $ex) { - throw new ArcanistUsageException( - "You have no committable Differential revisions. You can only commit ". - "revisions you own which have been 'accepted'."); + if (!$revision_id) { + $revision_data = $conduit->callMethodSynchronous( + 'differential.find', + array( + 'query' => 'committable', + 'guids' => array( + $this->getUserPHID(), + ), + ) + ); + + try { + $revision = $this->chooseRevision( + $revision_data, + null, + 'Which revision do you want to commit?' + ); + $revision_id = $revision->getID(); + } catch (ArcanistChooseNoRevisionsException $ex) { + throw new ArcanistUsageException( + "You have no committable Differential revisions. You can only ". + "commit revisions which have been 'accepted'."); + } } - $revision_id = $revision->getID(); - $revision_name = $revision->getName(); + $revision = null; + try { + $revision = $conduit->callMethodSynchronous( + 'differential.getrevision', + array( + 'revision_id' => $revision_id, + ) + ); + } catch (Exception $ex) { + throw new ArcanistUsageException( + "Revision D{$revision_id} does not exist." + ); + } + + if ($revision['statusName'] != 'Accepted') { + throw new ArcanistUsageException( + "Revision D{$revision_id} is not committable. You can only commit ". + "revisions which have been 'accepted'." + ); + } + + if ($revision['authorPHID'] != $this->getUserPHID()) { + $prompt = "You are not the author of revision D{$revision_id}, ". + 'are you sure you want to commit it?'; + if (!phutil_console_confirm($prompt)) { + throw new ArcanistUserAbortException(); + } + } + + $revision_name = $revision['title']; $message = $conduit->callMethodSynchronous( 'differential.getcommitmessage', @@ -140,8 +170,7 @@ EOTEXT return $err; } - protected function getCommitFileList( - ArcanistDifferentialRevisionRef $revision) { + protected function getCommitFileList(array $revision) { $repository_api = $this->getRepositoryAPI(); if (!($repository_api instanceof ArcanistSubversionAPI)) { @@ -151,9 +180,22 @@ EOTEXT $conduit = $this->getConduit(); - $revision_id = $revision->getID(); + $revision_id = $revision['id']; + + $revision = reset($conduit->callMethodSynchronous( + 'differential.find', + array( + 'query' => 'revision-ids', + 'guids' => array($revision_id,) + ) + )); + if (!$revision) { + throw new ArcanistUsageException( + "Revision D{$revision_id} does not exist." + ); + } + $revision_source = $revision['sourcePath']; - $revision_source = $revision->getSourcePath(); $working_copy = $repository_api->getPath(); if ($revision_source != $working_copy) { $prompt = diff --git a/src/workflow/mark-committed/ArcanistMarkCommittedWorkflow.php b/src/workflow/mark-committed/ArcanistMarkCommittedWorkflow.php index bcfaa9b7..654b9718 100644 --- a/src/workflow/mark-committed/ArcanistMarkCommittedWorkflow.php +++ b/src/workflow/mark-committed/ArcanistMarkCommittedWorkflow.php @@ -106,7 +106,7 @@ EOTEXT } if ($revision) { - if ($revision['authorPHID'] != $this->getUserPHID()) { + if (!$is_finalize && $revision['authorPHID'] != $this->getUserPHID()) { $prompt = "You are not the author of revision D{$revision_id}, ". 'are you sure you want to mark it committed?'; if (!phutil_console_confirm($prompt)) {