Skip to content

Latest commit

 

History

History
57 lines (37 loc) · 4.25 KB

File metadata and controls

57 lines (37 loc) · 4.25 KB

Managing Releases

A release are when a project formally publishes a new version so the community can use it. There are two types of releases:

  • Regular releases that follow semantic versioning and are considered production-ready.
  • Prereleases that are not considered production-ready and are intended to give the community a preview of upcoming changes.

1. Release Team

A two-person release team is assigned to each scheduled release. This two-person team is responsible for:

  1. The scheduled release on Friday
  2. Monitoring issues over the weekend
  3. Determining if a patch release is necessary on Monday
  4. Publishing the patch release (if necessary)

The two-person team should seek input from the whole team on the Monday following a release to double-check if a patch release is necessary.

2. Release Communication

Each scheduled release should be associated with a release issue. The release issue is the source of information for the team about the status of a release. Be sure the release issue has the type: release label so that it's easy to find.

3. Process

On the day of a scheduled release, the release team should follow these steps:

  1. Review open pull requests to see if any should be merged. In general, you can merge pull requests that:
    • Have been open at least two days and have been reviewed (these are just waiting for merge).
    • Important pull requests (as determined by the team). You should stop and have people review before merging if they haven't been already.
    • Documentation changes.
    • Small defect fixes written by a team member.
  2. Log into Jenkins and schedule a build for the "{product-name} Release" job.
  3. Wait for the "{product-name} Release" job to complete.
  4. Update the release blog post with a "Highlights" section, including new rules and anything else that's important.
  5. Make a release announcement in the public chatroom.
  6. Make a release announcement on Twitter.
  7. Make a release announcement on the release issue. Document any problems that occurred during the release, and remind the team not to merge anything other than documentation changes and defect fixes. Leave the release issue open.
  8. Add the patch release pending label to the release issue. (When this label is present, eslint-github-bot will create a pending status check on non-semver-patch pull requests, to ensure that they aren't accidentally merged while a patch release is pending.)

On the Monday following the scheduled release, the release team needs to determine if a patch release is necessary. A patch release is considered necessary if any of the following occurred since the scheduled release:

  • A regression defect is causing people's lint builds to fail when it previously passed.
  • Any defect that is causing a lot of problems for users (frequently happens due to new functionality).

The patch release decision should be made as early on Monday as possible. If a patch release is necessary, then follow the same steps as the scheduled release process.

In rare cases, a second patch release might be necessary if the release is known to have a severe regression that hasn't been fixed by Monday. If this occurs, the release team should announce the situation on the release issue, and leave the issue open until all patch releases are complete. However, it's usually better to fix defects for the next release cycle rather than doing a second patch release.

After the patch release has been published (or no patch release is necessary), close the release issue and inform the team that they can start merging in semver-minor changes again.

4. Emergency Releases

In general, we try not to do emergency releases (an emergency release is unplanned and isn't the regularly scheduled release or the anticipated patch release). Even if there is a regression, it's best to wait the weekend to see if any other problems arise so a patch release can fix as many issues as possible.

The only real exception is if {product-name} is completely unusable by most of the current users. For instance, we once pushed a release that errored for everyone because it was missing some core files. In that case, an emergency release is appropriate.