class WizardPluginBaseTest

Same name in other branches
  1. 8.9.x core/modules/views/tests/src/Unit/WizardPluginBaseTest.php \Drupal\Tests\views\Unit\WizardPluginBaseTest
  2. 10 core/modules/views/tests/src/Unit/WizardPluginBaseTest.php \Drupal\Tests\views\Unit\WizardPluginBaseTest
  3. 11.x 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 14

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) {
        $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 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 Deprecated Modifiers Object type Summary Overrides
PhpUnitWarnings::$deprecationWarnings private static property Deprecation warnings from PHPUnit to raise with @trigger_error().
PhpUnitWarnings::addWarning public function Converts PHPUnit deprecation warnings to E_USER_DEPRECATED.
UnitTestCase::$randomGenerator protected property The random generator.
UnitTestCase::$root protected property The app root. 1
UnitTestCase::assertArrayEquals Deprecated protected function Asserts if two arrays are equal by sorting them first.
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::getRandomGenerator protected function Gets the random generator for the utility methods.
UnitTestCase::getStringTranslationStub public function Returns a stub translation manager that just returns the passed string.
UnitTestCase::randomMachineName public function Generates a unique random string containing letters and numbers.
UnitTestCase::setUp protected function 338
UnitTestCase::setUpBeforeClass public static function
WizardPluginBaseTest::providerTestGetSelected public 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.