function EntityResourceRestTestCoverageTest::testEntityTypeRestTestCoverage

Same name and namespace in other branches
  1. 9 core/modules/rest/tests/src/Kernel/EntityResource/EntityResourceRestTestCoverageTest.php \Drupal\Tests\rest\Kernel\EntityResource\EntityResourceRestTestCoverageTest::testEntityTypeRestTestCoverage()
  2. 10 core/modules/rest/tests/src/Kernel/EntityResource/EntityResourceRestTestCoverageTest.php \Drupal\Tests\rest\Kernel\EntityResource\EntityResourceRestTestCoverageTest::testEntityTypeRestTestCoverage()
  3. 11.x core/modules/rest/tests/src/Kernel/EntityResource/EntityResourceRestTestCoverageTest.php \Drupal\Tests\rest\Kernel\EntityResource\EntityResourceRestTestCoverageTest::testEntityTypeRestTestCoverage()

Tests that all core content/config entity types have REST test coverage.

File

core/modules/rest/tests/src/Functional/EntityResource/EntityResourceRestTestCoverageTest.php, line 63

Class

EntityResourceRestTestCoverageTest
Checks that all core content/config entity types have REST test coverage.

Namespace

Drupal\Tests\rest\Functional\EntityResource

Code

public function testEntityTypeRestTestCoverage() {
    $tests = [
        // Test coverage for formats provided by the 'serialization' module.
'serialization' => [
            'path' => '\\Drupal\\Tests\\PROVIDER\\Functional\\Rest\\CLASS',
            'class suffix' => [
                'JsonAnonTest',
                'JsonBasicAuthTest',
                'JsonCookieTest',
                'XmlAnonTest',
                'XmlBasicAuthTest',
                'XmlCookieTest',
            ],
        ],
        // Test coverage for formats provided by the 'hal' module.
'hal' => [
            'path' => '\\Drupal\\Tests\\PROVIDER\\Functional\\Hal\\CLASS',
            'class suffix' => [
                'HalJsonAnonTest',
                'HalJsonBasicAuthTest',
                'HalJsonCookieTest',
            ],
        ],
    ];
    $problems = [];
    foreach ($this->definitions as $entity_type_id => $info) {
        $class_name_full = $info->getClass();
        $parts = explode('\\', $class_name_full);
        $class_name = end($parts);
        $module_name = $parts[1];
        foreach ($tests as $module => $info) {
            $path = $info['path'];
            $missing_tests = [];
            foreach ($info['class suffix'] as $postfix) {
                $class = str_replace([
                    'PROVIDER',
                    'CLASS',
                ], [
                    $module_name,
                    $class_name,
                ], $path . $postfix);
                $class_alternative = str_replace("\\Drupal\\Tests\\{$module_name}\\Functional", '\\Drupal\\FunctionalTests', $class);
                if (class_exists($class) || class_exists($class_alternative)) {
                    continue;
                }
                $missing_tests[] = $postfix;
            }
            if (!empty($missing_tests)) {
                $missing_tests_list = implode(', ', array_map(function ($missing_test) use ($class_name) {
                    return $class_name . $missing_test;
                }, $missing_tests));
                $which_normalization = $module === 'serialization' ? 'default' : $module;
                $problems[] = "{$entity_type_id}: {$class_name} ({$class_name_full}), {$which_normalization} normalization (expected tests: {$missing_tests_list})";
            }
        }
    }
    $all = count($this->definitions);
    $good = $all - count($problems);
    $this->assertSame([], $problems, $this->getLlamaMessage($good, $all));
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.