Tests numeric ordering of the result set.
public function testDateOrdering() {
foreach (array(
'second',
'minute',
'hour',
'day',
'month',
'year',
) as $granularity) {
foreach (array(
FALSE,
TRUE,
) as $reverse) {
$view = views_get_view('test_view');
$view
->setDisplay();
// Change the fields.
$view->displayHandlers
->get('default')
->overrideOption('fields', array(
'name' => array(
'id' => 'name',
'table' => 'views_test_data',
'field' => 'name',
'relationship' => 'none',
),
'created' => array(
'id' => 'created',
'table' => 'views_test_data',
'field' => 'created',
'relationship' => 'none',
),
));
// Change the ordering
$view->displayHandlers
->get('default')
->overrideOption('sorts', array(
'created' => array(
'id' => 'created',
'table' => 'views_test_data',
'field' => 'created',
'relationship' => 'none',
'granularity' => $granularity,
'order' => $reverse ? 'DESC' : 'ASC',
),
'id' => array(
'id' => 'id',
'table' => 'views_test_data',
'field' => 'id',
'relationship' => 'none',
'order' => 'ASC',
),
));
// Execute the view.
$this
->executeView($view);
// Verify the result.
$this
->assertEqual(count($this
->dataSet()), count($view->result), t('The number of returned rows match.'));
$this
->assertIdenticalResultset($view, $this
->expectedResultSet($granularity, $reverse), array(
'views_test_data_name' => 'name',
), t('Result is returned correctly when ordering by granularity @granularity, @reverse.', array(
'@granularity' => $granularity,
'@reverse' => $reverse ? t('reverse') : t('forward'),
)));
$view
->destroy();
unset($view);
}
}
}