Skip to content

Get Started: Other Runtime Options

Peter Thomas edited this page Jun 1, 2023 · 37 revisions

For all the options below, you can use the simple Karate GitHub Template as a sample project.

Standalone JAR

All of Karate (core API testing, parallel-runner / HTML reports, mocks and web / UI automation) is available as a single, executable JAR file.

The only pre-requisite (if not using jbang) is the Java Runtime Environment. Note that the "lighter" JRE is sufficient, not the full-blown JDK (Java Development Kit). There is a good chance that you already have it installed. You can confirm this by typing java -version on the command line. Java version 11 or above is required.

Look for the latest release on GitHub and scroll down to find the "Assets". And look for the file with the name: karate-<version>.jar. Rename the file to karate.jar to make commands easier to type.

You can view the command line help with the -h option:

java -jar karate.jar -h

To run a feature:

java -jar karate.jar my-test.feature

You can have multiple features (separated by spaces) or even folder paths as the last part of the command. Karate will run all feature files found in sub-directories.

For a complete description of all command line options, refer to: Usage

Docker

Wrapping Karate into a Docker container is simple, most teams just base off a Maven container.

There are some tips, tricks and recipes in this thread: https://github.com/karatelabs/karate/issues/396

For example this is how you can run tests without installing Java or Maven, and all you need is Docker installed:

docker run -it --rm -v "$(pwd)":/src -w /src -v "$HOME/.m2":/root/.m2 maven:3-jdk-11 mvn test

For an explanation of the above command, refer: Docker

NPM

There is official Karate support for NPM, this can make it easy to introduce Karate into some CI / CD pipelines.

JBang

Note that you can easily run Karate or even install applications based on Karate using jbang. It will take care of setting up a local Java runtime, which is really convenient. Note that jbang itself is super-easy to install and there is even a "Zero Install" option.

With jbang installed, you can do this (since a jbang-catalog.json is present within the karatelabs/jbang-catalog GitHub repository :

jbang karate@karatelabs -h

What's really interesting is that you can install karate as a local command-line application !

please replace RELEASE with the exact / version of Karate you intend to use if applicable

 jbang app install --name karate com.intuit.karate:karate-core:RELEASE:all

And now the command karate will be available in your terminal (after opening a new one or having re-loaded environment settings).

Which would make using Karate as easy as this !

karate -h

You can script complex automation, using the Java API that Karate makes available. So if you have a file called myscript.java written as a jbang script, you can install it as a system-wide command called myscript like this:

 jbang app install --name myscript myscript.java

Refer to the jbang documentation for more options.