3 namespace Doctrine\Tests\ORM\Functional\Ticket;
5 use Doctrine\Tests\Models\CMS\CmsUser;
6 use Doctrine\Tests\Models\CMS\CmsGroup;
7 use Doctrine\ORM\Tools\Pagination\Paginator;
12 class DDC1918Test extends \Doctrine\Tests\OrmFunctionalTestCase
14 protected function setUp()
16 $this->useModelSet('cms');
20 public function testLastPageCorrect()
23 for ($i = 0; $i < 3; $i++) {
24 $group = new CmsGroup();
25 $group->name = "test";
26 $this->_em->persist($group);
31 for ($i = 0; $i < 10; $i++) {
32 $user = new CmsUser();
33 $user->username = "user$i";
34 $user->name = "user$i";
35 $user->status = "active";
36 $user->groups = $groups;
38 $this->_em->persist($user);
43 $query = $this->_em->createQuery('SELECT u, g FROM Doctrine\Tests\Models\CMS\CmsUser u JOIN u.groups g');
44 $query->setFirstResult(6);
45 $query->setMaxResults(3);
47 $paginator = new Paginator($query, true);
48 $this->assertEquals(3, count(iterator_to_array($paginator)));
50 $query->setFirstResult(8);
51 $query->setMaxResults(3);
53 $paginator = new Paginator($query, true);
54 $this->assertEquals(2, count(iterator_to_array($paginator)));
56 $query->setFirstResult(10);
57 $query->setMaxResults(3);
59 $paginator = new Paginator($query, true);
60 $this->assertEquals(0, count(iterator_to_array($paginator)));