mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
MNT Add more test coverage to DataList::limit()
This commit is contained in:
parent
d1e0e1e305
commit
5090f49ecc
@ -121,34 +121,42 @@ class DataListTest extends SapphireTest
|
|||||||
$this->assertEquals(['Joe', 'Phil'], $list->limit(2, 1)->column('Name'));
|
$this->assertEquals(['Joe', 'Phil'], $list->limit(2, 1)->column('Name'));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testLimitAndOffset()
|
public function limitDataProvider(): array {
|
||||||
|
return [
|
||||||
|
'no limit' => [null, 0, 3],
|
||||||
|
'smaller limit' => [2, 0, 2],
|
||||||
|
'greater limit' => [4, 0, 3],
|
||||||
|
'one limit' => [1, 0, 1],
|
||||||
|
'zero limit' => [0, 0, 0],
|
||||||
|
'limit and offset' => [1, 1, 1],
|
||||||
|
'false limit equivalent to 0' => [false, 0, 0],
|
||||||
|
'offset only' => [null, 2, 1],
|
||||||
|
'offset greater than list length' => [null, 3, 0],
|
||||||
|
'negative length' => [-1, 0, 0, true],
|
||||||
|
'negative offset' => [0, -1, 0, true],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @dataProvider limitDataProvider
|
||||||
|
*/
|
||||||
|
public function testLimitAndOffset($length, $offset, $expectedCount, $expectException = false)
|
||||||
{
|
{
|
||||||
$list = TeamComment::get();
|
$list = TeamComment::get();
|
||||||
$check = $list->limit(3);
|
|
||||||
|
|
||||||
$this->assertEquals(3, $check->count());
|
if ($expectException) {
|
||||||
|
$this->expectException(\InvalidArgumentException::class);
|
||||||
|
}
|
||||||
|
|
||||||
$check = $list->limit(1);
|
$this->assertCount($expectedCount, $list->limit($length, $offset));
|
||||||
$this->assertEquals(1, $check->count());
|
$this->assertCount(
|
||||||
|
$expectedCount,
|
||||||
$check = $list->limit(1, 1);
|
$list->limit(0,9999)->limit($length, $offset),
|
||||||
$this->assertEquals(1, $check->count());
|
'Follow up limit calls unset previous ones'
|
||||||
|
);
|
||||||
$check = $list->limit(0);
|
|
||||||
$this->assertEquals(0, $check->count());
|
|
||||||
|
|
||||||
$check = $list->limit(false);
|
|
||||||
$this->assertEquals(0, $check->count());
|
|
||||||
|
|
||||||
$check = $list->limit(null);
|
|
||||||
$this->assertEquals(3, $check->count());
|
|
||||||
|
|
||||||
$check = $list->limit(null, 2);
|
|
||||||
$this->assertEquals(1, $check->count());
|
|
||||||
|
|
||||||
// count()/first()/last() methods may alter limit/offset, so run the query and manually check the count
|
// count()/first()/last() methods may alter limit/offset, so run the query and manually check the count
|
||||||
$check = $list->limit(null, 1)->toArray();
|
$this->assertCount($expectedCount, $list->limit($length, $offset)->toArray());
|
||||||
$this->assertEquals(2, count($check ?? []));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testDistinct()
|
public function testDistinct()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user