[DDC-1918] Fix weird results at the end of paginator when using fetch joins
This commit is contained in:
parent
9c682efb2f
commit
bc2476f342
@ -174,16 +174,18 @@ class Paginator implements \Countable, \IteratorAggregate
|
|||||||
|
|
||||||
$whereInQuery = $this->cloneQuery($this->query);
|
$whereInQuery = $this->cloneQuery($this->query);
|
||||||
// don't do this for an empty id array
|
// don't do this for an empty id array
|
||||||
if (count($ids) > 0) {
|
if (count($ids) == 0) {
|
||||||
$namespace = WhereInWalker::PAGINATOR_ID_ALIAS;
|
return new \ArrayIterator(array());
|
||||||
|
}
|
||||||
|
|
||||||
$whereInQuery->setHint(Query::HINT_CUSTOM_TREE_WALKERS, array('Doctrine\ORM\Tools\Pagination\WhereInWalker'));
|
$namespace = WhereInWalker::PAGINATOR_ID_ALIAS;
|
||||||
$whereInQuery->setHint(WhereInWalker::HINT_PAGINATOR_ID_COUNT, count($ids));
|
|
||||||
$whereInQuery->setFirstResult(null)->setMaxResults(null);
|
$whereInQuery->setHint(Query::HINT_CUSTOM_TREE_WALKERS, array('Doctrine\ORM\Tools\Pagination\WhereInWalker'));
|
||||||
foreach ($ids as $i => $id) {
|
$whereInQuery->setHint(WhereInWalker::HINT_PAGINATOR_ID_COUNT, count($ids));
|
||||||
$i++;
|
$whereInQuery->setFirstResult(null)->setMaxResults(null);
|
||||||
$whereInQuery->setParameter("{$namespace}_{$i}", $id);
|
foreach ($ids as $i => $id) {
|
||||||
}
|
$i++;
|
||||||
|
$whereInQuery->setParameter("{$namespace}_{$i}", $id);
|
||||||
}
|
}
|
||||||
|
|
||||||
$result = $whereInQuery->getResult($this->query->getHydrationMode());
|
$result = $whereInQuery->getResult($this->query->getHydrationMode());
|
||||||
|
@ -5,8 +5,6 @@ namespace Doctrine\Tests\ORM\Functional\Ticket;
|
|||||||
use Doctrine\Tests\Models\Quote\Group;
|
use Doctrine\Tests\Models\Quote\Group;
|
||||||
use Doctrine\Tests\Models\Quote\User;
|
use Doctrine\Tests\Models\Quote\User;
|
||||||
|
|
||||||
require_once __DIR__ . '/../../../TestInit.php';
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @group DDC-1845
|
* @group DDC-1845
|
||||||
* @group DDC-1885
|
* @group DDC-1885
|
||||||
|
62
tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1918Test.php
Normal file
62
tests/Doctrine/Tests/ORM/Functional/Ticket/DDC1918Test.php
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Doctrine\Tests\ORM\Functional\Ticket;
|
||||||
|
|
||||||
|
use Doctrine\Tests\Models\CMS\CmsUser;
|
||||||
|
use Doctrine\Tests\Models\CMS\CmsGroup;
|
||||||
|
use Doctrine\ORM\Tools\Pagination\Paginator;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DDC-1918
|
||||||
|
*/
|
||||||
|
class DDC1918Test extends \Doctrine\Tests\OrmFunctionalTestCase
|
||||||
|
{
|
||||||
|
protected function setUp()
|
||||||
|
{
|
||||||
|
$this->useModelSet('cms');
|
||||||
|
parent::setUp();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testLastPageCorrect()
|
||||||
|
{
|
||||||
|
$groups = array();
|
||||||
|
for ($i = 0; $i < 3; $i++) {
|
||||||
|
$group = new CmsGroup();
|
||||||
|
$group->name = "test";
|
||||||
|
$this->_em->persist($group);
|
||||||
|
|
||||||
|
$groups[] = $group;
|
||||||
|
}
|
||||||
|
|
||||||
|
for ($i = 0; $i < 10; $i++) {
|
||||||
|
$user = new CmsUser();
|
||||||
|
$user->username = "user$i";
|
||||||
|
$user->name = "user$i";
|
||||||
|
$user->status = "active";
|
||||||
|
$user->groups = $groups;
|
||||||
|
|
||||||
|
$this->_em->persist($user);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->_em->flush();
|
||||||
|
|
||||||
|
$query = $this->_em->createQuery('SELECT u, g FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.groups g');
|
||||||
|
$query->setFirstResult(6);
|
||||||
|
$query->setMaxResults(3);
|
||||||
|
|
||||||
|
$paginator = new Paginator($query, true);
|
||||||
|
$this->assertEquals(3, count(iterator_to_array($paginator)));
|
||||||
|
|
||||||
|
$query->setFirstResult(8);
|
||||||
|
$query->setMaxResults(3);
|
||||||
|
|
||||||
|
$paginator = new Paginator($query, true);
|
||||||
|
$this->assertEquals(2, count(iterator_to_array($paginator)));
|
||||||
|
|
||||||
|
$query->setFirstResult(10);
|
||||||
|
$query->setMaxResults(3);
|
||||||
|
|
||||||
|
$paginator = new Paginator($query, true);
|
||||||
|
$this->assertEquals(0, count(iterator_to_array($paginator)));
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user