Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Fixed #13689 -- Convert the per_page value to an integer upon initial…

…ization of the Paginator class to prevent unpleasant TypeErrors. Thanks, rbanffy, Eric Florenzano and Claude Paroz.

git-svn-id: http://code.djangoproject.com/svn/django/trunk@16073 bcc190cf-cafb-0310-a4f2-bffc1f526a37
  • Loading branch information...
commit 0e9692bc66ed7cfbbcb4c8031b36e82751685238 1 parent e744fec
@jezdez jezdez authored
View
4 django/core/paginator.py
@@ -13,8 +13,8 @@ class EmptyPage(InvalidPage):
class Paginator(object):
def __init__(self, object_list, per_page, orphans=0, allow_empty_first_page=True):
self.object_list = object_list
- self.per_page = per_page
- self.orphans = orphans
+ self.per_page = int(per_page)
+ self.orphans = int(orphans)
self.allow_empty_first_page = allow_empty_first_page
self._num_pages = self._count = None
View
5 tests/regressiontests/pagination_regress/tests.py
@@ -94,6 +94,11 @@ def test_paginator(self):
(([1, 2], 1, 1, True), (2, 1, [1])),
(([1, 2, 3], 2, 1, True), (3, 1, [1])),
((eleven, 10, 1, True), (11, 1, [1])),
+ # Non-integer inputs
+ ((ten, '4', 1, False), (10, 3, [1, 2, 3])),
+ ((ten, u'4', 1, False), (10, 3, [1, 2, 3])),
+ ((ten, 4, '1', False), (10, 3, [1, 2, 3])),
+ ((ten, 4, u'1', False), (10, 3, [1, 2, 3])),
)
for params, output in tests:
self.check_paginator(params, output)
Please sign in to comment.
Something went wrong with that request. Please try again.