WebKitTools/Scripts/webkitpy/tool/steps/postcodereview.py
changeset 0 4f2f89ce4247
equal deleted inserted replaced
-1:000000000000 0:4f2f89ce4247
       
     1 # Copyright (C) 2010 Google Inc. All rights reserved.
       
     2 #
       
     3 # Redistribution and use in source and binary forms, with or without
       
     4 # modification, are permitted provided that the following conditions are
       
     5 # met:
       
     6 #
       
     7 #     * Redistributions of source code must retain the above copyright
       
     8 # notice, this list of conditions and the following disclaimer.
       
     9 #     * Redistributions in binary form must reproduce the above
       
    10 # copyright notice, this list of conditions and the following disclaimer
       
    11 # in the documentation and/or other materials provided with the
       
    12 # distribution.
       
    13 #     * Neither the name of Google Inc. nor the names of its
       
    14 # contributors may be used to endorse or promote products derived from
       
    15 # this software without specific prior written permission.
       
    16 #
       
    17 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
       
    18 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
       
    19 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
       
    20 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
       
    21 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
       
    22 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
       
    23 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
       
    24 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
       
    25 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
       
    26 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
       
    27 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
       
    28 
       
    29 from webkitpy.tool.steps.abstractstep import AbstractStep
       
    30 from webkitpy.tool.steps.options import Options
       
    31 
       
    32 
       
    33 class PostCodeReview(AbstractStep):
       
    34     @classmethod
       
    35     def options(cls):
       
    36         return AbstractStep.options() + [
       
    37             Options.cc,
       
    38             Options.description,
       
    39         ]
       
    40 
       
    41     def run(self, state):
       
    42         patch = state.get("patch")
       
    43         bug_id = patch.bug_id()
       
    44         title = patch.name()
       
    45 
       
    46         # If the issue already exists, then the message becomes the label
       
    47         # of the new patch. Otherwise, it becomes the title of the whole
       
    48         # issue.
       
    49         if title:
       
    50             # This is the common case for the the first "upload" command.
       
    51             message = title
       
    52         elif bug_id:
       
    53             # This is the common case for the "post" command and
       
    54             # subsequent runs of the "upload" command.
       
    55             message = "Code review for %s" % self._tool.bugs.bug_url_for_bug_id(bug_id)
       
    56         else:
       
    57             # Unreachable with our current commands, but we might hit
       
    58             # this case if we support bug-less code reviews.
       
    59             message = "Code review"
       
    60 
       
    61         # Use the bug ID as the rietveld issue number. This means rietveld code reviews
       
    62         # when there are multiple different patches on a bug will be a bit wonky, but
       
    63         # webkit-patch assumes one-patch-per-bug.
       
    64         created_issue = self._tool.codereview.post(diff=self.cached_lookup(state, "diff"),
       
    65                                                    message=message,
       
    66                                                    codereview_issue=bug_id,
       
    67                                                    cc=self._options.cc)
       
    68 
       
    69         self._tool.bugs.set_flag_on_attachment(patch.id(), 'in-rietveld', '+')