2016-07-12 00:33:55 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/*
|
2016-12-29 12:09:26 +01:00
|
|
|
* This file is part of the NelmioApiDocBundle package.
|
2016-07-12 00:33:55 +02:00
|
|
|
*
|
2016-12-29 12:09:26 +01:00
|
|
|
* (c) Nelmio
|
2016-07-12 00:33:55 +02:00
|
|
|
*
|
|
|
|
* For the full copyright and license information, please view the LICENSE
|
|
|
|
* file that was distributed with this source code.
|
|
|
|
*/
|
|
|
|
|
2017-06-14 13:47:53 +02:00
|
|
|
namespace Nelmio\ApiDocBundle\Tests\Functional;
|
|
|
|
|
2016-07-29 10:22:40 +02:00
|
|
|
use ApiPlatform\Core\Bridge\Symfony\Bundle\ApiPlatformBundle;
|
2018-05-05 14:49:17 +02:00
|
|
|
use Bazinga\Bundle\HateoasBundle\BazingaHateoasBundle;
|
2017-06-20 20:49:50 +02:00
|
|
|
use FOS\RestBundle\FOSRestBundle;
|
2019-05-02 10:02:16 +02:00
|
|
|
use Hateoas\Configuration\Embedded;
|
2017-06-25 15:40:07 +02:00
|
|
|
use JMS\SerializerBundle\JMSSerializerBundle;
|
2016-12-29 12:09:26 +01:00
|
|
|
use Nelmio\ApiDocBundle\NelmioApiDocBundle;
|
2019-05-02 10:02:16 +02:00
|
|
|
use Nelmio\ApiDocBundle\Tests\Functional\Entity\BazingaUser;
|
2019-03-11 12:53:35 +01:00
|
|
|
use Nelmio\ApiDocBundle\Tests\Functional\Entity\NestedGroup\JMSPicture;
|
2020-12-16 23:44:26 +01:00
|
|
|
use Nelmio\ApiDocBundle\Tests\Functional\Entity\PrivateProtectedExposure;
|
2019-04-16 12:13:33 +02:00
|
|
|
use Nelmio\ApiDocBundle\Tests\Functional\ModelDescriber\VirtualTypeClassDoesNotExistsHandlerDefinedDescriber;
|
2016-07-12 00:33:55 +02:00
|
|
|
use Sensio\Bundle\FrameworkExtraBundle\SensioFrameworkExtraBundle;
|
|
|
|
use Symfony\Bundle\FrameworkBundle\FrameworkBundle;
|
|
|
|
use Symfony\Bundle\FrameworkBundle\Kernel\MicroKernelTrait;
|
2016-11-18 22:16:53 +01:00
|
|
|
use Symfony\Bundle\TwigBundle\TwigBundle;
|
2016-07-12 00:33:55 +02:00
|
|
|
use Symfony\Component\Config\Loader\LoaderInterface;
|
|
|
|
use Symfony\Component\DependencyInjection\ContainerBuilder;
|
2019-04-16 12:13:33 +02:00
|
|
|
use Symfony\Component\DependencyInjection\Definition;
|
2016-07-12 00:33:55 +02:00
|
|
|
use Symfony\Component\HttpKernel\Kernel;
|
|
|
|
use Symfony\Component\Routing\RouteCollectionBuilder;
|
2020-05-30 18:08:25 +02:00
|
|
|
use Symfony\Component\Serializer\Annotation\SerializedName;
|
2016-07-12 00:33:55 +02:00
|
|
|
|
|
|
|
class TestKernel extends Kernel
|
|
|
|
{
|
2020-11-20 17:06:56 +01:00
|
|
|
const USE_JMS = 1;
|
|
|
|
const USE_BAZINGA = 2;
|
|
|
|
const ERROR_ARRAY_ITEMS = 4;
|
|
|
|
|
2016-07-12 00:33:55 +02:00
|
|
|
use MicroKernelTrait;
|
|
|
|
|
2020-11-20 17:06:56 +01:00
|
|
|
private $flags;
|
2017-06-25 15:40:07 +02:00
|
|
|
|
2020-11-20 17:06:56 +01:00
|
|
|
public function __construct(int $flags = 0)
|
2017-06-25 15:40:07 +02:00
|
|
|
{
|
2020-11-20 17:06:56 +01:00
|
|
|
parent::__construct('test'.$flags, true);
|
2017-06-25 15:40:07 +02:00
|
|
|
|
2020-11-20 17:06:56 +01:00
|
|
|
$this->flags = $flags;
|
2017-06-25 15:40:07 +02:00
|
|
|
}
|
|
|
|
|
2016-07-12 00:33:55 +02:00
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function registerBundles()
|
|
|
|
{
|
2017-06-25 15:40:07 +02:00
|
|
|
$bundles = [
|
2016-07-12 00:33:55 +02:00
|
|
|
new FrameworkBundle(),
|
2016-11-18 22:16:53 +01:00
|
|
|
new TwigBundle(),
|
2016-07-12 00:33:55 +02:00
|
|
|
new SensioFrameworkExtraBundle(),
|
2016-07-29 10:22:40 +02:00
|
|
|
new ApiPlatformBundle(),
|
2016-12-29 12:09:26 +01:00
|
|
|
new NelmioApiDocBundle(),
|
2016-07-29 10:22:40 +02:00
|
|
|
new TestBundle(),
|
2020-05-31 17:47:18 +02:00
|
|
|
new FOSRestBundle(),
|
2016-07-12 00:33:55 +02:00
|
|
|
];
|
2017-06-25 15:40:07 +02:00
|
|
|
|
2020-11-20 17:06:56 +01:00
|
|
|
if ($this->flags & self::USE_JMS) {
|
2017-06-25 15:40:07 +02:00
|
|
|
$bundles[] = new JMSSerializerBundle();
|
2018-05-05 14:49:17 +02:00
|
|
|
|
2020-11-20 17:10:21 +01:00
|
|
|
if ($this->flags & self::USE_BAZINGA) {
|
2018-05-05 14:49:17 +02:00
|
|
|
$bundles[] = new BazingaHateoasBundle();
|
|
|
|
}
|
2017-06-25 15:40:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $bundles;
|
2016-07-12 00:33:55 +02:00
|
|
|
}
|
2016-07-15 00:04:07 +02:00
|
|
|
|
2016-07-12 00:33:55 +02:00
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
protected function configureRoutes(RouteCollectionBuilder $routes)
|
|
|
|
{
|
2018-01-05 13:08:02 +01:00
|
|
|
$routes->import(__DIR__.'/Controller/TestController.php', '/', 'annotation');
|
2017-06-25 15:40:07 +02:00
|
|
|
$routes->import(__DIR__.'/Controller/ApiController.php', '/', 'annotation');
|
2018-04-16 13:43:42 +02:00
|
|
|
$routes->import(__DIR__.'/Controller/ClassApiController.php', '/', 'annotation');
|
2017-06-25 15:40:07 +02:00
|
|
|
$routes->import(__DIR__.'/Controller/UndocumentedController.php', '/', 'annotation');
|
2020-07-11 17:53:09 +02:00
|
|
|
$routes->import(__DIR__.'/Controller/InvokableController.php', '/', 'annotation');
|
2016-07-29 10:22:40 +02:00
|
|
|
$routes->import('', '/api', 'api_platform');
|
2018-01-05 13:08:02 +01:00
|
|
|
$routes->add('/docs/{area}', 'nelmio_api_doc.controller.swagger_ui')->setDefault('area', 'default');
|
2021-02-01 23:29:53 +01:00
|
|
|
$routes->add('/docs.json', 'nelmio_api_doc.controller.swagger_json');
|
|
|
|
$routes->add('/docs.yaml', 'nelmio_api_doc.controller.swagger_yaml');
|
2020-05-31 17:47:18 +02:00
|
|
|
$routes->import(__DIR__.'/Controller/FOSRestController.php', '/', 'annotation');
|
2017-06-25 15:40:07 +02:00
|
|
|
|
2020-05-30 18:08:25 +02:00
|
|
|
if (class_exists(SerializedName::class)) {
|
|
|
|
$routes->import(__DIR__.'/Controller/SerializedNameController.php', '/', 'annotation');
|
|
|
|
}
|
|
|
|
|
2020-11-20 17:06:56 +01:00
|
|
|
if ($this->flags & self::USE_JMS) {
|
2017-06-25 15:40:07 +02:00
|
|
|
$routes->import(__DIR__.'/Controller/JMSController.php', '/', 'annotation');
|
|
|
|
}
|
2018-05-05 14:49:17 +02:00
|
|
|
|
2020-11-20 17:06:56 +01:00
|
|
|
if ($this->flags & self::USE_BAZINGA) {
|
2018-05-05 14:49:17 +02:00
|
|
|
$routes->import(__DIR__.'/Controller/BazingaController.php', '/', 'annotation');
|
2019-05-02 10:02:16 +02:00
|
|
|
|
|
|
|
try {
|
|
|
|
new \ReflectionMethod(Embedded::class, 'getType');
|
|
|
|
$routes->import(__DIR__.'/Controller/BazingaTypedController.php', '/', 'annotation');
|
|
|
|
} catch (\ReflectionException $e) {
|
|
|
|
}
|
2018-05-05 14:49:17 +02:00
|
|
|
}
|
2020-11-20 17:06:56 +01:00
|
|
|
|
|
|
|
if ($this->flags & self::ERROR_ARRAY_ITEMS) {
|
|
|
|
$routes->import(__DIR__.'/Controller/ArrayItemsErrorController.php', '/', 'annotation');
|
|
|
|
}
|
2016-07-12 00:33:55 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
protected function configureContainer(ContainerBuilder $c, LoaderInterface $loader)
|
|
|
|
{
|
2019-11-19 18:24:58 +01:00
|
|
|
$framework = [
|
2019-11-22 14:07:00 +01:00
|
|
|
'assets' => true,
|
2016-07-12 00:33:55 +02:00
|
|
|
'secret' => 'MySecretKey',
|
2016-07-29 10:22:40 +02:00
|
|
|
'test' => null,
|
|
|
|
'validation' => null,
|
2017-06-24 17:49:00 +02:00
|
|
|
'form' => null,
|
2017-06-14 13:47:53 +02:00
|
|
|
'serializer' => ['enable_annotations' => true],
|
2021-06-07 19:04:16 +02:00
|
|
|
'property_access' => true,
|
2019-11-19 18:24:58 +01:00
|
|
|
];
|
|
|
|
|
|
|
|
$c->loadFromExtension('framework', $framework);
|
2016-11-30 14:08:10 +01:00
|
|
|
|
2018-11-04 12:24:45 +01:00
|
|
|
$c->loadFromExtension('twig', [
|
|
|
|
'strict_variables' => '%kernel.debug%',
|
2020-05-31 17:47:18 +02:00
|
|
|
'exception_controller' => null,
|
2018-11-04 12:24:45 +01:00
|
|
|
]);
|
|
|
|
|
2019-11-19 18:24:58 +01:00
|
|
|
$c->loadFromExtension('sensio_framework_extra', [
|
|
|
|
'router' => [
|
|
|
|
'annotations' => false,
|
|
|
|
],
|
|
|
|
]);
|
|
|
|
|
2019-04-10 21:07:34 +02:00
|
|
|
$c->loadFromExtension('api_platform', [
|
|
|
|
'mapping' => ['paths' => ['%kernel.project_dir%/Tests/Functional/Entity']],
|
|
|
|
]);
|
|
|
|
|
2020-05-31 17:47:18 +02:00
|
|
|
$c->loadFromExtension('fos_rest', [
|
|
|
|
'format_listener' => [
|
|
|
|
'rules' => [
|
|
|
|
[
|
|
|
|
'path' => '^/',
|
|
|
|
'fallback_format' => 'json',
|
2017-06-26 10:34:42 +02:00
|
|
|
],
|
2017-06-20 20:49:50 +02:00
|
|
|
],
|
2020-05-31 17:47:18 +02:00
|
|
|
],
|
|
|
|
]);
|
|
|
|
|
|
|
|
// If FOSRestBundle 2.8
|
|
|
|
if (class_exists(\FOS\RestBundle\EventListener\ResponseStatusCodeListener::class)) {
|
|
|
|
$c->loadFromExtension('fos_rest', [
|
|
|
|
'exception' => [
|
|
|
|
'enabled' => false,
|
|
|
|
'exception_listener' => false,
|
|
|
|
'serialize_exceptions' => false,
|
|
|
|
],
|
|
|
|
'body_listener' => false,
|
|
|
|
'routing_loader' => false,
|
2019-12-20 10:49:22 +01:00
|
|
|
]);
|
|
|
|
}
|
2017-06-20 20:49:50 +02:00
|
|
|
|
2016-11-30 14:08:10 +01:00
|
|
|
// Filter routes
|
2016-12-29 12:09:26 +01:00
|
|
|
$c->loadFromExtension('nelmio_api_doc', [
|
2017-01-25 18:53:19 +01:00
|
|
|
'documentation' => [
|
2020-08-11 16:44:05 +02:00
|
|
|
'servers' => [ // from https://github.com/nelmio/NelmioApiDocBundle/issues/1691
|
|
|
|
[
|
|
|
|
'url' => 'https://api.example.com/secured/{version}',
|
|
|
|
'variables' => ['version' => ['default' => 'v1']],
|
|
|
|
],
|
|
|
|
],
|
2017-01-25 18:53:19 +01:00
|
|
|
'info' => [
|
2018-10-06 14:42:47 +02:00
|
|
|
'title' => 'My Default App',
|
2017-01-25 18:53:19 +01:00
|
|
|
],
|
2020-05-28 13:19:11 +02:00
|
|
|
'components' => [
|
|
|
|
'schemas' => [
|
|
|
|
'Test' => [
|
|
|
|
'type' => 'string',
|
|
|
|
],
|
2020-06-17 14:12:44 +02:00
|
|
|
|
|
|
|
// Ensures https://github.com/nelmio/NelmioApiDocBundle/issues/1650 is working
|
|
|
|
'Pet' => [
|
|
|
|
'type' => 'object',
|
|
|
|
],
|
|
|
|
'Cat' => [
|
|
|
|
'allOf' => [
|
|
|
|
['$ref' => '#/components/schemas/Pet'],
|
|
|
|
['type' => 'object'],
|
|
|
|
],
|
|
|
|
],
|
2021-06-07 18:20:25 +02:00
|
|
|
'AddProp' => [
|
|
|
|
'type' => 'object',
|
|
|
|
'additionalProperties' => false,
|
|
|
|
],
|
2018-02-19 10:49:52 +01:00
|
|
|
],
|
2020-05-28 13:19:11 +02:00
|
|
|
'parameters' => [
|
|
|
|
'test' => [
|
|
|
|
'name' => 'id',
|
|
|
|
'in' => 'path',
|
|
|
|
'required' => true,
|
|
|
|
],
|
2018-05-10 18:46:48 +02:00
|
|
|
],
|
2020-05-28 13:19:11 +02:00
|
|
|
'responses' => [
|
|
|
|
'201' => [
|
|
|
|
'description' => 'Awesome description',
|
|
|
|
],
|
2018-10-02 16:06:18 +07:00
|
|
|
],
|
|
|
|
],
|
2017-01-25 18:53:19 +01:00
|
|
|
],
|
2018-01-05 13:08:02 +01:00
|
|
|
'areas' => [
|
2018-07-27 09:59:45 +05:00
|
|
|
'default' => [
|
|
|
|
'path_patterns' => ['^/api(?!/admin)'],
|
|
|
|
'host_patterns' => ['^api\.'],
|
|
|
|
],
|
|
|
|
'test' => [
|
|
|
|
'path_patterns' => ['^/test'],
|
|
|
|
'host_patterns' => ['^api-test\.'],
|
|
|
|
'documentation' => [
|
|
|
|
'info' => [
|
|
|
|
'title' => 'My Test App',
|
|
|
|
],
|
2018-07-27 09:44:19 +05:00
|
|
|
],
|
2018-07-27 09:59:45 +05:00
|
|
|
],
|
2016-11-30 14:08:10 +01:00
|
|
|
],
|
2019-03-11 12:53:35 +01:00
|
|
|
'models' => [
|
|
|
|
'names' => [
|
2020-12-16 23:44:26 +01:00
|
|
|
[
|
|
|
|
'alias' => 'PrivateProtectedExposure',
|
|
|
|
'type' => PrivateProtectedExposure::class,
|
|
|
|
],
|
2019-03-11 12:53:35 +01:00
|
|
|
[
|
|
|
|
'alias' => 'JMSPicture_mini',
|
|
|
|
'type' => JMSPicture::class,
|
|
|
|
'groups' => ['mini'],
|
|
|
|
],
|
2019-05-02 10:02:16 +02:00
|
|
|
[
|
|
|
|
'alias' => 'BazingaUser_grouped',
|
|
|
|
'type' => BazingaUser::class,
|
|
|
|
'groups' => ['foo'],
|
|
|
|
],
|
2019-03-11 12:53:35 +01:00
|
|
|
],
|
|
|
|
],
|
2016-11-30 14:08:10 +01:00
|
|
|
]);
|
2019-04-16 12:13:33 +02:00
|
|
|
|
|
|
|
$def = new Definition(VirtualTypeClassDoesNotExistsHandlerDefinedDescriber::class);
|
|
|
|
$def->addTag('nelmio_api_doc.model_describer');
|
|
|
|
$c->setDefinition('nelmio.test.jms.virtual_type.describer', $def);
|
2016-07-12 00:33:55 +02:00
|
|
|
}
|
2017-06-25 15:40:07 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function getCacheDir()
|
|
|
|
{
|
2020-11-20 17:06:56 +01:00
|
|
|
return parent::getCacheDir().'/'.$this->flags;
|
2017-06-25 15:40:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function getLogDir()
|
|
|
|
{
|
2020-11-20 17:06:56 +01:00
|
|
|
return parent::getLogDir().'/'.$this->flags;
|
2017-06-25 15:40:07 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function serialize()
|
|
|
|
{
|
|
|
|
return serialize($this->useJMS);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function unserialize($str)
|
|
|
|
{
|
|
|
|
$this->__construct(unserialize($str));
|
|
|
|
}
|
2016-07-12 00:33:55 +02:00
|
|
|
}
|