NelmioApiDocBundle/Tests/Functional/SwaggerUiTest.php

92 lines
3.1 KiB
PHP
Raw Normal View History

2017-01-18 18:02:00 +01:00
<?php
/*
* This file is part of the NelmioApiDocBundle package.
*
* (c) Nelmio
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Nelmio\ApiDocBundle\Tests\Functional;
2021-02-01 23:29:53 +01:00
use OpenApi\Annotations\Server;
2019-12-19 15:41:14 +01:00
use Symfony\Bundle\FrameworkBundle\KernelBrowser;
2017-01-18 18:02:00 +01:00
class SwaggerUiTest extends WebTestCase
{
2019-12-19 15:41:14 +01:00
/**
* @var KernelBrowser
*/
private $client;
protected function setUp(): void
2017-07-05 15:41:53 +02:00
{
2019-12-19 15:41:14 +01:00
parent::setUp();
$this->client = static::createClient([], ['HTTP_HOST' => 'api.example.com', 'PHP_SELF' => '/app_dev.php/docs', 'SCRIPT_FILENAME' => '/var/www/app/web/app_dev.php']);
2017-07-05 15:41:53 +02:00
}
2019-12-19 15:41:14 +01:00
public function testSwaggerUi()
2017-01-18 18:02:00 +01:00
{
2019-12-19 15:41:14 +01:00
$crawler = $this->client->request('GET', '/app_dev.php/docs');
2017-01-18 18:02:00 +01:00
2019-12-19 15:41:14 +01:00
$response = $this->client->getResponse();
2017-01-18 18:02:00 +01:00
$this->assertEquals(200, $response->getStatusCode());
$this->assertEquals('UTF-8', $response->getCharset());
$this->assertEquals('text/html; charset=UTF-8', $response->headers->get('Content-Type'));
2017-01-18 18:02:00 +01:00
$expected = json_decode($this->getOpenApiDefinition()->toJson(), true);
2019-12-19 15:41:14 +01:00
$this->assertEquals($expected, json_decode($crawler->filterXPath('//script[@id="swagger-data"]')->text(), true)['spec']);
}
2019-12-19 15:41:14 +01:00
public function testApiPlatformSwaggerUi()
{
2019-12-19 15:41:14 +01:00
$crawler = $this->client->request('GET', '/app_dev.php/docs/test');
2017-07-05 15:41:53 +02:00
2019-12-19 15:41:14 +01:00
$response = $this->client->getResponse();
$this->assertEquals(200, $response->getStatusCode());
$this->assertEquals('text/html; charset=UTF-8', $response->headers->get('Content-Type'));
$expected = json_decode($this->getOpenApiDefinition('test')->toJson(), true);
$expected['servers'] = [
['url' => 'http://api.example.com/app_dev.php'],
];
2019-12-19 15:41:14 +01:00
$this->assertEquals($expected, json_decode($crawler->filterXPath('//script[@id="swagger-data"]')->text(), true)['spec']);
}
public function testJsonDocs()
{
2019-12-19 15:41:14 +01:00
$this->client->request('GET', '/app_dev.php/docs.json');
2019-12-19 15:41:14 +01:00
$response = $this->client->getResponse();
$this->assertEquals(200, $response->getStatusCode());
$this->assertEquals('application/json', $response->headers->get('Content-Type'));
$expected = json_decode($this->getOpenApiDefinition()->toJson(), true);
$expected['servers'] = [
['url' => 'http://api.example.com/app_dev.php'],
];
2017-07-05 15:41:53 +02:00
$this->assertEquals($expected, json_decode($response->getContent(), true));
2017-01-18 18:02:00 +01:00
}
2021-02-01 23:29:53 +01:00
public function testYamlDocs()
{
$this->client->request('GET', '/app_dev.php/docs.yaml');
$response = $this->client->getResponse();
$this->assertEquals(200, $response->getStatusCode());
$this->assertEquals('text/x-yaml; charset=UTF-8', $response->headers->get('Content-Type'));
$spec = $this->getOpenApiDefinition();
$spec->servers = [new Server(['url' => 'http://api.example.com/app_dev.php'])];
$expected = $spec->toYaml();
$this->assertEquals($expected, $response->getContent());
}
2017-01-18 18:02:00 +01:00
}