Commit e4efd51b authored by apavlov@chromium.org's avatar apavlov@chromium.org

Extend the git-cl-comments command functionality

The "comments" command is taught to:
- accept an arbitrary review issue id;
- post comments on the current or specified review issue.

This is required for the auto-rebaseline bot to notify a
rebaseline requestor of the fact that the rebaseline has happened
by means of posting a comment to the review issue that requested
the rebaseline, as suggested by iannucci@.

R=iannucci, szager, dpranke

Review URL: https://codereview.chromium.org/693873002

git-svn-id: svn://svn.chromium.org/chrome/trunk/tools/depot_tools@292844 0039d316-1c4b-4281-b951-d872f2087c98
parent 43b48640
...@@ -787,6 +787,9 @@ or verify this branch is set up to track another (via the --track argument to ...@@ -787,6 +787,9 @@ or verify this branch is set up to track another (via the --track argument to
def GetApprovingReviewers(self): def GetApprovingReviewers(self):
return get_approving_reviewers(self.GetIssueProperties()) return get_approving_reviewers(self.GetIssueProperties())
def AddComment(self, message):
return self.RpcServer().add_comment(self.GetIssue(), message)
def SetIssue(self, issue): def SetIssue(self, issue):
"""Set this branch's issue. If issue=0, clears the issue.""" """Set this branch's issue. If issue=0, clears the issue."""
if issue: if issue:
...@@ -1438,13 +1441,26 @@ def CMDissue(parser, args): ...@@ -1438,13 +1441,26 @@ def CMDissue(parser, args):
def CMDcomments(parser, args): def CMDcomments(parser, args):
"""Shows review comments of the current changelist.""" """Shows or posts review comments for any changelist."""
(_, args) = parser.parse_args(args) parser.add_option('-a', '--add-comment', dest='comment',
if args: help='comment to add to an issue')
parser.error('Unsupported argument: %s' % args) parser.add_option('-i', dest='issue',
help="review issue id (defaults to current issue)")
options, args = parser.parse_args(args)
issue = None
if options.issue:
try:
issue = int(options.issue)
except ValueError:
DieWithError('A review issue id is expected to be a number')
cl = Changelist(issue=issue)
if options.comment:
cl.AddComment(options.comment)
return 0
cl = Changelist()
if cl.GetIssue():
data = cl.GetIssueProperties() data = cl.GetIssueProperties()
for message in sorted(data['messages'], key=lambda x: x['date']): for message in sorted(data['messages'], key=lambda x: x['date']):
if message['disapproval']: if message['disapproval']:
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment