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();
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |