Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Release Crystal 1.13.2 #328

Closed
22 of 25 tasks
straight-shoota opened this issue Aug 20, 2024 · 0 comments
Closed
22 of 25 tasks

Release Crystal 1.13.2 #328

straight-shoota opened this issue Aug 20, 2024 · 0 comments
Assignees
Labels

Comments

@straight-shoota
Copy link
Member

straight-shoota commented Aug 20, 2024

Release preparation

  1. Prepare the changelog entry: crystal:scripts/github-changelog.cr
  2. Start preparing release notes (Release 1.13.2 crystal-website#822)
  3. Publish release PR draft
    • It should be populated with updates to CHANGELOG.md, src/VERSION and the version in shard.yml.
  4. Ensure that test-ecosystem functions and succeeeds on master

Release process

Source release

  1. Finalize the release PR
    • Make sure all changes are mentioned in the changelog
    • Check release date
    • Un-draft the PR
  2. Verify Maintenance CI workflow succeeds on the HEAD of the release branch
  3. Smoke test with test-ecosystem
  4. Merge the release PR
  5. Make the release and publish it on GitHub: ../distribution-scripts/processes/scripts/make-crystal-release.sh (run from crystallang/crystal@$VERSION work tree). This performs these steps:
    1. Tag & annotate the commit with the changelog using <M.m.p> pattern as version
    • git tag -s -a -m $VERSION $VERSION
    • git push --tags
    1. Publish Github release (https://github.com/crystal-lang/crystal/releases/new)
      • Copy the changelog section as description
      • Binaries are added later
  6. Close milestone (https://github.com/crystal-lang/crystal/milestones)
  7. Wait for the release build in circle CI (https://app.circleci.com/pipelines/github/crystal-lang/crystal)

Binary releases

  1. Publish build artifacts from CircleCI and GitHub Actions to GitHub release. For URL_TO_CIRCLECI_ARTIFACT grab the URL
    of any of the build artifacts in circleCI (doesn't matter which).
  2. Push changes to OBS for building linux packages
    1. Checkout https://github.com/crystal-lang/distribution-scripts and go to ./packages
    2. Configure build.opensuse.org credentials in environment variables:
      • export OBS_USER=
      • export OBS_PASSWORD=
    3. Update the crystal${VERSION%.*} package: ./obs-release.sh devel:languages:crystal crystal${VERSION%.*} $VERSION
    4. Now OBS builds the packages. It’s best to follow the build status in the browser:
      1. open https://build.opensuse.org/project/show/home:$OBS_USER:branches:devel:langauges:crystal/crystal
      2. Wait for all package build jobs to finish and succeed
    5. 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)
    6. Verify package installation
      • OBS_PROJECT=devel:languages:crystal bats test
  3. Tag latest docker images
    • Versioned docker images have been pushed to dockerhub.
    • Now just assign the latest tags:
    • ./docker/apply-latest-tags.sh ${VERSION}
  4. Publish snap package (you can use the docker image snapcore/snapcraft for running the following commands)
    1. docker run --pull=always --rm -it snapcore/snapcraft
    2. You need to logged in via snapcraft login
    3. Recent tagged release is published directly to edge channel. The CI logs the snap revision number. Otherwise the .snap file is in the artifacts.
    4. Check the current status to find the revision of the tagged release otherwise:
    5. snapcraft status crystal
    6. snapcraft release crystal <revision-number> beta
    7. snapcraft release crystal <revision-number> stable
  5. 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

  1. Publish API docs
    1. Have AWS_ACCESS_KEY_ID and AWS_SECRET_ACCESS_KEY env variables defined
    2. Run make -C docs publish_docs dist-redirect_latest CRYSTAL_VERSION=${VERSION} to publish docs to api/${VERSION} and apply redirect from api/latest to api/${VERSION}

Release announcements

  1. Publish release notes on the website
  2. Post announcement in https://forum.crystal-lang.org/c/news/official
  3. Announce on social media accounts (via Buffer; credentials are in Passbolt) and pin release posts
  4. Update https://github.com/crystal-lang/crystal-book/blob/master/crystal-version.txt

Post-release

  1. Update crystal master branch to use released version: crystal:scripts/release-update.sh ${VERSION}
    • Edit PREVIOUS_CRYSTAL_BASE_URL in .circleci/config.yml
    • Edit DOCKER_TEST_PREFIX in bin/ci
    • Edit prepare_build on_osx download package and folder
    • Edit .github/workflows/*.yml to point to docker image
    • Edit shell.nix latestCrystalBinary using nix-prefetch-url --unpack <url>
  2. Update default base version in test-ecosystem: test-ecosystem:scripts/release-update.sh ${VERSION}
  3. Merge release/${VERSION%.*} branch into master (if the two have diverged)
  • This needs to be a merge commit. Those are disabled in the GitHub UI.
  • git switch master && git pull && git merge release/${VERSION%.*}; git checkout master src/VERSION && git add src/VERSION && git commit
  • Double check merge commit history is as expected
  • 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.)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

1 participant