Rhino is an implementation of JavaScript in Java.
Rhino is licensed under the MPL 2.0.
Rhino requires Java 17 or higher to run, and 21 or higher to build. Java 25 is highly recommended.
To build and run a Rhino shell:
./gradlew run -q --console=plain
To run the tests:
git submodule init
git submodule update
./gradlew check
The current release is Rhino 1.9.1. Please see the Release Notes.
Releases
| Rhino 1.9.1 | February 15, 2026 |
| Rhino 1.9.0 | December 22, 2025 |
| Rhino 1.8.1 | December 2, 2025 |
| Rhino 1.8.0 | January 2, 2025 |
| Rhino 1.7.15 | May 3, 2024 |
| Rhino 1.7.14 | January 6, 2022 |
| Rhino 1.7.13 | September 2, 2020 |
| Rhino 1.7.12 | January 13, 2020 |
| Rhino 1.7.11 | May 30, 2019 |
| Rhino 1.7.10 | April 9, 2018 |
| Rhino 1.7.9 | March 15, 2018 |
| Rhino 1.7.8 | January 22, 2018 |
| Rhino 1.7.7.2 | August 24, 2017 |
| Rhino 1.7.7.1 | February 2, 2016 |
| Rhino 1.7.7 | June 17, 2015 |
| Rhino 1.7.6 | April 15, 2015 |
| Rhino 1.7R5 | January 29, 2015 |
Compatibility table which shows which advanced JavaScript features from ES6, and ES2016+ are implemented in Rhino.
Information for script builders and embedders:
Rhino 1.7.15 and before were primarily used in a single JAR called "rhino.jar".
Newer releases now organize the code using Java modules. There are four primary modules and one auxiliary module for Kotlin developers:
rhino-all: This creates an "all-in-one" JAR that includes rhino-runtime, rhino-tools, and rhino-xml. This is what's used if you want to run Rhino using "java jar".
rhino-kotlin: Enhanced support for code written in Kotlin, see the details.
The release contains the following other modules, which are used while building and testing but which are not published to Maven Central:
All applications that embed rhino need the main "rhino" module. Many applications don't need anything else -- consider doing the same, for a few reasons:
It's recommended to build Rhino using Java 25. However, it will build with Java 17 and up. The "spotless" tool, which enforces code formatting, will not run on older Java versions -- it will emit a warning.
Rhino runs on Java 17 and higher. The build tools use the "--release" flag to ensure that only features from Java 17 are used in the product.
The CI tools run the Rhino tests on Java 17, 21, and 25. Regardless of what version of Java you are building with, you can test on another Java version using the RHINO_TEST_JAVA_VERSION environment variable.
The "production" builds of Rhino build using Gradle, but on Linux and Mac you can also build Gradle using Bazel.
For normal development, you can build the code, run the static checks, and run all the tests like this:
git submodule init
git submodule update
./gradlew check
To just run the Rhino shell, you can do this from the top-level directory:
./gradlew run -q --console=plain
Alternately, you can build an all-in-one JAR and run that:
./gradlew shadowJar
java -jar rhino-all/build/libs/rhino-all-2.0.0-SNAPSHOT.jar
And finally, you can extract the classpath and use it in a variety of ways:
export CLASSPATH=$(./gradlew -q printClasspath)
java org.mozilla.javascript.tools.shell.Main
Building with Bazel instead of Gradle gives you a few advantages:
At the moment, we don't have all the support in Bazel to do everything that the Gradle build does so both will remain.
To build with Bazel:
For example, you can install a wrapper that will download the right version of Bazel:
npm install -g @bazel/bazelisk
You can run all the tests:
bazel test ...
You can run the shell (or skip the tests and go right here):
bazel run //:shell
If the JLine library is present, the Rhino shell will use it for command-line editing. The commands above will all include JLine. However, the Gradle wrapper interferes with JLine's ability to manipulate the terminal. For the best CLI experience, use either of the last two options, instead of ./gradlew run.
You can also run the benchmarks:
./gradlew jmh
When running the benchmarks you may find a couple of environment variables useful.
* BENCHMARK if set will limit the benchmarks run to those matching
the regular expression given.
* INTERPRETED can be set to true or false to only run the
benchmarks in interpreted or compiled mode.
* PROFILERS can be set to cpu or alloc to run the async profiler
for cpu time or memory allocations, or can be set to any other
string which will be passed to jmh as the value of the profilers
argument. This allows for things like running JFR as the profiler to
collect information on lock contention or other events.
It is a good idea to test major changes on Java 17 before assuming that they will pass the CI tests. To do this, set the environment variable RHINO_TEST_JAVA_VERSION to the version that you want to test. For example:
RHINO_TEST_JAVA_VERSION=17 ./gradlew check
This will only work if Gradle can find a JDK of the appropriate version. You can troubleshoot this using the command:
./gradlew -q javaToolchains
Not all installers seem to put JDKs in the places where Gradle can find them. When in doubt, installations from Adoptium seem to work on most platforms.
The "Jacoco" coverage is enabled by default for the main published modules as well as the special "tests" module. Coverage is generated for each of the main projects separately and available by running
./gradlew jacocoTestReport
To see an aggregated coverage report for everything, which is probably what you want, run
./gradlew testCodeCoverageReport
The result is in:
./tests/build/reports/jacoco/testCodeCoverageReport/html
-SNAPSHOT from version in gradle.properties in project root foldergradle.properties in $HOME/.gradle folder with following properties. Populate them with maven repo credentials and repo location.mavenUser=
mavenPassword=
mavenSnapshotRepo=
mavenReleaseRepo=
Gradle task to publish artifacts to Maven Central../gradlew publish
-SNAPSHOT to it in gradle.properties in project root folder.gradle.properties to GitHubIf you are using a modular JDK that disallows the reflective access to
non-public fields (16 and later), you may need to configure the JVM with the
--add-opens
option to authorize the packages that your scripts shall use, for example:
--add-opens java.desktop/javax.swing.table=ALL-UNNAMED
This is not necessary just to build or test Rhino -- it may be necessary when embedding it depending on what your project does.
Most issues are managed on GitHub:
https://github.com/mozilla/rhino/issues
To submit a new PR, please use the following process:
If you are adding new capabilities to Rhino, you may be making more test262 tests pass, which is a good thing. Please see the instructions on how to update our test262 configuration.
Because of differences between Java and JavaScript, when testing on newer Java versions, many Unicode-related test262 tests appear to pass, but they will fail on Java 17. Please ignore these!
Code formatting was introduced in 2021. The "spotless" plugin will fail your build if you have changed any files that have not yet been reformatted. Please use "spotlessApply" to reformat the necessary files.
If you are the first person to touch a big file that spotless wants to make hundreds of lines of changes to, please try to put the reformatting changes alone into a single Git commit so that we can separate reformatting changes from more substantive changes.
Currently, you must be building on Java 17 or higher for Spotless to run.
GitHub
$ claude mcp add rhino \
-- python -m otcore.mcp_server <graph>