class CKEditor5Test
Tests Drupal\ckeditor5\Plugin\Editor\CKEditor5.
@internal
Attributes
#[CoversClass(CKEditor5::class)]
#[Group('ckeditor5')]
Hierarchy
- class \Drupal\Tests\UnitTestCase uses \Drupal\Tests\PhpUnitCompatibilityTrait, \Prophecy\PhpUnit\ProphecyTrait, \Drupal\TestTools\Extension\DeprecationBridge\ExpectDeprecationTrait, \Drupal\Tests\RandomGeneratorTrait extends \PHPUnit\Framework\TestCase
- class \Drupal\Tests\ckeditor5\Unit\CKEditor5Test uses \Drupal\Tests\ckeditor5\Traits\PrivateMethodUnitTestTrait extends \Drupal\Tests\UnitTestCase
Expanded class hierarchy of CKEditor5Test
File
-
core/
modules/ ckeditor5/ tests/ src/ Unit/ CKEditor5Test.php, line 19
Namespace
Drupal\Tests\ckeditor5\UnitView source
class CKEditor5Test extends UnitTestCase {
use PrivateMethodUnitTestTrait;
/**
* Simulated CKEditor5::buildConfigurationForm() form structure.
*
* @var array
*/
protected const SIMULATED_FORM_STRUCTURE = [
'toolbar' => [
'available' => [],
'items' => [],
],
'available_items_description' => [],
'active_items_description' => [],
'plugin_settings' => [],
'plugins' => [
'providerA_plugin1' => [],
'providerB_plugin2' => [
'foo' => [],
'bar' => [],
],
],
];
/**
* Tests paths to form names.
*
* @legacy-covers \Drupal\ckeditor5\Plugin\Editor\CKEditor5::mapViolationPropertyPathsToFormNames
*/
public function testPathsToFormNames(string $property_path, string $expected_form_item_name, bool $expect_exception = FALSE) : void {
$mapMethod = self::getMethod(CKEditor5::class, 'mapViolationPropertyPathsToFormNames');
if ($expect_exception) {
$this->expectExceptionMessage('assert($shifted === \'settings\')');
}
$form_item_name = $mapMethod->invokeArgs(NULL, [
$property_path,
static::SIMULATED_FORM_STRUCTURE,
]);
if (!$expect_exception) {
$this->assertSame($expected_form_item_name, $form_item_name);
}
}
/**
* Data provider for testing mapViolationPropertyPathsToFormNames.
*
* @return array[]
* An array with the property path and expected form item name.
*/
public static function providerPathsToFormNames() : array {
return [
'validation error targeting toolbar items' => [
'settings.toolbar.items',
'settings][toolbar][items',
],
'validation error targeting a specific toolbar item' => [
'settings.toolbar.items.6',
'settings][toolbar][items',
],
'validation error targeting a simple plugin form' => [
'settings.plugins.providerA_plugin1',
'settings][plugins][providerA_plugin1',
],
'validation error targeting a simple plugin form, with deep config schema detail' => [
'settings.plugins.providerA_plugin1.foo.bar.baz',
'settings][plugins][providerA_plugin1',
],
'validation error targeting a complex plugin form' => [
'settings.plugins.providerB_plugin2',
'settings][plugins][providerB_plugin2',
],
'validation error targeting a complex plugin form, with deep config schema detail' => [
'settings.plugins.providerB_plugin2.foo.bar.baz',
'settings][plugins][providerB_plugin2][foo',
],
'unrealistic example one — should trigger exception' => [
'bad.bad.worst',
'I DO NOT EXIST',
TRUE,
],
'unrealistic example two — should trigger exception' => [
'one.two.three.four',
'one][two][three][four',
TRUE,
],
];
}
}
Members
| Title Sort descending | Modifiers | Object type | Summary | Overrides |
|---|---|---|---|---|
| CKEditor5Test::providerPathsToFormNames | public static | function | Data provider for testing mapViolationPropertyPathsToFormNames. | |
| CKEditor5Test::SIMULATED_FORM_STRUCTURE | protected | constant | Simulated CKEditor5::buildConfigurationForm() form structure. | |
| CKEditor5Test::testPathsToFormNames | public | function | Tests paths to form names. | |
| ExpectDeprecationTrait::expectDeprecation | public | function | Adds an expected deprecation. | |
| ExpectDeprecationTrait::setUpErrorHandler | public | function | Sets up the test error handler. | |
| ExpectDeprecationTrait::tearDownErrorHandler | public | function | Tears down the test error handler. | |
| PrivateMethodUnitTestTrait::getMethod | protected static | function | Gets a protected/private method to test. | |
| 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. | |
| UnitTestCase::$root | protected | property | The app root. | |
| 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::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::setDebugDumpHandler | public static | function | Registers the dumper CLI handler when the DebugDump extension is enabled. | |
| UnitTestCase::setUp | protected | function | 366 | |
| UnitTestCase::setupMockIterator | protected | function | Set up a traversable class mock to return specific items when iterated. |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.