class AlignmentPluginTest

Same name in other branches
  1. 9 core/modules/ckeditor5/tests/src/Unit/AlignmentPluginTest.php \Drupal\Tests\ckeditor5\Unit\AlignmentPluginTest
  2. 10 core/modules/ckeditor5/tests/src/Unit/AlignmentPluginTest.php \Drupal\Tests\ckeditor5\Unit\AlignmentPluginTest

@coversDefaultClass \Drupal\ckeditor5\Plugin\CKEditor5Plugin\Alignment @group ckeditor5 @internal

Hierarchy

Expanded class hierarchy of AlignmentPluginTest

File

core/modules/ckeditor5/tests/src/Unit/AlignmentPluginTest.php, line 17

Namespace

Drupal\Tests\ckeditor5\Unit
View source
class AlignmentPluginTest extends UnitTestCase {
    
    /**
     * Provides a list of configs to test.
     */
    public static function providerGetDynamicPluginConfig() : array {
        return [
            'All alignments' => [
                Alignment::DEFAULT_CONFIGURATION,
                [
                    'alignment' => [
                        'options' => [
                            [
                                'name' => 'left',
                                'className' => 'text-align-left',
                            ],
                            [
                                'name' => 'center',
                                'className' => 'text-align-center',
                            ],
                            [
                                'name' => 'right',
                                'className' => 'text-align-right',
                            ],
                            [
                                'name' => 'justify',
                                'className' => 'text-align-justify',
                            ],
                        ],
                    ],
                ],
            ],
            'No alignments allowed' => [
                [
                    'enabled_alignments' => [],
                ],
                [
                    'alignment' => [
                        'options' => [],
                    ],
                ],
            ],
            'Left only' => [
                [
                    'enabled_alignments' => [
                        'left',
                    ],
                ],
                [
                    'alignment' => [
                        'options' => [
                            [
                                'name' => 'left',
                                'className' => 'text-align-left',
                            ],
                        ],
                    ],
                ],
            ],
            'Left and justify only' => [
                [
                    'enabled_alignments' => [
                        'left',
                        'justify',
                    ],
                ],
                [
                    'alignment' => [
                        'options' => [
                            [
                                'name' => 'left',
                                'className' => 'text-align-left',
                            ],
                            [
                                'name' => 'justify',
                                'className' => 'text-align-justify',
                            ],
                        ],
                    ],
                ],
            ],
        ];
    }
    
    /**
     * @covers ::getDynamicPluginConfig
     * @dataProvider providerGetDynamicPluginConfig
     */
    public function testGetDynamicPluginConfig(array $configuration, array $expected_dynamic_config) : void {
        // Read the CKEditor 5 plugin's static configuration from YAML.
        $ckeditor5_plugin_definitions = Yaml::parseFile(__DIR__ . '/../../../ckeditor5.ckeditor5.yml');
        $static_plugin_config = $ckeditor5_plugin_definitions['ckeditor5_alignment']['ckeditor5']['config'];
        $plugin = new Alignment($configuration, 'ckeditor5_alignment', NULL);
        $dynamic_plugin_config = $plugin->getDynamicPluginConfig($static_plugin_config, $this->prophesize(EditorInterface::class)
            ->reveal());
        $this->assertSame($expected_dynamic_config, $dynamic_plugin_config);
    }

}

Members

Title Sort descending Modifiers Object type Summary Overrides
AlignmentPluginTest::providerGetDynamicPluginConfig public static function Provides a list of configs to test.
AlignmentPluginTest::testGetDynamicPluginConfig public function @covers ::getDynamicPluginConfig
@dataProvider providerGetDynamicPluginConfig
ExpectDeprecationTrait::expectDeprecation public function Adds an expected deprecation.
ExpectDeprecationTrait::getCallableName private static function Returns a callable as a string suitable for inclusion in a message.
ExpectDeprecationTrait::setUpErrorHandler public function Sets up the test error handler.
ExpectDeprecationTrait::tearDownErrorHandler public function Tears down the test error handler.
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::getConfigStorageStub public function Returns a stub config storage that returns the supplied configuration.
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::setUp protected function 367
UnitTestCase::setUpBeforeClass public static function

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