If you use Codeception installed using composer, install this module with the following command:
composer require --dev codeception/module-rest
Alternatively, you can enable REST
module in suite configuration file and run
codecept init upgrade4
This module was bundled with Codeception 2 and 3, but since version 4 it is necessary to install it separately.
Some modules are bundled with PHAR files.
Warning. Using PHAR file and composer in the same project can cause unexpected errors.
Module for testing REST WebService.
This module can be used either with frameworks or PHPBrowser. If a framework module is connected, the testing will occur in the application directly. Otherwise, a PHPBrowser should be specified as a dependency to send requests and receive responses from a server.
This module requires PHPBrowser or any of Framework modules enabled.
In case you need to configure low-level HTTP fields, that’s done on the PHPBrowser level. Check the example below for details.
modules:
enabled:
- REST:
depends: PhpBrowser
url: &url 'http://serviceapp/api/v1/' # you only need the &url anchor for further PhpBrowser configs
shortDebugResponse: 300 # only the first 300 chars of the response
config:
PhpBrowser:
url: *url # repeats the URL from the REST module; not needed if you don't have further settings like below
headers:
Content-Type: application/json
Conflicts with SOAP module
Allows to send REST request using AWS Authorization
Only works with PhpBrowser Example Config:
yml modules: enabled: - REST: aws: key: accessKey secret: accessSecret service: awsService region: awsRegion
Code:
<?php $I->amAWSAuthenticated(); ?>
param array
$additionalAWSConfig @throws ModuleExceptionAdds Bearer authentication via access token.
param
$accessToken[Part]
json[Part]
xmlAdds Digest authentication via username/password.
param
$usernameparam
$password[Part]
json[Part]
xmlAdds HTTP authentication via username/password.
param
$usernameparam
$password[Part]
json[Part]
xmlAdds NTLM authentication via username/password. Requires client to be Guzzle >=6.3.0 Out of scope for functional modules.
Example:
<?php $I->amNTLMAuthenticated('jon_snow', 'targaryen'); ?>
param
$usernameparam
$password @throws ModuleException[Part]
json[Part]
xmlDeletes a HTTP header (that was originally added by haveHttpHeader()), so that subsequent requests will not send it anymore.
Example:
<?php $I->haveHttpHeader('X-Requested-With', 'Codeception'); $I->sendGet('test-headers.php'); // ... $I->deleteHeader('X-Requested-With'); $I->sendPost('some-other-page.php'); ?>
param string
$name the name of the header to delete.[Part]
json[Part]
xmlChecks if the hash of a binary response is not the same as provided.
<?php $I->dontSeeBinaryResponseEquals("8c90748342f19b195b9c6b4eff742ded"); ?>
Opposite to seeBinaryResponseEquals
param
$hash the hashed data response expectedparam
$algo the hash algorithm to use. Default md5.[Part]
json[Part]
xmlChecks over the given HTTP header and (optionally) its value, asserting that are not there
param
$nameparam
$value[Part]
json[Part]
xmlChecks that response code is not equal to provided value.
<?php $I->dontSeeResponseCodeIs(200); // preferred to use \Codeception\Util\HttpCode $I->dontSeeResponseCodeIs(\Codeception\Util\HttpCode::OK);
[Part]
json[Part]
xmlparam
$codeChecks whether last response do not contain text.
param
$text[Part]
json[Part]
xmlOpposite to seeResponseContainsJson
[Part]
jsonparam array
$jsonOpposite to seeResponseJsonMatchesJsonPath
param string
$jsonPath[Part]
jsonOpposite to seeResponseJsonMatchesXpath
param string
$xpath[Part]
jsonOpposite to seeResponseMatchesJsonType
.
[Part]
jsonparam
$jsonType jsonType structureparam null
$jsonPath optionally set specific path to structure with JsonPath @see seeResponseMatchesJsonTypeAvailable since
2.1.3Checks XML response does not equal to provided XML. Comparison is done by canonicalizing both xml`s.
Parameter can be passed either as XmlBuilder, DOMDocument, DOMNode, XML string, or array (if no attributes).
param
$xml[Part]
xmlChecks XML response does not include provided XML. Comparison is done by canonicalizing both xml`s. Parameter can be passed either as XmlBuilder, DOMDocument, DOMNode, XML string, or array (if no attributes).
param
$xml[Part]
xmlChecks whether XML response does not match XPath
<?php $I->dontSeeXmlResponseMatchesXpath('//root/user[@id=1]');
[Part]
xmlparam
$xpathFinds and returns attribute of element. Element is matched by either CSS or XPath
param
$cssOrXPathparam
$attributereturn
string[Part]
xmlReturns data from the current JSON response using JSONPath as selector. JsonPath is XPath equivalent for querying Json structures. Try your JsonPath expressions online. Even for a single value an array is returned.
This method require flow/jsonpath
> 0.2 library to be installed.
Example:
<?php // match the first `user.id` in json $firstUserId = $I->grabDataFromResponseByJsonPath('$..users[0].id'); $I->sendPut('/user', array('id' => $firstUserId[0], 'name' => 'davert')); ?>
param string
$jsonPathreturn
array Array of matching items @throws \Exception[Part]
jsonAvailable since
2.0.9Returns the value of the specified header name
param
$nameparam Boolean
$first Whether to return the first value or all header values
return string|array The first header value if
$first is true, an array of values otherwise[Part]
json[Part]
xmlReturns current response so that it can be used in next scenario steps.
Example:
<?php $user_id = $I->grabResponse(); $I->sendPut('/user', array('id' => $user_id, 'name' => 'davert')); ?>
return
string[Part]
json[Part]
xmlAvailable since
1.1Finds and returns text contents of element. Element is matched by either CSS or XPath
param
$cssOrXPathreturn
string[Part]
xmlSets a HTTP header to be used for all subsequent requests. Use deleteHeader
to unset it.
<?php $I->haveHttpHeader('Content-Type', 'application/json'); // all next requests will contain this header ?>
param
$nameparam
$value[Part]
json[Part]
xmlSets SERVER parameter valid for all next requests.
$I->haveServerParameter('name', 'value');
Checks if the hash of a binary response is exactly the same as provided. Parameter can be passed as any hash string supported by hash(), with an optional second parameter to specify the hash type, which defaults to md5.
Example: Using md5 hash key
<?php $I->seeBinaryResponseEquals("8c90748342f19b195b9c6b4eff742ded"); ?>
Example: Using md5 for a file contents
<?php $fileData = file_get_contents("test_file.jpg"); $I->seeBinaryResponseEquals(md5($fileData)); ?>
Example: Using sha256 hash
<?php $fileData = '/9j/2wBDAAMCAgICAgMCAgIDAwMDBAYEBAQEBAgGBgUGCQgKCgkICQkKDA8MCgsOCwkJDRENDg8QEBEQCgwSExIQEw8QEBD/yQALCAABAAEBAREA/8wABgAQEAX/2gAIAQEAAD8A0s8g/9k='; // very small jpeg $I->seeBinaryResponseEquals(hash("sha256", base64_decode($fileData)), 'sha256'); ?>
param
$hash the hashed data response expectedparam
$algo the hash algorithm to use. Default md5.[Part]
json[Part]
xmlChecks over the given HTTP header and (optionally) its value, asserting that are there
param
$nameparam
$value[Part]
json[Part]
xmlChecks that http response header is received only once. HTTP RFC2616 allows multiple response headers with the same name. You can check that you didn’t accidentally sent the same header twice.
<?php $I->seeHttpHeaderOnce('Cache-Control'); ?>>
param
$name[Part]
json[Part]
xmlChecks response code equals to provided value.
<?php $I->seeResponseCodeIs(200); // preferred to use \Codeception\Util\HttpCode $I->seeResponseCodeIs(\Codeception\Util\HttpCode::OK);
[Part]
json[Part]
xmlparam
$codeChecks that the response code is 4xx
[Part]
json[Part]
xmlChecks that the response code 3xx
[Part]
json[Part]
xmlChecks that the response code is 5xx
[Part]
json[Part]
xmlChecks that the response code is 2xx
[Part]
json[Part]
xmlChecks whether the last response contains text.
param
$text[Part]
json[Part]
xmlChecks whether the last JSON response contains provided array. The response is converted to array with json_decode($response, true) Thus, JSON is represented by associative array. This method matches that response array contains provided array.
Examples:
<?php // response: {name: john, email: [email protected]} $I->seeResponseContainsJson(array('name' => 'john')); // response {user: john, profile: { email: [email protected] }} $I->seeResponseContainsJson(array('email' => '[email protected]')); ?>
This method recursively checks if one array can be found inside of another.
param array
$json[Part]
jsonChecks if response is exactly the same as provided.
[Part]
json[Part]
xmlparam
$responseChecks whether last response was valid JSON. This is done with json_last_error function.
[Part]
jsonChecks whether last response matches the supplied json schema (https://json-schema.org/) Supply schema as relative file path in your project directory or an absolute path
@see codecept_absolute_path()
param string
$schemaFilename[Part]
jsonChecks whether last response matches the supplied json schema (https://json-schema.org/) Supply schema as json string.
Examples:
<?php // response: {"name": "john", "age": 20} $I->seeResponseIsValidOnJsonSchemaString('{"type": "object"}'); // response {"name": "john", "age": 20} $schema = [ "properties" => [ "age" => [ "type" => "integer", "minimum" => 18 ] ] ]; $I->seeResponseIsValidOnJsonSchemaString(json_encode($schema)); ?>
param string
$schema[Part]
jsonChecks whether last response was valid XML. This is done with libxml_get_last_error function.
[Part]
xmlChecks if json structure in response matches JsonPath. JsonPath is XPath equivalent for querying Json structures. Try your JsonPath expressions online. This assertion allows you to check the structure of response json.
This method require flow/jsonpath
> 0.2 library to be installed.
{ "store": { "book": [ { "category": "reference", "author": "Nigel Rees", "title": "Sayings of the Century", "price": 8.95 }, { "category": "fiction", "author": "Evelyn Waugh", "title": "Sword of Honour", "price": 12.99 } ], "bicycle": { "color": "red", "price": 19.95 } } }
<?php // at least one book in store has author $I->seeResponseJsonMatchesJsonPath('$.store.book[*].author'); // first book in store has author $I->seeResponseJsonMatchesJsonPath('$.store.book[0].author'); // at least one item in store has price $I->seeResponseJsonMatchesJsonPath('$.store..price'); ?>
param string
$jsonPath[Part]
jsonAvailable since
2.0.9Checks if json structure in response matches the xpath provided. JSON is not supposed to be checked against XPath, yet it can be converted to xml and used with XPath. This assertion allows you to check the structure of response json. *
{ "store": { "book": [ { "category": "reference", "author": "Nigel Rees", "title": "Sayings of the Century", "price": 8.95 }, { "category": "fiction", "author": "Evelyn Waugh", "title": "Sword of Honour", "price": 12.99 } ], "bicycle": { "color": "red", "price": 19.95 } } }
<?php // at least one book in store has author $I->seeResponseJsonMatchesXpath('//store/book/author'); // first book in store has author $I->seeResponseJsonMatchesXpath('//store/book[1]/author'); // at least one item in store has price $I->seeResponseJsonMatchesXpath('/store//price'); ?>
param string
$xpath[Part]
jsonAvailable since
2.0.9Checks that JSON matches provided types. In case you don’t know the actual values of JSON data returned you can match them by type. It starts the check with a root element. If JSON data is an array it will check all elements of it. You can specify the path in the json which should be checked with JsonPath
Basic example:
<?php // {'user_id': 1, 'name': 'davert', 'is_active': false} $I->seeResponseMatchesJsonType([ 'user_id' => 'integer', 'name' => 'string|null', 'is_active' => 'boolean' ]); // narrow down matching with JsonPath: // {"users": [{ "name": "davert"}, {"id": 1}]} $I->seeResponseMatchesJsonType(['name' => 'string'], '$.users[0]'); ?>
You can check if the record contains fields with the data types you expect. The list of possible data types:
You can also use nested data type structures, and define multiple types for the same field:
<?php // {'user_id': 1, 'name': 'davert', 'company': {'name': 'Codegyre'}} $I->seeResponseMatchesJsonType([ 'user_id' => 'integer|string', // multiple types 'company' => ['name' => 'string'] ]); ?>
You can also apply filters to check values. Filter can be applied with a :
char after the type declaration, or after another filter if you need more than one.
Here is the list of possible filters:
integer:>{val}
- checks that integer is greater than {val} (works with float and string types too).integer:<{val}
- checks that integer is lower than {val} (works with float and string types too).string:url
- checks that value is valid url.string:date
- checks that value is date in JavaScript format: https://weblog.west-wind.com/posts/2014/Jan/06/JavaScript-JSON-Date-Parsing-and-real-Datesstring:email
- checks that value is a valid email according to http://emailregex.com/string:regex({val})
- checks that string matches a regex provided with {val}This is how filters can be used:
<?php // {'user_id': 1, 'email' => '[email protected]'} $I->seeResponseMatchesJsonType([ 'user_id' => 'string:>0:<1000', // multiple filters can be used 'email' => 'string:regex(~\@~)' // we just check that @ char is included ]); // {'user_id': '1'} $I->seeResponseMatchesJsonType([ 'user_id' => 'string:>0', // works with strings as well ]); ?>
You can also add custom filters by using {@link JsonType::addCustomFilter()}
. See JsonType reference.
[Part]
jsonparam array
$jsonTypeparam string
$jsonPath @see JsonTypeAvailable since
2.1.3Checks XML response equals provided XML. Comparison is done by canonicalizing both xml`s.
Parameters can be passed either as DOMDocument, DOMNode, XML string, or array (if no attributes).
param
$xml[Part]
xmlChecks XML response includes provided XML. Comparison is done by canonicalizing both xml`s. Parameter can be passed either as XmlBuilder, DOMDocument, DOMNode, XML string, or array (if no attributes).
Example:
<?php $I->seeXmlResponseIncludes("<result>1</result>"); ?>
param
$xml[Part]
xmlChecks whether XML response matches XPath
<?php $I->seeXmlResponseMatchesXpath('//root/user[@id=1]');
[Part]
xmlparam
$xpathSends DELETE request to given uri.
param
$urlparam array
$paramsparam array
$files[Part]
json[Part]
xmlSends a GET request to given uri.
param
$urlparam array
$params[Part]
json[Part]
xmlSends a HEAD request to given uri.
param
$urlparam array
$params[Part]
json[Part]
xmlSends LINK request to given uri.
param
$urlparam array
$linkEntries (entry is array with keys “uri” and “link-param”)@link http://tools.ietf.org/html/rfc2068#section-19.6.2.4
@author [email protected]
[Part]
json[Part]
xmlSends an OPTIONS request to given uri.
param
$urlparam array
$params[Part]
json[Part]
xmlSends PATCH request to given uri.
param
$urlparam array
$paramsparam array
$files[Part]
json[Part]
xmlSends a POST request to given uri. Parameters and files can be provided separately.
Example:
<?php //simple POST call $I->sendPost('/message', ['subject' => 'Read this!', 'to' => '[email protected]']); //simple upload method $I->sendPost('/message/24', ['inline' => 0], ['attachmentFile' => codecept_data_dir('sample_file.pdf')]); //uploading a file with a custom name and mime-type. This is also useful to simulate upload errors. $I->sendPost('/message/24', ['inline' => 0], [ 'attachmentFile' => [ 'name' => 'document.pdf', 'type' => 'application/pdf', 'error' => UPLOAD_ERR_OK, 'size' => filesize(codecept_data_dir('sample_file.pdf')), 'tmp_name' => codecept_data_dir('sample_file.pdf') ] ]); // If your field names contain square brackets (e.g. `<input type="text" name="form[task]">`), // PHP parses them into an array. In this case you need to pass the fields like this: $I->sendPost('/add-task', ['form' => [ 'task' => 'lorem ipsum', 'category' => 'miscellaneous', ]]);
param
$urlparam array|\JsonSerializable
$paramsparam array
$files A list of filenames or “mocks” of $_FILES (each entry being an array with the following keys: name, type, error, size, tmp_name (pointing to the real file path). Each key works as the “name” attribute of a file input field.@see http://php.net/manual/en/features.file-upload.post-method.php @see codecept_data_dir()
[Part]
json[Part]
xmlSends PUT request to given uri.
param
$urlparam array
$paramsparam array
$files[Part]
json[Part]
xmlSends UNLINK request to given uri.
param
$urlparam array
$linkEntries (entry is array with keys “uri” and “link-param”) @link http://tools.ietf.org/html/rfc2068#section-19.6.2.4 @author [email protected][Part]
json[Part]
xmlSets SERVER parameters valid for all next requests. this will remove old ones.
$I->setServerParameters([]);
Enables automatic redirects to be followed by the client
<?php $I->startFollowingRedirects();
[Part]
xml[Part]
jsonPrevents automatic redirects to be followed by the client
<?php $I->stopFollowingRedirects();
[Part]
xml[Part]
json
© 2011 Michael Bodnarchuk and contributors
Licensed under the MIT License.
https://codeception.com/docs/modules/REST