WizardPluginBaseTest.php
Namespace
Drupal\Tests\views\UnitFile
- 
              core/
modules/ views/ tests/ src/ Unit/ WizardPluginBaseTest.php  
View source
<?php
declare (strict_types=1);
namespace Drupal\Tests\views\Unit;
use Drupal\Core\Form\FormState;
use Drupal\Tests\UnitTestCase;
use Drupal\views\Plugin\views\wizard\WizardPluginBase;
use PHPUnit\Framework\Attributes\CoversClass;
use PHPUnit\Framework\Attributes\DataProvider;
use PHPUnit\Framework\Attributes\Group;
/**
 * Tests Drupal\views\Plugin\views\wizard\WizardPluginBase.
 */
class WizardPluginBaseTest extends UnitTestCase {
  
  /**
   * Tests get selected.
   *
   * @legacy-covers ::getSelected
   */
  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;
  }
}
Classes
| Title | Deprecated | Summary | 
|---|---|---|
| WizardPluginBaseTest | Tests Drupal\views\Plugin\views\wizard\WizardPluginBase. | 
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.