-
-
Notifications
You must be signed in to change notification settings - Fork 24
Closed
Labels
Description
Release preparation
- Announce expected release date (2025-10-14) and time span for feature freeze (starting on 2025-09-30)
- Feature freeze is about two weeks before release
- Set date on milestone
- Prepare the changelog entry:
crystal:scripts/github-changelog.cr(Changelog for 1.18.0 crystal#16153)- Ensure that all merged PRs are added to the milestone (check
is:pr is:merged sort:updated-desc no:milestone). - Ensure that all milestoned PRs are properly labelled (check
is:pr is:merged sort:updated-desc no:label milestone:1.18.0).
- Ensure that all merged PRs are added to the milestone (check
- Start preparing release notes
- Start feature freeze period (on 2025-09-30)
- Either no merging of features into
masteror split off release branch for backporting bugfixes.
- Either no merging of features into
- Publish release PR draft (Release 1.18.0 crystal-website#985)
- It should contain the expected date of the release.
- It should be populated with updates to
CHANGELOG.md,src/VERSIONand the version inshard.yml.
- Ensure documentation for language and compiler changes and other relevant changes is up to date.
- Crystal Book
- Update language specification
- Add
Deprecatedannotation in Built-in annotations: AddDeprecatedbuilt-in annotation crystal-book#842 -
Fresh variable naming scheme from Group temporary variables by file name: compound array assignments crystal#16122(Not necessary because the example uses an unnamed file where variables are not prefixed with a hash of the file name)
- Add
- Update compiler manual
-
CRYSTAL_DUMP_TYPE_INFOfrom Add the ability to dump type information to a JSON file crystal#16027
-
- Add or update guides / tutorials?
- Update language specification
- API Docs
-
ExecutionContext: default context, description ofConcurrent,#resize: Tweak docs forFiber::ExecutionContextcrystal#16196 -
Deprecated: parameters, enhance examples: Enhance documentation ofDeprecatedannotation crystal#16195
-
- Crystal Book
- Look for library updates, check and document compatibility at https://crystal-lang.org/reference/man/required_libraries.html and in lib bindings
- LLVM update 21.0->21.1/22.0: Update supported LLVM version to include 22.0 crystal-book#844
- Ensure that test-ecosystem functions and succeeds on master
Release process (on 2025-10-14)
Source release
- Finalize the release PR
- Make sure all changes are mentioned in the changelog
- Check release date
- Un-draft the PR
- Split off release branch (
release/x.y) - Verify Maintenance CI workflow succeeds on the HEAD of the release branch
- Smoke test with test-ecosystem
- Run Test Crystal & Shards Workflow with the release branch as
crystal_branch.
- Run Test Crystal & Shards Workflow with the release branch as
- Merge the release PR
- Make the release and publish it on GitHub:
../distribution-scripts/processes/scripts/make-crystal-release.sh(run fromcrystallang/[email protected]work tree). This performs these steps:- Tag & annotate the commit with the changelog using
<M.m.p>pattern as version
git tag -s -a -m 1.18.0 1.18.0git push --tags
- Publish Github release (https://github.com/crystal-lang/crystal/releases/new)
- Copy the changelog section as description
- Binaries are added later
- Tag & annotate the commit with the changelog using
- Close milestone (https://github.com/crystal-lang/crystal/milestones)
- Wait for the release build in circle CI (https://app.circleci.com/pipelines/github/crystal-lang/crystal)
- Fast-forward
release/1.18to[email protected]
Binary releases
- Publish build artifacts from CircleCI and GitHub Actions to GitHub release. For
URL_TO_CIRCLECI_ARTIFACTgrab the URL
of any of the build artifacts in circleCI (doesn't matter which).- Upload build artifacts from CircleCI:
../distribution-scripts/processes/scripts/publish-crystal-packages-on-github.sh $URL_TO_CIRCLECI_ARTIFACT(run fromcrystallang/[email protected]work tree)crystal-*-darwin-*.tar.gzcrystal-*-linux-*.tar.gzcrystal-*.pkgcrystal-*-docs.tar.gz
- Upload build artifacts from GHA (Windows):
- Windows CI:
crystal-release.zip->crystal-1.18.0-windows-x86_64-msvc-unsupported.zip - Windows CI:
crystal-installer.zip-> unzip ->crystal-1.18.0-windows-x86_64-msvc-unsupported.exe - MinGW-w64 CI:
x86_64-mingw-w64-crystal.zip->crystal-1.18.0-windows-x86_64-gnu-unsupported.zip - MinGW-w64 CI:
aarch64-mingw-w64-crystal.zip->crystal-1.18.0-windows-aarch64-gnu-unsupported.zip
- Windows CI:
- Upload build artifacts from CircleCI:
- Push changes to OBS for building linux packages
- Checkout https://github.com/crystal-lang/distribution-scripts and go to
./packages - Configure build.opensuse.org credentials in environment variables:
export OBS_USER=export OBS_PASSWORD=
- Update the
crystalpackage:./obs-release.sh devel:languages:crystal crystal 1.18.0- Uses the docker image
crystallang/oscto run the CLI client for OBS. - The script creates a branch in you home project, updates the version and pushes it back to OBS.
- You can also run the commands from that file manually and check build locally with
osc build xUbuntu_20.04 x86_64osc build Fedora_Rawhide x86_64
- Uses the docker image
- Create the
crystal1.18package:./obs-new-minor.sh devel:languages:crystal crystal1.18 1.18.0 crystal${OLD_VERSION%.*} - Now OBS builds the packages. It’s best to follow the build status in the browser:
open https://build.opensuse.org/project/show/home:$OBS_USER:branches:devel:langauges:crystal/crystal- Wait for all package build jobs to finish and succeed
- When everything is green, create a submit request against the original packages (Submit package link in the menu bar on the package in your branch)
- Verify package installation
OBS_PROJECT=devel:languages:crystal bats test
- Checkout https://github.com/crystal-lang/distribution-scripts and go to
- Tag
latestdocker images- Versioned docker images have been pushed to dockerhub.
- Now just assign the
latesttags: ./docker/apply-latest-tags.sh 1.18.0
- Publish snap package
- On https://snapcraft.io/crystal/releases promote the
latest/edgerelease tolatest/betaand thenlatest/stable
- On https://snapcraft.io/crystal/releases promote the
- Check PR for homebrew: https://github.com/Homebrew/homebrew-core/pulls?q=is%3Apr+crystal+sort%3Aupdated-desc
- It should've been automatically created
Publish documentation for the release
- Publish API docs
- Have
AWS_ACCESS_KEY_IDandAWS_SECRET_ACCESS_KEYenv variables defined- Keys can be generated at https://console.aws.amazon.com/iam/home#/security_credentials (contact a Manas admin if you don't have access).
- Run
make -C docs publish_docs dist-redirect_latest CRYSTAL_VERSION=1.18.0to publish docs toapi/1.18.0and apply redirect fromapi/latesttoapi/1.18.0 - Update API docs' 404 page to add
<base href="/api/${VERSION}/" />in the<head>
- Have
- Publish Crystal book
- Create
release/1.18branch and push it tocrystal-lang/crystal-book(deployment happens automatically in GHA) - Verify that deployment was successfull
- Create
Release announcements
- Publish release notes on the website
- Make sure all links to API docs point to
/api/1.18.0/ - Insert number of changes and contributers
- Make sure all links to API docs point to
- Post announcement in https://forum.crystal-lang.org/c/news/official
- Announce on social media accounts (via Buffer; credentials are in Passbolt) and pin release posts
- Update https://github.com/crystal-lang/crystal-book/blob/master/crystal-version.txt
- Post the release in https://opencollective.com/crystal-lang
Post-release
- Update crystal
masterbranch to use released version:crystal:scripts/release-update.sh 1.18.0- Edit PREVIOUS_CRYSTAL_BASE_URL in
.circleci/config.yml - Edit DOCKER_TEST_PREFIX in
bin/ci - Edit
prepare_buildon_osx download package and folder - Edit
.github/workflows/*.ymlto point to docker image - Edit
shell.nixlatestCrystalBinaryusingnix-prefetch-url --unpack <url> - Increment
src/VERSIONand version inshard.ymlto the next minor plus-devsuffix
- Edit PREVIOUS_CRYSTAL_BASE_URL in
- Perform uncomment/todos left in the repo
- Update default base version in test-ecosystem:
test-ecosystem:scripts/release-update.sh 1.18.0 - Merge
release/1.18branch intomaster(if the two have diverged)
- This needs to be a merge commit. Those are disabled in the GitHub UI.
- Create branch and PR:
git fetch upstream release/1.18 master git switch -c merge/1.18.0 upstream/master git merge upstream/release/1.18 # resolve conflicts git commit -m 'Merge `release/1.18` into master' git log --graph --decorate --pretty=oneline --abbrev-commit git push -u upstream merge/1.18.0 gh pr create --title 'Merge `release/1.18` into master' --label 'topic:infrastructure'
- Merge PR locally:
git switch master git merge --ff-only merge/1.18.0 # double check history git log --graph --decorate --pretty=oneline --abbrev-commit git push - GitHub branch protection rules normally prevent direct pushes to
master. This needs to be deactivated for this purpose, which can be on a
per-user basis. - In case master has diverged,
--ff-onlymerge will fail. Then you can
first rebasemerge/1.18.0on current master withgit rebase master --rebase-merges.