class SortTest in Drupal 10
Same name in this branch
- 10 core/tests/Drupal/Tests/PhpCs/SortTest.php \Drupal\Tests\PhpCs\SortTest
- 10 core/modules/views/tests/src/Kernel/Handler/SortTest.php \Drupal\Tests\views\Kernel\Handler\SortTest
- 10 core/modules/jsonapi/tests/src/Unit/Query/SortTest.php \Drupal\Tests\jsonapi\Unit\Query\SortTest
Same name and namespace in other branches
- 8 core/modules/views/tests/src/Kernel/Handler/SortTest.php \Drupal\Tests\views\Kernel\Handler\SortTest
- 9 core/modules/views/tests/src/Kernel/Handler/SortTest.php \Drupal\Tests\views\Kernel\Handler\SortTest
Tests for core Drupal\views\Plugin\views\sort\SortPluginBase handler.
@group views
Hierarchy
- class \Drupal\Tests\views\Kernel\Handler\SortTest extends \Drupal\Tests\views\Kernel\ViewsKernelTestBase
Expanded class hierarchy of SortTest
File
- core/
modules/ views/ tests/ src/ Kernel/ Handler/ SortTest.php, line 13
Namespace
Drupal\Tests\views\Kernel\HandlerView source
class SortTest extends ViewsKernelTestBase {
/**
* Views used by this test.
*
* @var array
*/
public static $testViews = [
'test_view',
];
/**
* Tests numeric ordering of the result set.
*/
public function testNumericOrdering() {
$view = Views::getView('test_view');
$view
->setDisplay();
// Change the ordering
$view->displayHandlers
->get('default')
->overrideOption('sorts', [
'age' => [
'order' => 'ASC',
'id' => 'age',
'table' => 'views_test_data',
'field' => 'age',
'relationship' => 'none',
],
]);
// Execute the view.
$this
->executeView($view);
// Verify the result.
$this
->assertSameSize($this
->dataSet(), $view->result, 'The number of returned rows match.');
$this
->assertIdenticalResultset($view, $this
->orderResultSet($this
->dataSet(), 'age'), [
'views_test_data_name' => 'name',
'views_test_data_age' => 'age',
]);
$view
->destroy();
$view
->setDisplay();
// Reverse the ordering
$view->displayHandlers
->get('default')
->overrideOption('sorts', [
'age' => [
'order' => 'DESC',
'id' => 'age',
'table' => 'views_test_data',
'field' => 'age',
'relationship' => 'none',
],
]);
// Execute the view.
$this
->executeView($view);
// Verify the result.
$this
->assertSameSize($this
->dataSet(), $view->result, 'The number of returned rows match.');
$this
->assertIdenticalResultset($view, $this
->orderResultSet($this
->dataSet(), 'age', TRUE), [
'views_test_data_name' => 'name',
'views_test_data_age' => 'age',
]);
}
/**
* Tests string ordering of the result set.
*/
public function testStringOrdering() {
$view = Views::getView('test_view');
$view
->setDisplay();
// Change the ordering
$view->displayHandlers
->get('default')
->overrideOption('sorts', [
'name' => [
'order' => 'ASC',
'id' => 'name',
'table' => 'views_test_data',
'field' => 'name',
'relationship' => 'none',
],
]);
// Execute the view.
$this
->executeView($view);
// Verify the result.
$this
->assertSameSize($this
->dataSet(), $view->result, 'The number of returned rows match.');
$this
->assertIdenticalResultset($view, $this
->orderResultSet($this
->dataSet(), 'name'), [
'views_test_data_name' => 'name',
'views_test_data_age' => 'age',
]);
$view
->destroy();
$view
->setDisplay();
// Reverse the ordering
$view->displayHandlers
->get('default')
->overrideOption('sorts', [
'name' => [
'order' => 'DESC',
'id' => 'name',
'table' => 'views_test_data',
'field' => 'name',
'relationship' => 'none',
],
]);
// Execute the view.
$this
->executeView($view);
// Verify the result.
$this
->assertSameSize($this
->dataSet(), $view->result, 'The number of returned rows match.');
$this
->assertIdenticalResultset($view, $this
->orderResultSet($this
->dataSet(), 'name', TRUE), [
'views_test_data_name' => 'name',
'views_test_data_age' => 'age',
]);
}
}