helmich / phpunit-psr7-assert
PHPUnit assertions for testing PSR7-compliant applications
Fund package maintenance!
martin-helmich
donate.helmich.me
Installs: 498 929
Dependents: 9
Suggesters: 0
Security: 0
Stars: 25
Watchers: 3
Forks: 4
Open Issues: 2
Requires
- php: ^8.0
- helmich/phpunit-json-assert: ^3.4
- psr/http-message: ^1.1 || ^2.0
Requires (Dev)
- guzzlehttp/psr7: ^2.4
- mockery/mockery: ^1.4.1
- phpunit/phpunit: ^8.0 || ^9.0 || ^10.0
Conflicts
- phpunit/phpunit: <8.0 || >= 11.0
README
This library adds several new assertions to PHPUnit that allow you to easily and concisely test HTTP request and response messages that implement the PSR-7 interfaces.
Author and copyright
Martin Helmich kontakt@martin-helmich.de This library is MIT-licensed.
Installation
$ composer require helmich/phpunit-psr7-assert
Compatibility
There are several release branches of this library, each of these being compatible with different releases of PHPUnit and PHP. The following table should give an easy overview:
When you are using composer require
and have already declared a dependency to
phpunit/phpunit
in your composer.json
file, Composer should pick latest
compatible version automatically.
Usage
Using the Psr7Assertions
trait
Simply use the trait Helmich\Psr7Assert\Psr7Assertions
in any of your test
cases. This trait offers a set of new assert*
functions that you can use in
your test cases:
<?php use Helmich\Psr7Assert\Psr7Assertions; use PHPUnit\Framework\Testcase; class MyTestCase extends Testcase { use Psr7Assertions; public function testRequestMatchesExpectations() { $request = /* build some instance of Psr\Http\Message\MessageInterface */; $this->assertRequestHasUri($request, '/foo'); $this->assertRequestIsPost($request); $this->assertMessageHasHeaders($request, [ 'content-type' => 'application/json', 'expect' => '202-accepted' ]); $this->assertMessageBodyMatchesJson($request, [ '$.username' => 'mhelmich' ]); } }
Most assertions take a $message
argument which is expected to be an instance
of the Psr\Http\Message\MessageInterface
class -- this means that many
assertions work both with request and response messages. These interfaces are
defined by the psr/http-message package.
Using the functional interface
This package also offers a functional interface that can be used in a more
fluent way than the assertions offered by the Psr7Assertions
trait. Simply
include the file src/Functions.php
for your test cases (preferably, using
Composer's autoload-dev
setting):
public function testRequestMatchesExpectations() { $request = /* build some instance of Psr\Http\Message\MessageInterface */; assertThat($request, logicalAnd( hasUri('/foo'), isPost(), hasHeaders([ 'content-type' => 'application/json', 'expect' => '202-accepted' ]), bodyMatchesJson(['$.username' => 'mhelmich']) )); }
Assertion reference
assertRequestHasUri($request, $uri)
/ hasUri($uri)
Asserts that the request URI of request $request
is equal to $uri
$this->assertRequestHasUri($request, '/foo')); assertThat($request, hasUri('/foo'));
assertMessageHasHeader($message, $header[, $constraint])
/ hasHeader($name[, $constraint])
Asserts that the header named $header
is present in the HTTP message. The exact behaviour of this assertion is dependent on the $constraint
parameter:
-
If no constraint is given, the assertion will match when the header is present and not empty.
-
If a primitive value is given as
$constraint
, the assertion will match when the header is present and is equal to the specified value -
If
$constraint
is an instance of thePHPUnit\Framework\Constraint\Constraint
class, the assertion will match when the constraint evaluates toTRUE
.Example:
assertThat($request, hasHeader('content-length', greaterThan(1000)));
assertMessageHasHeaders($message, $constraints)
/ hasHeaders($constraints)
Same as assertMessageHasHeader
, just with multiple headers. $constraints
is
a key-value array using header names as keys and constraints (see above) as values.
Example:
assertThat($request, hasHeaders([ 'content-type' => 'application/json', 'content-length' => greaterThan(1000) ]));
assertMessageBodyMatches($message, $constraint)
/ bodyMatches($constraint)
Asserts that the message body matches the constraint $constraint
. If
$constraint
is a primitive value, the assertion will pass when the message
body is equal to the constraint. If $constraint
is an instance of the
PHPUnit\Framework\Constraint\Constraint
class, the constraint will be evaluated
as-is.
assertMessageBodyMatchesJson($message, $jsonConstraints)
/ bodyMatchesJson($jsonConstraints)
This actually asserts several facts:
- The message must have a
content-type
header that is equal toapplication/json
- The message body must be a valid JSON string (that means decodeable by
json_decode
) - The encoded JSON object must match all constraints specified in the
$jsonConstraints
array. For this, the helmich/phpunit-json-assert package will be used.
assertMessageBodyMatchesForm($message, $formConstraints)
/ bodyMatchesForm($formConstraints)
This asserts that the message body contains application/x-www-form-urlencoded
-encoded
content, with individual variables matching the $formConstraints
array.
assertRequestHasMethod($request, $method)
/ hasMethod($method)
Asserts that the request has the method $method
. For the most common request
method, shorthand assertions are available:
assertRequestIsGet($request)
/isGet()
assertRequestIsPost($request)
/isPost()
assertRequestIsPut($request)
/isPut()
assertRequestIsDelete($request)
/isDelete()
assertResponseHasStatus($response, $status)
/ hasStatus($status)
Asserts that the response status matches a given constraint. If $status
is a
scalar value, this assertion will check for equality.
assertThat($response, hasStatus(200)); assertThat($response, hasStatus(logicalAnd(greaterThanOrEqual(200), lessThan(400))));
For the most common checks, some shorthand assertions are available:
assertResponseIsSuccess($response)
/isSuccess()
-- Status codes 200 to 299assertResponseIsRedirect($response)
/isRedirect()
-- Status codes 300 to 399assertResponseIsClientError($response)
/isClientError()
-- Status codes 400 to 499assertResponseIsServerError($response)
/isServerError()
-- Status codes 500 to 599
assertStringIsAbsoluteUri($uri)
/ isAbsoluteUri()
Assert that the string $uri
contains a valid absolute URL (scheme and hostname are required).
assertHasQueryParameter($uriOrRequest, $name[, $value])
/ hasQueryParameter($name[, $value])
Asserts that an URI contains a query parameter matching the given constraints.
$name
and $value
may both be string values as well as instances of the
PHPUnit\Framework\Constraint\Constraint
interface.
The $uriOrRequest
value may be
- a string, which will be interpreted as URI
- an instance of the
Psr\Http\Message\UriInterface
interface - an instance of the
Psr\Http\Message\RequestInterface
interface