SimplePaginatorTest.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141
  1. <?php
  2. declare(strict_types=1);
  3. /**
  4. * CakePHP(tm) : Rapid Development Framework (https://cakephp.org)
  5. * Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  6. *
  7. * Licensed under The MIT License
  8. * For full copyright and license information, please see the LICENSE.txt
  9. * Redistributions of files must retain the above copyright notice
  10. *
  11. * @copyright Copyright (c) Cake Software Foundation, Inc. (https://cakefoundation.org)
  12. * @link https://cakephp.org CakePHP(tm) Project
  13. * @since 3.9.0
  14. * @license https://www.opensource.org/licenses/mit-license.php MIT License
  15. */
  16. namespace Cake\Test\TestCase\Datasource\Paging;
  17. use Cake\Core\Configure;
  18. use Cake\Datasource\Paging\SimplePaginator;
  19. use Cake\Datasource\RepositoryInterface;
  20. use Cake\ORM\Entity;
  21. class SimplePaginatorTest extends NumericPaginatorTest
  22. {
  23. public function setUp(): void
  24. {
  25. parent::setUp();
  26. Configure::write('App.namespace', 'TestApp');
  27. $this->Paginator = new class extends SimplePaginator {
  28. public function getDefaults(string $alias, array $settings): array
  29. {
  30. return parent::getDefaults($alias, $settings);
  31. }
  32. public function mergeOptions(array $params, array $settings): array
  33. {
  34. return parent::mergeOptions($params, $settings);
  35. }
  36. public function validateSort(RepositoryInterface $object, array $options): array
  37. {
  38. return parent::validateSort($object, $options);
  39. }
  40. public function checkLimit(array $options): array
  41. {
  42. return parent::checkLimit($options);
  43. }
  44. };
  45. }
  46. /**
  47. * test paginate() and custom find, to make sure the correct count is returned.
  48. */
  49. public function testPaginateCustomFind(): void
  50. {
  51. $titleExtractor = function ($result) {
  52. $ids = [];
  53. foreach ($result as $record) {
  54. $ids[] = $record->title;
  55. }
  56. return $ids;
  57. };
  58. $table = $this->getTableLocator()->get('PaginatorPosts');
  59. $data = ['author_id' => 3, 'title' => 'Fourth Post', 'body' => 'Article Body, unpublished', 'published' => 'N'];
  60. $result = $table->save(new Entity($data));
  61. $this->assertNotEmpty($result);
  62. $result = $this->Paginator->paginate($table);
  63. $this->assertCount(4, $result, '4 rows should come back');
  64. $this->assertEquals(['First Post', 'Second Post', 'Third Post', 'Fourth Post'], $titleExtractor($result));
  65. $pagingParams = $result->pagingParams();
  66. $this->assertSame(1, $pagingParams['currentPage']);
  67. $this->assertNull($pagingParams['totalCount']);
  68. $settings = ['finder' => 'published'];
  69. $result = $this->Paginator->paginate($table, [], $settings);
  70. $this->assertCount(3, $result, '3 rows should come back');
  71. $this->assertEquals(['First Post', 'Second Post', 'Third Post'], $titleExtractor($result));
  72. $pagingParams = $result->pagingParams();
  73. $this->assertSame(1, $pagingParams['currentPage']);
  74. $this->assertNull($pagingParams['totalCount']);
  75. $settings = ['finder' => 'published', 'limit' => 2, 'page' => 2];
  76. $result = $this->Paginator->paginate($table, [], $settings);
  77. $this->assertCount(1, $result, '1 rows should come back');
  78. $this->assertEquals(['Third Post'], $titleExtractor($result));
  79. $pagingParams = $result->pagingParams();
  80. $this->assertSame(2, $pagingParams['currentPage']);
  81. $this->assertNull($pagingParams['totalCount']);
  82. $this->assertNull($pagingParams['pageCount']);
  83. $settings = ['finder' => 'published', 'limit' => 2];
  84. $result = $this->Paginator->paginate($table, [], $settings);
  85. $this->assertCount(2, $result, '2 rows should come back');
  86. $this->assertEquals(['First Post', 'Second Post'], $titleExtractor($result));
  87. $pagingParams = $result->pagingParams();
  88. $this->assertSame(1, $pagingParams['currentPage']);
  89. $this->assertNull($pagingParams['totalCount']);
  90. $this->assertNull($pagingParams['pageCount']);
  91. $this->assertTrue($pagingParams['hasNextPage']);
  92. $this->assertFalse($pagingParams['hasPrevPage']);
  93. $this->assertSame(2, $pagingParams['perPage']);
  94. $this->assertNull($pagingParams['limit']);
  95. }
  96. /**
  97. * Test that special paginate types are called and that the type param doesn't leak out into defaults or options.
  98. */
  99. public function testPaginateCustomFinder(): void
  100. {
  101. $settings = [
  102. 'PaginatorPosts' => [
  103. 'finder' => 'published',
  104. 'maxLimit' => 10,
  105. ],
  106. ];
  107. $table = $this->getTableLocator()->get('PaginatorPosts');
  108. $this->assertSame(3, $table->find('published')->count());
  109. $table->updateAll(['published' => 'N'], ['id' => 2]);
  110. $result = $this->Paginator->paginate($table, [], $settings);
  111. $pagingParams = $result->pagingParams();
  112. $this->assertSame(1, $pagingParams['start']);
  113. $this->assertSame(2, $pagingParams['end']);
  114. $this->assertSame(2, count($result));
  115. $this->assertSame(2, $pagingParams['count']);
  116. $this->assertFalse($pagingParams['hasNextPage']);
  117. }
  118. }