1
0
mirror of synced 2025-01-18 22:41:43 +03:00

Use a dataProvider to test both TreeWalker and SqlWalker pagination

This commit is contained in:
Sander Marechal 2012-03-07 08:52:00 +01:00
parent d2501a9e4a
commit 2f817b30c3

View File

@ -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),
);
}
} }