annotate llvm/docs/Phabricator.rst @ 164:fdfabb438fbf

...
author anatofuz
date Thu, 19 Mar 2020 17:02:53 +0900
parents 1d019706d866
children 0572611fdcc8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 .. _phabricator-reviews:
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 =============================
anatofuz
parents:
diff changeset
4 Code Reviews with Phabricator
anatofuz
parents:
diff changeset
5 =============================
anatofuz
parents:
diff changeset
6
anatofuz
parents:
diff changeset
7 .. contents::
anatofuz
parents:
diff changeset
8 :local:
anatofuz
parents:
diff changeset
9
anatofuz
parents:
diff changeset
10 If you prefer to use a web user interface for code reviews, you can now submit
anatofuz
parents:
diff changeset
11 your patches for Clang and LLVM at `LLVM's Phabricator`_ instance.
anatofuz
parents:
diff changeset
12
anatofuz
parents:
diff changeset
13 While Phabricator is a useful tool for some, the relevant -commits mailing list
anatofuz
parents:
diff changeset
14 is the system of record for all LLVM code review. The mailing list should be
anatofuz
parents:
diff changeset
15 added as a subscriber on all reviews, and Phabricator users should be prepared
anatofuz
parents:
diff changeset
16 to respond to free-form comments in mail sent to the commits list.
anatofuz
parents:
diff changeset
17
anatofuz
parents:
diff changeset
18 Sign up
anatofuz
parents:
diff changeset
19 -------
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 To get started with Phabricator, navigate to `https://reviews.llvm.org`_ and
anatofuz
parents:
diff changeset
22 click the power icon in the top right. You can register with a GitHub account,
anatofuz
parents:
diff changeset
23 a Google account, or you can create your own profile.
anatofuz
parents:
diff changeset
24
anatofuz
parents:
diff changeset
25 Make *sure* that the email address registered with Phabricator is subscribed
anatofuz
parents:
diff changeset
26 to the relevant -commits mailing list. If you are not subscribed to the commit
anatofuz
parents:
diff changeset
27 list, all mail sent by Phabricator on your behalf will be held for moderation.
anatofuz
parents:
diff changeset
28
anatofuz
parents:
diff changeset
29 Note that if you use your git user name as Phabricator user name,
anatofuz
parents:
diff changeset
30 Phabricator will automatically connect your submits to your Phabricator user in
anatofuz
parents:
diff changeset
31 the `Code Repository Browser`_.
anatofuz
parents:
diff changeset
32
anatofuz
parents:
diff changeset
33 Requesting a review via the command line
anatofuz
parents:
diff changeset
34 ----------------------------------------
anatofuz
parents:
diff changeset
35
anatofuz
parents:
diff changeset
36 Phabricator has a tool called *Arcanist* to upload patches from
anatofuz
parents:
diff changeset
37 the command line. To get you set up, follow the
anatofuz
parents:
diff changeset
38 `Arcanist Quick Start`_ instructions.
anatofuz
parents:
diff changeset
39
anatofuz
parents:
diff changeset
40 You can learn more about how to use arc to interact with
anatofuz
parents:
diff changeset
41 Phabricator in the `Arcanist User Guide`_.
anatofuz
parents:
diff changeset
42
anatofuz
parents:
diff changeset
43 .. _phabricator-request-review-web:
anatofuz
parents:
diff changeset
44
anatofuz
parents:
diff changeset
45 Requesting a review via the web interface
anatofuz
parents:
diff changeset
46 -----------------------------------------
anatofuz
parents:
diff changeset
47
anatofuz
parents:
diff changeset
48 The tool to create and review patches in Phabricator is called
anatofuz
parents:
diff changeset
49 *Differential*.
anatofuz
parents:
diff changeset
50
anatofuz
parents:
diff changeset
51 Note that you can upload patches created through git.
anatofuz
parents:
diff changeset
52 To make reviews easier, please always include **as much context as
anatofuz
parents:
diff changeset
53 possible** with your diff! Don't worry, Phabricator
anatofuz
parents:
diff changeset
54 will automatically send a diff with a smaller context in the review
anatofuz
parents:
diff changeset
55 email, but having the full file in the web interface will help the
anatofuz
parents:
diff changeset
56 reviewer understand your code.
anatofuz
parents:
diff changeset
57
anatofuz
parents:
diff changeset
58 To get a full diff, use one of the following commands (or just use Arcanist
anatofuz
parents:
diff changeset
59 to upload your patch):
anatofuz
parents:
diff changeset
60
anatofuz
parents:
diff changeset
61 * ``git show HEAD -U999999 > mypatch.patch``
anatofuz
parents:
diff changeset
62 * ``git format-patch -U999999 @{u}``
anatofuz
parents:
diff changeset
63
anatofuz
parents:
diff changeset
64 Before uploading your patch, please make sure it is formatted properly, as
anatofuz
parents:
diff changeset
65 described in :ref:`How to Submit a Patch <format patches>`.
anatofuz
parents:
diff changeset
66
anatofuz
parents:
diff changeset
67 To upload a new patch:
anatofuz
parents:
diff changeset
68
anatofuz
parents:
diff changeset
69 * Click *Differential*.
anatofuz
parents:
diff changeset
70 * Click *+ Create Diff*.
anatofuz
parents:
diff changeset
71 * Paste the text diff or browse to the patch file. Click *Create Diff*.
anatofuz
parents:
diff changeset
72 * Leave this first Repository field blank. (We'll fill in the Repository
anatofuz
parents:
diff changeset
73 later, when sending the review.)
anatofuz
parents:
diff changeset
74 * Leave the drop down on *Create a new Revision...* and click *Continue*.
anatofuz
parents:
diff changeset
75 * Enter a descriptive title and summary. The title and summary are usually
anatofuz
parents:
diff changeset
76 in the form of a :ref:`commit message <commit messages>`.
anatofuz
parents:
diff changeset
77 * Add reviewers (see below for advice). (If you set the Repository field
anatofuz
parents:
diff changeset
78 correctly, llvm-commits or cfe-commits will be subscribed automatically;
anatofuz
parents:
diff changeset
79 otherwise, you will have to manually subscribe them.)
anatofuz
parents:
diff changeset
80 * In the Repository field, enter the name of the project (LLVM, Clang,
anatofuz
parents:
diff changeset
81 etc.) to which the review should be sent.
anatofuz
parents:
diff changeset
82 * Click *Save*.
anatofuz
parents:
diff changeset
83
anatofuz
parents:
diff changeset
84 To submit an updated patch:
anatofuz
parents:
diff changeset
85
anatofuz
parents:
diff changeset
86 * Click *Differential*.
anatofuz
parents:
diff changeset
87 * Click *+ Create Diff*.
anatofuz
parents:
diff changeset
88 * Paste the updated diff or browse to the updated patch file. Click *Create Diff*.
anatofuz
parents:
diff changeset
89 * Select the review you want to from the *Attach To* dropdown and click
anatofuz
parents:
diff changeset
90 *Continue*.
anatofuz
parents:
diff changeset
91 * Leave the Repository field blank. (We previously filled out the Repository
anatofuz
parents:
diff changeset
92 for the review request.)
anatofuz
parents:
diff changeset
93 * Add comments about the changes in the new diff. Click *Save*.
anatofuz
parents:
diff changeset
94
anatofuz
parents:
diff changeset
95 Choosing reviewers: You typically pick one or two people as initial reviewers.
anatofuz
parents:
diff changeset
96 This choice is not crucial, because you are merely suggesting and not requiring
anatofuz
parents:
diff changeset
97 them to participate. Many people will see the email notification on cfe-commits
anatofuz
parents:
diff changeset
98 or llvm-commits, and if the subject line suggests the patch is something they
anatofuz
parents:
diff changeset
99 should look at, they will.
anatofuz
parents:
diff changeset
100
anatofuz
parents:
diff changeset
101
anatofuz
parents:
diff changeset
102 .. _finding-potential-reviewers:
anatofuz
parents:
diff changeset
103
anatofuz
parents:
diff changeset
104 Finding potential reviewers
anatofuz
parents:
diff changeset
105 ---------------------------
anatofuz
parents:
diff changeset
106
anatofuz
parents:
diff changeset
107 Here are a couple of ways to pick the initial reviewer(s):
anatofuz
parents:
diff changeset
108
anatofuz
parents:
diff changeset
109 * Use ``git blame`` and the commit log to find names of people who have
anatofuz
parents:
diff changeset
110 recently modified the same area of code that you are modifying.
anatofuz
parents:
diff changeset
111 * Look in CODE_OWNERS.TXT to see who might be responsible for that area.
anatofuz
parents:
diff changeset
112 * If you've discussed the change on a dev list, the people who participated
anatofuz
parents:
diff changeset
113 might be appropriate reviewers.
anatofuz
parents:
diff changeset
114
anatofuz
parents:
diff changeset
115 Even if you think the code owner is the busiest person in the world, it's still
anatofuz
parents:
diff changeset
116 okay to put them as a reviewer. Being the code owner means they have accepted
anatofuz
parents:
diff changeset
117 responsibility for making sure the review happens.
anatofuz
parents:
diff changeset
118
anatofuz
parents:
diff changeset
119 Reviewing code with Phabricator
anatofuz
parents:
diff changeset
120 -------------------------------
anatofuz
parents:
diff changeset
121
anatofuz
parents:
diff changeset
122 Phabricator allows you to add inline comments as well as overall comments
anatofuz
parents:
diff changeset
123 to a revision. To add an inline comment, select the lines of code you want
anatofuz
parents:
diff changeset
124 to comment on by clicking and dragging the line numbers in the diff pane.
anatofuz
parents:
diff changeset
125 When you have added all your comments, scroll to the bottom of the page and
anatofuz
parents:
diff changeset
126 click the Submit button.
anatofuz
parents:
diff changeset
127
anatofuz
parents:
diff changeset
128 You can add overall comments in the text box at the bottom of the page.
anatofuz
parents:
diff changeset
129 When you're done, click the Submit button.
anatofuz
parents:
diff changeset
130
anatofuz
parents:
diff changeset
131 Phabricator has many useful features, for example allowing you to select
anatofuz
parents:
diff changeset
132 diffs between different versions of the patch as it was reviewed in the
anatofuz
parents:
diff changeset
133 *Revision Update History*. Most features are self descriptive - explore, and
anatofuz
parents:
diff changeset
134 if you have a question, drop by on #llvm in IRC to get help.
anatofuz
parents:
diff changeset
135
anatofuz
parents:
diff changeset
136 Note that as e-mail is the system of reference for code reviews, and some
anatofuz
parents:
diff changeset
137 people prefer it over a web interface, we do not generate automated mail
anatofuz
parents:
diff changeset
138 when a review changes state, for example by clicking "Accept Revision" in
anatofuz
parents:
diff changeset
139 the web interface. Thus, please type LGTM into the comment box to accept
anatofuz
parents:
diff changeset
140 a change from Phabricator.
anatofuz
parents:
diff changeset
141
anatofuz
parents:
diff changeset
142 Committing a change
anatofuz
parents:
diff changeset
143 -------------------
anatofuz
parents:
diff changeset
144
anatofuz
parents:
diff changeset
145 Once a patch has been reviewed and approved on Phabricator it can then be
anatofuz
parents:
diff changeset
146 committed to trunk. If you do not have commit access, someone has to
anatofuz
parents:
diff changeset
147 commit the change for you (with attribution). It is sufficient to add
anatofuz
parents:
diff changeset
148 a comment to the approved review indicating you cannot commit the patch
anatofuz
parents:
diff changeset
149 yourself. If you have commit access, there are multiple workflows to commit the
anatofuz
parents:
diff changeset
150 change. Whichever method you follow it is recommended that your commit message
anatofuz
parents:
diff changeset
151 ends with the line:
anatofuz
parents:
diff changeset
152
anatofuz
parents:
diff changeset
153 ::
anatofuz
parents:
diff changeset
154
anatofuz
parents:
diff changeset
155 Differential Revision: <URL>
anatofuz
parents:
diff changeset
156
anatofuz
parents:
diff changeset
157 where ``<URL>`` is the URL for the code review, starting with
anatofuz
parents:
diff changeset
158 ``https://reviews.llvm.org/``.
anatofuz
parents:
diff changeset
159
anatofuz
parents:
diff changeset
160 This allows people reading the version history to see the review for
anatofuz
parents:
diff changeset
161 context. This also allows Phabricator to detect the commit, close the
anatofuz
parents:
diff changeset
162 review, and add a link from the review to the commit.
anatofuz
parents:
diff changeset
163
anatofuz
parents:
diff changeset
164 Note that if you use the Arcanist tool the ``Differential Revision`` line will
anatofuz
parents:
diff changeset
165 be added automatically. If you don't want to use Arcanist, you can add the
anatofuz
parents:
diff changeset
166 ``Differential Revision`` line (as the last line) to the commit message
anatofuz
parents:
diff changeset
167 yourself.
anatofuz
parents:
diff changeset
168
anatofuz
parents:
diff changeset
169 Using the Arcanist tool can simplify the process of committing reviewed code as
anatofuz
parents:
diff changeset
170 it will retrieve reviewers, the ``Differential Revision``, etc from the review
anatofuz
parents:
diff changeset
171 and place it in the commit message. You may also commit an accepted change
anatofuz
parents:
diff changeset
172 directly using ``git llvm push``, per the section in the :ref:`getting started
anatofuz
parents:
diff changeset
173 guide <commit_from_git>`.
anatofuz
parents:
diff changeset
174
anatofuz
parents:
diff changeset
175 Note that if you commit the change without using Arcanist and forget to add the
anatofuz
parents:
diff changeset
176 ``Differential Revision`` line to your commit message then it is recommended
anatofuz
parents:
diff changeset
177 that you close the review manually. In the web UI, under "Leap Into Action" put
anatofuz
parents:
diff changeset
178 the git revision number in the Comment, set the Action to "Close Revision" and
anatofuz
parents:
diff changeset
179 click Submit. Note the review must have been Accepted first.
anatofuz
parents:
diff changeset
180
anatofuz
parents:
diff changeset
181
anatofuz
parents:
diff changeset
182 Committing someone's change from Phabricator
anatofuz
parents:
diff changeset
183 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
anatofuz
parents:
diff changeset
184
anatofuz
parents:
diff changeset
185 On a clean Git repository on an up to date ``master`` branch run the
anatofuz
parents:
diff changeset
186 following (where ``<Revision>`` is the Phabricator review number):
anatofuz
parents:
diff changeset
187
anatofuz
parents:
diff changeset
188 ::
anatofuz
parents:
diff changeset
189
anatofuz
parents:
diff changeset
190 arc patch D<Revision>
anatofuz
parents:
diff changeset
191
anatofuz
parents:
diff changeset
192
anatofuz
parents:
diff changeset
193 This will create a new branch called ``arcpatch-D<Revision>`` based on the
anatofuz
parents:
diff changeset
194 current ``master`` and will create a commit corresponding to ``D<Revision>`` with a
anatofuz
parents:
diff changeset
195 commit message derived from information in the Phabricator review.
anatofuz
parents:
diff changeset
196
anatofuz
parents:
diff changeset
197 Check you are happy with the commit message and amend it if necessary. Then,
anatofuz
parents:
diff changeset
198 make sure the commit is up-to-date, and commit it. This can be done by running
anatofuz
parents:
diff changeset
199 the following:
anatofuz
parents:
diff changeset
200
anatofuz
parents:
diff changeset
201 ::
anatofuz
parents:
diff changeset
202
anatofuz
parents:
diff changeset
203 git pull --rebase origin master
anatofuz
parents:
diff changeset
204 git show # Ensure the patch looks correct.
anatofuz
parents:
diff changeset
205 ninja check-$whatever # Rerun the appropriate tests if needed.
anatofuz
parents:
diff changeset
206 git llvm push
anatofuz
parents:
diff changeset
207
anatofuz
parents:
diff changeset
208 Or
anatofuz
parents:
diff changeset
209
anatofuz
parents:
diff changeset
210 ::
anatofuz
parents:
diff changeset
211
anatofuz
parents:
diff changeset
212 arc land D<Revision>
anatofuz
parents:
diff changeset
213
anatofuz
parents:
diff changeset
214
anatofuz
parents:
diff changeset
215 Abandoning a change
anatofuz
parents:
diff changeset
216 -------------------
anatofuz
parents:
diff changeset
217
anatofuz
parents:
diff changeset
218 If you decide you should not commit the patch, you should explicitly abandon
anatofuz
parents:
diff changeset
219 the review so that reviewers don't think it is still open. In the web UI,
anatofuz
parents:
diff changeset
220 scroll to the bottom of the page where normally you would enter an overall
anatofuz
parents:
diff changeset
221 comment. In the drop-down Action list, which defaults to "Comment," you should
anatofuz
parents:
diff changeset
222 select "Abandon Revision" and then enter a comment explaining why. Click the
anatofuz
parents:
diff changeset
223 Submit button to finish closing the review.
anatofuz
parents:
diff changeset
224
anatofuz
parents:
diff changeset
225 Status
anatofuz
parents:
diff changeset
226 ------
anatofuz
parents:
diff changeset
227
anatofuz
parents:
diff changeset
228 Please let us know whether you like it and what could be improved! We're still
anatofuz
parents:
diff changeset
229 working on setting up a bug tracker, but you can email klimek-at-google-dot-com
anatofuz
parents:
diff changeset
230 and chandlerc-at-gmail-dot-com and CC the llvm-dev mailing list with questions
anatofuz
parents:
diff changeset
231 until then. We also could use help implementing improvements. This sadly is
anatofuz
parents:
diff changeset
232 really painful and hard because the Phabricator codebase is in PHP and not as
anatofuz
parents:
diff changeset
233 testable as you might like. However, we've put exactly what we're deploying up
anatofuz
parents:
diff changeset
234 on an `llvm-reviews GitHub project`_ where folks can hack on it and post pull
anatofuz
parents:
diff changeset
235 requests. We're looking into what the right long-term hosting for this is, but
anatofuz
parents:
diff changeset
236 note that it is a derivative of an existing open source project, and so not
anatofuz
parents:
diff changeset
237 trivially a good fit for an official LLVM project.
anatofuz
parents:
diff changeset
238
anatofuz
parents:
diff changeset
239 .. _LLVM's Phabricator: https://reviews.llvm.org
anatofuz
parents:
diff changeset
240 .. _`https://reviews.llvm.org`: https://reviews.llvm.org
anatofuz
parents:
diff changeset
241 .. _Code Repository Browser: https://reviews.llvm.org/diffusion/
anatofuz
parents:
diff changeset
242 .. _Arcanist Quick Start: https://secure.phabricator.com/book/phabricator/article/arcanist_quick_start/
anatofuz
parents:
diff changeset
243 .. _Arcanist User Guide: https://secure.phabricator.com/book/phabricator/article/arcanist/
anatofuz
parents:
diff changeset
244 .. _llvm-reviews GitHub project: https://github.com/r4nt/llvm-reviews/