70 lines
2.9 KiB
PHP
70 lines
2.9 KiB
PHP
<?php declare(strict_types=1);
|
|
|
|
/**
|
|
* @license Apache 2.0
|
|
*/
|
|
|
|
namespace OpenApi\Tests\Processors;
|
|
|
|
use OpenApi\Analysis;
|
|
use OpenApi\Annotations\Contact;
|
|
use OpenApi\Annotations\License;
|
|
use OpenApi\Context;
|
|
use OpenApi\Processors\CleanUnmerged;
|
|
use OpenApi\Processors\MergeIntoOpenApi;
|
|
use OpenApi\Tests\OpenApiTestCase;
|
|
|
|
class CleanUnmergedTest extends OpenApiTestCase
|
|
{
|
|
public function testCleanUnmergedProcessor()
|
|
{
|
|
$comment = <<<END
|
|
@OA\Info(
|
|
title="Info only has one contact field.",
|
|
version="test",
|
|
)
|
|
@OA\PathItem(path="/test"),
|
|
@OA\License(
|
|
name="MIT",
|
|
@OA\Contact(
|
|
name="Batman"
|
|
)
|
|
)
|
|
|
|
END;
|
|
$analysis = new Analysis($this->parseComment($comment), new Context());
|
|
$this->assertCount(4, $analysis->annotations);
|
|
$analysis->process(new MergeIntoOpenApi());
|
|
$this->assertCount(5, $analysis->annotations);
|
|
$before = $analysis->split();
|
|
$this->assertCount(3, $before->merged->annotations, 'Generated @OA\OpenApi, @OA\PathItem and @OA\Info');
|
|
$this->assertCount(2, $before->unmerged->annotations, '@OA\License + @OA\Contact');
|
|
$this->assertCount(0, $analysis->openapi->_unmerged);
|
|
$analysis->validate(); // Validation fails to detect the unmerged annotations.
|
|
|
|
// CleanUnmerged should place the unmerged annotions into the swagger->_unmerged array.
|
|
$analysis->process(new CleanUnmerged());
|
|
$between = $analysis->split();
|
|
$this->assertCount(3, $between->merged->annotations, 'Generated @OA\OpenApi, @OA\PathItem and @OA\Info');
|
|
$this->assertCount(2, $between->unmerged->annotations, '@OA\License + @OA\Contact');
|
|
$this->assertCount(2, $analysis->openapi->_unmerged); // 1 would also be oke, Could a'Only the @OA\License'
|
|
$this->assertOpenApiLogEntryContains('Unexpected @OA\License(), expected to be inside @OA\Info in ');
|
|
$this->assertOpenApiLogEntryContains('Unexpected @OA\Contact(), expected to be inside @OA\Info in ');
|
|
$analysis->validate();
|
|
|
|
// When a processor places a previously unmerged annotation into the swagger obect.
|
|
$license = $analysis->getAnnotationsOfType(License::class)[0];
|
|
$contact = $analysis->getAnnotationsOfType(Contact::class)[0];
|
|
$analysis->openapi->info->contact = $contact;
|
|
$this->assertCount(1, $license->_unmerged);
|
|
$analysis->process(new CleanUnmerged());
|
|
$this->assertCount(0, $license->_unmerged);
|
|
$after = $analysis->split();
|
|
$this->assertCount(4, $after->merged->annotations, 'Generated @OA\OpenApi, @OA\PathItem, @OA\Info and @OA\Contact');
|
|
$this->assertCount(1, $after->unmerged->annotations, '@OA\License');
|
|
$this->assertCount(1, $analysis->openapi->_unmerged);
|
|
$this->assertOpenApiLogEntryContains('Unexpected @OA\License(), expected to be inside @OA\Info in ');
|
|
$analysis->validate();
|
|
}
|
|
}
|