| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167 |
- <?php
- /**
- * CakePHP(tm) : Rapid Development Framework (http://cakephp.org)
- * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
- *
- * Licensed under The MIT License
- * For full copyright and license information, please see the LICENSE.txt
- * Redistributions of files must retain the above copyright notice
- *
- * @copyright Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
- * @link http://cakephp.org CakePHP(tm) Project
- * @since 3.9.0
- * @license http://www.opensource.org/licenses/mit-license.php MIT License
- */
- namespace Cake\Test\TestCase\Datasource;
- use Cake\Core\Configure;
- use Cake\Datasource\SimplePaginator;
- use Cake\ORM\Entity;
- class SimplePaginatorTest extends PaginatorTest
- {
- /**
- * Don't load data for fixtures for all tests
- *
- * @var bool
- */
- public $autoFixtures = false;
- public function setUp()
- {
- parent::setUp();
- Configure::write('App.namespace', 'TestApp');
- $this->Paginator = new SimplePaginator();
- $this->Post = $this->getMockRepository();
- }
- /**
- * test paginate() and custom find, to make sure the correct count is returned.
- *
- * @return void
- */
- public function testPaginateCustomFind()
- {
- $this->loadFixtures('Posts');
- $titleExtractor = function ($result) {
- $ids = [];
- foreach ($result as $record) {
- $ids[] = $record->title;
- }
- return $ids;
- };
- $table = $this->getTableLocator()->get('PaginatorPosts');
- $data = ['author_id' => 3, 'title' => 'Fourth Post', 'body' => 'Article Body, unpublished', 'published' => 'N'];
- $result = $table->save(new Entity($data));
- $this->assertNotEmpty($result);
- $result = $this->Paginator->paginate($table);
- $this->assertCount(4, $result, '4 rows should come back');
- $this->assertEquals(['First Post', 'Second Post', 'Third Post', 'Fourth Post'], $titleExtractor($result));
- $pagingParams = $this->Paginator->getPagingParams();
- $this->assertEquals(4, $pagingParams['PaginatorPosts']['current']);
- $this->assertNull($pagingParams['PaginatorPosts']['count']);
- $settings = ['finder' => 'published'];
- $result = $this->Paginator->paginate($table, [], $settings);
- $this->assertCount(3, $result, '3 rows should come back');
- $this->assertEquals(['First Post', 'Second Post', 'Third Post'], $titleExtractor($result));
- $pagingParams = $this->Paginator->getPagingParams();
- $this->assertEquals(3, $pagingParams['PaginatorPosts']['current']);
- $this->assertNull($pagingParams['PaginatorPosts']['count']);
- $settings = ['finder' => 'published', 'limit' => 2, 'page' => 2];
- $result = $this->Paginator->paginate($table, [], $settings);
- $this->assertCount(1, $result, '1 rows should come back');
- $this->assertEquals(['Third Post'], $titleExtractor($result));
- $pagingParams = $this->Paginator->getPagingParams();
- $this->assertEquals(1, $pagingParams['PaginatorPosts']['current']);
- $this->assertNull($pagingParams['PaginatorPosts']['count']);
- $this->assertSame(0, $pagingParams['PaginatorPosts']['pageCount']);
- $settings = ['finder' => 'published', 'limit' => 2];
- $result = $this->Paginator->paginate($table, [], $settings);
- $this->assertCount(2, $result, '2 rows should come back');
- $this->assertEquals(['First Post', 'Second Post'], $titleExtractor($result));
- $pagingParams = $this->Paginator->getPagingParams();
- $this->assertEquals(2, $pagingParams['PaginatorPosts']['current']);
- $this->assertNull($pagingParams['PaginatorPosts']['count']);
- $this->assertEquals(0, $pagingParams['PaginatorPosts']['pageCount']);
- $this->assertTrue($pagingParams['PaginatorPosts']['nextPage']);
- $this->assertFalse($pagingParams['PaginatorPosts']['prevPage']);
- $this->assertEquals(2, $pagingParams['PaginatorPosts']['perPage']);
- $this->assertNull($pagingParams['PaginatorPosts']['limit']);
- }
- /**
- * test paginate() and custom find with fields array, to make sure the correct count is returned.
- *
- * @return void
- */
- public function testPaginateCustomFindFieldsArray()
- {
- $this->loadFixtures('Posts');
- $table = $this->getTableLocator()->get('PaginatorPosts');
- $data = ['author_id' => 3, 'title' => 'Fourth Article', 'body' => 'Article Body, unpublished', 'published' => 'N'];
- $table->save(new Entity($data));
- $settings = [
- 'finder' => 'list',
- 'conditions' => ['PaginatorPosts.published' => 'Y'],
- 'limit' => 2,
- ];
- $results = $this->Paginator->paginate($table, [], $settings);
- $result = $results->toArray();
- $expected = [
- 1 => 'First Post',
- 2 => 'Second Post',
- ];
- $this->assertEquals($expected, $result);
- $result = $this->Paginator->getPagingParams()['PaginatorPosts'];
- $this->assertEquals(2, $result['current']);
- $this->assertNull($result['count']);
- $this->assertEquals(0, $result['pageCount']);
- $this->assertTrue($result['nextPage']);
- $this->assertFalse($result['prevPage']);
- }
- /**
- * Test that special paginate types are called and that the type param doesn't leak out into defaults or options.
- *
- * @return void
- */
- public function testPaginateCustomFinder()
- {
- $settings = [
- 'PaginatorPosts' => [
- 'finder' => 'published',
- 'fields' => ['id', 'title'],
- 'maxLimit' => 10,
- ],
- ];
- $this->loadFixtures('Posts');
- $table = $this->getTableLocator()->get('PaginatorPosts');
- $table->updateAll(['published' => 'N'], ['id' => 2]);
- $this->Paginator->paginate($table, [], $settings);
- $pagingParams = $this->Paginator->getPagingParams();
- $this->assertSame('published', $pagingParams['PaginatorPosts']['finder']);
- $this->assertSame(1, $pagingParams['PaginatorPosts']['start']);
- $this->assertSame(2, $pagingParams['PaginatorPosts']['end']);
- // nextPage will be always true for SimplePaginator
- $this->assertTrue($pagingParams['PaginatorPosts']['nextPage']);
- }
- }
|