function EntityResourceRestTestCoverageTest::testEntityTypeRestTestCoverage
Same name and namespace in other branches
- 9 core/modules/rest/tests/src/Kernel/EntityResource/EntityResourceRestTestCoverageTest.php \Drupal\Tests\rest\Kernel\EntityResource\EntityResourceRestTestCoverageTest::testEntityTypeRestTestCoverage()
- 10 core/modules/rest/tests/src/Kernel/EntityResource/EntityResourceRestTestCoverageTest.php \Drupal\Tests\rest\Kernel\EntityResource\EntityResourceRestTestCoverageTest::testEntityTypeRestTestCoverage()
- 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\EntityResourceCode
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.