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;
|
|
|
|
|
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;
|
|
|
|
|
2020-12-10 21:59:36 +01:00
|
|
|
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());
|
2020-10-02 13:52:30 -03:00
|
|
|
$this->assertEquals('UTF-8', $response->getCharset());
|
2017-06-20 20:49:50 +02:00
|
|
|
$this->assertEquals('text/html; charset=UTF-8', $response->headers->get('Content-Type'));
|
2017-01-18 18:02:00 +01:00
|
|
|
|
2019-12-19 15:41:14 +01:00
|
|
|
$expected = $this->getSwaggerDefinition()->toArray();
|
|
|
|
$expected['basePath'] = '/app_dev.php';
|
|
|
|
|
2018-01-05 13:08:02 +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()
|
2018-01-05 13:08:02 +01:00
|
|
|
{
|
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'));
|
2018-01-05 13:08:02 +01:00
|
|
|
|
2019-12-19 15:41:14 +01:00
|
|
|
$expected = $this->getSwaggerDefinition()->toArray();
|
|
|
|
$expected['basePath'] = '/app_dev.php';
|
2018-10-06 14:42:47 +02:00
|
|
|
$expected['info']['title'] = 'My Test App';
|
2018-01-05 13:08:02 +01:00
|
|
|
$expected['paths'] = [
|
|
|
|
'/api/dummies' => $expected['paths']['/api/dummies'],
|
|
|
|
'/api/foo' => $expected['paths']['/api/foo'],
|
|
|
|
'/api/dummies/{id}' => $expected['paths']['/api/dummies/{id}'],
|
|
|
|
'/test/test/' => ['get' => [
|
|
|
|
'responses' => ['200' => ['description' => 'Test']],
|
|
|
|
]],
|
2020-01-10 11:53:34 -05:00
|
|
|
'/test/test/{id}' => ['get' => [
|
|
|
|
'responses' => ['200' => ['description' => 'Test Ref']],
|
|
|
|
'parameters' => [['$ref' => '#/parameters/test']],
|
|
|
|
]],
|
2018-01-05 13:08:02 +01:00
|
|
|
];
|
2019-03-11 12:53:35 +01:00
|
|
|
$expected['definitions'] = [
|
|
|
|
'Dummy' => $expected['definitions']['Dummy'],
|
|
|
|
'Test' => ['type' => 'string'],
|
|
|
|
'JMSPicture_mini' => ['type' => 'object'],
|
2019-05-02 10:02:16 +02:00
|
|
|
'BazingaUser_grouped' => ['type' => 'object'],
|
2020-12-16 23:44:26 +01:00
|
|
|
'PrivateProtectedExposure' => $expected['definitions']['PrivateProtectedExposure'],
|
2019-03-11 12:53:35 +01:00
|
|
|
];
|
2018-01-05 13:08:02 +01:00
|
|
|
|
2019-12-19 15:41:14 +01:00
|
|
|
$this->assertEquals($expected, json_decode($crawler->filterXPath('//script[@id="swagger-data"]')->text(), true)['spec']);
|
2017-06-26 10:34:42 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testJsonDocs()
|
|
|
|
{
|
2019-12-19 15:41:14 +01:00
|
|
|
$this->client->request('GET', '/app_dev.php/docs.json');
|
2017-06-26 10:34:42 +02:00
|
|
|
|
2019-12-19 15:41:14 +01:00
|
|
|
$response = $this->client->getResponse();
|
2017-06-26 10:34:42 +02:00
|
|
|
$this->assertEquals(200, $response->getStatusCode());
|
|
|
|
$this->assertEquals('application/json', $response->headers->get('Content-Type'));
|
|
|
|
|
2017-07-05 15:41:53 +02:00
|
|
|
$expected = $this->getSwaggerDefinition()->toArray();
|
|
|
|
$expected['basePath'] = '/app_dev.php';
|
2019-04-10 20:55:04 +02:00
|
|
|
$expected['host'] = 'api.example.com';
|
2017-07-05 15:41:53 +02:00
|
|
|
|
|
|
|
$this->assertEquals($expected, json_decode($response->getContent(), true));
|
2017-01-18 18:02:00 +01:00
|
|
|
}
|
|
|
|
}
|