There is a script - compare-master-to-stable.js - that helps with this. We just want to make sure that good commits (low risk fixes + docs fixes) got cherry-picked into stable branch and nothing interesting got merged only into stable branch.
A super-heroic power (adverb-verb phrase).
Example Commit: https://github.com/angular/angular.js/commit/7ab5098c14ee4f195dbfe2681e402fe2dfeacd78
- Run
node_modules/.bin/changez -o changes.md -v <new version> <base branch>
- Review the generated file and manually fix typos, group and reorder stuff if needed.
- Move the content into CHANGELOG.md add release code-names to headers.
- Push the changes to your private github repo and review.
- cherry-pick the release notes commit to the appropriate branches.
Usually this will be the commit containing the release notes, but it may also be in the past.
scripts/jenkins/release.sh --git-push-dryrun=false --commit-sha=8822a4f --version-number=1.7.6 --version-name=gravity-manipulation
-
The SHA is of the commit to release (could be in the past).
-
The version number and code-name that should be released, not the next version number (e.g. to release 1.2.12 you enter 1.2.12 as release version and the code-name that was picked for 1.2.12, cauliflower-eradication).
-
You will need to have write access to all the AngularJS github dist repositories and publish rights for the AngularJS packages on npm.
-
Create the next milestone if it doesn't exist yet-giving ita due date.
-
Move all open issues and PRs for the current milestone to the next milestone
You can do this by filtering the current milestone, selecting via checklist, and moving to the next milestone within the GH issues page. -
Close the current milestone click the milestones tab and close from there.
-
Create a new holding milestone for the release after next-but don't give it a due date otherwise that will mess up the dashboard.
Google CDNs are fed with data from google3 every day at 11:15am PT it takes only few minutes for the import to propagate). If we want to make our files available, we need submit our CLs before this time on the day of the release.
This is the version used to compute what version to link to in the CDN. If you update this too early then the CDN lookup fails and you end up with 'null, for the version, which breaks the docs.
The versions in the modal are updated (based on the versions available on CDN) as part of the Travis deploy stage: https://github.com/angular/angularjs.org/blob/a4d25c5abcd39e8ce19d31cb1c78073d13c4c974/.travis.yml#L26 (You may need to explicitly trigger the Travis job. e.g. re-running the last job.)
Double check that angularjs.org is up to date with the new release version before sharing.
- Collect a list of contributors
use: git log --format='%aN' v1.2.12..v1.2.13 | sort -u
- Write a blog post (for minor releases, not patch releases) and publish it with the "release" tag
- Post on twitter as yourself (tweet from your heart; there is no template for this), retweet as @AngularJS
- Update angularjs.org to use the latest branch.
- Write up a migration document.
- Create a new git branch for the version that has been released (e.g. 1.8.x).
- Check that the build and release scripts still work.
- Update the dist-tag of the old branch, see angular#12722.
- Write a blog post.