You are here

SortRandomTest.php in Drupal 9

Same filename and directory in other branches
  1. 8 core/modules/views/tests/src/Kernel/Handler/SortRandomTest.php

File

core/modules/views/tests/src/Kernel/Handler/SortRandomTest.php
View source
<?php

namespace Drupal\Tests\views\Kernel\Handler;

use Drupal\Core\Cache\Cache;
use Drupal\views\Plugin\views\display\DisplayPluginBase;
use Drupal\Tests\views\Kernel\ViewsKernelTestBase;
use Drupal\views\Views;

/**
 * Tests for core Drupal\views\Plugin\views\sort\Random handler.
 *
 * @group views
 */
class SortRandomTest extends ViewsKernelTestBase {

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

  /**
   * Add more items to the test set, to make the order tests more robust.
   *
   * In total we have then 60 entries, which makes a probability of a collision
   * of 1/60!, which is around 1/1E80, which is higher than the estimated amount
   * of protons / electrons in the observable universe, also called the
   * eddington number.
   *
   * @see http://wikipedia.org/wiki/Eddington_number
   */
  protected function dataSet() {
    $data = parent::dataSet();
    for ($i = 0; $i < 55; $i++) {
      $data[] = [
        'name' => 'name_' . $i,
        'age' => $i,
        'job' => 'job_' . $i,
        'created' => rand(0, time()),
        'status' => 1,
      ];
    }
    return $data;
  }

  /**
   * Return a basic view with random ordering.
   */
  protected function getBasicRandomView() {
    $view = Views::getView('test_view');
    $view
      ->setDisplay();

    // Add a random ordering.
    $view->displayHandlers
      ->get('default')
      ->overrideOption('sorts', [
      'random' => [
        'id' => 'random',
        'field' => 'random',
        'table' => 'views',
      ],
    ]);
    return $view;
  }

  /**
   * Tests random ordering of the result set.
   *
   * @see DatabaseSelectTestCase::testRandomOrder()
   */
  public function testRandomOrdering() {

    // Execute a basic view first.
    $view = Views::getView('test_view');
    $this
      ->executeView($view);

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

    // Execute a random view, we expect the result set to be different.
    $view_random = $this
      ->getBasicRandomView();
    $this
      ->executeView($view_random);
    $this
      ->assertSameSize($this
      ->dataSet(), $view_random->result, 'The number of returned rows match.');
    $this
      ->assertNotIdenticalResultset($view_random, $view->result, [
      'views_test_data_name' => 'views_test_data_name',
      'views_test_data_age' => 'views_test_data_name',
    ]);

    // Execute a second random view, we expect the result set to be different again.
    $view_random_2 = $this
      ->getBasicRandomView();
    $this
      ->executeView($view_random_2);
    $this
      ->assertSameSize($this
      ->dataSet(), $view_random_2->result, 'The number of returned rows match.');
    $this
      ->assertNotIdenticalResultset($view_random, $view->result, [
      'views_test_data_name' => 'views_test_data_name',
      'views_test_data_age' => 'views_test_data_name',
    ]);
  }

  /**
   * Tests random ordering with tags based caching.
   *
   * The random sorting should opt out of caching by defining a max age of 0.
   * At the same time, the row render caching still works.
   */
  public function testRandomOrderingWithRenderCaching() {
    $view_random = $this
      ->getBasicRandomView();
    $display =& $view_random->storage
      ->getDisplay('default');
    $display['display_options']['cache'] = [
      'type' => 'tag',
    ];
    $view_random->storage
      ->save();

    /** @var \Drupal\Core\Render\RendererInterface $renderer */
    $renderer = \Drupal::service('renderer');

    /** @var \Drupal\Core\Render\RenderCacheInterface $render_cache */
    $render_cache = \Drupal::service('render_cache');
    $original = $build = DisplayPluginBase::buildBasicRenderable($view_random
      ->id(), 'default');
    $result = $renderer
      ->renderPlain($build);
    $original['#cache'] += [
      'contexts' => [],
    ];
    $original['#cache']['contexts'] = Cache::mergeContexts($original['#cache']['contexts'], $this->container
      ->getParameter('renderer.config')['required_cache_contexts']);
    $this
      ->assertFalse($render_cache
      ->get($original), 'Ensure there is no render cache entry.');
    $build = DisplayPluginBase::buildBasicRenderable($view_random
      ->id(), 'default');
    $result2 = $renderer
      ->renderPlain($build);

    // Ensure that the random ordering works and don't produce the same result.
    $this
      ->assertNotEquals($result, $result2);
  }

}

Classes

Namesort descending Description
SortRandomTest Tests for core Drupal\views\Plugin\views\sort\Random handler.