debian-mirror-gitlab/doc/user/project/releases/index.md

785 lines
32 KiB
Markdown
Raw Normal View History

2019-10-12 21:52:04 +05:30
---
type: reference, howto
2020-05-24 23:13:21 +05:30
stage: Release
2021-02-22 17:27:13 +05:30
group: Release
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments
2019-10-12 21:52:04 +05:30
---
2021-04-29 21:17:54 +05:30
# Releases **(FREE)**
2019-02-15 15:39:39 +05:30
2020-06-23 00:09:42 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/41766) in GitLab 11.7.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
To introduce a checkpoint in your source code history, you can assign a
[Git tag](https://git-scm.com/book/en/v2/Git-Basics-Tagging) at the moment of release.
However, in most cases, your users need more than just the raw source code.
They need compiled objects or other assets output by your CI/CD system.
2021-09-30 23:02:18 +05:30
A GitLab Release can be:
- A snapshot of the source code of your repository.
- [Generic packages](../../packages/generic_packages/index.md) created from job artifacts.
- Other metadata associated with a released version of your code.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
You can create a GitLab release on any branch. When you create a release:
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
- GitLab automatically archives source code and associates it with the release.
- GitLab automatically creates a JSON file that lists everything in the release,
so you can compare and audit releases. This file is called [release evidence](#release-evidence).
- You can add release notes and a message for the tag associated with the release.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
After you create a release, you can [associate milestones with it](#associate-milestones-with-a-release),
and attach [release assets](#release-assets), like runbooks or packages.
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
## View releases
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/36667) in GitLab 12.8.
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
To view a list of releases:
2020-04-08 14:13:33 +05:30
2021-09-04 01:27:46 +05:30
- On the left sidebar, select **Deployments > Releases**, or
2020-07-28 23:09:34 +05:30
- On the project's overview page, if at least one release exists, click the number of releases.
![Number of Releases](img/releases_count_v13_2.png "Incremental counter of Releases")
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
- On public projects, this number is visible to all users.
- On private projects, this number is visible to users with Reporter
[permissions](../../permissions.md#project-members-permissions) or higher.
2019-02-15 15:39:39 +05:30
2021-01-29 00:20:46 +05:30
### Sort Releases
On the top right of the **Releases** page, you can use the sorting button to order releases by
**Released date** or **Created date**. You can sort releases in ascending or descending order.
![Sort Releases dropdown button](img/releases_sort_v13_6.png)
2020-07-28 23:09:34 +05:30
## Create a release
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/32812) in GitLab 12.9. Releases can be created directly in the GitLab UI.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
You can create a release in the user interface, or by using the
[Releases API](../../../api/releases/index.md#create-a-release).
2020-10-24 23:57:45 +05:30
We recommend using the API to create releases as one of the last steps in your
CI/CD pipeline.
2019-02-15 15:39:39 +05:30
2021-09-30 23:02:18 +05:30
Only users with at least the Developer role can create releases.
Read more about [Release permissions](#release-permissions).
2021-01-03 14:25:43 +05:30
2020-07-28 23:09:34 +05:30
To create a new release through the GitLab UI:
2019-02-15 15:39:39 +05:30
2021-09-04 01:27:46 +05:30
1. On the left sidebar, select **Deployments > Releases** and select **New release**.
2021-04-17 20:07:23 +05:30
1. Open the [**Tag name**](#tag-name) dropdown. Select an existing tag or type
in a new tag name. Selecting an existing tag that is already associated with
a release will result in a validation error.
1. If creating a new tag, open the **Create from** dropdown. Select a
branch, tag, or commit SHA to use when creating the new tag.
2020-10-24 23:57:45 +05:30
1. Optionally, fill out any additional information about the release, such as its
[title](#title), [milestones](#associate-milestones-with-a-release),
[release notes](#release-notes-description), or [assets links](#links).
1. Click **Create release**.
2019-02-15 15:39:39 +05:30
2021-12-11 22:18:48 +05:30
## Create a release by using a CI/CD job
2021-02-22 17:27:13 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/19298) in GitLab 12.7.
2021-12-11 22:18:48 +05:30
You can create a release directly as part of the GitLab CI/CD pipeline
by using [the `release` keyword](../../../ci/yaml/index.md#release) in the job definition.
2021-02-22 17:27:13 +05:30
The release is created only if the job processes without error. If the Rails API returns an error
during release creation, the release job fails.
2021-12-11 22:18:48 +05:30
### CI/CD example of the `release` keyword
To create a release when you push a Git tag, or when you add a Git tag
in the UI by going to **Repository > Tags**:
```yaml
release_job:
stage: release
image: registry.gitlab.com/gitlab-org/release-cli:latest
rules:
- if: $CI_COMMIT_TAG # Run this job when a tag is created manually
script:
- echo 'running release_job'
release:
name: 'Release $CI_COMMIT_TAG'
description: 'Created using the release-cli $EXTRA_DESCRIPTION' # $EXTRA_DESCRIPTION must be defined
tag_name: '$CI_COMMIT_TAG' # elsewhere in the pipeline.
ref: '$CI_COMMIT_TAG'
milestones:
- 'm1'
- 'm2'
- 'm3'
released_at: '2020-07-15T08:00:00Z' # Optional, is auto generated if not defined, or can use a variable.
assets: # Optional, multiple asset links
links:
- name: 'asset1'
url: 'https://example.com/assets/1'
- name: 'asset2'
url: 'https://example.com/assets/2'
filepath: '/pretty/url/1' # optional
link_type: 'other' # optional
```
To create a release automatically when commits are pushed or merged to the default branch,
using a new Git tag that is defined with variables:
```yaml
prepare_job:
stage: prepare # This stage must run before the release stage
rules:
- if: $CI_COMMIT_TAG
when: never # Do not run this job when a tag is created manually
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH # Run this job when commits are pushed or merged to the default branch
script:
- echo "EXTRA_DESCRIPTION=some message" >> variables.env # Generate the EXTRA_DESCRIPTION and TAG environment variables
- echo "TAG=v$(cat VERSION)" >> variables.env # and append to the variables.env file
artifacts:
reports:
dotenv: variables.env # Use artifacts:reports:dotenv to expose the variables to other jobs
release_job:
stage: release
image: registry.gitlab.com/gitlab-org/release-cli:latest
needs:
- job: prepare_job
artifacts: true
rules:
- if: $CI_COMMIT_TAG
when: never # Do not run this job when a tag is created manually
- if: $CI_COMMIT_BRANCH == $CI_DEFAULT_BRANCH # Run this job when commits are pushed or merged to the default branch
script:
- echo 'running release_job for $TAG'
release:
name: 'Release $TAG'
description: 'Created using the release-cli $EXTRA_DESCRIPTION' # $EXTRA_DESCRIPTION and the $TAG
tag_name: '$TAG' # variables must be defined elsewhere
ref: '$CI_COMMIT_SHA' # in the pipeline. For example, in the
milestones: # prepare_job
- 'm1'
- 'm2'
- 'm3'
released_at: '2020-07-15T08:00:00Z' # Optional, is auto generated if not defined, or can use a variable.
assets:
links:
- name: 'asset1'
url: 'https://example.com/assets/1'
- name: 'asset2'
url: 'https://example.com/assets/2'
filepath: '/pretty/url/1' # optional
link_type: 'other' # optional
```
NOTE:
Environment variables set in `before_script` or `script` are not available for expanding
in the same job. Read more about
[potentially making variables available for expanding](https://gitlab.com/gitlab-org/gitlab-runner/-/issues/6400).
### Use a custom SSL CA certificate authority
You can use the `ADDITIONAL_CA_CERT_BUNDLE` CI/CD variable to configure a custom SSL CA certificate authority,
which is used to verify the peer when the `release-cli` creates a release through the API using HTTPS with custom certificates.
The `ADDITIONAL_CA_CERT_BUNDLE` value should contain the
[text representation of the X.509 PEM public-key certificate](https://tools.ietf.org/html/rfc7468#section-5.1)
or the `path/to/file` containing the certificate authority.
For example, to configure this value in the `.gitlab-ci.yml` file, use the following:
```yaml
release:
variables:
ADDITIONAL_CA_CERT_BUNDLE: |
-----BEGIN CERTIFICATE-----
MIIGqTCCBJGgAwIBAgIQI7AVxxVwg2kch4d56XNdDjANBgkqhkiG9w0BAQsFADCB
...
jWgmPqF3vUbZE0EyScetPJquRFRKIesyJuBFMAs=
-----END CERTIFICATE-----
script:
- echo "Create release"
release:
name: 'My awesome release'
tag_name: '$CI_COMMIT_TAG'
```
The `ADDITIONAL_CA_CERT_BUNDLE` value can also be configured as a
[custom variable in the UI](../../../ci/variables/index.md#custom-cicd-variables),
either as a `file`, which requires the path to the certificate, or as a variable,
which requires the text representation of the certificate.
### `release-cli` command line
The entries under the `release` node are transformed into a `bash` command line and sent
to the Docker container, which contains the [release-cli](https://gitlab.com/gitlab-org/release-cli).
You can also call the `release-cli` directly from a `script` entry.
For example, if you use the YAML described previously:
```shell
release-cli create --name "Release $CI_COMMIT_SHA" --description "Created using the release-cli $EXTRA_DESCRIPTION" --tag-name "v${MAJOR}.${MINOR}.${REVISION}" --ref "$CI_COMMIT_SHA" --released-at "2020-07-15T08:00:00Z" --milestone "m1" --milestone "m2" --milestone "m3" --assets-link "{\"name\":\"asset1\",\"url\":\"https://example.com/assets/1\",\"link_type\":\"other\"}
```
### Create multiple releases in a single pipeline
A pipeline can have multiple `release` jobs, for example:
```yaml
ios-release:
script:
- echo 'iOS release job'
release:
tag_name: v1.0.0-ios
description: 'iOS release v1.0.0'
android-release:
script:
- echo 'Android release job'
release:
tag_name: v1.0.0-android
description: 'Android release v1.0.0'
```
### Release assets as Generic packages
You can use [Generic packages](../../packages/generic_packages/index.md) to host your release assets.
For a complete example, see the [Release assets as Generic packages](https://gitlab.com/gitlab-org/release-cli/-/tree/master/docs/examples/release-assets-as-generic-package/)
project.
## Upcoming releases
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/38105) in GitLab 12.1.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
You can create a release ahead of time by using the [Releases API](../../../api/releases/index.md#upcoming-releases).
When you set a future `released_at` date, an **Upcoming Release** badge is displayed next to the
release tag. When the `released_at` date and time has passed, the badge is automatically removed.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
![An upcoming release](img/upcoming_release_v12_7.png)
2020-06-23 00:09:42 +05:30
2020-07-28 23:09:34 +05:30
## Edit a release
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/26016) in GitLab 12.6. Asset link editing was [introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/9427) in GitLab 12.10.
2020-04-08 14:13:33 +05:30
2021-10-27 15:23:28 +05:30
Only users with at least the Developer role can edit releases.
2021-09-30 23:02:18 +05:30
Read more about [Release permissions](#release-permissions).
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
To edit the details of a release:
2020-04-08 14:13:33 +05:30
2021-09-04 01:27:46 +05:30
1. On the left sidebar, select **Deployments > Releases**.
2020-07-28 23:09:34 +05:30
1. In the top-right corner of the release you want to modify, click **Edit this release** (the pencil icon).
1. On the **Edit Release** page, change the release's details.
1. Click **Save changes**.
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
You can edit the release title, notes, associated milestones, and asset links.
2020-11-24 15:15:51 +05:30
To change the release date use the
2020-07-28 23:09:34 +05:30
[Releases API](../../../api/releases/index.md#update-a-release).
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
## Add release notes to Git tags
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
If you have an existing Git tag, you can add release notes to it.
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
You can do this in the user interface, or by using the [Releases API](../../../api/releases/index.md).
We recommend using the API to add release notes as one of the last steps in your CI/CD release pipeline.
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
In the interface, to add release notes to a new Git tag:
1. Navigate to your project's **Repository > Tags**.
1. Click **New tag**.
1. In the **Release notes** field, enter the release's description.
You can use Markdown and drag and drop files to this field.
1. Click **Create tag**.
In the interface, to add release notes to an existing Git tag:
1. Navigate to your project's **Repository > Tags**.
1. Click **Edit release notes** (the pencil icon).
1. In the **Release notes** field, enter the release's description.
You can use Markdown in this field, and drag and drop files to it.
1. Click **Save changes**.
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
## Associate milestones with a release
2019-12-26 22:10:19 +05:30
2020-06-23 00:09:42 +05:30
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/29020) in GitLab 12.5.
2020-05-24 23:13:21 +05:30
> - [Updated](https://gitlab.com/gitlab-org/gitlab/-/issues/39467) to edit milestones in the UI in GitLab 13.0.
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
You can associate a release with one or more [project milestones](../milestones/index.md#project-milestones-and-group-milestones).
2021-01-29 00:20:46 +05:30
[GitLab Premium](https://about.gitlab.com/pricing/) customers can specify [group milestones](../milestones/index.md#project-milestones-and-group-milestones) to associate with a release.
2020-07-28 23:09:34 +05:30
You can do this in the user interface, or by including a `milestones` array in your request to
the [Releases API](../../../api/releases/index.md#create-a-release).
In the user interface, to associate milestones to a release:
2020-05-24 23:13:21 +05:30
2021-09-04 01:27:46 +05:30
1. On the left sidebar, select **Deployments > Releases**.
2020-07-28 23:09:34 +05:30
1. In the top-right corner of the release you want to modify, click **Edit this release** (the pencil icon).
1. From the **Milestones** list, select each milestone you want to associate. You can select multiple milestones.
1. Click **Save changes**.
2019-12-26 22:10:19 +05:30
2021-09-04 01:27:46 +05:30
On the **Deployments > Releases** page, the **Milestone** is listed in the top
2020-07-28 23:09:34 +05:30
section, along with statistics about the issues in the milestones.
2019-12-26 22:10:19 +05:30
2020-04-08 14:13:33 +05:30
![A Release with one associated milestone](img/release_with_milestone_v12_9.png)
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
Releases are also visible on the **Issues > Milestones** page, and when you click a milestone
on this page.
Here is an example of milestones with no releases, one release, and two releases, respectively.
2019-12-26 22:10:19 +05:30
![Milestones with and without Release associations](img/milestone_list_with_releases_v12_5.png)
2020-07-28 23:09:34 +05:30
## Get notified when a release is created
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/26001) in GitLab 12.4.
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
You can be notified by email when a new release is created for your project.
2019-02-15 15:39:39 +05:30
2020-07-28 23:09:34 +05:30
To subscribe to notifications for releases:
2019-02-15 15:39:39 +05:30
2021-09-04 01:27:46 +05:30
1. On the left sidebar, select **Project information**.
2020-07-28 23:09:34 +05:30
1. Click **Notification setting** (the bell icon).
1. In the list, click **Custom**.
2021-10-27 15:23:28 +05:30
1. Select the **New release** checkbox.
2020-07-28 23:09:34 +05:30
1. Close the dialog box to save.
2019-10-12 21:52:04 +05:30
2020-07-28 23:09:34 +05:30
## Prevent unintentional releases by setting a deploy freeze
2020-03-13 15:44:24 +05:30
2021-11-11 11:23:49 +05:30
> - [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/29382) in GitLab 13.0.
> - The ability to delete freeze periods through the UI was [introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/212451) in GitLab 14.3.
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
Prevent unintended production releases during a period of time you specify by
setting a [*deploy freeze* period](../../../ci/environments/deployment_safety.md).
Deploy freezes help reduce uncertainty and risk when automating deployments.
2020-03-13 15:44:24 +05:30
2020-10-24 23:57:45 +05:30
A maintainer can set a deploy freeze window in the user interface or by using the [Freeze Periods API](../../../api/freeze_periods.md) to set a `freeze_start` and a `freeze_end`, which
2020-07-28 23:09:34 +05:30
are defined as [crontab](https://crontab.guru/) entries.
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
If the job that's executing is within a freeze period, GitLab CI/CD creates an environment
variable named `$CI_DEPLOY_FREEZE`.
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
To prevent the deployment job from executing, create a `rules` entry in your
2021-11-11 11:23:49 +05:30
`.gitlab-ci.yml`, for example:
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
```yaml
deploy_to_production:
stage: deploy
script: deploy_to_prod.sh
rules:
- if: $CI_DEPLOY_FREEZE == null
```
2020-03-13 15:44:24 +05:30
2020-10-24 23:57:45 +05:30
To set a deploy freeze window in the UI, complete these steps:
2021-09-04 01:27:46 +05:30
1. Sign in to GitLab as a user with the [Maintainer role](../../permissions.md).
1. On the left sidebar, select **Project information**.
2021-04-17 20:07:23 +05:30
1. In the left navigation menu, navigate to **Settings > CI/CD**.
2020-10-24 23:57:45 +05:30
1. Scroll to **Deploy freezes**.
1. Click **Expand** to see the deploy freeze table.
1. Click **Add deploy freeze** to open the deploy freeze modal.
2021-11-18 22:05:49 +05:30
1. Enter the start time, end time, and time zone of the desired deploy freeze period.
2020-10-24 23:57:45 +05:30
1. Click **Add deploy freeze** in the modal.
2021-11-11 11:23:49 +05:30
1. After the deploy freeze is saved, you can edit it by selecting the edit button (**{pencil}**) and remove it by selecting the delete button (**{remove}**).
![Deploy freeze modal for setting a deploy freeze period](img/deploy_freeze_v14_3.png)
2020-10-24 23:57:45 +05:30
2020-07-28 23:09:34 +05:30
If a project contains multiple freeze periods, all periods apply. If they overlap, the freeze covers the
complete overlapping period.
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
For more information, see [Deployment safety](../../../ci/environments/deployment_safety.md).
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
## Release fields
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
The following fields are available when you create or edit a release.
2020-04-08 14:13:33 +05:30
2020-10-24 23:57:45 +05:30
### Title
The release title can be customized using the **Release title** field when
creating or editing a release. If no title is provided, the release's tag name
is used instead.
2020-07-28 23:09:34 +05:30
### Tag name
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
The release tag name should include the release version. GitLab uses [Semantic Versioning](https://semver.org/)
for our releases, and we recommend you do too. Use `(Major).(Minor).(Patch)`, as detailed in the
[GitLab Policy for Versioning](../../../policy/maintenance.md#versioning).
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
For example, for GitLab version `10.5.7`:
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
- `10` represents the major version. The major release was `10.0.0`, but often referred to as `10.0`.
- `5` represents the minor version. The minor release was `10.5.0`, but often referred to as `10.5`.
- `7` represents the patch number.
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
Any part of the version number can be multiple digits, for example, `13.10.11`.
2020-04-08 14:13:33 +05:30
2020-07-28 23:09:34 +05:30
### Release notes description
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
Every release has a description. You can add any text you like, but we recommend
including a changelog to describe the content of your release. This helps users
quickly scan the differences between each release you publish.
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
[Git's tagging messages](https://git-scm.com/book/en/v2/Git-Basics-Tagging) and
Release note descriptions are unrelated. Description supports [Markdown](../../markdown.md).
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
### Release assets
2019-12-26 22:10:19 +05:30
2021-06-08 01:23:25 +05:30
A release contains the following types of assets:
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
- [Source code](#source-code)
2021-09-30 23:02:18 +05:30
- [Link](#links)
2021-06-08 01:23:25 +05:30
#### Source code
GitLab automatically generates `zip`, `tar.gz`, `tar.bz2`, and `tar`
archived source code from the given Git tag. These are read-only assets.
2020-04-22 19:07:51 +05:30
2021-09-30 23:02:18 +05:30
#### Links
A link is any URL which can point to whatever you like: documentation, built
binaries, or other related materials. These can be both internal or external
links from your GitLab instance.
Each link as an asset has the following attributes:
| Attribute | Description | Required |
| ---- | ----------- | --- |
| `name` | The name of the link. | Yes |
| `url` | The URL to download a file. | Yes |
| `filepath` | The redirect link to the `url`. See [this section](#permanent-links-to-release-assets) for more information. | No |
| `link_type` | The content kind of what users can download via `url`. See [this section](#link-types) for more information. | No |
##### Permanent links to release assets
2019-12-21 20:55:43 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/27300) in GitLab 12.9.
2019-12-21 20:55:43 +05:30
2020-07-28 23:09:34 +05:30
The assets associated with a release are accessible through a permanent URL.
2020-10-24 23:57:45 +05:30
GitLab always redirects this URL to the actual asset
2020-07-28 23:09:34 +05:30
location, so even if the assets move to a different location, you can continue
to use the same URL. This is defined during [link creation](../../../api/releases/links.md#create-a-link) or [updating](../../../api/releases/links.md#update-a-link).
2019-12-21 20:55:43 +05:30
2021-06-08 01:23:25 +05:30
The format of the URL is:
2019-12-21 20:55:43 +05:30
2020-07-28 23:09:34 +05:30
```plaintext
https://host/namespace/project/releases/:release/downloads/:filepath
```
2019-12-21 20:55:43 +05:30
2020-07-28 23:09:34 +05:30
If you have an asset for the `v11.9.0-rc2` release in the `gitlab-org`
namespace and `gitlab-runner` project on `gitlab.com`, for example:
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
```json
{
"name": "linux amd64",
"filepath": "/binaries/gitlab-runner-linux-amd64",
2021-06-08 01:23:25 +05:30
"url": "https://gitlab-runner-downloads.s3.amazonaws.com/v11.9.0-rc2/binaries/gitlab-runner-linux-amd64",
"link_type": "other"
2020-07-28 23:09:34 +05:30
}
```
This asset has a direct link of:
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
```plaintext
https://gitlab.com/gitlab-org/gitlab-runner/releases/v11.9.0-rc2/downloads/binaries/gitlab-runner-linux-amd64
```
2020-10-24 23:57:45 +05:30
The physical location of the asset can change at any time and the direct link remains unchanged.
2019-12-26 22:10:19 +05:30
2021-09-30 23:02:18 +05:30
##### Link Types
2019-12-26 22:10:19 +05:30
2021-09-30 23:02:18 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/207257) in GitLab 13.1.
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
The four types of links are "Runbook," "Package," "Image," and "Other."
2021-09-30 23:02:18 +05:30
The `link_type` parameter accepts one of the following four values:
- `runbook`
- `package`
- `image`
- `other` (default)
This field has no effect on the URL and it's only used for visual purposes in the Releases page of your project.
##### Use a generic package for attaching binaries
You can use [generic packages](../../packages/generic_packages/index.md)
to store any artifacts from a release or tag pipeline,
that can also be used for attaching binary files to an individual release entry.
You basically need to:
1. [Push the artifacts to the Generic Package Registry](../../packages/generic_packages/index.md#publish-a-package-file).
1. [Attach the package link to the release](#links).
The following example generates release assets, publishes them
as a generic package, and then creates a release:
```yaml
stages:
- build
- upload
- release
variables:
# Package version can only contain numbers (0-9), and dots (.).
# Must be in the format of X.Y.Z, i.e. should match /\A\d+\.\d+\.\d+\z/ regular expresion.
# See https://docs.gitlab.com/ee/user/packages/generic_packages/#publish-a-package-file
PACKAGE_VERSION: "1.2.3"
DARWIN_AMD64_BINARY: "myawesomerelease-darwin-amd64-${PACKAGE_VERSION}"
LINUX_AMD64_BINARY: "myawesomerelease-linux-amd64-${PACKAGE_VERSION}"
PACKAGE_REGISTRY_URL: "${CI_API_V4_URL}/projects/${CI_PROJECT_ID}/packages/generic/myawesomerelease/${PACKAGE_VERSION}"
build:
stage: build
image: alpine:latest
rules:
- if: $CI_COMMIT_TAG
script:
- mkdir bin
- echo "Mock binary for ${DARWIN_AMD64_BINARY}" > bin/${DARWIN_AMD64_BINARY}
- echo "Mock binary for ${LINUX_AMD64_BINARY}" > bin/${LINUX_AMD64_BINARY}
artifacts:
paths:
- bin/
upload:
stage: upload
image: curlimages/curl:latest
rules:
- if: $CI_COMMIT_TAG
script:
- |
2021-11-11 11:23:49 +05:30
curl --header "JOB-TOKEN: ${CI_JOB_TOKEN}" --upload-file bin/${DARWIN_AMD64_BINARY} "${PACKAGE_REGISTRY_URL}/${DARWIN_AMD64_BINARY}"
2021-09-30 23:02:18 +05:30
- |
2021-11-11 11:23:49 +05:30
curl --header "JOB-TOKEN: ${CI_JOB_TOKEN}" --upload-file bin/${LINUX_AMD64_BINARY} "${PACKAGE_REGISTRY_URL}/${LINUX_AMD64_BINARY}"
2021-09-30 23:02:18 +05:30
release:
# Caution, as of 2021-02-02 these assets links require a login, see:
# https://gitlab.com/gitlab-org/gitlab/-/issues/299384
stage: release
image: registry.gitlab.com/gitlab-org/release-cli:latest
rules:
- if: $CI_COMMIT_TAG
script:
- |
release-cli create --name "Release $CI_COMMIT_TAG" --tag-name $CI_COMMIT_TAG \
--assets-link "{\"name\":\"${DARWIN_AMD64_BINARY}\",\"url\":\"${PACKAGE_REGISTRY_URL}/${DARWIN_AMD64_BINARY}\"}" \
--assets-link "{\"name\":\"${LINUX_AMD64_BINARY}\",\"url\":\"${PACKAGE_REGISTRY_URL}/${LINUX_AMD64_BINARY}\"}"
```
PowerShell users may need to escape the double quote `"` inside a JSON
string with a `` ` `` (back tick) for `--assets-link` and `ConvertTo-Json`
before passing on to the `release-cli`.
For example:
```yaml
release:
script:
- $env:asset = "{`"name`":`"MyFooAsset`",`"url`":`"https://gitlab.com/upack/artifacts/download/$env:UPACK_GROUP/$env:UPACK_NAME/$($env:GitVersion_SemVer)?contentOnly=zip`"}"
- $env:assetjson = $env:asset | ConvertTo-Json
- release-cli create --name $CI_COMMIT_TAG --description "Release $CI_COMMIT_TAG" --ref $CI_COMMIT_TAG --tag-name $CI_COMMIT_TAG --assets-link=$env:assetjson
```
NOTE:
Directly attaching [job artifacts](../../../ci/pipelines/job_artifacts.md)
links to a release is not recommended, because artifacts are ephemeral and
are used to pass data in the same pipeline. This means there's a risk that
they could either expire or someone might manually delete them.
2019-12-26 22:10:19 +05:30
2020-07-28 23:09:34 +05:30
## Release evidence
2019-12-26 22:10:19 +05:30
2020-06-23 00:09:42 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/26019) in GitLab 12.6.
2019-12-26 22:10:19 +05:30
2020-04-22 19:07:51 +05:30
Each time a release is created, GitLab takes a snapshot of data that's related to it.
2021-03-08 18:12:59 +05:30
This data is saved in a JSON file and called *release evidence*. The feature
includes test artifacts and linked milestones to facilitate
2020-11-24 15:15:51 +05:30
internal processes, like external audits.
2020-07-28 23:09:34 +05:30
To access the release evidence, on the Releases page, click the link to the JSON file that's listed
under the **Evidence collection** heading.
2020-04-22 19:07:51 +05:30
2020-11-24 15:15:51 +05:30
You can also [use the API](../../../api/releases/index.md#collect-release-evidence) to
2020-07-28 23:09:34 +05:30
generate release evidence for an existing release. Because of this, each release
can have multiple release evidence snapshots. You can view the release evidence and
its details on the Releases page.
2019-12-26 22:10:19 +05:30
2021-01-03 14:25:43 +05:30
When the issue tracker is disabled, release evidence [can't be downloaded](https://gitlab.com/gitlab-org/gitlab/-/issues/208397).
2020-05-24 23:13:21 +05:30
2020-07-28 23:09:34 +05:30
Here is an example of a release evidence object:
2019-12-26 22:10:19 +05:30
```json
{
"release": {
"id": 5,
2020-06-23 00:09:42 +05:30
"tag_name": "v4.0",
2019-12-26 22:10:19 +05:30
"name": "New release",
2020-06-23 00:09:42 +05:30
"project": {
"id": 20,
"name": "Project name",
"created_at": "2019-04-14T11:12:13.940Z",
"description": "Project description"
},
"created_at": "2019-06-28 13:23:40 UTC",
"description": "Release description",
2019-12-26 22:10:19 +05:30
"milestones": [
{
"id": 11,
"title": "v4.0-rc1",
"state": "closed",
"due_date": "2019-05-12 12:00:00 UTC",
"created_at": "2019-04-17 15:45:12 UTC",
"issues": [
{
"id": 82,
"title": "The top-right popup is broken",
"author_name": "John Doe",
"author_email": "john@doe.com",
"state": "closed",
"due_date": "2019-05-10 12:00:00 UTC"
},
{
"id": 89,
"title": "The title of this page is misleading",
"author_name": "Jane Smith",
"author_email": "jane@smith.com",
"state": "closed",
"due_date": "nil"
}
]
},
{
"id": 12,
"title": "v4.0-rc2",
"state": "closed",
"due_date": "2019-05-30 18:30:00 UTC",
"created_at": "2019-04-17 15:45:12 UTC",
"issues": []
}
2020-07-28 23:09:34 +05:30
],
"report_artifacts": [
{
"url":"https://gitlab.example.com/root/project-name/-/jobs/111/artifacts/download"
}
2019-12-26 22:10:19 +05:30
]
}
}
```
2021-03-11 19:13:27 +05:30
### Collect release evidence **(PREMIUM SELF)**
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/199065) in [GitLab Premium](https://about.gitlab.com/pricing/) 12.10.
2020-03-13 15:44:24 +05:30
2020-11-24 15:15:51 +05:30
When a release is created, release evidence is automatically collected. To initiate evidence collection any other time, use an [API call](../../../api/releases/index.md#collect-release-evidence). You can collect release evidence multiple times for one release.
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
Evidence collection snapshots are visible on the Releases page, along with the timestamp the evidence was collected.
2020-03-13 15:44:24 +05:30
2020-10-24 23:57:45 +05:30
### Include report artifacts as release evidence **(ULTIMATE)**
2020-04-22 19:07:51 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/32773) in [GitLab Ultimate](https://about.gitlab.com/pricing/) 13.2.
2020-04-22 19:07:51 +05:30
2021-09-30 23:02:18 +05:30
When you create a release, if [job artifacts](../../../ci/yaml/index.md#artifactsreports) are included in the last pipeline that ran, they are automatically included in the release as release evidence.
2020-04-22 19:07:51 +05:30
2020-07-28 23:09:34 +05:30
Although job artifacts normally expire, artifacts included in release evidence do not expire.
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
To enable job artifact collection you need to specify both:
2020-03-13 15:44:24 +05:30
2021-09-30 23:02:18 +05:30
1. [`artifacts:paths`](../../../ci/yaml/index.md#artifactspaths)
1. [`artifacts:reports`](../../../ci/yaml/index.md#artifactsreports)
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
```yaml
ruby:
script:
- gem install bundler
- bundle install
- bundle exec rspec --format progress --format RspecJunitFormatter --out rspec.xml
artifacts:
paths:
- rspec.xml
reports:
junit: rspec.xml
```
2020-03-13 15:44:24 +05:30
2021-01-03 14:25:43 +05:30
If the pipeline ran successfully, when you create your release, the `rspec.xml` file is saved as
release evidence.
2020-03-13 15:44:24 +05:30
2021-01-03 14:25:43 +05:30
If you [schedule release evidence collection](#schedule-release-evidence-collection),
some artifacts may already be expired by the time of evidence collection. To avoid this you can use
2021-09-30 23:02:18 +05:30
the [`artifacts:expire_in`](../../../ci/yaml/index.md#artifactsexpire_in)
2021-01-03 14:25:43 +05:30
keyword. Learn more in [this issue](https://gitlab.com/gitlab-org/gitlab/-/issues/222351).
2020-04-22 19:07:51 +05:30
2020-07-28 23:09:34 +05:30
### Schedule release evidence collection
2020-04-22 19:07:51 +05:30
2020-07-28 23:09:34 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/23697) in GitLab 12.8.
2020-04-22 19:07:51 +05:30
2020-07-28 23:09:34 +05:30
In the API:
2020-04-22 19:07:51 +05:30
2020-07-28 23:09:34 +05:30
- If you specify a future `released_at` date, the release becomes an **Upcoming Release**
and the evidence is collected on the date of the release. You cannot collect
release evidence before then.
- If you use a past `released_at` date, no evidence is collected.
- If you do not specify a `released_at` date, release evidence is collected on the
date the release is created.
2020-04-22 19:07:51 +05:30
2021-09-30 23:02:18 +05:30
## Release permissions
> [The permission model for create, update and delete actions was fixed](https://gitlab.com/gitlab-org/gitlab/-/issues/327505) in GitLab 14.1.
### View a release and download assets
2021-12-11 22:18:48 +05:30
> [Changes were made to the Guest role access](https://gitlab.com/gitlab-org/gitlab/-/issues/335209) in GitLab 14.5.
- Users with the [Reporter role or above](../../../user/permissions.md#project-members-permissions)
have read and download access to the project releases.
- Users with the [Guest role](../../../user/permissions.md#project-members-permissions)
2021-09-30 23:02:18 +05:30
have read and download access to the project releases.
2021-12-11 22:18:48 +05:30
This includes associated Git-tag-names, release description, author information of the releases.
However, other repository-related information, such as [source code](#source-code), [release evidence](#release-evidence) are redacted.
2021-09-30 23:02:18 +05:30
### Create, update, and delete a release and its assets
- Users with [Developer role or above](../../../user/permissions.md#project-members-permissions)
have write access to the project releases and assets.
- If a release is associated with a [protected tag](../protected_tags.md),
the user must be [allowed to create the protected tag](../protected_tags.md#configuring-protected-tags) too.
As an example of release permission control, you can allow only
[Maintainer role or above](../../../user/permissions.md#project-members-permissions)
to create, update, and delete releases by protecting the tag with a wildcard (`*`),
and set **Maintainer** in the **Allowed to create** column.
2021-01-29 00:20:46 +05:30
## Release Command Line
2020-05-24 23:13:21 +05:30
2021-01-29 00:20:46 +05:30
> [Introduced](https://gitlab.com/gitlab-org/release-cli/-/merge_requests/6) in GitLab 12.10.
2020-05-24 23:13:21 +05:30
2021-01-29 00:20:46 +05:30
The Release CLI is a command-line tool for managing GitLab Releases from the command line or from
2021-02-22 17:27:13 +05:30
the GitLab CI/CD configuration file, `.gitlab-ci.yml`.
2020-05-24 23:13:21 +05:30
2020-07-28 23:09:34 +05:30
With it, you can create, update, modify, and delete releases right through the
terminal.
2020-05-24 23:13:21 +05:30
2021-01-29 00:20:46 +05:30
Read the [Release CLI documentation](https://gitlab.com/gitlab-org/release-cli/-/blob/master/docs/index.md)
2020-07-28 23:09:34 +05:30
for details.
2020-06-23 00:09:42 +05:30
2021-04-17 20:07:23 +05:30
## Release Metrics **(ULTIMATE)**
2021-03-11 19:13:27 +05:30
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/issues/259703) in GitLab Premium 13.9.
Group-level release metrics are available by navigating to **Group > Analytics > CI/CD**.
These metrics include:
- Total number of releases in the group
- Percentage of projects in the group that have at least one release
2021-10-27 15:23:28 +05:30
## Working example project
The Guided Exploration project [Utterly Automated Software and Artifact Versioning with GitVersion](https://gitlab.com/guided-explorations/devops-patterns/utterly-automated-versioning) demonstrates:
- Using GitLab releases.
- Using the GitLab `release-cli`.
- Creating a generic package.
- Linking the package to the release.
- Using a tool called [GitVersion](https://gitversion.net/) to automatically determine and increment versions for complex repositories.
You can copy the example project to your own group or instance for testing. More details on what other GitLab CI patterns are demonstrated are available at the project page.
2021-09-30 23:02:18 +05:30
## Troubleshooting
### Getting `403 Forbidden` or `Something went wrong while creating a new release` errors when creating, updating or deleting releases and their assets
2019-10-12 21:52:04 +05:30
2021-09-30 23:02:18 +05:30
If the release is associted with a [protected tag](../protected_tags.md),
the UI/API request might result in an authorization failure.
Make sure that the user or a service/bot account is allowed to
[create the protected tag](../protected_tags.md#configuring-protected-tags) too.
2019-10-12 21:52:04 +05:30
2021-09-30 23:02:18 +05:30
See [the release permissions](#release-permissions) for more information.