From ce95ab8f025cc9f35990f0c2d9a290eec1ece753 Mon Sep 17 00:00:00 2001 From: Moayad Mardini Date: Fri, 25 Jul 2014 11:04:58 +0300 Subject: [PATCH] [1.7.x] Fixed #23088 -- Used `six` `range` type in `Paginator.page_range`. Backport of 6508db2ff9 from master --- django/core/paginator.py | 2 +- tests/pagination/tests.py | 7 +++++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/django/core/paginator.py b/django/core/paginator.py index c8b9377856..75292236fa 100644 --- a/django/core/paginator.py +++ b/django/core/paginator.py @@ -96,7 +96,7 @@ class Paginator(object): Returns a 1-based range of pages for iterating through within a template for loop. """ - return range(1, self.num_pages + 1) + return six.moves.range(1, self.num_pages + 1) page_range = property(_get_page_range) diff --git a/tests/pagination/tests.py b/tests/pagination/tests.py index c2ad54c5ad..3ff1306045 100644 --- a/tests/pagination/tests.py +++ b/tests/pagination/tests.py @@ -232,6 +232,13 @@ class PaginationTests(unittest.TestCase): self.assertEqual(page2.previous_page_number(), 1) self.assertIsNone(page2.next_page_number()) + def test_page_range_type(self): + """ + Ticket #23088: Paginator.page_range is of inconsistent type in Py2/Py3 + """ + paginator = Paginator([1, 2, 3], 2) + self.assertEqual(type(paginator.page_range), six.moves.range) + class ModelPaginationTests(TestCase): """