class WizardPluginBaseTest
Same name and namespace in other branches
- 11.x core/modules/views/tests/src/Unit/WizardPluginBaseTest.php \Drupal\Tests\views\Unit\WizardPluginBaseTest
- 10 core/modules/views/tests/src/Unit/WizardPluginBaseTest.php \Drupal\Tests\views\Unit\WizardPluginBaseTest
- 8.9.x core/modules/views/tests/src/Unit/WizardPluginBaseTest.php \Drupal\Tests\views\Unit\WizardPluginBaseTest
@coversDefaultClass \Drupal\views\Plugin\views\wizard\WizardPluginBase
@group views
Hierarchy
- class \Drupal\Tests\UnitTestCase uses \Drupal\Tests\Traits\PhpUnitWarnings, \Drupal\Tests\PhpUnitCompatibilityTrait, \Symfony\Bridge\PhpUnit\ExpectDeprecationTrait extends \PHPUnit\Framework\TestCase
- class \Drupal\Tests\views\Unit\WizardPluginBaseTest extends \Drupal\Tests\UnitTestCase
Expanded class hierarchy of WizardPluginBaseTest
File
-
core/
modules/ views/ tests/ src/ Unit/ WizardPluginBaseTest.php, line 14
Namespace
Drupal\Tests\views\UnitView 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;
}
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.