class TestDiscoveryTest
@coversDefaultClass \Drupal\Core\Test\TestDiscovery
      
    
@group Test
Hierarchy
- class \Drupal\Tests\UnitTestCase uses \Drupal\Tests\Traits\PhpUnitWarnings, \Drupal\Tests\PhpUnitCompatibilityTrait, \Prophecy\PhpUnit\ProphecyTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait, \Drupal\Tests\RandomGeneratorTrait extends \PHPUnit\Framework\TestCase- class \Drupal\Tests\Core\Test\TestDiscoveryTest extends \Drupal\Tests\UnitTestCase
 
Expanded class hierarchy of TestDiscoveryTest
File
- 
              core/tests/ Drupal/ Tests/ Core/ Test/ TestDiscoveryTest.php, line 21 
Namespace
Drupal\Tests\Core\TestView source
class TestDiscoveryTest extends UnitTestCase {
  
  /**
   * @covers ::getTestInfo
   * @dataProvider infoParserProvider
   */
  public function testTestInfoParser($expected, $classname, $doc_comment = NULL) : void {
    $info = TestDiscovery::getTestInfo($classname, $doc_comment);
    $this->assertEquals($expected, $info);
  }
  public static function infoParserProvider() {
    // A module provided unit test.
    $tests[] = [
      // Expected result.
[
        'name' => static::class,
        'group' => 'Test',
        'groups' => [
          'Test',
        ],
        'description' => 'Tests \\Drupal\\Core\\Test\\TestDiscovery.',
        'type' => 'PHPUnit-Unit',
      ],
      // Classname.
static::class,
    ];
    // A core unit test.
    $tests[] = [
      // Expected result.
[
        'name' => 'Drupal\\Tests\\Core\\DrupalTest',
        'group' => 'DrupalTest',
        'groups' => [
          'DrupalTest',
        ],
        'description' => 'Tests \\Drupal.',
        'type' => 'PHPUnit-Unit',
      ],
      // Classname.
'Drupal\\Tests\\Core\\DrupalTest',
    ];
    // Functional PHPUnit test.
    $tests[] = [
      // Expected result.
[
        'name' => 'Drupal\\FunctionalTests\\BrowserTestBaseTest',
        'group' => 'browsertestbase',
        'groups' => [
          'browsertestbase',
          '#slow',
        ],
        'description' => 'Tests BrowserTestBase functionality.',
        'type' => 'PHPUnit-Functional',
      ],
      // Classname.
'Drupal\\FunctionalTests\\BrowserTestBaseTest',
    ];
    // Kernel PHPUnit test.
    $tests['phpunit-kernel'] = [
      // Expected result.
[
        'name' => '\\Drupal\\Tests\\file\\Kernel\\FileItemValidationTest',
        'group' => 'file',
        'groups' => [
          'file',
        ],
        'description' => 'Tests that files referenced in file and image fields are always validated.',
        'type' => 'PHPUnit-Kernel',
      ],
      // Classname.
'\\Drupal\\Tests\\file\\Kernel\\FileItemValidationTest',
    ];
    // Test with a different amount of leading spaces.
    $tests[] = [
      // Expected result.
[
        'name' => 'Drupal\\Tests\\ExampleTest',
        'group' => 'test',
        'groups' => [
          'test',
        ],
        'description' => 'Example test.',
        'type' => 'PHPUnit-Unit',
      ],
      // Classname.
'Drupal\\Tests\\ExampleTest',
      // Doc block.
"/**\n   * Example test.\n   *\n   * @group test\n   */\n ",
    ];
    // Make sure that a "* @" inside a string does not get parsed as an
    // annotation.
    $tests[] = [
      // Expected result.
[
        'name' => 'Drupal\\Tests\\ExampleTest',
        'group' => 'test',
        'groups' => [
          'test',
        ],
        'description' => 'Example test. * @',
        'type' => 'PHPUnit-Unit',
      ],
      // Classname.
'Drupal\\Tests\\ExampleTest',
      // Doc block.
"/**\n   * Example test. * @\n   *\n   * @group test\n   */\n ",
    ];
    // Multiple @group annotations.
    $tests[] = [
      // Expected result.
[
        'name' => 'Drupal\\Tests\\ExampleTest',
        'group' => 'test1',
        'groups' => [
          'test1',
          'test2',
        ],
        'description' => 'Example test.',
        'type' => 'PHPUnit-Unit',
      ],
      // Classname.
'Drupal\\Tests\\ExampleTest',
      // Doc block.
"/**\n * Example test.\n *\n * @group test1\n * @group test2\n */\n ",
    ];
    // A great number of @group annotations.
    $tests['many-group-annotations'] = [
      // Expected result.
[
        'name' => 'Drupal\\Tests\\ExampleTest',
        'group' => 'test1',
        'groups' => [
          'test1',
          'test2',
          'another',
          'more',
          'many',
          'enough',
          'whoa',
        ],
        'description' => 'Example test.',
        'type' => 'PHPUnit-Unit',
      ],
      // Classname.
'Drupal\\Tests\\ExampleTest',
      // Doc block.
"/**\n * Example test.\n *\n * @group test1\n * @group test2\n * @group another\n * @group more\n * @group many\n * @group enough\n * @group whoa\n */\n ",
    ];
    // Multi-line summary line.
    $tests[] = [
      // Expected result.
[
        'name' => 'Drupal\\Tests\\ExampleTest',
        'description' => 'Example test. And the summary line continues and there is no gap to the annotation.',
        'type' => 'PHPUnit-Unit',
        'group' => 'test',
        'groups' => [
          'test',
        ],
      ],
      // Classname.
'Drupal\\Tests\\ExampleTest',
      // Doc block.
"/**\n * Example test. And the summary line continues and there is no gap to the\n * annotation.\n *\n * @group test\n */\n ",
    ];
    return $tests;
  }
  
  /**
   * @covers ::getTestInfo
   */
  public function testTestInfoParserMissingGroup() : void {
    $classname = 'Drupal\\KernelTests\\field\\BulkDeleteTest';
    $doc_comment = <<<EOT
    /**
     * Bulk delete storages and fields, and clean up afterwards.
     */
    EOT;
    $this->expectException(MissingGroupException::class);
    $this->expectExceptionMessage('Missing @group annotation in Drupal\\KernelTests\\field\\BulkDeleteTest');
    TestDiscovery::getTestInfo($classname, $doc_comment);
  }
  
  /**
   * @covers ::getTestInfo
   */
  public function testTestInfoParserMissingSummary() : void {
    $classname = 'Drupal\\KernelTests\\field\\BulkDeleteTest';
    $doc_comment = <<<EOT
    /**
     * @group field
     */
    EOT;
    $info = TestDiscovery::getTestInfo($classname, $doc_comment);
    $this->assertEmpty($info['description']);
  }
  protected function setupVfsWithTestClasses() {
    vfsStream::setup('drupal');
    $test_file = <<<EOF
    <?php
    
    /**
     * Test description
     * @group example
     */
    class FunctionalExampleTest {}
    EOF;
    $test_profile_info = <<<EOF
    name: Testing
    type: profile
    core_version_requirement: '*'
    EOF;
    $test_module_info = <<<EOF
    name: Testing
    type: module
    core_version_requirement: '*'
    EOF;
    vfsStream::create([
      'modules' => [
        'test_module' => [
          'test_module.info.yml' => $test_module_info,
          'tests' => [
            'src' => [
              'Functional' => [
                'FunctionalExampleTest.php' => $test_file,
                'FunctionalExampleTest2.php' => str_replace([
                  'FunctionalExampleTest',
                  '@group example',
                ], [
                  'FunctionalExampleTest2',
                  '@group example2',
                ], $test_file),
              ],
              'Kernel' => [
                'KernelExampleTest3.php' => str_replace([
                  'FunctionalExampleTest',
                  '@group example',
                ], [
                  'KernelExampleTest3',
                  "@group example2\n * @group kernel\n",
                ], $test_file),
                'KernelExampleTestBase.php' => str_replace([
                  'FunctionalExampleTest',
                  '@group example',
                ], [
                  'KernelExampleTestBase',
                  '@group example2',
                ], $test_file),
                'KernelExampleTrait.php' => str_replace([
                  'FunctionalExampleTest',
                  '@group example',
                ], [
                  'KernelExampleTrait',
                  '@group example2',
                ], $test_file),
                'KernelExampleInterface.php' => str_replace([
                  'FunctionalExampleTest',
                  '@group example',
                ], [
                  'KernelExampleInterface',
                  '@group example2',
                ], $test_file),
              ],
            ],
          ],
        ],
      ],
      'profiles' => [
        'test_profile' => [
          'test_profile.info.yml' => $test_profile_info,
          'modules' => [
            'test_profile_module' => [
              'test_profile_module.info.yml' => $test_module_info,
              'tests' => [
                'src' => [
                  'Kernel' => [
                    'KernelExampleTest4.php' => str_replace([
                      'FunctionalExampleTest',
                      '@group example',
                    ], [
                      'KernelExampleTest4',
                      '@group example3',
                    ], $test_file),
                  ],
                ],
              ],
            ],
          ],
        ],
      ],
    ]);
  }
  
  /**
   * @covers ::getTestClasses
   */
  public function testGetTestClasses() : void {
    $this->setupVfsWithTestClasses();
    $extensions = [
      'test_module' => new Extension('vfs://drupal', 'module', 'modules/test_module/test_module.info.yml'),
    ];
    $test_discovery = $this->getTestDiscoveryMock('vfs://drupal', $extensions);
    $result = $test_discovery->getTestClasses();
    $this->assertCount(3, $result);
    $this->assertEquals([
      'example' => [
        'Drupal\\Tests\\test_module\\Functional\\FunctionalExampleTest' => [
          'name' => 'Drupal\\Tests\\test_module\\Functional\\FunctionalExampleTest',
          'description' => 'Test description',
          'group' => 'example',
          'groups' => [
            'example',
          ],
          'type' => 'PHPUnit-Functional',
        ],
      ],
      'example2' => [
        'Drupal\\Tests\\test_module\\Functional\\FunctionalExampleTest2' => [
          'name' => 'Drupal\\Tests\\test_module\\Functional\\FunctionalExampleTest2',
          'description' => 'Test description',
          'group' => 'example2',
          'groups' => [
            'example2',
          ],
          'type' => 'PHPUnit-Functional',
        ],
        'Drupal\\Tests\\test_module\\Kernel\\KernelExampleTest3' => [
          'name' => 'Drupal\\Tests\\test_module\\Kernel\\KernelExampleTest3',
          'description' => 'Test description',
          'group' => 'example2',
          'groups' => [
            'example2',
            'kernel',
          ],
          'type' => 'PHPUnit-Kernel',
        ],
      ],
      'kernel' => [
        'Drupal\\Tests\\test_module\\Kernel\\KernelExampleTest3' => [
          'name' => 'Drupal\\Tests\\test_module\\Kernel\\KernelExampleTest3',
          'description' => 'Test description',
          'group' => 'example2',
          'groups' => [
            'example2',
            'kernel',
          ],
          'type' => 'PHPUnit-Kernel',
        ],
      ],
    ], $result);
  }
  
  /**
   * Mock a TestDiscovery object to return specific extension values.
   */
  protected function getTestDiscoveryMock($app_root, $extensions) {
    $class_loader = $this->prophesize(ClassLoader::class);
    $module_handler = $this->prophesize(ModuleHandlerInterface::class);
    $test_discovery = $this->getMockBuilder(TestDiscovery::class)
      ->setConstructorArgs([
      $app_root,
      $class_loader->reveal(),
      $module_handler->reveal(),
    ])
      ->onlyMethods([
      'getExtensions',
    ])
      ->getMock();
    $test_discovery->expects($this->any())
      ->method('getExtensions')
      ->willReturn($extensions);
    return $test_discovery;
  }
  
  /**
   * @covers ::getTestClasses
   */
  public function testGetTestClassesWithSelectedTypes() : void {
    $this->setupVfsWithTestClasses();
    $extensions = [
      'test_module' => new Extension('vfs://drupal', 'module', 'modules/test_module/test_module.info.yml'),
      'test_profile_module' => new Extension('vfs://drupal', 'profile', 'profiles/test_profile/modules/test_profile_module/test_profile_module.info.yml'),
    ];
    $test_discovery = $this->getTestDiscoveryMock('vfs://drupal', $extensions);
    $result = $test_discovery->getTestClasses(NULL, [
      'PHPUnit-Kernel',
    ]);
    $this->assertCount(4, $result);
    $this->assertEquals([
      'example' => [],
      'example2' => [
        'Drupal\\Tests\\test_module\\Kernel\\KernelExampleTest3' => [
          'name' => 'Drupal\\Tests\\test_module\\Kernel\\KernelExampleTest3',
          'description' => 'Test description',
          'group' => 'example2',
          'groups' => [
            'example2',
            'kernel',
          ],
          'type' => 'PHPUnit-Kernel',
        ],
      ],
      'kernel' => [
        'Drupal\\Tests\\test_module\\Kernel\\KernelExampleTest3' => [
          'name' => 'Drupal\\Tests\\test_module\\Kernel\\KernelExampleTest3',
          'description' => 'Test description',
          'group' => 'example2',
          'groups' => [
            'example2',
            'kernel',
          ],
          'type' => 'PHPUnit-Kernel',
        ],
      ],
      'example3' => [
        'Drupal\\Tests\\test_profile_module\\Kernel\\KernelExampleTest4' => [
          'name' => 'Drupal\\Tests\\test_profile_module\\Kernel\\KernelExampleTest4',
          'description' => 'Test description',
          'group' => 'example3',
          'groups' => [
            'example3',
          ],
          'type' => 'PHPUnit-Kernel',
        ],
      ],
    ], $result);
  }
  
  /**
   * @covers ::getTestClasses
   */
  public function testGetTestsInProfiles() : void {
    $this->setupVfsWithTestClasses();
    $class_loader = $this->prophesize(ClassLoader::class);
    $container = new Container();
    $container->set('kernel', new DrupalKernel('prod', new ClassLoader()));
    $container->setParameter('site.path', 'sites/default');
    \Drupal::setContainer($container);
    $test_discovery = new TestDiscovery('vfs://drupal', $class_loader->reveal());
    $result = $test_discovery->getTestClasses('test_profile_module', [
      'PHPUnit-Kernel',
    ]);
    $expected = [
      'example3' => [
        'Drupal\\Tests\\test_profile_module\\Kernel\\KernelExampleTest4' => [
          'name' => 'Drupal\\Tests\\test_profile_module\\Kernel\\KernelExampleTest4',
          'description' => 'Test description',
          'group' => 'example3',
          'groups' => [
            'example3',
          ],
          'type' => 'PHPUnit-Kernel',
        ],
      ],
    ];
    $this->assertEquals($expected, $result);
  }
  
  /**
   * @covers ::getPhpunitTestSuite
   * @dataProvider providerTestGetPhpunitTestSuite
   */
  public function testGetPhpunitTestSuite($classname, $expected) : void {
    $this->assertEquals($expected, TestDiscovery::getPhpunitTestSuite($classname));
  }
  public static function providerTestGetPhpunitTestSuite() {
    $data = [];
    $data['simpletest-web test'] = [
      '\\Drupal\\rest\\Tests\\NodeTest',
      FALSE,
    ];
    $data['module-unittest'] = [
      static::class,
      'Unit',
    ];
    $data['module-kernel test'] = [
      '\\Drupal\\KernelTests\\Core\\Theme\\TwigMarkupInterfaceTest',
      'Kernel',
    ];
    $data['module-functional test'] = [
      '\\Drupal\\FunctionalTests\\BrowserTestBaseTest',
      'Functional',
    ];
    $data['module-functional javascript test'] = [
      '\\Drupal\\Tests\\toolbar\\FunctionalJavascript\\ToolbarIntegrationTest',
      'FunctionalJavascript',
    ];
    $data['core-unittest'] = [
      '\\Drupal\\Tests\\ComposerIntegrationTest',
      'Unit',
    ];
    $data['core-unittest2'] = [
      'Drupal\\Tests\\Core\\DrupalTest',
      'Unit',
    ];
    $data['core-unittest3'] = [
      'Drupal\\Tests\\Scripts\\TestSiteApplicationTest',
      'Unit',
    ];
    $data['core-kernel test'] = [
      '\\Drupal\\KernelTests\\KernelTestBaseTest',
      'Kernel',
    ];
    $data['core-functional test'] = [
      '\\Drupal\\FunctionalTests\\ExampleTest',
      'Functional',
    ];
    $data['core-functional javascript test'] = [
      '\\Drupal\\FunctionalJavascriptTests\\ExampleTest',
      'FunctionalJavascript',
    ];
    $data['core-build test'] = [
      '\\Drupal\\BuildTests\\Framework\\Tests\\BuildTestTest',
      'Build',
    ];
    return $data;
  }
  
  /**
   * Ensure that classes are not reflected when the docblock is empty.
   *
   * @covers ::getTestInfo
   */
  public function testGetTestInfoEmptyDocblock() : void {
    // If getTestInfo() performed reflection, it won't be able to find the
    // class we asked it to analyze, so it will throw a ReflectionException.
    // We want to make sure it didn't do that, because we already did some
    // analysis and already have an empty docblock. getTestInfo() will throw
    // MissingGroupException because the annotation is empty.
    $this->expectException(MissingGroupException::class);
    TestDiscovery::getTestInfo('Drupal\\Tests\\ThisTestDoesNotExistTest', '');
  }
  
  /**
   * Ensure TestDiscovery::scanDirectory() ignores certain abstract file types.
   *
   * @covers ::scanDirectory
   */
  public function testScanDirectoryNoAbstract() : void {
    $this->setupVfsWithTestClasses();
    $files = TestDiscovery::scanDirectory('Drupal\\Tests\\test_module\\Kernel\\', vfsStream::url('drupal/modules/test_module/tests/src/Kernel'));
    $this->assertNotEmpty($files);
    $this->assertArrayNotHasKey('Drupal\\Tests\\test_module\\Kernel\\KernelExampleTestBase', $files);
    $this->assertArrayNotHasKey('Drupal\\Tests\\test_module\\Kernel\\KernelExampleTrait', $files);
    $this->assertArrayNotHasKey('Drupal\\Tests\\test_module\\Kernel\\KernelExampleInterface', $files);
    $this->assertArrayHasKey('Drupal\\Tests\\test_module\\Kernel\\KernelExampleTest3', $files);
  }
}Members
| Title Sort descending | Deprecated | Modifiers | Object type | Summary | Overrides | 
|---|---|---|---|---|---|
| PhpUnitWarnings::$deprecationWarnings | private static | property | Deprecation warnings from PHPUnit to raise with @trigger_error(). | ||
| PhpUnitWarnings::addWarning | public | function | Converts PHPUnit deprecation warnings to E_USER_DEPRECATED. | ||
| RandomGeneratorTrait::getRandomGenerator | protected | function | Gets the random generator for the utility methods. | ||
| RandomGeneratorTrait::randomMachineName | protected | function | Generates a unique random string containing letters and numbers. | ||
| RandomGeneratorTrait::randomObject | public | function | Generates a random PHP object. | ||
| RandomGeneratorTrait::randomString | public | function | Generates a pseudo-random string of ASCII characters of codes 32 to 126. | ||
| RandomGeneratorTrait::randomStringValidate | Deprecated | public | function | Callback for random string validation. | |
| TestDiscoveryTest::getTestDiscoveryMock | protected | function | Mock a TestDiscovery object to return specific extension values. | ||
| TestDiscoveryTest::infoParserProvider | public static | function | |||
| TestDiscoveryTest::providerTestGetPhpunitTestSuite | public static | function | |||
| TestDiscoveryTest::setupVfsWithTestClasses | protected | function | |||
| TestDiscoveryTest::testGetPhpunitTestSuite | public | function | @covers ::getPhpunitTestSuite[[api-linebreak]] @dataProvider providerTestGetPhpunitTestSuite | ||
| TestDiscoveryTest::testGetTestClasses | public | function | @covers ::getTestClasses[[api-linebreak]] | ||
| TestDiscoveryTest::testGetTestClassesWithSelectedTypes | public | function | @covers ::getTestClasses[[api-linebreak]] | ||
| TestDiscoveryTest::testGetTestInfoEmptyDocblock | public | function | Ensure that classes are not reflected when the docblock is empty. | ||
| TestDiscoveryTest::testGetTestsInProfiles | public | function | @covers ::getTestClasses[[api-linebreak]] | ||
| TestDiscoveryTest::testScanDirectoryNoAbstract | public | function | Ensure TestDiscovery::scanDirectory() ignores certain abstract file types. | ||
| TestDiscoveryTest::testTestInfoParser | public | function | @covers ::getTestInfo[[api-linebreak]] @dataProvider infoParserProvider | ||
| TestDiscoveryTest::testTestInfoParserMissingGroup | public | function | @covers ::getTestInfo[[api-linebreak]] | ||
| TestDiscoveryTest::testTestInfoParserMissingSummary | public | function | @covers ::getTestInfo[[api-linebreak]] | ||
| UnitTestCase::$root | protected | property | The app root. | 1 | |
| UnitTestCase::getClassResolverStub | protected | function | Returns a stub class resolver. | ||
| UnitTestCase::getConfigFactoryStub | public | function | Returns a stub config factory that behaves according to the passed array. | ||
| UnitTestCase::getConfigStorageStub | public | function | Returns a stub config storage that returns the supplied configuration. | ||
| UnitTestCase::getContainerWithCacheTagsInvalidator | protected | function | Sets up a container with a cache tags invalidator. | ||
| UnitTestCase::getStringTranslationStub | public | function | Returns a stub translation manager that just returns the passed string. | ||
| UnitTestCase::setUp | protected | function | 357 | ||
| UnitTestCase::setUpBeforeClass | public static | function | |||
| UnitTestCase::__get | public | function | 
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.
