From cf3b78579b492ae3b878723d0e35284d42a54ba5 Mon Sep 17 00:00:00 2001 From: Kanad Gupta <8854718+kanadgupta@users.noreply.github.com> Date: Thu, 14 Sep 2023 12:09:46 -0500 Subject: [PATCH] ci: sync changes back to next (#890) --- .github/workflows/release.yml | 7 +++++++ MAINTAINERS.md | 18 ++++++------------ 2 files changed, 13 insertions(+), 12 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index fcbc28c75..18d5cd355 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -71,3 +71,10 @@ jobs: NPM_CONFIG_PROVENANCE: 'true' NPM_TOKEN: ${{ secrets.NPM_TOKEN }} run: npx semantic-release + + - name: Sync changes back to next + if: ${{ github.ref }} == 'refs/heads/main' + uses: ad-m/github-push-action@master + with: + github_token: ${{ secrets.RELEASE_GH_TOKEN }} + branch: next diff --git a/MAINTAINERS.md b/MAINTAINERS.md index ac67ece1a..3d65c3e0b 100644 --- a/MAINTAINERS.md +++ b/MAINTAINERS.md @@ -12,31 +12,25 @@ Nearly all of our release process is automated. In this section, we discuss ever When code is merged into the `main` or `next` branches, a release workflow (powered by [`semantic-release`](https://github.com/semantic-release/semantic-release)) automatically kicks off that does the following: - All commit messages since the last release are analyzed to determine whether or not the new changes warrant a new release (i.e., if the changes are features or fixes as opposed to smaller housekeeping changes) 🧐 -- Based on the changes, the version is bumped in [`package.json`](./package.json) with a new git tag 🏷️ For example, say the current version is `8.5.1` and the commit history includes a new feature. This would result in a minor semver bump, which would produce the following tags: +- Based on the changes, the version is bumped in [`package.json`](./package.json) and the [`action.yml`](./action.yml) with a new git tag 🏷️ For example, say the current version is `8.5.1` and the commit history includes a new feature. This would result in a minor semver bump, which would produce the following tags: - A release tag like `v8.6.0` if on the `main` branch - A prerelease tag like `v8.6.0-next.1` if on the `next` branch - A changelog is generated and appended to [`CHANGELOG.md`](./CHANGELOG.md) 🪵 - A build commit (like [this](https://github.com/readmeio/rdme/commit/533a2db50b39c3b6130b3af07bebaed38218db4c)) is created with the updated `package*.json` and `CHANGELOG.md` files 🆕 +- A new Docker image is built with the latest code and release metadata and pushed to [the GitHub Container Registry](https://github.com/readmeio/rdme/pkgs/container/rdme) 🐳 - A couple duplicated tags are created for the current commit so our users can refer to them differently in their GitHub Actions (e.g., `8.6.0`, `v8`) 🔖 - The new commit and tags are pushed to GitHub 📌 - The new version is published to the `npm` registry 🚀 The package [distribution tag](https://docs.npmjs.com/adding-dist-tags-to-packages) will depend on which branch is being pushed to: - If on the `main` branch, a version is pushed on the main distribution tag (a.k.a. `latest`, which is used when someone runs `npm i rdme` with no other specifiers). - If on the `next` branch, the prerelease distribution tag (a.k.a. [`next`](https://www.npmjs.com/package/rdme/v/next)) is updated. - A [GitHub release is created](https://docs.github.com/en/repositories/releasing-projects-on-github/managing-releases-in-a-repository#creating-a-release) for the tag (in draft form) 🐙 +- If on the `main` branch, the new changes are backported to the `next` branch so both branches remain in sync 🔄 ## One more thing ☝️ > [!NOTE] -> The steps in this section are only required if you're building an actual release and not a prelease (i.e., changes are being merged into the `main` branch). +> This section is only required if you're building an actual release and not a prelease (i.e., changes are being merged into the `main` branch). -While nearly all of our release process is automated, there are a couple quick steps remaining: +While nearly all of our release process is automated, there's one more step left before we call it a day — writing up and publishing [the GitHub release](https://github.com/readmeio/rdme/releases)! The automation creates a GitHub release in a draft state, but it needs to be published so the latest version is surfaced to folks that discover our tool via [the GitHub Marketplace listing](https://github.com/marketplace/actions/rdme-sync-to-readme). -1. **Backport the changes in the `main` branch back into `next`** 🔙 you can do so by running the following: - -```sh -git checkout next -git merge main -git push -``` - -2. **Fluff out the GitHub release and publish it** ✍️ the GitHub release is currently in draft form but it needs to be published so the latest version is surfaced to folks that discover our tool via [the GitHub Marketplace listing](https://github.com/marketplace/actions/rdme-sync-to-readme). I like to summarize the changes and note any highlights in a blurb above the auto-generated release notes. These release links are nice for sharing with customers, on socials, etc. +I like to summarize the changes and note any highlights in a blurb above the auto-generated release notes. These release links are nice for sharing with customers, on socials, etc. and because of the way that GitHub's algorithm works, they present a great opportunity for our developer tools to get more visibility — so definitely worth putting a little thought and care into these!