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 overhaul #638

Closed
rgoldberg opened this issue Nov 15, 2024 · 0 comments · Fixed by #640
Closed

Release overhaul #638

rgoldberg opened this issue Nov 15, 2024 · 0 comments · Fixed by #640
Assignees
Labels
🧽 chore Administrative task: documentation, build, test, release, git, etc.
Milestone

Comments

@rgoldberg
Copy link
Contributor

rgoldberg commented Nov 15, 2024

Release Workflow

The automated release workflow shouldn't be kicked off when a release has been published (on: release: types: [published]), because the release will have then already been made available to the public.

If anything fails or is suboptimal (like poorly worded generated release notes) in the workflow, we'd need to either delete, modify, or supersede the botched release, all of which are suboptimal.

It's best to split the release process into 3 stages:

Stage 1: Generate Draft

  • When a tag matching a version string regex (v\d+(?:\.\d+)*(?:-(?:alpha|beta|rc)\.\d+)?) is pushed to the main branch of the mas-cli/mas repo, run a workflow that will:
    • Stop progressing if any step fails.
      • Revert prior steps if any step fails.
    • Checkout the tag
    • Validate the tag:
      • Ensure that the the tag is annotated & signed (& possibly ensure its message follows conventions).
      • Otherwise (e.g., the tag is lightweight, unsigned, improperly signed, or its message is improperly formatted), delete the tag & stop processing.
    • Build
    • Package the *.pkg(s)
    • Create a GitHub Release draft.
      • Autogenerate release notes.
      • Label the draft as a prerelease if the version tag contains a -.
    • Upload the *.pkg(s) to the draft
    • Create a mas-cli/tap/mas formula bump PR, which will generate (but not yet publish) bottles for all applicable macOS versions & platforms
  • In an emergency, a release can be made manually via the GitHub web or cli interface

Stage 2: Manual Draft Inspection / Modification

After inspecting everything created in stage 1, the releaser may then either:

  • Publish the draft as a release as is
  • Modify the draft, then publish the draft as a release
  • Delete the draft

Stage 3: Publish Release / Delete Draft

No GitHub workflow events fire when a GitHub Release draft is deleted. Thus, if the releaser decides to delete the GitHub Release draft in stage 2, we can either have a script/delete_draft script that will take care of deleting / reverting / closing / etc. everything, or just have them manually clean everything up.

If the releaser publishes the draft, then an on: release: types: [published] workflow will:

  • If the release is not a prerelease, bump the homebrew-core mas formula.
  • Apply the pr-pull label to the mas-cli/tap/mas formula bump PR, which will approve the PR & publish bottles to a new GitHub Release for the new mas version in mas-cli/homebrew-tap for:
    • Intel for macOS 10.13 & newer.
    • Apple Silicon for macOS 11 & newer.

The custom tap bottle generation & publishing process has been implemented as follows, but not tested due to issues getting the testing environment setup (see mas-cli/homebrew-tap#66 for the custom tap issue):

  • When the custom tap formula PR is pushed to mas-cli/tap, the tests.yml workflow will:
    • Build one bottle for arm64 on macos-15 & one bottle for x86_64 on macOS-13
    • Rename each bottle from the macOS version on which it was built to the macOS version name for the oldest supported macOS version for each respective platform:
      • Rename to *arm64_big_sur* for arm64
      • Rename to *high_sierra* for x86_64
    • Download the mas 1.8.6 el_capitan bottle for x86_64 from the 1.8.6 release
    • Upload all 3 bottles as artifacts to the GitHub PR
  • When the PR is labelled with pr-pull, the publish.yml workflow will:
    • Publish the 3 bottles to a new GitHub Release for the new mas version in the custom tap repo.

Legacy Version Patch Branches

If we ever release patches for legacy mas versions, they should be done in a legacy version patch branch.

Given that we aren't patching legacy versions right now, the first revamp of the new release system doesn't need to support it, but we might want to think through the workflow to support it in the future.

See #655 for details about legacy version patch branches & other git-related proposals.

Current Work

  • If possible, replace existing lightweight version tags with backdated signed annotated tags.
  • GitHub Release artifacts:
    • Include version (& platform? & macOS version?) in mas.pkg filename for existing versions
    • Platform-specific (instead of universal) installers
  • Document release process #357

Possible Future Tasks

  • Cleanup actions/checkout@v4 output:
    • git config --global advice.detachedHead false
  • Ensure bottles built with the newest installed Xcode version?
  • Rename build-test.yml as build-test-lint.yml.
  • Custom tap version tags & releases for existing versions?
  • Artifact attestations for builds
  • Dangerfile.swift appears to be used only for PRs made directly on mas-cli/mas, not for those via forks:
    • Setup for fork PRs.
    • Or delete it.
  • Move .github/*.yml into .github/workflows?
  • Depend on swift command instead of on Xcode?
  • github_prerelease_allowlist.json?
  • GitHub/git protections #655
  • Use YAML & JSON schemas for validation #657

Completed

  • 3 stages outlined above implemented, except for:
    • the custom tap bottle build workflows
    • script/delete_draft
  • Remove extraneous files from mas-cli/mas repo:
    • Makefile
    • .github/event.json
    • Many shell scripts
    • Homebrew formulae: store each only in its respective tap repo, e.g., homebrew/homebrew-core or mas-cli/tap
      • Bump homebrew-core & mas-cli/tap/mas formulae in taps instead of locally generating / modifying them.
        • Do not create a manual pull request for the custom tap.
    • Generate files only when absolutely necessary, but git ignore them, e.g., Sources/mas/Package.swift
  • Do not commit or branch in mas-cli/mas on release.
  • Store values in as few places as possible, e.g.:
    • Store version in mas-cli/mas repo only in version tag, not in any files or in any branch names.
  • Reuse existing functionality (like brew bump-formula-pr) instead of reinventing the wheel.
  • Standardize:
    • Ensure the same tools are used everywhere, e.g.:
      • ensure /bin/bash is used everywhere instead of some places using bash from the $PATH.
    • Remove dependencies whose functionality can be performed by other things, e.g.:
      • sd: script that used it was deleted, but if script had been kept, should use shell scripting instead
      • mise: use brew bundle instead
  • Scope code, e.g.,:
    • Formulae should be bumped only during a release, so do not perform bumps in scripts called by release workflow; instead, embed bumps in the workflow itself, otherwise people might incorrectly run bump scripts outside of the workflow.
      • If, under extraordinary circumstances, someone must bump the formulae outside of the release process, they should know enough about the release process to know that they should just copy the bump commands from the workflow.
  • Limit pathways, prevent bad values, & make config more explicit, e.g.:
    • shell scripts should accept only arguments, not environment variables.
    • Release workflows & shell scripts should:
      • Require that the release tag is a properly formatted version tag.
      • Checkout the release version tag, then use that version tag as the source for the version & for the git revision.
      • Not accept arguments, environment variables, or anything else to specify version, tag, branch, revision, etc.
  • Replace script/version --write & script/version_bump with script/generate_version_info_for_swift
  • When working locally, versions used (e.g. in Sources/mas/Package.swift) for revisions that aren't directly tagged with a version tag are now specified by the full git describe --tags output, which includes the current revision & the number of commits since the tag.
  • Merge all release.yml jobs into one.
  • shell script cleanup:
    • Migrate from bash to zsh.
    • Standardize settings at beginning of scripts using .
      • Prevent some external settings from affecting scripts.
      • cd into project root at beginning of every script.
    • Use -Ndfgku in all shebangs (add -e to all shebangs except for lint's).
    • Lowercase all non-environment variables.
    • Quote as appropriate.
    • Include braces in all variable uses.
    • Use printf instead of echo.
    • Write to stderr where appropriate.
    • Inline single-use variables.
    • Improve script outputs.
    • Simplify & standardize scripts.
    • Use more zsh builtins instead of external commands.
  • Fix informational URLs throughout repo:
    • Replace redirecting links.
    • Remove defunct links.
    • http -> http.
  • Ensure all files have one & only one trailing newline, and no leading newlines.
  • Minor Swift cleanups.
  • Improve documentation & samples.
  • Improve & simplify .editorconfig.
  • Upgrade danger-swift from 3.18.0 to 3.20.2.
  • Suppress script/test boilerplate output.
  • Fix mas-cli/tap/mas tap URLs.
  • Remove .actrc & act brew dependency
  • Cleanup actions/checkout@v4 output:
    • git config --global init.defaultBranch main
  • Include mas version in mas.pkg filename.
  • Platform-specific bottles.
  • Custom tap version tags & releases.
  • Bottles in mas-cli/homebrew-tap instead of in mas-cli/mas

Resolve:

@rgoldberg rgoldberg added the 🧽 chore Administrative task: documentation, build, test, release, git, etc. label Nov 15, 2024
@rgoldberg rgoldberg self-assigned this Nov 15, 2024
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
…sistent with the shebangs that are used throughout.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
…sion values.

It only seems to be used for testing with `act`. `event.json` should either be generated or be manually created; in either case, it should reside somewhere that is ignored by git, as the only source of version info in git should be version tags.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
…mmand substitutions, respectively.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
…g it.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Remove commented code.

Improve step name.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
…b instead of once per each step of that job.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Change YAML emoji to fix spacing issue.

Move YAML lint before Git lint to keep the names getting progressively shorter.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
We shouldn't need to delete `Brewfile.lock.json` because it doesn't actually lock anything; it just records versions that were installed.

If we don't delete it, new `brew bundle install` run just adds info about what was installed during its run to the existing info about previous bundle installs.

By not deleting, the code can be simplified as per this commit.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Remove mise.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
…same OS, then a checksum is required only for the oldest OS version that shares that bottle/checksum; all later versions of the OS will use that checksum.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Fix acceptable argument count.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Use braces around bash variable uses.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Nov 16, 2024
Ensure no newlines at beginning of any file.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Delete any tags that lack a valid signature.

Delete any version tags that are not on the main branch.

Create a draft GitHub Release iff the package installer builds properly.

Do not bump the `homebrew-core` `mas` formula.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Rename `mas.pkg` as `mas-${version}.pkg`.

Use `/usr/local/bin` for `--install-location` instead of having executable stored in `.pkg` under `mas_components.pkg/Payload/usr/local/bin`.

Do not output SHA-256 of `.pkg`.

Move `script/build …` earlier.

Rename variables & temporary folders to follow Apple's terminology.

Update comments.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
No longer include `script/bootstrap` in build instructions since it is only necessary for linting & formatting.

Minor text improvements.

Improve URLs.

Replace `and` with `&`.

Improve example console output.

Wrap long line.

Improve spacing.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
…sary for building.

Improve `script/bootstrap` documentation.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
…Bump mas-cli/tap/mas formula` step.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
…in `tag-pushed.yml`.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
…d.yml`.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
…li/tap/mas formula` step in `tag-pushed` job in `tag-pushed.yml`.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Avoid warning from checkout step.

Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 20, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 22, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 22, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 22, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 22, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 22, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
rgoldberg added a commit to rgoldberg/mas that referenced this issue Dec 22, 2024
Partial mas-cli#638

Signed-off-by: Ross Goldberg <484615+rgoldberg@users.noreply.github.com>
This was referenced Dec 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🧽 chore Administrative task: documentation, build, test, release, git, etc.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant