This small library will make it very easy for you to validate your request and response objects against a given Open API Schemas.
Under the hood league/openapi-psr7-validator
is used but abstracted in a way that it can be replaced with any other implementation.
- Your test case must use the OpenAPIValidatorTrait or extend App\Tests\ApiTestCase
- Your test case must instantiate and set the App\Tests\OpenAPISchemaValidator with the right schema. If you don't do this, the next steps will fail with an exception.
- Call
assertRequestMatchesOpenAPISchema($request)
to validate the request against the OpenAPI schema. - Call
assertResponseMatchesOpenAPISchema($response)
to validate the response against the OpenAPI schema.
use Phauthentic\PHPUnit\OpenAPIValidator\OpenAPIValidatorTrait;
class MyTestCase extends TestCase
{
use OpenAPIValidatorTrait;
public function setUp(): void
{
parent::setUp();
// Load your OpenAPI schema
self::setOpenAPISchemaValidator = new OpenAPISchemaValidator(
'path/to/openapi.yaml',
);
}
public function testSomeAPIIntegration(): void
{
// Create a client and make a request or whatever your framework
// provides you to make such calls.
$client = $this->createClient();
$client->request('POST', '/api/v1/products', [
'productName' => 'PHP',
]);
// Assert the request and response against the OpenAPI schema
self::assertRequestMatchesOpenAPISchema($client->getRequest());
self::assertResponseMatchesOpenAPISchema($client->getResponse());
path: '/api/v1/follows',
method: 'post'
);
}
}
Symfony does not support the PSR-7 interface for requests and responses. This means that you cannot use the OpenAPISchemaValidator directly in your Symfony tests. This package provides a workaround for this limitation by using the Symfony Bridge for PHPUnit. This bridge provides a way to use the PSR-7 interface in your Symfony tests.
You need to add those dependencies to your project via Composer:
- nyholm/psr7
- symfony/phpunit-bridge
Instead of using the OpenAPISchemaValidator use the OpenAPISymfonySchemaValidator in your test case.
self::setOpenAPISchemaValidator = new OpenAPISymfonySchemaValidator(
'path/to/openapi.yaml',
);
This bundle is under the MIT license.
Copyright Florian Krämer