Skip to content

Latest commit

 

History

History
50 lines (41 loc) · 2.77 KB

release-instructions.md

File metadata and controls

50 lines (41 loc) · 2.77 KB

Dependency notes

Release Procedure

  1. (Optional) Update minor dependencies in package.json
    • npx npm-check-updates
    • or npm outdated + npm update --save
  2. Stable release only: make sure there aren’t any @11ty/* dependencies on pre-release versions alpha/beta/canary
  3. If the minimum Node version changed, make sure you update package.json engines property.
    • Make sure the error message works correctly for Node versions less than 10.
      • 0.12.x+ requires Node 10+
      • 1.x+ requires Node 12+
      • 2.x+ requires Node 14+
      • 3.x+ requires Node 18+
  4. rm -rf node_modules && rm -f package-lock.json && npm install
  5. npm audit
  6. Make sure npm run check (eslint) runs okay
  7. Make sure npm run test (ava) runs okay
  8. Update version in package.json
    • (Alpha) Use -alpha.1 suffix
    • (Beta) Use -beta.1 suffix
  9. Run npm run coverage
  10. Check it all in and commit
  11. Tag new version
  12. Wait for GitHub Actions to complete to know that the build did not fail.
  13. Publish a release on GitHub at https://github.com/11ty/eleventy/releases pointing to the tag of the release. Hitting the publish button on this workflow will use GitHub Actions to publish the package to npm on the correct dist-tag and includes npm package provenance for the release.
  • Main release: no version suffix publishes to latest (default) tag on npm
  • Canary release: -alpha. version suffix in package.json publishes to canary tag on npm: #2758
  • Beta release: -beta. version suffix publishes to beta tag on npm

Unfortunate note about npm and tags (specifically canary here): if you push a 1.0.0-canary.x to canary (even though 2.0.0-canary.x exists), it will use the last pushed tag when you npm install from @canary (not the highest version number)

Docs/Website (Main releases only)

  1. Maybe search for -alpha. (-canary.?) or -beta. in the docs copy to update to the stable release, if applicable.
  2. Check in a new 11ty-website site with updated package.json version.
  3. Add version to 11ty-website versions.json
  4. Commit it
  5. Create a new branch for branched version
  6. (Main) Check out the previous version git branch and add outdated: true to _data/config.json and commit/push.
  7. Go to https://app.netlify.com/sites/11ty/settings/domain and set up a subdomain for it.

Downstream dependencies

  1. Update eleventy-base-blog to use new version
  2. Update 11ty-website to use new version