NelmioApiDocBundle/Tests/Functional/SwaggerUiTest.php

92 lines
3.2 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;
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()
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('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';
$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'));
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';
$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']],
]],
'/test/test/{id}' => ['get' => [
'responses' => ['200' => ['description' => 'Test Ref']],
'parameters' => [['$ref' => '#/parameters/test']],
]],
];
2019-03-11 12:53:35 +01:00
$expected['definitions'] = [
'Dummy' => $expected['definitions']['Dummy'],
'Test' => ['type' => 'string'],
'JMSPicture_mini' => ['type' => 'object'],
'BazingaUser_grouped' => ['type' => 'object'],
2019-03-11 12:53:35 +01:00
];
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'));
2017-07-05 15:41:53 +02:00
$expected = $this->getSwaggerDefinition()->toArray();
$expected['basePath'] = '/app_dev.php';
$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
}
}