https://github.com/bauhausphp/assert-psr-response
PHP package with class to assert PSR-7 responses
https://github.com/bauhausphp/assert-psr-response
assertion psr-7
Last synced: 8 months ago
JSON representation
PHP package with class to assert PSR-7 responses
- Host: GitHub
- URL: https://github.com/bauhausphp/assert-psr-response
- Owner: bauhausphp
- License: mit
- Created: 2018-01-06T20:36:37.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-03-09T06:56:48.000Z (over 3 years ago)
- Last Synced: 2024-12-26T20:28:02.932Z (over 1 year ago)
- Topics: assertion, psr-7
- Language: PHP
- Homepage:
- Size: 94.7 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
[](https://github.com/bauhausphp/assert-psr-response/actions?query=workflow%3ABuild)
[](https://codecov.io/gh/bauhausphp/assert-psr-response)
[](https://packagist.org/packages/bauhaus/assert-psr-response)
[](https://packagist.org/packages/bauhaus/assert-psr-response)
[](composer.json)
[](LICENSE)
# Assert PSR Response
This composer package aims to provide an easy way to assert
[PSR-7](http://www.php-fig.org/psr/psr-7/) responses.
## Motivation
I created this package because my constant need of asserting only certain values
of PSR responses during acceptance tests.
## Installation
Install it using [Composer](https://getcomposer.org/):
```shell
$ composer require bauhaus/assert-psr-response
```
## Usage
```php
withStatus(404)
->withHeader('Content-Type', 'text/html');
$assertion->assert($psrResponse);
// throw PsrResponseAssertionException with message:
// Actual response status code '404' is not equal to the expected '200'
// Actual response header line 'Content-Type' 'text/html' is not equal to the expected 'application/json'
```
## Available Matchers
- `StatusCode::equalTo(200)`
- `HeaderLine::equalTo('Header-Name', 'Header-Value')`
- `JsonBody::equalTo('{"field":"value"}')`
## Contribution
There is two ways to contribute with this project. The first one is by opening
an issue [here](https://github.com/bauhausphp/assert-psr-response/issues). The second
one is by coding:
1. Fork this project and clone it on your local dev environment
2. Install dependencies throught the command: `composer install`
3. Run the locally tests before ubmiting a pull request:
* To test code standards: `composer run test:cs`
* To run unit tests: `composer run test:unit`
* To run all tests in a roll: `composer run tests`