You are here

class BasicTest in Drupal 10

Same name in this branch
  1. 10 core/modules/views/tests/src/Kernel/BasicTest.php \Drupal\Tests\views\Kernel\BasicTest
  2. 10 core/modules/views/tests/src/Functional/Wizard/BasicTest.php \Drupal\Tests\views\Functional\Wizard\BasicTest
Same name and namespace in other branches
  1. 8 core/modules/views/tests/src/Kernel/BasicTest.php \Drupal\Tests\views\Kernel\BasicTest
  2. 9 core/modules/views/tests/src/Kernel/BasicTest.php \Drupal\Tests\views\Kernel\BasicTest

A basic query test for Views.

@group views

Hierarchy

Expanded class hierarchy of BasicTest

File

core/modules/views/tests/src/Kernel/BasicTest.php, line 12

Namespace

Drupal\Tests\views\Kernel
View source
class BasicTest extends ViewsKernelTestBase {

  /**
   * Views used by this test.
   *
   * @var array
   */
  public static $testViews = [
    'test_view',
    'test_simple_argument',
  ];

  /**
   * Tests a trivial result set.
   */
  public function testSimpleResultSet() {
    $view = Views::getView('test_view');
    $view
      ->setDisplay();

    // Execute the view.
    $this
      ->executeView($view);

    // Verify the result.
    $this
      ->assertCount(5, $view->result, 'The number of returned rows match.');
    $this
      ->assertIdenticalResultset($view, $this
      ->dataSet(), [
      'views_test_data_name' => 'name',
      'views_test_data_age' => 'age',
    ]);
  }

  /**
   * Tests filtering of the result set.
   */
  public function testSimpleFiltering() {
    $view = Views::getView('test_view');
    $view
      ->setDisplay();

    // Add a filter.
    $view->displayHandlers
      ->get('default')
      ->overrideOption('filters', [
      'age' => [
        'operator' => '<',
        'value' => [
          'value' => '28',
          'min' => '',
          'max' => '',
        ],
        'group' => '0',
        'exposed' => FALSE,
        'expose' => [
          'operator' => FALSE,
          'label' => '',
        ],
        'id' => 'age',
        'table' => 'views_test_data',
        'field' => 'age',
        'relationship' => 'none',
      ],
    ]);

    // Execute the view.
    $this
      ->executeView($view);

    // Build the expected result.
    $dataset = [
      [
        'id' => 1,
        'name' => 'John',
        'age' => 25,
      ],
      [
        'id' => 2,
        'name' => 'George',
        'age' => 27,
      ],
      [
        'id' => 4,
        'name' => 'Paul',
        'age' => 26,
      ],
    ];

    // Verify the result.
    $this
      ->assertCount(3, $view->result, 'The number of returned rows match.');
    $this
      ->assertIdenticalResultSet($view, $dataset, [
      'views_test_data_name' => 'name',
      'views_test_data_age' => 'age',
    ]);
  }

  /**
   * Tests simple argument.
   */
  public function testSimpleArgument() {

    // Execute with a view
    $view = Views::getView('test_simple_argument');
    $view
      ->setArguments([
      27,
    ]);
    $this
      ->executeView($view);

    // Build the expected result.
    $dataset = [
      [
        'id' => 2,
        'name' => 'George',
        'age' => 27,
      ],
    ];

    // Verify the result.
    $this
      ->assertCount(1, $view->result, 'The number of returned rows match.');
    $this
      ->assertIdenticalResultSet($view, $dataset, [
      'views_test_data_name' => 'name',
      'views_test_data_age' => 'age',
    ]);

    // Test "show all" if no argument is present.
    $view = Views::getView('test_simple_argument');
    $this
      ->executeView($view);

    // Build the expected result.
    $dataset = $this
      ->dataSet();
    $this
      ->assertCount(5, $view->result, 'The number of returned rows match.');
    $this
      ->assertIdenticalResultSet($view, $dataset, [
      'views_test_data_name' => 'name',
      'views_test_data_age' => 'age',
    ]);
  }

}

Members