class WizardPluginBaseTest

Same name and namespace in other branches
  1. 9 core/modules/views/tests/src/Unit/WizardPluginBaseTest.php \Drupal\Tests\views\Unit\WizardPluginBaseTest
  2. 8.9.x core/modules/views/tests/src/Unit/WizardPluginBaseTest.php \Drupal\Tests\views\Unit\WizardPluginBaseTest
  3. 10 core/modules/views/tests/src/Unit/WizardPluginBaseTest.php \Drupal\Tests\views\Unit\WizardPluginBaseTest

@coversDefaultClass \Drupal\views\Plugin\views\wizard\WizardPluginBase

@group views

Hierarchy

Expanded class hierarchy of WizardPluginBaseTest

File

core/modules/views/tests/src/Unit/WizardPluginBaseTest.php, line 16

Namespace

Drupal\Tests\views\Unit
View source
class WizardPluginBaseTest extends UnitTestCase {
    
    /**
     * @covers ::getSelected
     *
     * @dataProvider providerTestGetSelected
     */
    public function testGetSelected($expected, $element = [], $parents = [], $user_input = [], $not_rebuilding_expected = NULL) : void {
        $not_rebuilding_expected = $not_rebuilding_expected ?: $expected;
        $form_state = new FormState();
        $form_state->setUserInput($user_input);
        $actual = WizardPluginBase::getSelected($form_state, $parents, 'the_default_value', $element);
        $this->assertSame($not_rebuilding_expected, $actual);
        $this->assertSame($user_input, $form_state->getUserInput());
        $form_state->setRebuild();
        $actual = WizardPluginBase::getSelected($form_state, $parents, 'the_default_value', $element);
        $this->assertSame($expected, $actual);
        $this->assertSame($user_input, $form_state->getUserInput());
    }
    
    /**
     * Provides test data for testGetSelected().
     */
    public static function providerTestGetSelected() {
        $data = [];
        // A form element with an invalid #type.
        $data['invalid_type'] = [
            'the_default_value',
            [
                '#type' => 'checkbox',
            ],
        ];
        // A form element with no #options.
        $data['no_options'] = [
            'the_default_value',
            [
                '#type' => 'select',
            ],
        ];
        // A valid form element with no user input.
        $data['no_user_input'] = [
            'the_default_value',
            [
                '#type' => 'select',
                '#options' => [
                    'option1' => 'Option 1',
                ],
            ],
        ];
        // A valid form element with user input that doesn't correspond to it.
        $data['mismatched_input'] = [
            'the_default_value',
            [
                '#type' => 'select',
                '#options' => [
                    'option1' => 'Option 1',
                ],
            ],
            [
                'foo',
                'bar',
            ],
            [
                'foo' => [
                    'foo' => 'value1',
                ],
            ],
        ];
        // A valid form element with a valid dynamic value that matches the default
        // value.
        $data['matching_default'] = [
            'the_default_value',
            [
                '#type' => 'select',
                '#options' => [
                    'the_default_value' => 'Option 1',
                ],
            ],
            [
                'foo',
                'bar',
            ],
            [
                'foo' => [
                    'bar' => 'the_default_value',
                ],
            ],
        ];
        // A valid form element with a valid dynamic value that does not match the
        // default value.
        $data['mismatched_value'] = [
            'option1',
            [
                '#type' => 'select',
                '#options' => [
                    'option1' => 'Option 1',
                ],
            ],
            [
                'foo',
                'bar',
            ],
            [
                'foo' => [
                    'bar' => 'option1',
                ],
            ],
            'the_default_value',
        ];
        return $data;
    }

}

Members

Title Sort descending Modifiers Object type Summary Overrides
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 354
UnitTestCase::setUpBeforeClass public static function
WizardPluginBaseTest::providerTestGetSelected public static function Provides test data for testGetSelected().
WizardPluginBaseTest::testGetSelected public function @covers ::getSelected

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