class StyleGridTest

Same name and namespace in other branches
  1. 9 core/modules/views/tests/src/Kernel/Plugin/StyleGridTest.php \Drupal\Tests\views\Kernel\Plugin\StyleGridTest
  2. 8.9.x core/modules/views/tests/src/Kernel/Plugin/StyleGridTest.php \Drupal\Tests\views\Kernel\Plugin\StyleGridTest
  3. 11.x core/modules/views/tests/src/Kernel/Plugin/StyleGridTest.php \Drupal\Tests\views\Kernel\Plugin\StyleGridTest

Tests the grid style plugin.

@group views

Hierarchy

Expanded class hierarchy of StyleGridTest

See also

\Drupal\views\Plugin\views\style\Grid

File

core/modules/views/tests/src/Kernel/Plugin/StyleGridTest.php, line 16

Namespace

Drupal\Tests\views\Kernel\Plugin
View source
class StyleGridTest extends PluginKernelTestBase {
  
  /**
   * Views used by this test.
   *
   * @var array
   */
  public static $testViews = [
    'test_grid',
  ];
  
  /**
   * Keeps track of which alignments have been tested.
   *
   * @var array
   */
  protected $alignmentsTested = [];
  
  /**
   * Tests the grid style.
   */
  public function testGrid() : void {
    $view = Views::getView('test_grid');
    foreach ([
      'horizontal',
      'vertical',
    ] as $alignment) {
      $this->assertGrid($view, $alignment, 5);
      $this->assertGrid($view, $alignment, 4);
      $this->assertGrid($view, $alignment, 3);
      $this->assertGrid($view, $alignment, 2);
      $this->assertGrid($view, $alignment, 1);
    }
  }
  
  /**
   * Generates a grid and asserts that it is displaying correctly.
   *
   * @param \Drupal\views\ViewExecutable $view
   *   The executable to prepare.
   * @param string $alignment
   *   The alignment of the grid to test.
   * @param int $columns
   *   The number of columns in the grid to test.
   *
   * @internal
   */
  protected function assertGrid(ViewExecutable $view, string $alignment, int $columns) : void {
    $view->setDisplay('default');
    $view->initStyle();
    $view->initHandlers();
    $view->initQuery();
    $view->style_plugin->options['alignment'] = $alignment;
    $view->style_plugin->options['columns'] = $columns;
    $this->executeView($view);
    $output = $view->preview();
    $output = \Drupal::service('renderer')->renderRoot($output);
    $this->setRawContent($output);
    if (!in_array($alignment, $this->alignmentsTested)) {
      $result = $this->xpath('//div[contains(@class, "views-view-grid") and contains(@class, :alignment) and contains(@class, :columns)]', [
        ':alignment' => $alignment,
        ':columns' => 'cols-' . $columns,
      ]);
      $this->assertGreaterThan(0, count($result), ucfirst($alignment) . " grid markup detected.");
      $this->alignmentsTested[] = $alignment;
    }
    $width = '0';
    switch ($columns) {
      case 5:
        $width = '20';
        break;

      case 4:
        $width = '25';
        break;

      case 3:
        $width = '33.3333';
        break;

      case 2:
        $width = '50';
        break;

      case 1:
        $width = '100';
        break;

    }
    // Ensure last column exists.
    $result = $this->xpath('//div[contains(@class, "views-col") and contains(@class, :columns) and starts-with(@style, :width)]', [
      ':columns' => 'col-' . $columns,
      ':width' => 'width: ' . $width,
    ]);
    $this->assertGreaterThan(0, count($result), ucfirst($alignment) . " {$columns} column grid: last column exists and automatic width calculated correctly.");
    // Ensure no extra columns were generated.
    $result = $this->xpath('//div[contains(@class, "views-col") and contains(@class, :columns)]', [
      ':columns' => 'col-' . ($columns + 1),
    ]);
    $this->assertEmpty($result, ucfirst($alignment) . " {$columns} column grid: no extraneous columns exist.");
    // Ensure tokens are being replaced in custom row/column classes.
    $result = $this->xpath('//div[contains(@class, "views-col") and contains(@class, "name-John")]');
    $this->assertGreaterThan(0, count($result), ucfirst($alignment) . " {$columns} column grid: Token replacement verified in custom column classes.");
    $result = $this->xpath('//div[contains(@class, "views-row") and contains(@class, "age-25")]');
    $this->assertGreaterThan(0, count($result), ucfirst($alignment) . " {$columns} column grid: Token replacement verified in custom row classes.");
  }

}

Members

Title Sort descending Modifiers Object type Summary
StyleGridTest::$alignmentsTested protected property Keeps track of which alignments have been tested.
StyleGridTest::$testViews public static property Views used by this test.
StyleGridTest::assertGrid protected function Generates a grid and asserts that it is displaying correctly.
StyleGridTest::testGrid public function Tests the grid style.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.