]> git.immae.eu Git - github/wallabag/wallabag.git/commitdiff
Fix #1551 - Redirect to the last page when current page is out of range 1700/head
authorMaxime LECLERCQ <maxime.leclercq@smile.fr>
Fri, 19 Feb 2016 13:22:27 +0000 (14:22 +0100)
committerMaxime LECLERCQ <maxime.leclercq@smile.fr>
Fri, 19 Feb 2016 15:02:31 +0000 (16:02 +0100)
src/Wallabag/CoreBundle/Controller/EntryController.php
src/Wallabag/CoreBundle/Tests/Controller/EntryControllerTest.php

index ea77d138125fb63127cd0d4e90a719493847d442..0fae3a0ff1d49687749a6cb802de2d5686a151cf 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 32d6a57537e253088ff6feb31badfaab8e29eea1..5512d6e1bd08f80860578226efa57d6c541bc412 100644 (file)
@@ -216,6 +216,17 @@ class EntryControllerTest extends WallabagCoreTestCase
         $this->assertEquals(200, $client->getResponse()->getStatusCode());
     }
 
+    public function testRangeException()
+    {
+        $this->logInAs('admin');
+        $client = $this->getClient();
+
+        $client->request('GET', '/all/list/900');
+
+        $this->assertEquals(302, $client->getResponse()->getStatusCode());
+        $this->assertEquals('/all/list', $client->getResponse()->getTargetUrl());
+    }
+
     /**
      * @depends testPostNewOk
      */