📝(release) update release.md

Update documentation on release
This commit is contained in:
Marie PUPO JEAMMET
2025-03-18 18:14:48 +01:00
committed by Marie
parent 230ff21220
commit 8b89a1112d

View File

@@ -17,48 +17,52 @@ Whenever we are cooking a new release (e.g. `4.18.1`) we should follow a standar
This script will ask you for the version you want to release and the kind of release (patch, minor, major). It will then: This script will ask you for the version you want to release and the kind of release (patch, minor, major). It will then:
1. Create a new branch named: `release/4.18.1`. - Create a new branch named: `release/4.18.1`.
2. Bump the release number for backend and frontend project. - Bump the release number for backend and frontend project.
3. Update the project's `Changelog` following the [keepachangelog](https://keepachangelog.com/en/0.3.0/) recommendations - Update the project's `Changelog` following the [keepachangelog](https://keepachangelog.com/en/0.3.0/) recommendations
4. Commit your changes with the following format: the 🔖 release emoji, the type of release (patch/minor/patch) and the release version: - Commit your changes with the following format: 🔖 release emoji, type of release (patch/minor/patch) and release version:
```text ```text
🔖(minor) release version 4.18.1 🔖(minor) release version 4.18.1
``` ```
3. Open a pull request ask you to wait for an approval from your peers and merge it. - Triggers Crowdin translation action and open related PR
4. Ask you to tag and push your commit: - Open release PR. Wait for an approval from your peers and merge it.
> [!NOTE]
> It also open the PR for pre-prod deployment, see following section.
3. Following release script instructions,
- merge translation and release pulls requests
- tag and push your commit:
```bash ```bash
git tag v4.18.1 && git push origin tag v4.18.1 git tag v4.18.1 && git push origin tag v4.18.1
``` ```
Doing this triggers the CI and tells it to build the new Docker image versions that you targeted earlier in the Helm files. This triggers the CI building new Docker images. You can ensure images were successfully built on Docker Hub [here for back-end](https://hub.docker.com/r/lasuite/people-backend/tags) and [here for front-end](https://hub.docker.com/r/lasuite/people-frontend/tags).
5. Ensure the new [backend](https://hub.docker.com/r/lasuite/people-backend/tags) and [frontend](https://hub.docker.com/r/lasuite/people-frontend/tags) image tags are on Docker Hub.
6. Create a PR on the [lasuite-deploiement](https://github.com/numerique-gouv/lasuite-deploiement) repository to bump the preprod version. # Deploying
7. The release is now done! ## Staging
# Deploying The `staging` platform is deployed automatically with every update of the `main` branch.
> [!TIP] ## Pre-prod and production
> The `staging` platform is deployed automatically with every update of the `main` branch.
Making a new release doesn't publish it automatically in production. If you used the release script and had permission to push on [lasuite-deploiement](https://github.com/numerique-gouv/lasuite-deploiement), a deployment branch has been created. You can skip step 1.
Deployment is done by ArgoCD. ArgoCD checks for the `production` tag and automatically deploys the production platform with the targeted commit. Otherwise, for manual preprod and for production deployments :
1. Bump tag version for both front-end and back-end images in the `.gotmpl` file located in `manifests/<your-product>/env.d/<your-environment>/`,
2. Add optional new secrets and variables, if applicable
3. Create a pull request
4. Submit to approval and merge PR
To publish, we mark the commit we want with the `production` tag. ArgoCD is then notified that the tag has changed. It then deploys the Docker image tags specified in the Helm files of the targeted commit. The release is now done! 🎉
To publish the release you just made:
```bash
git tag --force production v4.18.1
git push --force origin production
```