You are here

class FieldBooleanTest in Drupal 10

Same name and namespace in other branches
  1. 8 core/modules/views/tests/src/Kernel/Handler/FieldBooleanTest.php \Drupal\Tests\views\Kernel\Handler\FieldBooleanTest
  2. 9 core/modules/views/tests/src/Kernel/Handler/FieldBooleanTest.php \Drupal\Tests\views\Kernel\Handler\FieldBooleanTest

Tests the core Drupal\views\Plugin\views\field\Boolean handler.

@group views

Hierarchy

  • class \Drupal\Tests\views\Kernel\Handler\FieldBooleanTest extends \Drupal\Tests\views\Kernel\ViewsKernelTestBase

Expanded class hierarchy of FieldBooleanTest

File

core/modules/views/tests/src/Kernel/Handler/FieldBooleanTest.php, line 13

Namespace

Drupal\Tests\views\Kernel\Handler
View source
class FieldBooleanTest extends ViewsKernelTestBase {

  /**
   * Views used by this test.
   *
   * @var array
   */
  public static $testViews = [
    'test_view',
  ];
  public function dataSet() {

    // Use default dataset but remove the age from john and paul
    $data = parent::dataSet();
    $data[0]['age'] = 0;
    $data[3]['age'] = 0;
    return $data;
  }
  public function viewsData() {
    $data = parent::viewsData();
    $data['views_test_data']['age']['field']['id'] = 'boolean';
    return $data;
  }
  public function testFieldBoolean() {
    $view = Views::getView('test_view');
    $view
      ->setDisplay();
    $view->displayHandlers
      ->get('default')
      ->overrideOption('fields', [
      'age' => [
        'id' => 'age',
        'table' => 'views_test_data',
        'field' => 'age',
        'relationship' => 'none',
      ],
    ]);
    $this
      ->executeView($view);

    // This is john, which has no age, there are no custom formats defined, yet.
    $this
      ->assertEquals('No', $view->field['age']
      ->advancedRender($view->result[0]));
    $this
      ->assertEquals('Yes', $view->field['age']
      ->advancedRender($view->result[1]));

    // Reverse the output.
    $view->field['age']->options['not'] = TRUE;
    $this
      ->assertEquals('Yes', $view->field['age']
      ->advancedRender($view->result[0]));
    $this
      ->assertEquals('No', $view->field['age']
      ->advancedRender($view->result[1]));
    unset($view->field['age']->options['not']);

    // Use another output format.
    $view->field['age']->options['type'] = 'true-false';
    $this
      ->assertEquals('False', $view->field['age']
      ->advancedRender($view->result[0]));
    $this
      ->assertEquals('True', $view->field['age']
      ->advancedRender($view->result[1]));

    // test awesome unicode.
    $view->field['age']->options['type'] = 'unicode-yes-no';
    $this
      ->assertEquals('✖', $view->field['age']
      ->advancedRender($view->result[0]));
    $this
      ->assertEquals('✔', $view->field['age']
      ->advancedRender($view->result[1]));

    // Set a custom output format.
    $view->field['age']->formats['test'] = [
      'Test-True',
      'Test-False',
    ];
    $view->field['age']->options['type'] = 'test';
    $this
      ->assertEquals('Test-False', $view->field['age']
      ->advancedRender($view->result[0]));
    $this
      ->assertEquals('Test-True', $view->field['age']
      ->advancedRender($view->result[1]));
  }

}

Members