Cucumber REST Steps
With this library you can use Cucumber to test REST endpoints
Steps in this library
-
^I call (GET|POST|PUT|HEAD|DELETE|OPTIONS|PATCH|TRACE) "([^"]*)"$
-> Make a request to a URL with the given HTTP methodGiven I call GET "https://github.com"
-
^I call (GET|POST|PUT|HEAD|DELETE|OPTIONS|PATCH|TRACE) "([^"]*)" with data(?:[:])?$
-> Make a request to a URL with the given HTTP method and with the given json body. The json body will be parsed from a doc string in yaml formatGiven I call POST "https://github.com" with data: """ foo: "bar" wee: - "yi" """
This example will make a POST request to https://github.com with a json body
{"foo": "bar", "wee": ["yi"]}
-
^I call (GET|POST|PUT|HEAD|DELETE|OPTIONS|PATCH|TRACE) "([^"]*)" with data from "([^"]*)"$
-> Make a request to a URL with the given HTTP method and use the given file to get the json bodyGiven I call POST "https://github.com" with data from file "json.json"
This example will make a POST request to https://github.com obtaining the json body from the file json.json
-
^I call (GET|POST|PUT|HEAD|DELETE|OPTIONS|PATCH|TRACE) "([^"]*)" with query params(?:[:])?$
-> Make a request to a URL with the given HTTP method and with the query params parsed from a data tableGiven I call GET "https://github.com" with query params: | param | value |
This example will make a GET request to https://github.com?param=value
-
^I call (GET|POST|PUT|HEAD|DELETE|OPTIONS|PATCH|TRACE) "([^"]*)" with file "([^"]*)" from "([^"]*)"$
-> Make a request to a URL with the given HTTP method and with a file from the classpathGiven I call POST "https://github.com" with file "myfile" from "files/file.txt"
This example will make a POST request to https://github.com with a file with name myfile and content from files/file.txt
-
^I call (GET|POST|PUT|HEAD|DELETE|OPTIONS|PATCH|TRACE) "([^"]*)" with empty file "([^"]*)"$
-> Make a request to a URL with the given HTTP method and with an empty file. This step is useful to test what happens when you submit an empty file to your endpointGiven I call POST "https://github.com" with empty file "myfile"
This example will make a POST request to https://github.com with a file with name myfile and empty content
-
^I set headers to(?:[:])?$
-> Set the request headers from the data table. You should use this step before any of the previous stepsGiven I set headers to: | header | value |
This example put a header header with value value to the request
-
^The response status should be (\d+)$
-> Asserts that the given response status is equals to a numberThen The response status should be 200
This example asserts that the response status is 200 (OK)
-
^The response is empty$
-> Asserts that the given response is emptyThen The response is empty
-
^The response should be(?:[:])?$
-> Asserts that the response is equals to the given json. The json will be parsed from a doc string in yaml formatThen The response should be: """ foo: "bar" """
This example asserts that the response is
{"foo": "bar"}
-
^The response should contain empty array$
-> Asserts that the response is an empty arrayThen The response should contain empty array
This example asserts that the response is
[]
-
^The response should contain array with size (\d+)$
-> Asserts that the response is an array and has the given sizeThen The response should contain array with size 3
This example asserts that the response is an array and has 3 elements
-
^The response should be array(?:[:])?$
-> Asserts that the response is the given array. The array will be parsed from a doc string in yaml formatThen The response should be array: """ - "foo" - "bar" """
This example asserts that the response is the array
["foo", "bar"]
-
^The response should contain "([^"]*)"$
-> Asserts that the response contains the given keyThen The response should contain "foo"
This example asserts that the response contains the key foo with any value
-
^The response should not contain "([^"]*)"$
-> Asserts that the response doesn't contain the given keyThen The response should not contain "foo"
This example asserts that the response doesn't contain the key foo
-
^The response should contain "([^"]*)" with value "([^"]*)"$
-> Asserts that the response contains the given key with the given valueThen The response should contain "foo" with value "bar"
This example asserts that the response contains the key foo with value "bar"
-
^The response should not contain "([^"]*)" with value "([^"]*)"$
-> Asserts that the response contains the given key but the value is not the given valueThen The response should not contain "foo" with value "bar"
This example asserts that the response contains the key foo but its value is not "bar"
-
^The response should contain(?: (less than|more than|at least|at most))? (\\d+) entit(?:ies|y)$
-> Asserts that the response is an array and has less than, more than, at least or at most entitiesThen The response should contains 3 entities
This example asserts that the response is an array with 3 elements
Then The response should contains less than 3 entities
This example asserts that the response is an array with less than 3 elements
Then The response should contains more than 3 entities
This example asserts that the response is an array with more than 3 elements
Then The response should contains at least 3 entities
This example asserts that the response is an array with at least 3 elements
Then The response should contains at most 3 entities
This example asserts that the response is an array with at most 3 elements
-
^Response entity "([^"]*)" should contain "([^"]*)"$
-> Asserts that the given entity from the response contains the given keyThen Response entity "foo" should contain "bar"
This example asserts that the response entity foo contains the key bar with any value
-
^Response entity "([^"]*)" should not contain "([^"]*)"$
-> Asserts that the given entity from the response doesn't contain the given keyThen Response entity "foo" should not contain "bar"
This example asserts that the response entity foo doesn't contain the key bar
-
^Response entity "([^"]*)" should contain "([^"]*)" with value "([^"]*)"$
-> Asserts that the given entity from the response contains the given key with the given valueThen Response entity "foo" should contain "bar" with value "wee"
This example asserts that the response entity foo contains the key bar with value "wee"
-
^Response entity "([^"]*)" should not contain "([^"]*)" with value "([^"]*)"$
-> Asserts that the given entity from the response contains the given key but the value is not the given valueThen Response entity "foo" should not contain "bar" with value "wee"
This example asserts that the response entity foo contains the key bar but the value is not "wee"
-
^Response entity \"([^\"]*)\" should contain array(?:[:])?$
-> Asserts that the given response entity is the given array. The array will be parsed from a doc string in yaml formatThen Response entity "foo" should contain array: """ - "bar" - "wee" """
This example asserts that the response entity foo contains the array
["bar", "wee"]
-
^Response entity \"([^\"]*)\" should contain(?: (less than|more than|at least|at most))? (\\d+) entit(?:ies|y)$
-> Assert than the given entity from the response is an array and has less than, more than, at least or at most entitiesThen Response entity "foo" should contains 3 entities
This example asserts that the response entity foo is an array with 3 elements
Then Response entity "foo" should contains less than 3 entities
This example asserts that the response entity foo is an array with less than 3 elements
Then Response entity "foo" should contains more than 3 entities
This example asserts that the response entity foo is an array with more than 3 elements
Then Response entity "foo" should contains at least 3 entities
This example asserts that the response entity foo is an array with at least 3 elements
Then Response entity "foo" should contains at most 3 entities
This example asserts that the response entity foo is an array with at most 3 elements
-
^The response headers should contain "([^"]*)"$
-> Asserts that the response headers contain the given headerThe response headers should contain "foo"
This example asserts that the response headers contain a header foo with any value
-
^The response headers should not contain "([^"]*)"$
-> Asserts that the response headers don't contain the given headerThe response headers should not contain "foo"
This example asserts that the response headers don't contain a header foo
-
^The response headers should contain "([^"]*)" with value "([^"]*)"$
-> Asserts that the response headers contain the given header and any of its values is the given valueThe response headers should contain "foo" with value "bar"
This example asserts that the response headers contain a header foo and has bar value
-
^The response headers should not contain "([^"]*)" with value "([^"]*)"$
-> Asserts that the response headers contain the given header and none of its values is the given valueThe response headers should not contain "foo" with value "bar"
This example asserts that the response headers contain a header foo and hasn`t bar as value
-
You can access to the response object and use it to chain another request
Given I call GET "https://github.com" Then I call GET "https://github.com/$.foo.bar"
In this example we made a request and then we made another request using the value of foo.bar from the first response
Installation
Add dependency to your pom.xml
<dependency>
<groupId>es.rubenjgarcia</groupId>
<artifactId>cucumber-rest-steps</artifactId>
<version>1.1.0-SNAPSHOT</version>
<scope>test</scope>
</dependency>
Create the test class with the package glue
import cucumber.api.CucumberOptions;
import cucumber.api.junit.Cucumber;
import org.junit.runner.RunWith;
@RunWith(Cucumber.class)
@CucumberOptions(glue = {"es.rubenjgarcia.cucumber.rest.steps"}, features = "classpath:features")
public class CucumberTestCase {
}