‪TYPO3CMS  ‪main
ConstructorArgumentMatcherTest.php
Go to the documentation of this file.
1 <?php
2 
3 declare(strict_types=1);
4 
5 /*
6  * This file is part of the TYPO3 CMS project.
7  *
8  * It is free software; you can redistribute it and/or modify it under
9  * the terms of the GNU General Public License, either version 2
10  * of the License, or any later version.
11  *
12  * For the full copyright and license information, please read the
13  * LICENSE.txt file that was distributed with this source code.
14  *
15  * The TYPO3 project - inspiring people to share!
16  */
17 
19 
20 use PhpParser\NodeTraverser;
21 use PhpParser\NodeVisitor\NameResolver;
22 use PhpParser\ParserFactory;
23 use PHPUnit\Framework\TestCase;
27 
28 final class ‪ConstructorArgumentMatcherTest extends TestCase
29 {
30  public static function ‪hitsFromFixtureAreFoundDataProvider(): array
31  {
32  $defaults = [
33  'restFiles' => [
34  'Breaking-87193-DeprecatedFunctionalityRemoved.rst',
35  ],
36  ];
37 
38  return [
39  'required' => [
40  [
41  'required' => array_merge($defaults, [
42  'numberOfMandatoryArguments' => 4,
43  ]),
44  ],
45  [34, 35, 36, 37, 44, 45],
46  ],
47  'dropped' => [
48  [
49  'dropped' => array_merge($defaults, [
50  'maximumNumberOfArguments' => 2,
51  ]),
52  ],
53  [34, 35, 36, 37, 44, 45],
54  ],
55  'called' => [
56  [
57  'called' => array_merge($defaults, [
58  'numberOfMandatoryArguments' => 1,
59  'maximumNumberOfArguments' => 3,
60  ]),
61  ],
62  [34, 35, 36, 37, 44, 45],
63  ],
64  'unused' => [
65  [
66  'unused' => array_merge($defaults, [
67  'unusedArgumentNumbers' => [2],
68  ]),
69  ],
70  [34, 35, 36, 37],
71  ],
72  ];
73  }
74 
79  public function ‪hitsFromFixtureAreFound(array $configuration, array $expectation): void
80  {
81  ‪$parser = (new ParserFactory())->create(ParserFactory::ONLY_PHP7);
82  $fixtureFile = __DIR__ . '/Fixtures/ConstructorArgumentMatcherFixture.php';
83  $statements = ‪$parser->parse(file_get_contents($fixtureFile));
84 
85  // first process completely to resolve fully qualified names of arguments
86  $traverser = new NodeTraverser();
87  $traverser->addVisitor(new NameResolver());
88  $statements = $traverser->traverse($statements);
89 
90  // second process to actually work on the pre-resolved statements
91  $traverser = new NodeTraverser();
92  $traverser->addVisitor(new ‪GeneratorClassesResolver());
93  $subject = new ‪ConstructorArgumentMatcher([
94  Subject::class => $configuration,
95  ]);
96  $traverser->addVisitor($subject);
97  $traverser->traverse($statements);
98 
99  $lineNumbers = array_column($subject->getMatches(), 'line');
100  self::assertEquals($expectation, $lineNumbers);
101  }
102 }
‪TYPO3\CMS\Install\Tests\Unit\ExtensionScanner\Php\Matcher\ConstructorArgumentMatcherTest
Definition: ConstructorArgumentMatcherTest.php:29
‪TYPO3\CMS\Install\ExtensionScanner\Php\GeneratorClassesResolver
Definition: GeneratorClassesResolver.php:42
‪TYPO3\CMS\Install\Tests\Unit\ExtensionScanner\Php\Matcher\ConstructorArgumentMatcherTest\hitsFromFixtureAreFoundDataProvider
‪static hitsFromFixtureAreFoundDataProvider()
Definition: ConstructorArgumentMatcherTest.php:30
‪$parser
‪$parser
Definition: annotationChecker.php:108
‪TYPO3\CMS\Install\Tests\Unit\ExtensionScanner\Php\Matcher
Definition: AbstractCoreMatcherTest.php:18
‪TYPO3\CMS\Install\ExtensionScanner\Php\Matcher\ConstructorArgumentMatcher
Definition: ConstructorArgumentMatcher.php:37
‪TYPO3\CMS\Install\Tests\Unit\ExtensionScanner\Php\Matcher\Fixtures\Subject
Definition: Subject.php:24
‪TYPO3\CMS\Install\Tests\Unit\ExtensionScanner\Php\Matcher\ConstructorArgumentMatcherTest\hitsFromFixtureAreFound
‪hitsFromFixtureAreFound(array $configuration, array $expectation)
Definition: ConstructorArgumentMatcherTest.php:79