function EntityResourceRestTestCoverageTest::testEntityTypeRestTestCoverage

Same name in other branches
  1. 8.9.x core/modules/rest/tests/src/Functional/EntityResource/EntityResourceRestTestCoverageTest.php \Drupal\Tests\rest\Functional\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/Kernel/EntityResource/EntityResourceRestTestCoverageTest.php, line 68

Class

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

Namespace

Drupal\Tests\rest\Kernel\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',
            ],
        ],
    ];
    $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})";
            }
        }
        $config_entity = is_subclass_of($class_name_full, ConfigEntityInterface::class);
        $config_test = is_subclass_of($class, ConfigEntityResourceTestBase::class) || is_subclass_of($class_alternative, ConfigEntityResourceTestBase::class);
        if ($config_entity && !$config_test) {
            $problems[] = "{$entity_type_id}: {$class_name} is a config entity, but the test is for content entities.";
        }
        elseif (!$config_entity && $config_test) {
            $problems[] = "{$entity_type_id}: {$class_name} is a content entity, but the test is for config entities.";
        }
    }
    $this->assertSame([], $problems);
}

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