Start a code review

Important

If your Helix server is configured as a commit-edge deployment, and your normal connection is to an edge server, Swarm refuses to start reviews for shelved changes that have not been promoted to the commit server.

Within Swarm, this means that the Request Review button does not appear for unpromoted shelved changes. Outside of Swarm, attempts to start reviews for unpromoted shelved changelists appear to do nothing. Ask your Helix server administrator for assistance if you cannot start a review.

An administrator of the Helix server can automatically promote shelved changes to the commit server by setting the configurable dm.shelve.promote to 1.

Tip

If your changelist only contains a stream spec and its location in the Helix server is not associated with a Swarm project, the review that you create will not have any default reviewers or workflow rules. To associate the review with a project so that it has default reviewers and obeys the project workflow rules, include a file change from the project path in the changelist when you create the review.

  1. Use the P4D command line or a P4D client to create the shelved or committed changelist.
  2. Start a code review by using one of the following approaches:

Use Swarm:

  1. Use Swarm to view a shelved or submitted changelist.
  2. Tip

    To view a shelved or submitted changelist, use a Quick URL. For example, if your change is 54321, visit the URL: https://myswarm.url/54321.

  3. Click the Request Review button to request a review of that changelist.
  4. Requesting a review on a shelved changelist uses the pre-commit model and requesting a review on a submitted changelist uses the post-commit model.

Use P4D command line:

When you are about to shelve or submit files:

  1. Include #review within your changelist (separated from other text with whitespace, or on a separate line).

    Once the review begins, Swarm replaces #review with #review-12345, where 12345 is the review's identifier.

    Note

    The #review keyword is customizable. For details, see Review keyword.

  2. At this time, you can add reviewers to the code review by using @mention for users, and @@mention for groups in the changelist description for each desired reviewer.
  3. If your @mention or @@mention includes an asterisk (*) before the userid or groupid, for example @*userid, that user or all of the group members become required reviewers. If your @@mention includes an exclamation mark (!) before the groupid, for example @@!groupid, the members of that group become required reviewers but only one member of the group is required to vote. See Required reviewers for details.

  4. Complete your shelve or submit operation.
  5. Warning

    If you shelve a changelist and subsequently edit the description to include #review, a review is not started. You must re-shelve the files after adding #review.

Use Git Fusion:

  1. When you are using Git FusionClosedA Perforce product that integrates Git with Helix, offering enterprise-ready Git repository management, and workflows that allow Git and Helix server users to collaborate on the same projects using their preferred tools., you can start a review by pushing your changes to a target branch using the following command:
  2. $ git push origin task1:review/main/new

    task1 is the name of the current Git task branch, and main is the target branch that the proposed changes are intended for.

    Important

    The target branch must be mapped to a named Helix server branch in the Git Fusion repo configuration.

    See the Converting a lightweight branch into a fully-populated branch section of the Git Fusion Guide for details.

  3. When the command completes, the output indicates the review id that has been created:
  4. remote: Perforce: Swarm review assigned: review/main/1234

    where 1234 is the review id that was just created.

    For more information on Git Fusion, see the Git Fusion Guide.

Tip

You can also start a Swarm review with P4V, P4VS, and P4Eclipse. See below for details:

Note

If you are using P4V and its Swarm integration, and you encounter the error Host requires authentication, ask your Helix Core server administrator for assistance. See P4V Authentication for details.

Once a review has started

Wait for someone else to review your code, or see Contribute comments or code changes to a code review More review activities are available.