debian-mirror-gitlab/doc/development/documentation/site_architecture/release_process.md

169 lines
7.5 KiB
Markdown
Raw Normal View History

2021-01-29 00:20:46 +05:30
---
stage: none
group: unassigned
2021-02-22 17:27:13 +05:30
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
2021-01-29 00:20:46 +05:30
---
2021-04-17 20:07:23 +05:30
# Monthly release process
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
When a new GitLab version is released on the 22nd, we need to release the published documentation
for the new version.
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
This should be done as soon as possible after the GitLab version is announced, so that:
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
- The published documentation includes the three most recent minor releases of the current major
version, and the most recent minor releases of the last two major versions. For example 13.9,
13.8, 13.7, 12.10, and 11.11.
- Documentation updates after the 22nd are for the next release. The versions drop down
should have the current milestone with `-pre` appended to it, for example `13.10-pre`.
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
Each documentation release:
2020-10-24 23:57:45 +05:30
2021-04-17 20:07:23 +05:30
- Has a dedicated branch, named in the format `XX.yy`.
- Has a Docker image that contains a build of that branch.
For example:
- For [GitLab 13.9](https://docs.gitlab.com/13.9/index.html), the
[stable branch](https://gitlab.com/gitlab-org/gitlab-docs/-/tree/13.9) and Docker image:
[`registry.gitlab.com/gitlab-org/gitlab-docs:13.9`](https://gitlab.com/gitlab-org/gitlab-docs/container_registry/631635).
- For [GitLab 13.8](https://docs.gitlab.com/13.8/index.html), the
[stable branch](https://gitlab.com/gitlab-org/gitlab-docs/-/tree/13.8) and Docker image:
[`registry.gitlab.com/gitlab-org/gitlab-docs:13.8`](https://gitlab.com/gitlab-org/gitlab-docs/container_registry/631635).
To set up a documentation release, follow these steps:
1. [Add the charts version](#add-chart-version), so that the documentation is built using the
[version of the charts project that maps to](https://docs.gitlab.com/charts/installation/version_mappings.html)
the GitLab release. This step may have been completed already.
1. [Create a stable branch and Docker image](#create-stable-branch-and-docker-image-for-release) for
the new version.
1. [Create a release merge request](#create-release-merge-request) for the new version, which
updates the version dropdown menu for the current documentation and adds the release to the
Docker configuration. For example, the
[release merge request for 13.9](https://gitlab.com/gitlab-org/gitlab-docs/-/merge_requests/1555).
1. [Update the three online versions](#update-dropdown-for-online-versions), so that they display the new release on their
version dropdown menus. For example:
- The merge request to [update the 13.9 version dropdown menu for the 13.9 release](https://gitlab.com/gitlab-org/gitlab-docs/-/merge_requests/1556).
- The merge request to [update the 13.8 version dropdown menu for the 13.9 release](https://gitlab.com/gitlab-org/gitlab-docs/-/merge_requests/1557).
- The merge request to [update the 13.7 version dropdown menu for the 13.9 release](https://gitlab.com/gitlab-org/gitlab-docs/-/merge_requests/1558).
1. [Merge the release merge request and run the necessary Docker image builds](#merge-release-merge-request-and-run-docker-image-builds).
## Add chart version
To add a new charts version for the release:
2020-10-24 23:57:45 +05:30
2020-05-24 23:13:21 +05:30
1. Make sure you're in the root path of the `gitlab-docs` repository.
2019-12-26 22:10:19 +05:30
1. Open `content/_data/chart_versions.yaml` and add the new stable branch version using the
2021-04-17 20:07:23 +05:30
[version mapping](https://docs.gitlab.com/charts/installation/version_mappings.html). Only the
`major.minor` version is needed.
2019-12-26 22:10:19 +05:30
1. Create a new merge request and merge it.
2021-02-22 17:27:13 +05:30
NOTE:
2021-04-17 20:07:23 +05:30
If you have time, add anticipated future mappings to `content/_data/chart_versions.yaml`. This saves
a step for the next GitLab release.
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
## Create stable branch and Docker image for release
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
To create a stable branch and Docker image for the release:
2019-12-26 22:10:19 +05:30
2020-05-24 23:13:21 +05:30
1. Make sure you're in the root path of the `gitlab-docs` repository.
2021-04-17 20:07:23 +05:30
1. Run the Rake task to create the single version. For example, to create the 13.9 release branch
and perform others tasks:
2019-12-26 22:10:19 +05:30
2020-04-08 14:13:33 +05:30
```shell
2021-04-17 20:07:23 +05:30
./bin/rake "release:single[13.9]"
2020-04-08 14:13:33 +05:30
```
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
A branch for the release is created, a new `Dockerfile.13.9` is created, and `.gitlab-ci.yml`
has branches variables updated into a new branch. These files are automatically committed.
1. Push the newly created branch, but **don't create a merge request**. After you push, the
`image:docs-single` job creates a new Docker image tagged with the name of the branch you created
earlier. You can see the Docker image in the `registry` environment at
<https://gitlab.com/gitlab-org/gitlab-docs/-/environments/folders/registry>.
2020-03-13 15:44:24 +05:30
2021-04-17 20:07:23 +05:30
For example, see [the 13.9 release pipeline](https://gitlab.com/gitlab-org/gitlab-docs/-/pipelines/260288747).
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
Optionally, you can test locally by:
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
1. Building the image and running it. For example, for GitLab 13.9 documentation:
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
```shell
docker build -t docs:13.9 -f Dockerfile.13.9 .
docker run -it --rm -p 4000:4000 docs:13.9
```
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
1. Visiting <http://localhost:4000/13.9/> to see if everything works correctly.
## Create release merge request
2019-12-26 22:10:19 +05:30
2021-02-22 17:27:13 +05:30
NOTE:
2021-04-17 20:07:23 +05:30
An [epic is open](https://gitlab.com/groups/gitlab-org/-/epics/4361) to automate this step.
2020-06-23 00:09:42 +05:30
2021-04-17 20:07:23 +05:30
To create the release merge request for the release:
2019-12-26 22:10:19 +05:30
2020-05-24 23:13:21 +05:30
1. Make sure you're in the root path of the `gitlab-docs` repository.
2021-04-17 20:07:23 +05:30
1. Create a branch `release-X-Y`. For example:
2019-12-26 22:10:19 +05:30
2020-03-13 15:44:24 +05:30
```shell
git checkout master
2021-04-17 20:07:23 +05:30
git checkout -b release-13-9
2019-12-26 22:10:19 +05:30
```
2021-04-17 20:07:23 +05:30
1. Edit `content/_data/versions.yaml` and update the lists of versions to reflect the new release:
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
- Add the latest version to the `online:` section.
- Move the oldest version in `online:` to the `offline:` section. There should now be three
versions in `online:`.
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
1. Update these Dockerfiles:
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
- `dockerfiles/Dockerfile.archives`: Add the latest version to the top of the list.
- `Dockerfile.master`: Remove the oldest version, and add the newest version to the
top of the list.
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
1. Commit and push to create the merge request. For example:
2019-12-26 22:10:19 +05:30
2020-03-13 15:44:24 +05:30
```shell
2019-12-26 22:10:19 +05:30
git add content/ Dockerfile.master dockerfiles/Dockerfile.archives
2021-04-17 20:07:23 +05:30
git commit -m "Release 13.9"
git push origin release-13-9
2019-12-26 22:10:19 +05:30
```
2021-04-17 20:07:23 +05:30
Do not merge the release merge request yet.
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
## Update dropdown for online versions
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
To update`content/_data/versions.yaml` for all online versions (stable branches `X.Y` of the
`gitlab-docs` project):
2020-10-24 23:57:45 +05:30
2021-04-17 20:07:23 +05:30
1. Run the Rake task that creates all of the necessary merge requests to update the dropdowns. For
example, for the 13.9 release:
2019-12-26 22:10:19 +05:30
2020-03-13 15:44:24 +05:30
```shell
2021-04-17 20:07:23 +05:30
git checkout release-13-9
2019-12-26 22:10:19 +05:30
./bin/rake release:dropdowns
```
2021-04-17 20:07:23 +05:30
These merge requests are set to automatically merge.
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
1. [Visit the merge requests page](https://gitlab.com/gitlab-org/gitlab-docs/-/merge_requests?label_name%5B%5D=release)
to check that their pipelines pass. After all MRs are merged, proceed to the following and final
step.
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
## Merge release merge request and run Docker image builds
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
The merge requests for the dropdowns should now all be merged into their respective stable branches.
Each merge triggers a new pipeline for each stable branch. Wait for the stable branch pipelines to
complete, then:
2019-12-26 22:10:19 +05:30
2020-10-24 23:57:45 +05:30
1. Check the [pipelines page](https://gitlab.com/gitlab-org/gitlab-docs/pipelines)
2019-12-26 22:10:19 +05:30
and make sure all stable branches have green pipelines.
2021-04-17 20:07:23 +05:30
1. After all the pipelines succeed, merge the [release merge request](#create-release-merge-request).
2020-10-24 23:57:45 +05:30
1. Finally, run the
[`Build docker images weekly` pipeline](https://gitlab.com/gitlab-org/gitlab-docs/pipeline_schedules)
2021-02-22 17:27:13 +05:30
that builds the `:latest` and `:archives` Docker images.
2019-12-26 22:10:19 +05:30
2021-04-17 20:07:23 +05:30
As the last step in the scheduled pipeline, the documentation site deploys with all new versions.