SortRandomTest.php
Same filename in other branches
Namespace
Drupal\Tests\views\Kernel\HandlerFile
-
core/
modules/ views/ tests/ src/ Kernel/ Handler/ SortRandomTest.php
View source
<?php
declare (strict_types=1);
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() : void {
// 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() : void {
$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->renderInIsolation($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->renderInIsolation($build);
// Ensure that the random ordering works and don't produce the same result.
// We use assertNotSame and cast values to strings since HTML tags are
// significant.
$this->assertNotSame((string) $result, (string) $result2);
}
}
Classes
Title | Deprecated | Summary |
---|---|---|
SortRandomTest | Tests for core Drupal\views\Plugin\views\sort\Random handler. |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.