class FilterCrudTest in Drupal 10
Same name and namespace in other branches
- 8 core/modules/filter/tests/src/Kernel/FilterCrudTest.php \Drupal\Tests\filter\Kernel\FilterCrudTest
- 9 core/modules/filter/tests/src/Kernel/FilterCrudTest.php \Drupal\Tests\filter\Kernel\FilterCrudTest
Tests creation, loading, updating, deleting of text formats and filters.
@group filter
Hierarchy
- class \Drupal\KernelTests\KernelTestBase extends \PHPUnit\Framework\TestCase implements ServiceProviderInterface uses \Drupal\Tests\PhpUnitCompatibilityTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait, AssertContentTrait, ConfigTestTrait, ExtensionListTestTrait, RandomGeneratorTrait, TestRequirementsTrait, PhpUnitWarnings
- class \Drupal\Tests\filter\Kernel\FilterCrudTest
Expanded class hierarchy of FilterCrudTest
File
- core/
modules/ filter/ tests/ src/ Kernel/ FilterCrudTest.php, line 14
Namespace
Drupal\Tests\filter\KernelView source
class FilterCrudTest extends KernelTestBase {
/**
* Modules to enable.
*
* @var array
*/
protected static $modules = [
'filter',
'filter_test',
'system',
'user',
];
/**
* Tests CRUD operations for text formats and filters.
*/
public function testTextFormatCrud() {
// Add a text format with minimum data only.
$format = FilterFormat::create([
'format' => 'empty_format',
'name' => 'Empty format',
]);
$format
->save();
$this
->verifyTextFormat($format);
// Add another text format specifying all possible properties.
$format = FilterFormat::create([
'format' => 'custom_format',
'name' => 'Custom format',
]);
$format
->setFilterConfig('filter_url', [
'status' => 1,
'settings' => [
'filter_url_length' => 30,
],
]);
$format
->save();
$this
->verifyTextFormat($format);
// Alter some text format properties and save again.
$format
->set('name', 'Altered format');
$format
->setFilterConfig('filter_url', [
'status' => 0,
]);
$format
->setFilterConfig('filter_autop', [
'status' => 1,
]);
$format
->save();
$this
->verifyTextFormat($format);
// Add a filter_test_replace filter and save again.
$format
->setFilterConfig('filter_test_replace', [
'status' => 1,
]);
$format
->save();
$this
->verifyTextFormat($format);
// Disable the text format.
$format
->disable()
->save();
$formats = filter_formats();
$this
->assertTrue(!isset($formats[$format
->id()]), 'filter_formats: Disabled text format no longer exists.');
}
/**
* Tests disabling the fallback text format.
*/
public function testDisableFallbackFormat() {
$this
->installConfig([
'filter',
]);
$message = '\\LogicException with message "The fallback text format \'plain_text\' cannot be disabled." was thrown.';
try {
FilterFormat::load('plain_text')
->disable();
$this
->fail($message);
} catch (\LogicException $e) {
$this
->assertSame("The fallback text format 'plain_text' cannot be disabled.", $e
->getMessage(), $message);
}
}
/**
* Verifies that a text format is properly stored.
*/
public function verifyTextFormat($format) {
$t_args = [
'%format' => $format
->label(),
];
$default_langcode = \Drupal::languageManager()
->getDefaultLanguage()
->getId();
// Verify the loaded filter has all properties.
$filter_format = FilterFormat::load($format
->id());
$this
->assertEquals($format
->id(), $filter_format
->id(), new FormattableMarkup('filter_format_load: Proper format id for text format %format.', $t_args));
$this
->assertEquals($format
->label(), $filter_format
->label(), new FormattableMarkup('filter_format_load: Proper title for text format %format.', $t_args));
$this
->assertEquals($format
->get('weight'), $filter_format
->get('weight'), new FormattableMarkup('filter_format_load: Proper weight for text format %format.', $t_args));
// Check that the filter was created in site default language.
$this
->assertEquals($default_langcode, $format
->language()
->getId(), new FormattableMarkup('filter_format_load: Proper language code for text format %format.', $t_args));
// Verify the permission exists and has the correct dependencies.
$permissions = \Drupal::service('user.permissions')
->getPermissions();
$this
->assertTrue(isset($permissions[$format
->getPermissionName()]));
$this
->assertEquals([
'config' => [
$format
->getConfigDependencyName(),
],
], $permissions[$format
->getPermissionName()]['dependencies']);
}
}