• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# Copyright (C) 2009 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
29from webkitpy.thirdparty.mock import Mock
30from webkitpy.tool.commands.commandtest import CommandsTest
31from webkitpy.tool.commands.upload import *
32from webkitpy.tool.mocktool import MockOptions, MockTool
33
34class UploadCommandsTest(CommandsTest):
35    def test_commit_message_for_current_diff(self):
36        tool = MockTool()
37        expected_stdout = "This is a fake commit message that is at least 50 characters.\n"
38        self.assert_execute_outputs(CommitMessageForCurrentDiff(), [], expected_stdout=expected_stdout, tool=tool)
39
40    def test_clean_pending_commit(self):
41        self.assert_execute_outputs(CleanPendingCommit(), [])
42
43    def test_assign_to_committer(self):
44        tool = MockTool()
45        expected_stderr = "Warning, attachment 128 on bug 42 has invalid committer (non-committer@example.com)\nBug 77 is already assigned to foo@foo.com (None).\nBug 76 has no non-obsolete patches, ignoring.\n"
46        self.assert_execute_outputs(AssignToCommitter(), [], expected_stderr=expected_stderr, tool=tool)
47        tool.bugs.reassign_bug.assert_called_with(42, "eric@webkit.org", "Attachment 128 was posted by a committer and has review+, assigning to Eric Seidel for commit.")
48
49    def test_obsolete_attachments(self):
50        expected_stderr = "Obsoleting 2 old patches on bug 42\n"
51        self.assert_execute_outputs(ObsoleteAttachments(), [42], expected_stderr=expected_stderr)
52
53    def test_post(self):
54        options = MockOptions()
55        options.cc = None
56        options.check_style = True
57        options.comment = None
58        options.description = "MOCK description"
59        options.request_commit = False
60        options.review = True
61        options.suggest_reviewers = False
62        expected_stderr = """MOCK: user.open_url: file://...
63Was that diff correct?
64Obsoleting 2 old patches on bug 42
65MOCK add_patch_to_bug: bug_id=42, description=MOCK description, mark_for_review=True, mark_for_commit_queue=False, mark_for_landing=False
66MOCK: user.open_url: http://example.com/42
67"""
68        self.assert_execute_outputs(Post(), [42], options=options, expected_stderr=expected_stderr)
69
70    def test_attach_to_bug(self):
71        options = MockOptions()
72        options.comment = "extra comment"
73        options.description = "file description"
74        expected_stderr = """MOCK add_attachment_to_bug: bug_id=42, description=file description filename=None
75-- Begin comment --
76extra comment
77-- End comment --
78"""
79        self.assert_execute_outputs(AttachToBug(), [42, "path/to/file.txt", "file description"], options=options, expected_stderr=expected_stderr)
80
81    def test_attach_to_bug_no_description_or_comment(self):
82        options = MockOptions()
83        options.comment = None
84        options.description = None
85        expected_stderr = """MOCK add_attachment_to_bug: bug_id=42, description=file.txt filename=None
86"""
87        self.assert_execute_outputs(AttachToBug(), [42, "path/to/file.txt"], options=options, expected_stderr=expected_stderr)
88
89    def test_land_safely(self):
90        expected_stderr = "Obsoleting 2 old patches on bug 42\nMOCK add_patch_to_bug: bug_id=42, description=Patch for landing, mark_for_review=False, mark_for_commit_queue=False, mark_for_landing=True\n"
91        self.assert_execute_outputs(LandSafely(), [42], expected_stderr=expected_stderr)
92
93    def test_prepare_diff_with_arg(self):
94        self.assert_execute_outputs(Prepare(), [42])
95
96    def test_prepare(self):
97        expected_stderr = "MOCK create_bug\nbug_title: Mock user response\nbug_description: Mock user response\ncomponent: MOCK component\ncc: MOCK cc\n"
98        self.assert_execute_outputs(Prepare(), [], expected_stderr=expected_stderr)
99
100    def test_upload(self):
101        options = MockOptions()
102        options.cc = None
103        options.check_style = True
104        options.comment = None
105        options.description = "MOCK description"
106        options.request_commit = False
107        options.review = True
108        options.suggest_reviewers = False
109        expected_stderr = """MOCK: user.open_url: file://...
110Was that diff correct?
111Obsoleting 2 old patches on bug 42
112MOCK add_patch_to_bug: bug_id=42, description=MOCK description, mark_for_review=True, mark_for_commit_queue=False, mark_for_landing=False
113MOCK: user.open_url: http://example.com/42
114"""
115        self.assert_execute_outputs(Upload(), [42], options=options, expected_stderr=expected_stderr)
116
117    def test_mark_bug_fixed(self):
118        tool = MockTool()
119        tool._scm.last_svn_commit_log = lambda: "r9876 |"
120        options = Mock()
121        options.bug_id = 42
122        options.comment = "MOCK comment"
123        expected_stderr = """Bug: <http://example.com/42> Bug with two r+'d and cq+'d patches, one of which has an invalid commit-queue setter.
124Revision: 9876
125MOCK: user.open_url: http://example.com/42
126Is this correct?
127Adding comment to Bug 42.
128MOCK bug comment: bug_id=42, cc=None
129--- Begin comment ---
130MOCK comment
131
132Committed r9876: <http://trac.webkit.org/changeset/9876>
133--- End comment ---
134
135"""
136        self.assert_execute_outputs(MarkBugFixed(), [], expected_stderr=expected_stderr, tool=tool, options=options)
137
138    def test_edit_changelog(self):
139        self.assert_execute_outputs(EditChangeLogs(), [])
140