5.0 KiB
Rhino Release Process
Prepare the repository
Update the version in gradle.properties to the new release version.
Update RELEASE_NOTES.md to include at least a summary of the major features of the release. (This is historical, but many find it helpful to have a single file in the repo that lists the major changes.)
Update README.md to add a row to the table of releases that points to the GitHub release that we'll create in the next step (just follow the pattern that's there).
Now might be a good time to run "./gradlew publishToMavenLocal" and use the published JARs as a sanity check.
Update Native Compatibility Table
The offial Kangax "compat table" now supports Rhino, but it's convenient to have our own that shows progress across all releases. Here's how to update it:
git clone -b gh-pages https://github.com/gbrail/node-compat-table.git
cd node-compat-table
Now, edit "rhinoall.sh" to include the new release -- it includes a series of lines that fetch old releases, and use your local build of the new one. Then, update the table:
./rhinoall.sh
The resulting "index.html" can be copied into "docs/compat/engines.html" in this repo.
Push the Release to GitHub
At this point, the current contents of your directory correspond to the new release. Prepare a pull request containing the changes, submit it, and merge it -- the result will be that the head of the "master" branch will build your new release.
Update to that branch and create a tag for the release, where XX is a number like "1_7_14":
git pull origin master
git tag Rhino_XX_Release
git push origin Rhino_XX_Release
Now, on the Rhino "Releases" tab in GitHub, create a release that corresponds to the new tag. Include the following:
- A cut and paste of the part of RELEASE_NOTES.md added for the release
- The three JARs created by "./gradlew.jar"
- The ZIP file created by "./gradlew distZip"
- A ZIP of the source will be included automatically by GitHub
Push the release to Maven Central
The "Publish to Maven Central" action on GitHub Actions will automatically build the release, sign the JARs, and push it to oss.sonatype.org in the "org.mozilla" area. Kick off this job using the "Actions" tag in the GitHub UI.
Next, Log in to oss.sonatype.org, verify that all the checks that happen there were successful, and "close" the release. It will appear on Maven Central a few hours later.
Update Homebrew
The Homebrew team for Mac does not necessarily pick up Rhino releases automatically. It may be necessary to submit a PR to the "homebrew/homebrew" repo in GitHub for a change to the file "Library/Formula/rhino.rb".
Update Kangax Compatibility Table
Check out kangax/compat-table
and prepare a pull request to describe
support in the new version of Rhino. First, add a new environment for the
version to environments.json
like so:
"rhino1_7_14": {
"full": "Rhino 1.7.14",
"short": "Rhino 1.7.14",
"family": "Rhino",
"platformtype": "engine",
"release": "2022-01-06",
"obsolete": true
},
Copy the most recent rhino JAR into the directory as rhino.jar
. Next, run
rhino.js
. This will produce a number of messages indicating that failing
tests now pass, or that new tests now have recorded results:
**** data-es2016plus ****
data-es2016plus -> Error.cause property -> AggregateError.prototype lacks cause: test result out of date, res: true, actual: false
Manually update each indicated data-*.js
file with updated test data as
indicated. For example, a test that failed in 1.7.13 and passed in 1.7.14
would have a res
section with the following diff:
res: {
babel6corejs2: false,
babel7corejs3: babel.corejs,
/* ... */
rhino1_7_13: false,
+ rhino1_7_14: true,
}
Rerun rhino.js
and verify it produces no output. Then npm run build
and
submit your pull request.
Update Babel
Once the compat-table
changes are merged, check out babel/babel
and prepare
a pull request to enable support for babel-preset-env
in the new release.
- Update
COMPAT_TABLE_COMMIT
inpackages/babel-compat-data/scripts/download-compat-table.sh
to correspond to the merge commit incompat-table
. - Run
make build-compat-data && make bootstrap && OVERWRITE=true yarn jest
.
Then submit the resulting patch as a pull request to Babel.
Update core-js-compat
Compatibility data for core-js
, the babel
polyfill engine, also needs to
be updated.
- Check out
zloirock/core-js
and runnpm install && npm run build-compat
. - Define the actual Rhino version in the
compat-rhino-prepare
task inpackage.json
. - Run
npm run compat-rhino
and you will see the results of tests in the console. - Much like in
compat-table
, editpackages/core-js-compat/src/data.mjs
to add a linerhino: 1.7.[XX]
for any newly-passing test labeled as "not required". - Submit a pull request with changes.
Prepare for Next Release
Now it's time to move to the next "SNAPSHOT" release. Update gradle.properties, create a PR, and push the new PR. Now development can proceeed anew!