]> git.immae.eu Git - github/wallabag/wallabag.git/commitdiff
Restore old behavior for OutOfRangeCurrentPageException
authorNicolas Lœuillet <nicolas@loeuillet.org>
Tue, 12 Apr 2016 14:40:18 +0000 (16:40 +0200)
committerNicolas Lœuillet <nicolas@loeuillet.org>
Tue, 12 Apr 2016 14:40:18 +0000 (16:40 +0200)
src/Wallabag/CoreBundle/Controller/EntryController.php
src/Wallabag/CoreBundle/Tests/Controller/EntryControllerTest.php

index e60777070aa782bdff707e3f246d03ba96fcccb7..cba58858a16f68d868b5f09e8604e1c41cf4de3f 100644 (file)
@@ -3,6 +3,7 @@
 namespace Wallabag\CoreBundle\Controller;
 
 use Pagerfanta\Adapter\DoctrineORMAdapter;
+use Pagerfanta\Exception\OutOfRangeCurrentPageException;
 use Pagerfanta\Pagerfanta;
 use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
 use Symfony\Bundle\FrameworkBundle\Controller\Controller;
@@ -252,7 +253,13 @@ class EntryController extends Controller
         $entries = new Pagerfanta($pagerAdapter);
 
         $entries->setMaxPerPage($this->getUser()->getConfig()->getItemsPerPage());
-        $entries->setCurrentPage($page);
+        try {
+            $entries->setCurrentPage($page);
+        } catch (OutOfRangeCurrentPageException $e) {
+            if ($page > 1) {
+                return $this->redirect($this->generateUrl($type, array('page' => $entries->getNbPages())), 302);
+            }
+        }
 
         return $this->render(
             'WallabagCoreBundle:Entry:entries.html.twig',
index 2d846454a1f98988fedc67d5b8e5db0f45dd7686..a35278980cd7620d41ba408b85a44def43aa73c0 100644 (file)
@@ -225,7 +225,8 @@ class EntryControllerTest extends WallabagCoreTestCase
 
         $client->request('GET', '/all/list/900');
 
-        $this->assertEquals(404, $client->getResponse()->getStatusCode());
+        $this->assertEquals(302, $client->getResponse()->getStatusCode());
+        $this->assertEquals('/all/list', $client->getResponse()->getTargetUrl());
     }
 
     /**