Skip to content

Latest commit

 

History

History
92 lines (67 loc) · 3.12 KB

gitlab-releases.md

File metadata and controls

92 lines (67 loc) · 3.12 KB

GitLab Releases

For this feature, at least GitLab v11.7 is required. GitLab 11.7 introduces Releases to create release entries (much like GitHub), including release assets. Releases are attached to an existing Git tag, so make sure the Git part is configured correctly.

GitLab releases work just like GitHub releases:

GitLab Releases do not support pre-releases or drafts.

Prerequisite checks

First, release-it will check whether the GITLAB_TOKEN environment variable is set. Otherwise it will throw an error and exit. Then, it will authenticate, and verify whether the current user is a collaborator and authorized to publish a release.

To skip these checks, use gitlab.skipChecks.

Release notes

By default, the output of git.changelog is used for the GitLab release notes. This is the printed Changelog: ... when release-it boots. This can be overridden with the gitlab.releaseNotes option to customize the release notes for the GitLab release. This script will run just before the actual GitLab release itself. Make sure it outputs to stdout. An example:

{
  "gitlab": {
    "release": true,
    "releaseNotes": "generate-release-notes.sh ${latestVersion} ${version}"
  }
}

See Changelog for more information about generating changelogs/release notes.

Attach binary assets

To upload binary release assets with a GitLab release (such as compiled executables, minified scripts, documentation), provide one or more glob patterns for the gitlab.assets option. After the release, the assets are available to download from the project's releases page. Example:

{
  "gitlab": {
    "release": true,
    "assets": ["dist/*.dmg"]
  }
}

Origin

The origin can be set to a string such as "http://example.org:3000" to use a different origin from what would be derived from the Git url (e.g. to use http over the default https://${repo.host}).

Private CA Authority

If you're running your own GitLab instance with an HTTPS certificate issued by a private certificate Authority, you can specify the root CA certificate with certificateAuthorityFile, for example:

{
  "gitlab": {
    "release": true,
    "tokenHeader": "PRIVATE-TOKEN",
    "certificateAuthorityFile": "./my-root-ca.crt"
  }
}

Update the latest release

The latest GitLab release can be updated, e.g. to update the releases notes or add release assets.

  • Use --no-increment to skip updating the version.
  • Use --no-git to skip Git actions.
  • Use --no-npm to skip publishing to npm if there's a package.json.

Use the other options to update the release, such as --gitlab.assets to add assets.

Example command to add assets to the latest release:

release-it --no-increment --no-git --gitlab.release --gitlab.assets=*.zip