Use a dataProvider to test both TreeWalker and SqlWalker pagination
This commit is contained in:
parent
d2501a9e4a
commit
2f817b30c3
@ -24,23 +24,29 @@ class PaginationTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
$this->populate();
|
$this->populate();
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testCountSimpleWithoutJoin()
|
/**
|
||||||
|
* @dataProvider useSqlWalkers
|
||||||
|
*/
|
||||||
|
public function testCountSimpleWithoutJoin($useSqlWalkers)
|
||||||
{
|
{
|
||||||
$dql = "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u";
|
$dql = "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u";
|
||||||
$query = $this->_em->createQuery($dql);
|
$query = $this->_em->createQuery($dql);
|
||||||
|
|
||||||
$paginator = new Paginator($query);
|
$paginator = new Paginator($query);
|
||||||
$paginator->setUseSqlWalkers(false);
|
$paginator->setUseSqlWalkers($useSqlWalkers);
|
||||||
$this->assertEquals(3, count($paginator));
|
$this->assertEquals(3, count($paginator));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testCountWithFetchJoin()
|
/**
|
||||||
|
* @dataProvider useSqlWalkers
|
||||||
|
*/
|
||||||
|
public function testCountWithFetchJoin($useSqlWalkers)
|
||||||
{
|
{
|
||||||
$dql = "SELECT u,g FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.groups g";
|
$dql = "SELECT u,g FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.groups g";
|
||||||
$query = $this->_em->createQuery($dql);
|
$query = $this->_em->createQuery($dql);
|
||||||
|
|
||||||
$paginator = new Paginator($query);
|
$paginator = new Paginator($query);
|
||||||
$paginator->setUseSqlWalkers(false);
|
$paginator->setUseSqlWalkers($useSqlWalkers);
|
||||||
$this->assertEquals(3, count($paginator));
|
$this->assertEquals(3, count($paginator));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -54,13 +60,16 @@ class PaginationTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
$this->assertEquals(9, count($paginator));
|
$this->assertEquals(9, count($paginator));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testIterateSimpleWithoutJoinFetchJoinHandlingOff()
|
/**
|
||||||
|
* @dataProvider useSqlWalkers
|
||||||
|
*/
|
||||||
|
public function testIterateSimpleWithoutJoinFetchJoinHandlingOff($useSqlWalkers)
|
||||||
{
|
{
|
||||||
$dql = "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u";
|
$dql = "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u";
|
||||||
$query = $this->_em->createQuery($dql);
|
$query = $this->_em->createQuery($dql);
|
||||||
|
|
||||||
$paginator = new Paginator($query, false);
|
$paginator = new Paginator($query, false);
|
||||||
$paginator->setUseSqlWalkers(false);
|
$paginator->setUseSqlWalkers($useSqlWalkers);
|
||||||
|
|
||||||
$data = array();
|
$data = array();
|
||||||
foreach ($paginator as $user) {
|
foreach ($paginator as $user) {
|
||||||
@ -69,13 +78,16 @@ class PaginationTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
$this->assertEquals(3, count($data));
|
$this->assertEquals(3, count($data));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testIterateSimpleWithoutJoinFetchJoinHandlingOn()
|
/**
|
||||||
|
* @dataProvider useSqlWalkers
|
||||||
|
*/
|
||||||
|
public function testIterateSimpleWithoutJoinFetchJoinHandlingOn($useSqlWalkers)
|
||||||
{
|
{
|
||||||
$dql = "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u";
|
$dql = "SELECT u FROM Doctrine\Tests\Models\CMS\CmsUser u";
|
||||||
$query = $this->_em->createQuery($dql);
|
$query = $this->_em->createQuery($dql);
|
||||||
|
|
||||||
$paginator = new Paginator($query, true);
|
$paginator = new Paginator($query, true);
|
||||||
$paginator->setUseSqlWalkers(false);
|
$paginator->setUseSqlWalkers($useSqlWalkers);
|
||||||
|
|
||||||
$data = array();
|
$data = array();
|
||||||
foreach ($paginator as $user) {
|
foreach ($paginator as $user) {
|
||||||
@ -84,13 +96,16 @@ class PaginationTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
$this->assertEquals(3, count($data));
|
$this->assertEquals(3, count($data));
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testIterateWithFetchJoin()
|
/**
|
||||||
|
* @dataProvider useSqlWalkers
|
||||||
|
*/
|
||||||
|
public function testIterateWithFetchJoin($useSqlWalkers)
|
||||||
{
|
{
|
||||||
$dql = "SELECT u,g FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.groups g";
|
$dql = "SELECT u,g FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.groups g";
|
||||||
$query = $this->_em->createQuery($dql);
|
$query = $this->_em->createQuery($dql);
|
||||||
|
|
||||||
$paginator = new Paginator($query, true);
|
$paginator = new Paginator($query, true);
|
||||||
$paginator->setUseSqlWalkers(false);
|
$paginator->setUseSqlWalkers($useSqlWalkers);
|
||||||
|
|
||||||
$data = array();
|
$data = array();
|
||||||
foreach ($paginator as $user) {
|
foreach ($paginator as $user) {
|
||||||
@ -151,4 +166,12 @@ class PaginationTest extends \Doctrine\Tests\OrmFunctionalTestCase
|
|||||||
}
|
}
|
||||||
$this->_em->flush();
|
$this->_em->flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function useSqlWalkers()
|
||||||
|
{
|
||||||
|
return array(
|
||||||
|
array(true),
|
||||||
|
array(false),
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user