Running Cucumber From the Command Line

DZone 's Guide to

Running Cucumber From the Command Line

Learn the steps and conditions for running the Cucumber automated testing tool from the command line in this quick walkthrough.

· DevOps Zone ·
Free Resource

Recently, I’ve been spending some time with Cucumber and joined the Cucumber Gitter channel when somebody pointed out that they were having trouble running Cucumber from the command line. I usually run Cucumber from Maven, so I thought it would be interesting to see what was required to run cucumber from the command line.

As described in the documentation, you can run Cucumber features from the command line by using the CLI-runner with the following command:

java cucumber.api.cli.Main

You can get help by using the --help option:

java cucumber.api.cli.Main --help

This looks pretty straightforward if you are familiar with Java, but the "hard" part comes from understanding how to use the Java command with its classpath options.

One important aspect is that the cucumber.api.cli.Main class is located in the cucumber-core jar file, so when you want to run this class, you need to provide the cucumber-core jar on your classpath. In this case, I take the jar(s) from my Maven repository and include all required dependencies:

$ java -cp "/Users/jreijn/.m2/repository/info/cukes/cucumber-core/1.2.5/cucumber-core-1.2.5.jar:/Users/jreijn/.m2/repository/info/cukes/gherkin/2.12.2/gherkin-2.12.2.jar:/Users/jreijn/.m2/repository/info/cukes/cucumber-java/1.2.5/cucumber-java-1.2.5.jar:/Users/jreijn/.m2/repository/info/cukes/cucumber-jvm-deps/1.0.5/cucumber-jvm-deps-1.0.5.jar" cucumber.api.cli.Main

If you run this it should result in the following message:

Got no path to feature directory or feature file
0 Scenarios
0 Steps

Now to be able to run we need to run a feature file you will need to provide two additional arguments:

  1. Your feature file(s)
  2. Your glue code (step definitions, hooks, etc)

Your feature files can be added to the end of the command line:

$ java -cp "/Users/jreijn/.m2/repository/info/cukes/cucumber-core/1.2.5/cucumber-core-1.2.5.jar:/Users/jreijn/.m2/repository/info/cukes/gherkin/2.12.2/gherkin-2.12.2.jar:/Users/jreijn/.m2/repository/info/cukes/cucumber-java/1.2.5/cucumber-java-1.2.5.jar:/Users/jreijn/.m2/repository/info/cukes/cucumber-jvm-deps/1.0.5/cucumber-jvm-deps-1.0.5.jar" cucumber.api.cli.Main Developer/sources/github/cucumber-jvm-extentreport/src/test/resources/cucumber/feature_one.feature

This will probably result in the following message:


3 Scenarios (3 undefined)
6 Steps (6 undefined)

You can implement missing steps with the snippets below:


This means it can’t find the step definitions, hooks, etc that correspond to your feature file.

Let’s add the glue code required for running the tests. In the below example I’ll use my maven projects target directory, which contains my step definitions in the test-classes directory. You can do that by adding the directory to your classpath, and with the argument --glue com.sitture.definitions, provide the Java package that contains step definition Java classes.

$ java -cp "/Users/jreijn/.m2/repository/info/cukes/cucumber-core/1.2.5/cucumber-core-1.2.5.jar:/Users/jreijn/.m2/repository/info/cukes/gherkin/2.12.2/gherkin-2.12.2.jar:/Users/jreijn/.m2/repository/info/cukes/cucumber-java/1.2.5/cucumber-java-1.2.5.jar:/Users/jreijn/.m2/repository/info/cukes/cucumber-jvm-deps/1.0.5/cucumber-jvm-deps-1.0.5.jar:/Users/jreijn/Developer/sources/github/cucumber-jvm-extentreport/target/test-classes/" cucumber.api.cli.Main --glue com.sitture.definitions Developer/sources/github/cucumber-jvm-extentreport/src/test/resources/cucumber/feature_one.feature

This should result in something similar to:


3 Scenarios (3 passed)
6 Steps (6 passed)

Which seems about right and shows how we can run Cucumber from the command line with the Cucumber CLI.

cucumber ,java ,testing ,bdd ,devops

Published at DZone with permission of Jeroen Reijn . See the original article here.

Opinions expressed by DZone contributors are their own.

{{ parent.title || parent.header.title}}

{{ parent.tldr }}

{{ parent.urlSource.name }}