| = Review UI |
| |
| Reviewing changes is an important task and the Gerrit Web UI provides |
| many functionalities to make the review process comfortable and |
| efficient. This is a guide through the review UI that explains the |
| different functions and UI elements. |
| |
| [[change-screen]] |
| == Change Screen |
| |
| The change screen shows the details of a single change and provides |
| various actions on it. |
| |
| image::images/user-review-ui-change-screen.png[width=800, link="images/user-review-ui-change-screen.png"] |
| |
| [[commit-message]] |
| === Commit Message Block |
| |
| The focus of the change screen is on the commit message since this is |
| the most important information about a change. The numeric change ID |
| and the change status are displayed right above the commit message. |
| |
| image::images/user-review-ui-change-screen-commit-message.png[width=800, link="images/user-review-ui-change-screen-commit-message.png"] |
| |
| The commit message can be edited directly in the Web UI by clicking on |
| the `Edit Message` button in the change header. This opens a drop-down |
| editor box in which the commit message can be edited. Saving |
| modifications of the commit message automatically creates a new patch |
| set for the change. The commit message may only be edited on the |
| current patch set. |
| |
| image::images/user-review-ui-change-screen-edit-commit-message.png[width=800, link="images/user-review-ui-change-screen-edit-commit-message.png"] |
| |
| The numeric change ID is a link to the change and clicking on it |
| refreshes the change screen. By copying the link location you can get |
| the permalink of the change. |
| |
| image::images/user-review-ui-change-screen-permalink.png[width=800, link="images/user-review-ui-change-screen-permalink.png"] |
| |
| The change status shows the state of the change: |
| |
| - `Needs <label>`: |
| + |
| The change is in review and an approval on the shown label is still |
| required to make the change submittable. |
| |
| - `Not <label>`: |
| + |
| The change is in review and a veto vote on the shown label is |
| preventing the submit. |
| |
| [[not-current]] |
| - `Not Current`: |
| + |
| The currently viewed patch set is outdated. |
| + |
| Please note that some operations, like voting, are not available on |
| outdated patch sets, but only on the current patch set. |
| |
| - `Ready to Submit`: |
| + |
| The change has all necessary approvals and may be submitted. |
| |
| - `Submitted, Merge Pending`: |
| + |
| The change was submitted and was added to the merge queue. |
| + |
| The change stays in the merge queue if it depends on a change that is |
| still in review. In this case it will get automatically merged when all |
| predecessor changes have been merged. |
| + |
| This status can also mean that the change depends on an abandoned |
| change or on an outdated patch set of another change. In this case you |
| may want to rebase the change. |
| |
| - `Merged`: |
| + |
| The change was successfully merged into the destination branch. |
| |
| - `Abandoned`: |
| + |
| The change was abandoned. |
| |
| - `Draft`: |
| + |
| The change is a draft that is only visible to the change owner, the |
| reviewers that were explicitly added to the change, and users who have |
| the link:access-control.html#category_view_drafts[View Drafts] global |
| capability assigned. |
| |
| [[commit-info]] |
| === Commit Info Block |
| |
| The commit info block shows information about the commit of the |
| currently viewed patch set. |
| |
| It displays the author and the committer as links to a list of this |
| person's changes that have the same status as the currently viewed |
| change. |
| |
| The commit ID, the parent commit(s) and the link:user-changeid.html[Change-Id] are |
| displayed with a copy-to-clipboard icon that allows the ID to be copied |
| into the clipboard. |
| |
| If a Git web browser, such as GitWeb or Gitiles, is configured, there |
| is also a link to the commit in the Git web browser. |
| |
| image::images/user-review-ui-change-screen-commit-info.png[width=800, link="images/user-review-ui-change-screen-commit-info.png"] |
| |
| If a merge commit is viewed this is highlighted by an icon. |
| |
| image::images/user-review-ui-change-screen-commit-info-merge-commit.png[width=800, link="images/user-review-ui-change-screen-commit-info-merge-commit.png"] |
| |
| [[change-info]] |
| === Change Info Block |
| |
| The change info block contains detailed information about the change |
| and offers actions on the change. |
| |
| image::images/user-review-ui-change-screen-change-info.png[width=800, link="images/user-review-ui-change-screen-change-info.png"] |
| |
| - Change Owner: |
| + |
| The owner of the change is displayed as a link to a list of the owner's |
| changes that have the same status as the currently viewed change. |
| + |
| image::images/user-review-ui-change-screen-change-info-owner.png[width=800, link="images/user-review-ui-change-screen-change-info-owner.png"] |
| |
| - Reviewers: |
| + |
| The reviewers of the change are displayed as chip tokens. |
| + |
| For each reviewer there is a tooltip that shows on which labels the |
| reviewer is allowed to vote. |
| + |
| New reviewers can be added by clicking on the `Add...` button. Typing |
| into the pop-up text field activates auto completion of user and group |
| names. |
| + |
| Reviewers can be removed from the change by clicking on the `x` icon |
| in the reviewer's chip token. Removing a reviewer also removes the |
| current votes of the reviewer. The removal of votes is recorded as a |
| message on the change. |
| + |
| Removing reviewers is protected by permissions: |
| |
| ** Users can always remove themselves. |
| ** The change owner may remove any zero or positive score. |
| ** Users with the link:access-control.html#category_remove_reviewer[ |
| Remove Reviewer] access right, the branch owner, the project owner |
| and Gerrit administrators may remove anyone. |
| |
| + |
| image::images/user-review-ui-change-screen-change-info-reviewers.png[width=800, link="images/user-review-ui-change-screen-change-info-reviewers.png"] |
| |
| - Project / Branch / Topic: |
| + |
| The name of the project for which the change was done is displayed as a |
| link to the link:user-dashboards.html#project-default-dashboard[default |
| dashboard] of the project. If no default dashboard is defined, the link |
| opens a list of open changes on the project. |
| + |
| Clicking on the settings icon on the right side navigates to the |
| project administration screen. |
| + |
| The name of the destination branch is displayed as a link to a list |
| with all changes on this branch that have the same status as the |
| currently viewed change. |
| + |
| If a topic was assigned to the change it is displayed below the branch. |
| By clicking on the edit icon the topic can be set. This requires the |
| link:access-control.html#category_edit_topic_name[Edit Topic Name] |
| access right. To be able to set a topic on a closed change, the |
| `Edit Topic Name` must be assigned with the `force` flag. |
| + |
| image::images/user-review-ui-change-screen-change-info-project-branch-topic.png[width=800, link="images/user-review-ui-change-screen-change-info-project-branch-topic.png"] |
| |
| - Submit Strategy: |
| + |
| The link:project-setup.html#submit_type[submit strategy] that will be |
| used to submit the change. The submit strategy is only displayed for |
| open changes. |
| + |
| image::images/user-review-ui-change-screen-change-info-submit-strategy.png[width=800, link="images/user-review-ui-change-screen-change-info-submit-strategy.png"] |
| + |
| If a change cannot be merged due to path conflicts this is highlighted |
| by a bold red `Cannot Merge` label. |
| + |
| image::images/user-review-ui-change-screen-change-info-cannot-merge.png[width=800, link="images/user-review-ui-change-screen-change-info-cannot-merge.png"] |
| |
| - Time of Last Update: |
| + |
| image::images/user-review-ui-change-screen-change-info-last-update.png[width=800, link="images/user-review-ui-change-screen-change-info-last-update.png"] |
| |
| - Actions: |
| + |
| Depending on the change state and the permissions of the user, different |
| actions are available on the change: |
| |
| ** `Submit`: |
| + |
| Submits the change and adds it to the merge queue. If possible the |
| change is merged into the destination branch. |
| + |
| The `Submit` button is available if the change is submittable and |
| the link:access-control.html#category_submit[Submit] access right is |
| assigned. |
| + |
| It is also possible to submit changes that have merge conflicts. This |
| allows to do the conflict resolution for a change series in a single |
| merge commit and submit the changes in reverse order. |
| |
| ** `Abandon`: |
| + |
| Abandons the change. |
| + |
| The `Abandon` button is only available if the change is open and the |
| link:access-control.html#category_abandon[Abandon] access right is |
| assigned. |
| + |
| When a change is abandoned, a panel appears that allows one to type a |
| comment message to explain why the change is being abandoned. |
| |
| ** `Restore`: |
| + |
| Restores the change. |
| + |
| The `Restore` button is only available if the change is abandoned and |
| the link:access-control.html#category_abandon[Abandon] and the |
| link:access-control.html#category_push[Push] access right is |
| assigned. |
| + |
| When a change is restored, a panel appears that allows one to type a |
| comment message to explain why the change is being restored. |
| |
| ** `Rebase`: |
| + |
| Rebases the change. The rebase is always done with content merge |
| enabled. If the rebase is successful a new patch set with the rebased |
| commit is created. If the rebase fails, there are conflicts that have |
| to be resolved manually. |
| + |
| If the change does not depend on another open change, it is rebased |
| onto the tip of the destination branch. |
| + |
| If the change depends on another open change, it is rebased onto the |
| current patch set of that other change. |
| + |
| The `Rebase` button is only available if the change can be rebased and |
| the link:access-control.html#category_rebase[Rebase] access right is |
| assigned. Rebasing merge commits is not supported. |
| |
| ** `Cherry-Pick`: |
| + |
| Allows to cherry-pick the change to another branch. The destination |
| branch can be selected from a dialog. Cherry-picking a change creates a |
| new open change on the selected destination branch. |
| + |
| It is also possible to cherry-pick a change to the same branch. This is |
| effectively the same as rebasing it to the current tip of the |
| destination branch. This can be used to remove dependencies on other |
| open changes. |
| + |
| Users can only cherry-pick changes to branches for which they are |
| allowed to upload changes for review. |
| |
| ** `Publish`: |
| + |
| Publishes the currently viewed draft patch set. If this is the first |
| patch set of a change that is published, the change will be published |
| as well. |
| + |
| The `Publish` button is only available if a draft patch set is viewed |
| and the user is the change owner or has the |
| link:access-control.html#category_publish_drafts[Publish Drafts] access |
| right assigned. |
| |
| ** `Delete Change` / `Delete Revision`: |
| + |
| Deletes the draft change / the currently viewed draft patch set. |
| + |
| The `Delete Change` / `Delete Revision` buttons are only available if a |
| draft patch set is viewed and the user is the change owner or has the |
| link:access-control.html#category_delete_drafts[Delete Drafts] access |
| right assigned. |
| |
| ** Further actions may be available if plugins are installed. |
| |
| + |
| image::images/user-review-ui-change-screen-change-info-actions.png[width=800, link="images/user-review-ui-change-screen-change-info-actions.png"] |
| |
| - Labels & Votes: |
| + |
| Approving votes are colored green; veto votes are colored red. |
| + |
| image::images/user-review-ui-change-screen-change-info-labels.png[width=800, link="images/user-review-ui-change-screen-change-info-labels.png"] |
| |
| [[files]] |
| === File List |
| |
| The file list shows the files that are modified in the currently viewed |
| patch set. |
| |
| image::images/user-review-ui-change-screen-file-list.png[width=800, link="images/user-review-ui-change-screen-file-list.png"] |
| |
| The checkboxes in front of the file names allow files to be marked as reviewed. |
| |
| image::images/user-review-ui-change-screen-file-list-mark-as-reviewed.png[width=800, link="images/user-review-ui-change-screen-file-list-mark-as-reviewed.png"] |
| |
| The type of a file modification is indicated by the character in front |
| of the file name: |
| |
| - 'no character' (Modified): |
| + |
| The file existed before this change and is modified. |
| |
| - `A` (Added): |
| + |
| The file is newly added. |
| |
| - `D` (Deleted): |
| + |
| The file is deleted. |
| |
| - `R` (Renamed): |
| + |
| The file is renamed. |
| |
| - `C` (Copied): |
| + |
| The file is new and is copied from an existing file. |
| |
| image::images/user-review-ui-change-screen-file-list-modification-type.png[width=800, link="images/user-review-ui-change-screen-file-list-modification-type.png"] |
| |
| If a file is renamed or copied, the name of the original file is |
| displayed in gray below the file name. |
| |
| image::images/user-review-ui-change-screen-file-list-rename.png[width=800, link="images/user-review-ui-change-screen-file-list-rename.png"] |
| |
| Repeating path segments are grayed out. |
| |
| image::images/user-review-ui-change-screen-file-list-repeating-paths.png[width=800, link="images/user-review-ui-change-screen-file-list-repeating-paths.png"] |
| |
| Inline comments on a file are shown in the `Comments` column. |
| |
| Draft comments, i.e. comments that have been written by the current |
| user but not yet published, are highlighted in red. |
| |
| New comments from other users, that were published after the current |
| user last reviewed this change, are highlighted in bold. |
| |
| image::images/user-review-ui-change-screen-file-list-comments.png[width=800, link="images/user-review-ui-change-screen-file-list-comments.png"] |
| |
| The size of the modifications in the files can be seen in the `Size` |
| column. The footer row shows the total size of the change. |
| |
| For files, the `Size` column shows the sum of inserted and deleted |
| lines as one number. For the total size, inserted and deleted lines are |
| shown separately. In addition, the number of insertions and deletions |
| is shown as a bar. The size of the bar indicates the amount of changed |
| lines, and its coloring in green and red shows the proportion of |
| insertions to deletions. |
| |
| The size information is useful to easily spot the files that contain |
| the most modifications; these files are likely to be the most relevant |
| files for this change. The total change size gives an estimate of how |
| long a review of this change may take. |
| |
| image::images/user-review-ui-change-screen-file-list-size.png[width=800, link="images/user-review-ui-change-screen-file-list-size.png"] |
| |
| In the header of the file list, the `Diff Against` selection can be |
| changed. This selection allows one to choose if the currently viewed |
| patch set should be compared against its base or against another patch |
| set of this change. The file list is updated accordingly. |
| |
| The file list header also provides an `Open All` button that opens the |
| diff views for all files in the file list. |
| |
| image::images/user-review-ui-change-screen-file-list-header.png[width=800, link="images/user-review-ui-change-screen-file-list-header.png"] |
| |
| [[patch-sets]] |
| === Patch Sets |
| |
| The change screen only presents one patch set at a time. Which patch |
| set is currently viewed can be seen from the `Patch Sets` drop-down |
| panel in the change header. It shows the number of the currently viewed |
| patch set and the total number of patch sets, in the form: "current |
| patch set/number of patch sets". |
| |
| If a non-current patch set is viewed this is indicated by the |
| link:#not-current[Not Current] change state. Please note that some |
| operations are only available on the current patch set. |
| |
| image::images/user-review-ui-change-screen-patch-sets.png[width=800, link="images/user-review-ui-change-screen-patch-sets.png"] |
| |
| The patch set drop-down list shows the list of patch sets and allows to |
| switch between them. The patch sets are sorted in descending order so |
| that the current patch set is always on top. |
| |
| Patch sets that have unpublished draft comments are marked by a comment |
| icon. |
| |
| Draft patch sets are marked with `DRAFT`. |
| |
| image::images/user-review-ui-change-screen-patch-set-list.png[width=800, link="images/user-review-ui-change-screen-patch-set-list.png"] |
| |
| [[download]] |
| === Download |
| |
| The `Download` drop-down panel in the change header offers commands and |
| links for downloading the currently viewed patch set. |
| |
| image::images/user-review-ui-change-screen-download-commands.png[width=800, link="images/user-review-ui-change-screen-download-commands.png"] |
| |
| The available download commands depend on the installed Gerrit plugins. |
| The most popular plugin for download commands, the |
| link:https://gerrit-review.googlesource.com/#/admin/projects/plugins/download-commands[ |
| download-commands] plugin, provides commands to checkout, pull and |
| cherry-pick a patch set. |
| |
| Each command has a copy-to-clipboard icon that allows the command to be |
| copied into the clipboard. This makes it easy to paste and execute the |
| command on a Git command line. |
| |
| If several download schemes are configured on the server (e.g. SSH and |
| HTTP) there is a drop-down list to switch between the download schemes. |
| Gerrit automatically remembers the download scheme that was last chosen |
| and selects this download scheme the next time the download commands |
| drop-down panel is opened. |
| |
| The `Patch-File` links provide the Git patch file for the currently |
| viewed patch set for download. The patch file can be base64 encoded or |
| zipped. |
| |
| The `Archive` links allow one to download an archive with the contents |
| of the currently viewed patch set. The archive is offered in several |
| formats (e.g. tar and tbz2); which formats are available depends on the |
| configuration of the server. |
| |
| image::images/user-review-ui-change-screen-download-commands-list.png[width=800, link="images/user-review-ui-change-screen-download-commands-list.png"] |
| |
| [[included-in]] |
| === Included In |
| |
| For merged changes the `Included In` drop-down panel is available in |
| the change header. |
| |
| image::images/user-review-ui-change-screen-included-in.png[width=800, link="images/user-review-ui-change-screen-included-in.png"] |
| |
| The `Included In` drop-down panel shows the branches and tags in which |
| the change is included. E.g. if a change fixes a bug, this allows to |
| quickly see in which released versions the bug-fix is contained |
| (assuming that every release is tagged). |
| |
| image::images/user-review-ui-change-screen-included-in-list.png[width=800, link="images/user-review-ui-change-screen-included-in-list.png"] |
| |
| [[star]] |
| === Star Change |
| |
| The star icon in the change header allows to mark the change as a |
| favorite. Clicking on the star icon again, unstars the change. |
| |
| image::images/user-review-ui-change-screen-star.png[width=800, link="images/user-review-ui-change-screen-star.png"] |
| |
| Starring a change turns on email notifications for this change. |
| |
| Starred changed are listed under `My` > `Starred Changes`. |
| and can be queried by the link:user-search.html#is[is:starred] search |
| operator. |
| |
| [[related-changes]] |
| === Related Changes |
| |
| If there are changes that are related to the currently viewed change |
| they are displayed in the third column of the change screen. |
| |
| There are several lists of related changes and a tab control is used to |
| display each list of related changes in its own tab. |
| |
| The following tabs may be displayed: |
| |
| [[related-changes-tab]] |
| - `Related Changes`: |
| + |
| This tab page shows changes on which the current change depends |
| (ancestors) and open changes that depend on the current change |
| (descendants). For merge commits it also shows the closed changes that |
| will be merged into the destination branch by submitting the merge |
| commit. |
| + |
| The changes are sorted in the same way as the output of 'git log'. This |
| means the relationship between the changes can be inferred from the |
| position of the changes in the list. Changes listed above the current |
| change are descendants; changes below the current change are ancestors. |
| + |
| For merged changes this tab is only shown if there are open |
| descendants. |
| + |
| image::images/user-review-ui-change-screen-related-changes.png[width=800, link="images/user-review-ui-change-screen-related-changes.png"] |
| + |
| Related changes may be decorated with an icon to signify dependencies |
| on outdated patch sets, or commits that are not associated to changes |
| under review: |
| + |
| ** Orange Dot: |
| + |
| The selected patch set of the change is outdated; it is not the current |
| patch set of the change. |
| + |
| If an ancestor change is marked with an orange dot it means that the |
| currently viewed patch set depends on a outdated patch set of the |
| ancestor change. This is because a new patch set for the ancestor |
| change was uploaded in the meantime and as result the currently viewed |
| patch set now needs to be rebased. |
| + |
| If a descendant change is marked with an orange dot it means that an |
| old patch set of the descendant change depends on the currently viewed |
| patch set. It may be that the descendant was rebased in the meantime |
| and with the new patch set this dependency was removed. |
| |
| ** Green Tilde: |
| + |
| The selected patch set of the change is an indirect descendant of the |
| currently viewed patch set; it has a dependency to another patch set of |
| this change. E.g. this could mean that a new patch set was uploaded for |
| this change and the descendant change now needs to be rebased. Please |
| note that following the link to an indirect descendant change may |
| result in a completely different related changes listing. |
| |
| ** Black Dot: |
| + |
| Indicates a merged ancestor, e.g. the commit was directly pushed into |
| the repository bypassing code review, or the ancestor change was |
| reviewed and submitted on another branch. The latter may indicate that |
| the user has accidentally pushed the commit to the wrong branch, e.g. |
| the commit was done on `branch-a`, but was then pushed to |
| `refs/for/branch-b`. |
| |
| + |
| image::images/user-review-ui-change-screen-related-changes-indicators.png[width=800, link="images/user-review-ui-change-screen-related-changes-indicators.png"] |
| |
| - `Conflicts With`: |
| + |
| This tab page shows changes that conflict with the current change. |
| Non-mergeable changes are filtered out; only conflicting changes that |
| are mergeable are shown. |
| + |
| If this change is merged, its conflicting changes will have merge |
| conflicts and must be rebased. The rebase of the other changes with the |
| conflict resolution must then be done manually. |
| + |
| image::images/user-review-ui-change-screen-conflicts-with.png[width=800, link="images/user-review-ui-change-screen-conflicts-with.png"] |
| |
| - `Same Topic`: |
| + |
| This tab page shows changes that have the same topic as the current |
| change. Only open changes are included in the list. |
| + |
| image::images/user-review-ui-change-screen-same-topic.png[width=800, link="images/user-review-ui-change-screen-same-topic.png"] |
| |
| - `Cherry-Picks`: |
| + |
| This tab page shows changes with the same link:user-changeid.html[ |
| Change-Id] for the current project. |
| + |
| Abandoned changes are filtered out. |
| + |
| For each change in this list the destination branch is shown as a |
| prefix in front of the change subject. |
| + |
| image::images/user-review-ui-change-screen-cherry-picks.png[width=800, link="images/user-review-ui-change-screen-cherry-picks.png"] |
| |
| If there are no related changes for a tab, the tab is not displayed. |
| |
| [[reply]] |
| === Reply |
| |
| The `Reply...` button in the change header allows to reply to the |
| currently viewed patch set; one can add a summary comment, publish |
| inline draft comments, and vote on the labels. |
| |
| image::images/user-review-ui-change-screen-reply.png[width=800, link="images/user-review-ui-change-screen-reply.png"] |
| |
| Clicking on the `Reply...` button opens a popup panel. |
| |
| A text box allows to type a summary comment for the currently viewed |
| patch set. |
| |
| If the current patch set is viewed, radio buttons are displayed for |
| each label on which the user is allowed to vote. Voting on non-current |
| patch sets is not possible. |
| |
| Typing "LGTM" (acronym for 'Looks Good To Me') in the summary comment |
| text box automatically selects the highest possible score for the |
| 'Code-Review' label. |
| |
| The inline draft comments that will be published are displayed in a |
| separate section so that they can be reviewed before publishing. There |
| are links to navigate to the inline comments which can be used if a |
| comment needs to be edited. |
| |
| The `Post` button publishes the comments and the votes. |
| |
| image::images/user-review-ui-change-screen-replying.png[width=800, link="images/user-review-ui-change-screen-replying.png"] |
| |
| If a user can approve a label that is still required, a quick approve |
| button appears in the change header that allows to add this missing |
| approval by a single click. The quick approve button only appears if |
| there is a single label that is still required and can be approved by |
| the user. |
| |
| E.g. if a change requires approvals on the 'Code-Review' and the |
| 'Verified' labels, and there is already a '+1 Verified' vote, then |
| if the user is allowed to vote the max score on 'Code-Review', a |
| `Code-Review+2` quick approve button appears that approves the |
| 'Code-Review' label if clicked. |
| |
| Using the quick approve button also publishes all inline draft |
| comments; a summary comment is only added if the reply popup panel is |
| open when the quick approve button is clicked. |
| |
| image::images/user-review-ui-change-screen-quick-approve.png[width=800, link="images/user-review-ui-change-screen-quick-approve.png"] |
| |
| [[history]] |
| === History |
| |
| The history of the change can be seen in the lower part of the screen. |
| |
| The history contains messages for all kinds of change updates, e.g. a |
| message is added when a new patch set is uploaded or when a review was |
| done. |
| |
| Messages with new comments from other users, that were published after |
| the current user last reviewed this change, are automatically expanded. |
| |
| image::images/user-review-ui-change-screen-history.png[width=800, link="images/user-review-ui-change-screen-history.png"] |
| |
| It is possible to directly reply to a change message by clicking on the |
| reply icon in the right upper corner of a change message. This opens |
| the reply popup panel and prefills the text box with the quoted comment. |
| Then the reply can be written below the quoted comment or inserted |
| inline. Lines starting with " > " will be rendered as a block quote. |
| Please note that for a correct rendering it is important to leave a blank |
| line between a quoted block and the reply to it. |
| |
| image::images/user-review-ui-change-screen-reply-to-comment.png[width=800, link="images/user-review-ui-change-screen-reply-to-comment.png"] |
| |
| Inline comments are directly displayed in the change history and there |
| are links to navigate to the inline comments. |
| |
| image::images/user-review-ui-change-screen-inline-comments.png[width=800, link="images/user-review-ui-change-screen-inline-comments.png"] |
| |
| The `Expand All` button expands all messages; the `Collapse All` button |
| collapses all messages. |
| |
| [[update-notification]] |
| === Update Notification |
| |
| The change screen automatically polls for updates to the currently |
| viewed change. If there is an update the user is informed by a popup |
| panel in the bottom right corner. |
| |
| The polling frequency depends on the server configuration; by default |
| it is 30 seconds. Polling may also be completely disabled by the |
| administrator. |
| |
| image::images/user-review-ui-change-screen-change-update.png[width=800, link="images/user-review-ui-change-screen-change-update.png"] |
| |
| [[plugin-extensions]] |
| === Plugin Extensions |
| |
| Gerrit plugins may extend the change screen; they can add buttons for |
| additional actions to the change info block and display arbitrary UI |
| controls below the change info block. |
| |
| image::images/user-review-ui-change-screen-plugin-extensions.png[width=800, link="images/user-review-ui-change-screen-plugin-extensions.png"] |
| |
| [[old-change-screen]] |
| === Old Change Screen |
| |
| In addition to the normal change screen, this Gerrit version still |
| includes the old change screen that was used in earlier Gerrit |
| versions. Users that want to continue using the old change screen can |
| configure it in their preferences under |
| `Settings` > `Preferences` > `Change View`: |
| |
| image::images/user-review-ui-change-view-preference.png[width=800, link="images/user-review-ui-change-view-preference.png"] |
| |
| [WARNING] |
| The old change screen will be removed in a later version of Gerrit. |
| |
| [[side-by-side]] |
| == Side-by-Side Diff Screen |
| |
| The side-by-side diff screen shows a single patch; the old file version |
| is displayed on the left side of the screen; the new file version is |
| displayed on the right side of the screen. |
| |
| This screen allows to review a patch and to comment on it. |
| |
| image::images/user-review-ui-side-by-side-diff-screen.png[width=800, link="images/user-review-ui-side-by-side-diff-screen.png"] |
| |
| In the screen header the project name and the name of the viewed patch |
| file are shown. |
| |
| If a Git web browser is configured on the server, the project name and |
| the file path are displayed as links to the project and the folder in |
| the Git web browser. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-project-and-file.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-project-and-file.png"] |
| |
| The checkbox in front of the project name and the file name allows the |
| patch to be marked as reviewed. The link:#mark-reviewed[Mark Reviewed] |
| diff preference allows to control whether the files should be |
| automatically marked as reviewed when they are viewed. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-reviewed.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-reviewed.png"] |
| |
| The scrollbar shows patch diffs and inline comments as annotations. |
| This provides a good overview of the lines in the patch that are |
| relevant for reviewing. By clicking on an annotation one can quickly |
| navigate to the corresponding line in the patch. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-scrollbar.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-scrollbar.png"] |
| |
| A gap between lines in the file content that is caused by aligning the |
| left and right side or by displaying inline comments is shown as a |
| vertical red bar in the line number column. This prevents a gap from |
| being mistaken for blank lines in the file |
| |
| image::images/user-review-ui-side-by-side-diff-screen-red-bar.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-red-bar.png"] |
| |
| [[patch-set-selection]] |
| In the header, on each side, the list of patch sets is shown. Clicking |
| on a patch set changes the selection for the patch set comparison and |
| the screen is refreshed to show the diff between the selected patch |
| sets. The currently selected patch set is highlighted by a light blue |
| background. |
| |
| On the left side `Base` can be selected to compare a patch set against |
| its base. For merge commits `Auto Merge` is available instead which |
| allows to compare the patch against the result of the auto merge. The |
| auto merge version may contain Git conflict markers and is useful for |
| reviewing how conflicts are resolved by a patch. |
| |
| Reviewers that are reviewing a patch for the first time look at its |
| diff against its base; reviewers that have reviewed an old patch |
| version before, may see what has changed since that version by |
| comparing the old patch against the current patch. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-patch-sets.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-patch-sets.png"] |
| |
| The download icon next to the patch set list allows to download the |
| patch. Unless the mime type of the file is configured as safe, the |
| download file is a zip archive that contains the patch file. |
| |
| If the compared patches are identical, this is highlighted by a red |
| `No Differences` label in the screen header. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-no-differences.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-no-differences.png"] |
| |
| If a file was renamed, the old and new file paths are shown in the |
| header together with a similarity index that shows how much of the file |
| content is unmodified. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-rename.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-rename.png"] |
| |
| For navigating between the patches in a patch set there are navigation |
| buttons on the right side of the screen header. The left arrow button |
| navigates to the previous patch; the right arrow button navigates to |
| the next patch. The arrow up button leads back to the change screen. In |
| all cases the selection for the patch set comparison is kept. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-navigation.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-navigation.png"] |
| |
| [[inline-comments]] |
| === Inline Comments |
| |
| Inline comments are displayed directly in the patch file under the code |
| that is commented. Inline comments can be placed on lines or on code |
| blocks. |
| |
| If an inline comment relates to a code block, this code block is |
| highlighted by a yellow background. |
| |
| Code blocks with comments may overlap. This means it is possible to |
| attach several comments to the same code. |
| |
| The lines of the patch file are linkable. To link to a certain line in |
| the patch file, '@<line-number>' must be appended to the patch link, |
| e.g. `http://host:8080/#/c/56857/2/Documentation/user-review-ui.txt@665`. |
| To link to a line in the old file version, '@a<line-number>' must be |
| appended to the patch link. These links can be used to directly link to |
| certain inline comments. |
| |
| If the diff preference link:#expand-all-comments[Expand All Comments] |
| is set to `Expand`, all inline comments will be automatically expanded. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-inline-comments.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-inline-comments.png"] |
| |
| In the header of the comment box, the name of the comment author and |
| the timestamp of the comment are shown. If avatars are configured on |
| the server, the avatar image of the comment author is displayed in the |
| top left corner. Below the actual comment there are buttons to reply to |
| the comment. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-comment-box.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-comment-box.png"] |
| |
| Clicking on the `Reply` button opens an editor to type the reply. |
| |
| Quoting is supported, but only by manually copying & pasting the old |
| comment that should be quoted and prefixing every line by " > ". Please |
| note that for a correct rendering it is important to leave a blank line |
| between a quoted block and the reply to it. |
| |
| Clicking on the `Save` button saves the comment as a draft. To make it |
| visible to other users it must be published from the change screen by |
| link:#reply[replying] to the change. |
| |
| The `Cancel` button cancels the editing and discards any changes to the |
| draft comment. |
| |
| Clicking on the `Discard` button deletes the inline draft comment. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-comment-reply.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-comment-reply.png"] |
| |
| Draft comments are marked by the text "Draft" in the header in the |
| place of the comment author. |
| |
| A draft comment can be edited by clicking on the `Edit` button, or |
| deleted by clicking on the `Discard` button. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-comment-edit.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-comment-edit.png"] |
| |
| Clicking on the `Done` button is a quick way to reply with "Done" to a |
| comment. This is used to mark a comment as addressed by a follow-up |
| patch set. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-replied-done.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-replied-done.png"] |
| |
| [[add-inline-comment]] |
| To add a new inline comment there are several possibilities: |
| |
| - select a code block and press 'c' |
| - select a code block and click on the popup comment icon |
| - go to a line, by clicking on it or by link:#key-navigation[key |
| navigation], and press 'c' |
| - click on a line number |
| |
| There are many ways to select code for commenting on it. The most |
| frequently used methods are: |
| |
| - by mouse: |
| ** click and drag with the mouse to select a block |
| ** double-click on a word to select it |
| ** double-click and drag with the mouse to select a code block word-wise |
| ** triple-click on a line to select it |
| ** triple-click and drag with the mouse to select a code block line-wise |
| |
| - by keys (the same keys that are used for visual selection in Vim): |
| ** press 'v' + arrow keys (or 'h', 'j', 'k', 'l') to select a block |
| ** press 'V' + arrow keys (or 'j', 'k') to select a code block line-wise |
| ** type 'bvw' to select a word |
| |
| image::images/user-review-ui-side-by-side-diff-screen-comment.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-comment.png"] |
| |
| For typing the new comment, a new comment box is shown under the code |
| that is commented. |
| |
| Clicking on the `Save` button saves the new comment as a draft. To make |
| it visible to other users it must be published from the change screen |
| by link:#reply[replying] to the change. |
| |
| Clicking on the `Discard` button deletes the new comment. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-commented.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-commented.png"] |
| |
| [[file-level-comments]] |
| === File Level Comments |
| |
| Comments that apply to a whole file can be added on file level. |
| |
| File level comments are added by clicking on the comment icon in the |
| header above the file. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-file-level-comment.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-file-level-comment.png"] |
| |
| Clicking on the comment icon opens a comment box for typing the file |
| level comment. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-file-level-commented.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-file-level-commented.png"] |
| |
| [[search]] |
| === Search |
| |
| For searching within a patch file, a Vim-like search is supported. |
| Typing `/` opens the search box. Typing in the search box immediately |
| highlights matches in the patch file with a yellow background. Using |
| JavaScript regular expressions in the search term is supported. The |
| search is case insensitive. After confirming the search by `ENTER` one |
| can navigate between the matches by `n` / `N` to go to the next / |
| previous match. Skipped lines are automatically expanded if they |
| contain a match and one navigates to it. |
| |
| For additional possibilities to search please check the |
| link:http://www.vim.org/docs.php[Vim documentation]. There are other |
| useful ways to search, e.g. while the cursor is on a word, pressing `*` |
| or `#` searches for the next or previous occurrence of the word. |
| |
| Searching by `Ctrl-F` finds matches only in the visible area of the |
| screen unless the link:#render[Render] diff preference is set to `Slow`. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-search.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-search.png"] |
| |
| [[key-navigation]] |
| === Key Navigation |
| |
| Vim-like commands can be used to navigate within a patch file: |
| |
| - `h` / `j` / `k` / `l` moves the cursor left / down / up / right |
| - `0` / `$` moves the cursor to the start / end of the line |
| - `gg` / `G` moves to cursor to the start / end of the file |
| - `Ctrl-D` / `Ctrl-U` scolls downwards / upwards |
| |
| Please check the link:http://www.vim.org/docs.php[Vim documentation] |
| for further information. |
| |
| [[diff-preferences]] |
| === Diff Preferences |
| |
| There are several options to control how patch diffs should be |
| rendered. Users can configure their preferences in the diff |
| preferences. The diff preferences can be accessed by clicking on the |
| settings icon in the screen header. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-preferences.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-preferences.png"] |
| |
| The diff preferences popup allows to change the diff preferences. |
| By clicking on the `Save` button changes to the diff preferences are |
| saved permanently. Clicking on the `Apply` button applies the new |
| diff preferences to the current screen, but they are discarded when the |
| screen is refreshed. The `Save` button is only available if the user is |
| signed in. |
| |
| image::images/user-review-ui-side-by-side-diff-screen-preferences-popup.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-preferences-popup.png"] |
| |
| The following diff preferences can be configured: |
| |
| - `Theme`: |
| + |
| Controls the theme that is used to render the file content. |
| + |
| E.g. users could choose to work with a dark theme. |
| + |
| image::images/user-review-ui-side-by-side-diff-screen-dark-theme.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-dark-theme.png"] |
| |
| - `Ignore Whitespace`: |
| + |
| Controls whether differences in whitespace should be ignored or not. |
| + |
| ** `None`: |
| + |
| All differences in whitespace are highlighted. |
| + |
| ** `At Line End`: |
| + |
| Whitespace differences at the end of lines are ignored. |
| + |
| ** `Leading, At Line End`: |
| + |
| Whitespace differences at the beginning and end of lines are ignored. |
| + |
| ** `All`: |
| + |
| All differences in whitespace are ignored. |
| |
| - `Tab Width`: |
| + |
| Controls how many spaces should be displayed for a tab. |
| |
| - `Columns`: |
| + |
| Sets the preferred line length. At this position a vertical dashed line |
| is displayed so that one can easily detect lines the exceed the |
| preferred line length. |
| + |
| image::images/user-review-ui-side-by-side-diff-screen-column.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-column.png"] |
| |
| - `Lines Of Context`: |
| + |
| The number of context lines that should be displayed before and after |
| any diff. If the `entire file` checkbox is selected, the full file is |
| rendered. |
| + |
| Skipped common lines can be expanded by clicking on the placeholder for |
| the skipped lines. |
| + |
| Clicking on "... skipped <n> common lines ..." expands the complete |
| block of skipped lines. |
| + |
| If many lines are skipped there are additional links to expand the |
| context by ten lines before and after the skipped block. |
| + |
| image::images/user-review-ui-side-by-side-diff-screen-expand-skipped-lines.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-expand-skipped-lines.png"] |
| |
| - `Intraline Difference`: |
| + |
| Controls whether intraline differences should be highlighted. |
| + |
| image::images/user-review-ui-side-by-side-diff-screen-intraline-difference.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-intraline-difference.png"] |
| |
| - `Syntax Highlighting`: |
| + |
| Controls whether syntax highlighting should be enabled. |
| + |
| The language for the syntax highlighting is automatically detected from |
| the file extension. |
| + |
| image::images/user-review-ui-side-by-side-diff-screen-syntax-coloring.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-syntax-coloring.png"] |
| |
| - `Whitespace Errors`: |
| + |
| Controls whether whitespace errors are highlighted. |
| |
| - `Show Tabs`: |
| + |
| Controls whether tabs are highlighted. |
| |
| - `Line Numbers`: |
| + |
| Controls whether line numbers are shown. |
| |
| - `Top Menu`: |
| + |
| Controls whether the top menu is shown. |
| |
| [[mark-reviewed]] |
| - `Mark Reviewed`: |
| + |
| Controls whether the files of the patch set should be automatically |
| marked as reviewed when they are viewed. |
| |
| [[expand-all-comments]] |
| - `Expand All Comments`: |
| + |
| Controls whether all comments should be automatically expanded. |
| |
| - `Render`: |
| + |
| Controls how patch files that exceed the screen size are rendered. |
| + |
| If `Fast` is selected file contents which are outside of the visible |
| area are not attached to the browser's DOM tree. This makes the |
| rendering fast, but searching by `Ctrl+F` only finds content which is |
| in the visible area. |
| + |
| If `Slow` is selected all file contents are attached to the browser's |
| DOM tree, which makes the rendering slow for large files. The advantage |
| of this setting is that `Ctrl+F` can be used to search in the complete |
| file. |
| |
| [[keyboard-shortcuts]] |
| == Keyboard Shortcuts |
| |
| Navigation within the review UI can be completely done by keys, and |
| most actions can be controlled by keyboard shortcuts. Typing `?` opens |
| a popup that shows a list of available keyboard shortcuts: |
| |
| - Change Screen |
| + |
| image::images/user-review-ui-change-screen-keyboard-shortcuts.png[width=800, link="images/user-review-ui-change-screen-keyboard-shortcuts.png"] |
| |
| - Side-by-Side Diff Screen |
| + |
| image::images/user-review-ui-side-by-side-diff-screen-keyboard-shortcuts.png[width=800, link="images/user-review-ui-side-by-side-diff-screen-keyboard-shortcuts.png"] |
| + |
| In addition, Vim-like commands can be used to link:#key-navigation[ |
| navigate] and link:#search[search] within a patch file. |
| |
| [[new-vs-old]] |
| == New Review UI vs. Old Review UI |
| |
| There are some important conceptual differences between the old and |
| new review UIs: |
| |
| - The old change screen directly shows all patch sets of the change. |
| With the new change screen only a single patch set is displayed; |
| users can switch between the patch sets by choosing another patch |
| set from the link:#patch-sets[Patch Sets] drop down panel in the |
| screen header. |
| - On the old side-by-side diff screen, new comments are inserted by |
| double-clicking on a line. With the new side-by-side diff screen |
| double-click is used to select a word for commenting on it; there |
| are link:#add-inline-comment[several ways to insert new comments], |
| e.g. by selecting a code block and clicking on the popup comment |
| icon. |
| |
| Limitations of the new review UI: |
| |
| - The new side-by-side diff screen cannot render images. |
| |
| - Unified diff view is missing: |
| + |
| By setting `Diff View (New Change Screen)` in the user preferences to |
| `Unified Diff` the new change screen can be configured to open the file |
| diffs in the old unified diff view. |
| |
| Users preferring the old review UI can link:#old-change-screen[ |
| configure the change view] in their preferences. |
| |
| GERRIT |
| ------ |
| Part of link:index.html[Gerrit Code Review] |
| |
| SEARCHBOX |
| --------- |