diff options
| author | Tom Christie | 2012-02-07 03:14:08 -0800 |
|---|---|---|
| committer | Tom Christie | 2012-02-07 03:14:08 -0800 |
| commit | 5b7c8658bada462996c23bd618add39d963e859f (patch) | |
| tree | 3061d8760cb92139a8867eace3b7860ecd838b37 | |
| parent | 0f49f9b2b5c4e36c6edbb9b135e5653bdec46ce2 (diff) | |
| parent | 76a7d35813b637bb199a0d388468f9265f8adaf2 (diff) | |
| download | django-rest-framework-5b7c8658bada462996c23bd618add39d963e859f.tar.bz2 | |
Merge pull request #156 from j4mie/duplicate-page-param
Ensure duplicate "page" parameters are not created
| -rw-r--r-- | djangorestframework/mixins.py | 2 | ||||
| -rw-r--r-- | djangorestframework/tests/mixins.py | 9 |
2 files changed, 10 insertions, 1 deletions
diff --git a/djangorestframework/mixins.py b/djangorestframework/mixins.py index f4a9c998..836c3a59 100644 --- a/djangorestframework/mixins.py +++ b/djangorestframework/mixins.py @@ -679,7 +679,7 @@ class PaginatorMixin(object): Constructs a url used for getting the next/previous urls """ url = URLObject.parse(self.request.get_full_path()) - url = url.add_query_param('page', page_number) + url = url.set_query_param('page', page_number) limit = self.get_limit() if limit != self.limit: diff --git a/djangorestframework/tests/mixins.py b/djangorestframework/tests/mixins.py index a7512efc..8268fdca 100644 --- a/djangorestframework/tests/mixins.py +++ b/djangorestframework/tests/mixins.py @@ -280,3 +280,12 @@ class TestPagination(TestCase): self.assertTrue('foo=bar' in content['next']) self.assertTrue('another=something' in content['next']) self.assertTrue('page=2' in content['next']) + + def test_duplicate_parameters_are_not_created(self): + """ Regression: ensure duplicate "page" parameters are not added to + paginated URLs. So page 1 should contain ?page=2, not ?page=1&page=2 """ + request = self.req.get('/paginator/?page=1') + response = MockPaginatorView.as_view()(request) + content = json.loads(response.content) + self.assertTrue('page=2' in content['next']) + self.assertFalse('page=1' in content['next']) |
