1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
|
<?php
declare(strict_types=1);
namespace Doctrine\Tests\ORM\Functional\Ticket;
use Doctrine\ORM\Tools\Pagination\Paginator;
use Doctrine\Tests\Models\CMS\CmsGroup;
use Doctrine\Tests\Models\CMS\CmsUser;
use Doctrine\Tests\OrmFunctionalTestCase;
use PHPUnit\Framework\Attributes\Group;
use function iterator_to_array;
#[Group('DDC-1918')]
class DDC1918Test extends OrmFunctionalTestCase
{
protected function setUp(): void
{
$this->useModelSet('cms');
parent::setUp();
}
public function testLastPageCorrect(): void
{
$groups = [];
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);
self::assertCount(3, iterator_to_array($paginator));
$query->setFirstResult(8);
$query->setMaxResults(3);
$paginator = new Paginator($query, true);
self::assertCount(2, iterator_to_array($paginator));
$query->setFirstResult(10);
$query->setMaxResults(3);
$paginator = new Paginator($query, true);
self::assertCount(0, iterator_to_array($paginator));
}
}
|