2021-04-20 17:00:14 +02:00
|
|
|
# Cutting a Deno release
|
|
|
|
|
|
|
|
**During this process `main` branch (or any other branch that you're creating
|
|
|
|
release from) should be frozen and no commits should land until the release is
|
|
|
|
cut.**
|
|
|
|
|
2021-06-22 10:39:44 -04:00
|
|
|
## Updating `deno_std`
|
|
|
|
|
2021-09-22 06:53:47 +10:00
|
|
|
1. Checkout a branch for releasing `std` (e.g. `release_#.#.#`).
|
|
|
|
|
|
|
|
2. Open a PR on the `deno_std` repo that bumps the version in `version.ts` and
|
2021-06-22 10:39:44 -04:00
|
|
|
updates `Releases.md`
|
2021-07-27 00:26:39 +02:00
|
|
|
|
2021-09-22 06:53:47 +10:00
|
|
|
3. Before merging the PR, make sure that all tests pass when run using binary
|
2021-07-27 00:26:39 +02:00
|
|
|
produced from bumping crates (point 3. from below).
|
|
|
|
|
2021-09-22 06:53:47 +10:00
|
|
|
4. Create a tag with the version number (_without_ `v` prefix).
|
2021-06-22 10:39:44 -04:00
|
|
|
|
|
|
|
## Updating the main repo
|
|
|
|
|
2021-09-22 06:53:47 +10:00
|
|
|
1. Checkout a branch for releasing crate dependencies (e.g. `deps_#.#.#`).
|
|
|
|
|
|
|
|
2. Run `./tools/release/01_bump_dependency_crate_versions.ts` to increase the
|
2021-08-25 09:02:22 -04:00
|
|
|
minor versions of all crates in the `bench_util`, `core`, `ext`, and
|
|
|
|
`runtime` directories.
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 06:53:47 +10:00
|
|
|
3. Commit these changes with a commit message like
|
|
|
|
`chore: bump crate version for #.#.#` and create a PR for this change.
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 06:53:47 +10:00
|
|
|
4. Make sure CI pipeline passes (DO NOT merge yet).
|
2021-08-25 09:02:22 -04:00
|
|
|
|
2021-09-22 06:53:47 +10:00
|
|
|
5. Run `./tools/release/02_publish_dependency_crates.ts` to publish these bumped
|
2021-08-25 09:02:22 -04:00
|
|
|
crates to `crates.io`
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-14 16:46:36 -04:00
|
|
|
**Make sure that `cargo` is logged on with a user that has permissions to
|
|
|
|
publish those crates.**
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-14 16:46:36 -04:00
|
|
|
If there are any problems when you publish, that require you to change the
|
|
|
|
code, then after applying the fixes they should be committed and pushed to
|
|
|
|
the PR.
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 06:53:47 +10:00
|
|
|
6. Once all crates are published merge the PR.
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
7. Update your main branch and checkout another branch (e.g. `release_#.#.#`).
|
2021-08-25 09:02:22 -04:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
8. Run `./tools/release/03_bump_cli_version.ts` to bump the CLI version.
|
2021-08-25 09:02:22 -04:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
9. If you are doing a patch release, answer `y` to the _Increment patch?_
|
|
|
|
prompt.
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
10. Use the output of the above command to update `Releases.md` (removing
|
|
|
|
`refactor`, `test` and `doc` commits)
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
11. Create a PR for these changes.
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
12. Make sure CI pipeline passes.
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
13. Publish `cli` crate to `crates.io`
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
14. Merge the PR.
|
|
|
|
|
|
|
|
15. Create a tag with the version number (with `v` prefix).
|
|
|
|
|
|
|
|
16. Wait for CI pipeline on the created tag branch to pass.
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-15 09:16:06 -04:00
|
|
|
The CI pipeline will create a release draft on GitHub
|
|
|
|
(https://github.com/denoland/deno/releases).
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
17. Upload Apple M1 build to the release draft & to dl.deno.land.
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
18. Publish the release on Github
|
2021-04-20 17:00:14 +02:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
19. Update the Deno version on the website by updating
|
2021-04-20 17:00:14 +02:00
|
|
|
https://github.com/denoland/deno_website2/blob/main/versions.json.
|
2021-06-22 10:39:44 -04:00
|
|
|
|
2021-09-22 08:44:46 +10:00
|
|
|
20. Push a new tag to [`manual`](https://github.com/denoland/manual). The tag
|
2021-09-15 09:16:06 -04:00
|
|
|
must match the CLI tag; you don't need to create dedicated commit for that
|
|
|
|
purpose, it's enough to tag the latest commit in that repo.
|
2021-07-27 00:26:39 +02:00
|
|
|
|
2021-06-22 10:39:44 -04:00
|
|
|
## Updating `deno_docker`
|
|
|
|
|
|
|
|
1. Open a PR on the `deno_docker` repo that bumps the Deno version in all
|
|
|
|
Dockerfiles, the README and the example Dockerfile
|
|
|
|
2. Create a tag with the version number (_without_ `v` prefix).
|