debian-mirror-gitlab/doc/ci/review_apps/index.md

308 lines
15 KiB
Markdown
Raw Normal View History

2019-09-04 21:01:54 +05:30
---
2021-12-11 22:18:48 +05:30
stage: Verify
2022-04-04 11:22:00 +05:30
group: Pipeline Insights
2022-11-25 23:54:43 +05:30
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/product/ux/technical-writing/#assignments
2019-09-04 21:01:54 +05:30
---
2023-01-13 00:05:48 +05:30
# Review apps **(FREE)**
2017-08-17 22:00:37 +05:30
2023-01-13 00:05:48 +05:30
Review apps are a collaboration tool that provide an environment to showcase product changes.
2017-08-17 22:00:37 +05:30
2021-04-17 20:07:23 +05:30
NOTE:
If you have a Kubernetes cluster, you can automate this feature in your applications
by using [Auto DevOps](../../topics/autodevops/index.md).
2023-01-13 00:05:48 +05:30
Review apps:
2018-12-05 23:21:45 +05:30
- Provide an automatic live preview of changes made in a feature branch by spinning up a dynamic environment for your merge requests.
2019-07-07 11:18:12 +05:30
- Allow designers and product managers to see your changes without needing to check out your branch and run your changes in a sandbox environment.
2021-09-30 23:02:18 +05:30
- Are fully integrated with the [GitLab DevOps LifeCycle](../../index.md#the-entire-devops-lifecycle).
2018-12-05 23:21:45 +05:30
- Allow you to deploy your changes wherever you want.
2023-01-13 00:05:48 +05:30
![review apps workflow](img/continuous-delivery-review-apps.svg)
2018-12-05 23:21:45 +05:30
2021-10-27 15:23:28 +05:30
In the previous example:
2017-08-17 22:00:37 +05:30
2023-01-13 00:05:48 +05:30
- A review app is built every time a commit is pushed to `topic branch`.
2019-07-31 22:56:46 +05:30
- The reviewer fails two reviews before passing the third review.
2021-04-17 20:07:23 +05:30
- After the review passes, `topic branch` is merged into the default branch, where it's deployed to staging.
- After its approval in staging, the changes that were merged into the default branch are deployed to production.
2017-08-17 22:00:37 +05:30
2023-01-13 00:05:48 +05:30
## How review apps work
2019-07-31 22:56:46 +05:30
2023-01-13 00:05:48 +05:30
A review app is a mapping of a branch with an [environment](../environments/index.md).
Access to the review app is made available as a link on the [merge request](../../user/project/merge_requests/index.md) relevant to the branch.
2019-07-31 22:56:46 +05:30
The following is an example of a merge request with an environment set dynamically.
2017-08-17 22:00:37 +05:30
2023-01-13 00:05:48 +05:30
![review app in merge request](img/review_apps_preview_in_mr.png)
2017-08-17 22:00:37 +05:30
2019-07-31 22:56:46 +05:30
In this example, a branch was:
2018-12-05 23:21:45 +05:30
- Successfully built.
2021-10-27 15:23:28 +05:30
- Deployed under a dynamic environment that can be reached by selecting **View app**.
2018-12-05 23:21:45 +05:30
2023-01-13 00:05:48 +05:30
After adding review apps to your workflow, you follow the branched Git flow. That is:
2019-09-30 21:07:59 +05:30
2023-01-13 00:05:48 +05:30
1. Push a branch and let the runner deploy the review app based on the `script` definition of the dynamic environment job.
2020-11-24 15:15:51 +05:30
1. Wait for the runner to build and deploy your web application.
2021-10-27 15:23:28 +05:30
1. To view the changes live, select the link in the merge request related to the branch.
2019-09-30 21:07:59 +05:30
2023-01-13 00:05:48 +05:30
## Configuring review apps
2018-12-05 23:21:45 +05:30
2023-01-13 00:05:48 +05:30
Review apps are built on [dynamic environments](../environments/index.md#create-a-dynamic-environment), which allow you to dynamically create a new environment for each branch.
2018-12-05 23:21:45 +05:30
2023-01-13 00:05:48 +05:30
The process of configuring review apps is as follows:
2017-08-17 22:00:37 +05:30
2023-01-13 00:05:48 +05:30
1. Set up the infrastructure to host and deploy the review apps (check the [examples](#review-apps-examples) below).
2020-11-24 15:15:51 +05:30
1. [Install](https://docs.gitlab.com/runner/install/) and [configure](https://docs.gitlab.com/runner/commands/) a runner to do deployment.
2021-11-11 11:23:49 +05:30
1. Set up a job in `.gitlab-ci.yml` that uses the [predefined CI/CD variable](../variables/index.md) `${CI_COMMIT_REF_SLUG}`
2020-03-13 15:44:24 +05:30
to create dynamic environments and restrict it to run only on branches.
2023-01-13 00:05:48 +05:30
Alternatively, you can get a YAML template for this job by [enabling review apps](#enable-review-app-button) for your project.
1. Optionally, set a job that [manually stops](../environments/index.md#stop-an-environment) the review apps.
2017-08-17 22:00:37 +05:30
2023-01-13 00:05:48 +05:30
### Enable review app button
2020-03-13 15:44:24 +05:30
2020-06-23 00:09:42 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/118844) in GitLab 12.8.
2020-03-13 15:44:24 +05:30
2023-01-13 00:05:48 +05:30
When configuring review apps for a project, you add a new job to the `.gitlab-ci.yml` file,
2021-10-27 15:23:28 +05:30
as mentioned above. To facilitate this, and if you are using Kubernetes, you can select
2023-01-13 00:05:48 +05:30
**Enable review app** and GitLab prompts you with a template code block that
2021-10-27 15:23:28 +05:30
you can copy and paste into `.gitlab-ci.yml` as a starting point.
Prerequisite:
2022-04-04 11:22:00 +05:30
- You need at least the Developer role for the project.
2020-03-13 15:44:24 +05:30
2023-01-13 00:05:48 +05:30
To use the review apps template:
2021-10-27 15:23:28 +05:30
2023-01-13 00:05:48 +05:30
1. On the top bar, select **Main menu > Projects** and find the project you want to create a review app job for.
2021-10-27 15:23:28 +05:30
1. On the left sidebar, select **Deployments > Environments**.
2023-01-13 00:05:48 +05:30
1. Select **Enable review app**.
2020-03-13 15:44:24 +05:30
1. Copy the provided code snippet and paste it into your
`.gitlab-ci.yml` file:
2023-01-13 00:05:48 +05:30
![enable review apps modal](img/enable_review_app_v12_8.png)
2020-03-13 15:44:24 +05:30
2021-10-27 15:23:28 +05:30
You can edit this template as needed.
2020-03-13 15:44:24 +05:30
2023-01-13 00:05:48 +05:30
## Review apps auto-stop
2020-03-13 15:44:24 +05:30
2023-01-13 00:05:48 +05:30
See how to [configure review apps environments to expire and auto-stop](../environments/index.md#stop-an-environment-after-a-certain-time-period)
2020-03-13 15:44:24 +05:30
after a given period of time.
2023-01-13 00:05:48 +05:30
## Review apps examples
2017-08-17 22:00:37 +05:30
2023-01-13 00:05:48 +05:30
The following are example projects that demonstrate review app configuration:
2018-12-05 23:21:45 +05:30
2022-11-25 23:54:43 +05:30
| Project | Configuration file |
|-------------------------------------------------------------------------|--------------------|
| [NGINX](https://gitlab.com/gitlab-examples/review-apps-nginx) | [`.gitlab-ci.yml`](https://gitlab.com/gitlab-examples/review-apps-nginx/-/blob/b9c1f6a8a7a0dfd9c8784cbf233c0a7b6a28ff27/.gitlab-ci.yml#L20) |
| [OpenShift](https://gitlab.com/gitlab-examples/review-apps-openshift) | [`.gitlab-ci.yml`](https://gitlab.com/gitlab-examples/review-apps-openshift/-/blob/82ebd572334793deef2d5ddc379f38942f3488be/.gitlab-ci.yml#L42) |
| [HashiCorp Nomad](https://gitlab.com/gitlab-examples/review-apps-nomad) | [`.gitlab-ci.yml`](https://gitlab.com/gitlab-examples/review-apps-nomad/-/blob/ca372c778be7aaed5e82d3be24e98c3f10a465af/.gitlab-ci.yml#L110) |
| [GitLab Documentation](https://gitlab.com/gitlab-org/gitlab-docs/) | [`build-and-deploy.gitlab-ci.yml`](https://gitlab.com/gitlab-org/gitlab-docs/-/blob/a715625496303cbd90ff89f3d3658ea8d36ce0f3/.gitlab/ci/build-and-deploy.gitlab-ci.yml#L59) |
| [`https://about.gitlab.com/`](https://gitlab.com/gitlab-com/www-gitlab-com/) | [`.gitlab-ci.yml`](https://gitlab.com/gitlab-com/www-gitlab-com/-/blob/6ffcdc3cb9af2abed490cbe5b7417df3e83cd76c/.gitlab-ci.yml#L332) |
| [GitLab Insights](https://gitlab.com/gitlab-org/gitlab-insights/) | [`.gitlab-ci.yml`](https://gitlab.com/gitlab-org/gitlab-insights/-/blob/9e63f44ac2a5a4defc965d0d61d411a768e20546/.gitlab-ci.yml#L234) |
2018-12-05 23:21:45 +05:30
2023-01-13 00:05:48 +05:30
Other examples of review apps:
2020-06-23 00:09:42 +05:30
- <i class="fa fa-youtube-play youtube" aria-hidden="true"></i>
[Cloud Native Development with GitLab](https://www.youtube.com/watch?v=jfIyQEwrocw).
2023-01-13 00:05:48 +05:30
- [Review apps for Android](https://about.gitlab.com/blog/2020/05/06/how-to-create-review-apps-for-android-with-gitlab-fastlane-and-appetize-dot-io/).
2019-03-02 22:35:43 +05:30
2019-09-30 21:07:59 +05:30
## Route Maps
2019-03-02 22:35:43 +05:30
Route Maps allows you to go directly from source files
2020-05-24 23:13:21 +05:30
to public pages on the [environment](../environments/index.md) defined for
2023-01-13 00:05:48 +05:30
review apps.
2019-07-31 22:56:46 +05:30
Once set up, the review app link in the merge request
2019-03-02 22:35:43 +05:30
widget can take you directly to the pages changed, making it easier
and faster to preview proposed modifications.
2019-07-31 22:56:46 +05:30
Configuring Route Maps involves telling GitLab how the paths of files
2019-03-02 22:35:43 +05:30
in your repository map to paths of pages on your website using a Route Map.
2021-03-08 18:12:59 +05:30
Once set, GitLab displays **View on ...** buttons, which take you
2019-03-02 22:35:43 +05:30
to the pages changed directly from merge requests.
2020-01-01 13:55:28 +05:30
To set up a route map, add a file inside the repository at `.gitlab/route-map.yml`,
2019-03-02 22:35:43 +05:30
which contains a YAML array that maps `source` paths (in the repository) to `public`
paths (on the website).
2019-09-30 21:07:59 +05:30
### Route Maps example
2019-03-02 22:35:43 +05:30
2019-07-31 22:56:46 +05:30
The following is an example of a route map for [Middleman](https://middlemanapp.com),
2021-02-22 17:27:13 +05:30
a static site generator (SSG) used to build the [GitLab website](https://about.gitlab.com),
2019-03-02 22:35:43 +05:30
deployed from its [project on GitLab.com](https://gitlab.com/gitlab-com/www-gitlab-com):
```yaml
# Team data
2020-11-24 15:15:51 +05:30
- source: 'data/team.yml' # data/team.yml
public: 'team/' # team/
2019-03-02 22:35:43 +05:30
# Blogposts
2020-11-24 15:15:51 +05:30
- source: /source\/posts\/([0-9]{4})-([0-9]{2})-([0-9]{2})-(.+?)\..*/ # source/posts/2017-01-30-around-the-world-in-6-releases.html.md.erb
public: '\1/\2/\3/\4/' # 2017/01/30/around-the-world-in-6-releases/
2019-03-02 22:35:43 +05:30
# HTML files
2020-11-24 15:15:51 +05:30
- source: /source\/(.+?\.html).*/ # source/index.html.haml
public: '\1' # index.html
2019-03-02 22:35:43 +05:30
# Other files
2020-11-24 15:15:51 +05:30
- source: /source\/(.*)/ # source/images/blogimages/around-the-world-in-6-releases-cover.png
public: '\1' # images/blogimages/around-the-world-in-6-releases-cover.png
2019-03-02 22:35:43 +05:30
```
2019-07-31 22:56:46 +05:30
Mappings are defined as entries in the root YAML array, and are identified by a `-` prefix. Within an entry, there is a hash map with two keys:
2019-03-02 22:35:43 +05:30
- `source`
2019-07-31 22:56:46 +05:30
- A string, starting and ending with `'`, for an exact match.
- A regular expression, starting and ending with `/`, for a pattern match:
- The regular expression needs to match the entire source path - `^` and `$` anchors are implied.
- Can include capture groups denoted by `()` that can be referred to in the `public` path.
- Slashes (`/`) can, but don't have to, be escaped as `\/`.
- Literal periods (`.`) should be escaped as `\.`.
- `public`, a string starting and ending with `'`.
- Can include `\N` expressions to refer to capture groups in the `source` regular expression in order of their occurrence, starting with `\1`.
2019-03-02 22:35:43 +05:30
The public path for a source path is determined by finding the first
`source` expression that matches it, and returning the corresponding
`public` path, replacing the `\N` expressions with the values of the
`()` capture groups if appropriate.
In the example above, the fact that mappings are evaluated in order
of their definition is used to ensure that `source/index.html.haml`
2021-03-08 18:12:59 +05:30
matches `/source\/(.+?\.html).*/` instead of `/source\/(.*)/`,
and results in a public path of `index.html`, instead of
2019-03-02 22:35:43 +05:30
`index.html.haml`.
2021-03-08 18:12:59 +05:30
After you have the route mapping set up, it takes effect in the following locations:
2019-03-02 22:35:43 +05:30
2021-10-27 15:23:28 +05:30
- In the merge request widget:
- The **View app** button takes you to the environment URL set in the `.gitlab-ci.yml` file.
- The list shows the first 5 matched items from the route map, but you can filter them if more
2019-07-31 22:56:46 +05:30
than 5 are available.
2019-03-02 22:35:43 +05:30
![View app file list in merge request widget](img/view_on_mr_widget.png)
2022-03-02 08:16:31 +05:30
- In the diff for a comparison or commit.
2019-03-02 22:35:43 +05:30
2021-03-11 19:13:27 +05:30
![View on environment button in merge request diff](img/view_on_env_mr.png)
2019-03-02 22:35:43 +05:30
- In the blob file view.
2021-03-11 19:13:27 +05:30
![View on environment button in file view](img/view_on_env_blob.png)
2019-07-31 22:56:46 +05:30
2021-03-11 19:13:27 +05:30
## Visual Reviews **(PREMIUM)**
2019-09-04 21:01:54 +05:30
2021-03-11 19:13:27 +05:30
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/10761) in GitLab 12.0.
> - [Moved](https://about.gitlab.com/blog/2021/01/26/new-gitlab-product-subscription-model/) to GitLab Premium in 13.9.
2022-06-21 17:19:12 +05:30
> - It's [deployed behind a feature flag](../../user/feature_flags.md), `anonymous_visual_review_feedback`, disabled by default.
2023-01-13 00:05:48 +05:30
> - It's disabled on GitLab.com.
2022-06-21 17:19:12 +05:30
FLAG:
On self-managed GitLab, by default this feature is not available. To make it available,
ask an administrator to [enable the feature flag](../../administration/feature_flags.md) named `anonymous_visual_review_feedback`.
2019-09-04 21:01:54 +05:30
2021-01-03 14:25:43 +05:30
With Visual Reviews, members of any team (Product, Design, Quality, and so on) can provide feedback comments through a form in your review apps. The comments are added to the merge request that triggered the review app.
2019-09-04 21:01:54 +05:30
2021-01-03 14:25:43 +05:30
### Using Visual Reviews
2019-09-04 21:01:54 +05:30
2021-01-03 14:25:43 +05:30
After Visual Reviews has been [configured](#configure-review-apps-for-visual-reviews) for the
2023-01-13 00:05:48 +05:30
review app, the Visual Reviews feedback form is overlaid on the right side of every page.
2020-01-01 13:55:28 +05:30
2021-01-03 14:25:43 +05:30
![Visual review feedback form](img/toolbar_feedback_form_v13_5.png)
To use the feedback form to make a comment in the merge request:
2021-10-27 15:23:28 +05:30
1. On the right side of a page, select the **Review** tab.
2021-01-03 14:25:43 +05:30
1. Make a comment on the visual review. You can make use of all the
[Markdown annotations](../../user/markdown.md) that are also available in
merge request comments.
1. Enter your personal information:
- If [`data-require-auth`](#authentication-for-visual-reviews) is `true`, you must enter your [personal access token](../../user/profile/personal_access_tokens.md).
- Otherwise, enter your name, and optionally your email.
2021-10-27 15:23:28 +05:30
1. Select **Send feedback**.
2021-01-03 14:25:43 +05:30
<i class="fa fa-youtube-play youtube" aria-hidden="true"></i>
To see Visual reviews in action, see the [Visual Reviews Walk through](https://youtu.be/1_tvWTlPfM4).
2023-01-13 00:05:48 +05:30
### Configure review apps for Visual Reviews
2020-01-01 13:55:28 +05:30
2023-01-13 00:05:48 +05:30
The feedback form is served through a script you add to pages in your review app.
2021-10-27 15:23:28 +05:30
It should be added to the `<head>` of your application and
2021-01-03 14:25:43 +05:30
consists of some project and merge request specific values. Here's how it
looks for a project with code hosted in a project on GitLab.com:
2019-09-30 21:07:59 +05:30
```html
<script
data-project-id='11790219'
data-merge-request-id='1'
2021-01-03 14:25:43 +05:30
data-mr-url='https://gitlab.com'
2019-09-30 21:07:59 +05:30
data-project-path='sarah/review-app-tester'
2020-04-22 19:07:51 +05:30
data-require-auth='true'
2019-09-30 21:07:59 +05:30
id='review-app-toolbar-script'
2021-01-03 14:25:43 +05:30
src='https://gitlab.com/assets/webpack/visual_review_toolbar.js'>
2019-09-30 21:07:59 +05:30
</script>
```
2019-09-04 21:01:54 +05:30
2021-03-11 19:13:27 +05:30
Ideally, you should use [CI/CD variables](../variables/predefined_variables.md)
2019-09-30 21:07:59 +05:30
to replace those values at runtime when each review app is created:
- `data-project-id` is the project ID, which can be found by the `CI_PROJECT_ID`
variable.
- `data-merge-request-id` is the merge request ID, which can be found by the
`CI_MERGE_REQUEST_IID` variable. `CI_MERGE_REQUEST_IID` is available only if
2021-09-30 23:02:18 +05:30
[`only: [merge_requests]`](../pipelines/merge_request_pipelines.md)
2019-09-30 21:07:59 +05:30
is used and the merge request is created.
2021-03-08 18:12:59 +05:30
- `data-mr-url` is the URL of the GitLab instance and is the same for all
2019-09-30 21:07:59 +05:30
review apps.
- `data-project-path` is the project's path, which can be found by `CI_PROJECT_PATH`.
2021-03-08 18:12:59 +05:30
- `data-require-auth` is optional for public projects but required for [private and internal ones](#authentication-for-visual-reviews). If this is set to `true`, the user is required to enter their [personal access token](../../user/profile/personal_access_tokens.md) instead of their name and email.
2019-09-30 21:07:59 +05:30
- `id` is always `review-app-toolbar-script`, you don't need to change that.
- `src` is the source of the review toolbar script, which resides in the
2021-03-08 18:12:59 +05:30
respective GitLab instance and is the same for all review apps.
2019-09-30 21:07:59 +05:30
2021-01-03 14:25:43 +05:30
For example, in a Ruby application with code hosted on in a project GitLab.com, you would need to have this script:
2019-09-30 21:07:59 +05:30
```html
<script
data-project-id="ENV['CI_PROJECT_ID']"
data-merge-request-id="ENV['CI_MERGE_REQUEST_IID']"
2021-01-03 14:25:43 +05:30
data-mr-url='https://gitlab.com'
2019-09-30 21:07:59 +05:30
data-project-path="ENV['CI_PROJECT_PATH']"
id='review-app-toolbar-script'
2021-01-03 14:25:43 +05:30
src='https://gitlab.com/assets/webpack/visual_review_toolbar.js'>
2019-09-30 21:07:59 +05:30
</script>
```
2019-09-04 21:01:54 +05:30
2019-09-30 21:07:59 +05:30
Then, when your app is deployed via GitLab CI/CD, those variables should get
replaced with their real values.
2019-09-04 21:01:54 +05:30
2020-01-01 13:55:28 +05:30
### Determining merge request ID
The visual review tools retrieve the merge request ID from the `data-merge-request-id`
data attribute included in the `script` HTML tag used to add the visual review tools
to your review app.
2021-04-17 20:07:23 +05:30
After determining the ID for the merge request to link to a visual review app, you
can supply the ID by either:
2020-01-01 13:55:28 +05:30
2020-05-24 23:13:21 +05:30
- Hard-coding it in the script tag via the data attribute `data-merge-request-id` of the app.
2020-01-01 13:55:28 +05:30
- Dynamically adding the `data-merge-request-id` value during the build of the app.
- Supplying it manually through the visual review form in the app.
2022-08-13 15:12:31 +05:30
If the ID is missing from the `script`, the visual review tool prompts you to enter the
merge request ID before you can provide feedback.
2021-01-03 14:25:43 +05:30
### Authentication for Visual Reviews
2019-09-30 21:07:59 +05:30
2021-01-03 14:25:43 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/42750#note_317271120) in GitLab 12.10.
To enable visual reviews for private and internal projects, set the
2022-06-21 17:19:12 +05:30
[`data-require-auth` variable](#configure-review-apps-for-visual-reviews) to `true`. When enabled,
2021-01-03 14:25:43 +05:30
the user must enter a [personal access token](../../user/profile/personal_access_tokens.md)
with `api` scope before submitting feedback.
2019-09-04 21:01:54 +05:30
2021-01-03 14:25:43 +05:30
This same method can be used to require authentication for any public projects.