mirror of
https://github.com/netbox-community/netbox.git
synced 2025-12-09 01:49:35 -06:00
Merge pull request #20528 from netbox-community/02496-max-page
Some checks are pending
CI / build (20.x, 3.10) (push) Waiting to run
CI / build (20.x, 3.12) (push) Waiting to run
CodeQL / Analyze (${{ matrix.language }}) (none, actions) (push) Waiting to run
CodeQL / Analyze (${{ matrix.language }}) (none, python) (push) Waiting to run
CI / build (20.x, 3.11) (push) Waiting to run
CodeQL / Analyze (${{ matrix.language }}) (none, javascript-typescript) (push) Waiting to run
Some checks are pending
CI / build (20.x, 3.10) (push) Waiting to run
CI / build (20.x, 3.12) (push) Waiting to run
CodeQL / Analyze (${{ matrix.language }}) (none, actions) (push) Waiting to run
CodeQL / Analyze (${{ matrix.language }}) (none, python) (push) Waiting to run
CI / build (20.x, 3.11) (push) Waiting to run
CodeQL / Analyze (${{ matrix.language }}) (none, javascript-typescript) (push) Waiting to run
20496 make max_page_size upper bound
This commit is contained in:
commit
f8c074045f
@ -44,22 +44,28 @@ class OptionalLimitOffsetPagination(LimitOffsetPagination):
|
|||||||
return list(queryset[self.offset:])
|
return list(queryset[self.offset:])
|
||||||
|
|
||||||
def get_limit(self, request):
|
def get_limit(self, request):
|
||||||
|
max_limit = self.default_limit
|
||||||
|
MAX_PAGE_SIZE = get_config().MAX_PAGE_SIZE
|
||||||
|
if MAX_PAGE_SIZE:
|
||||||
|
max_limit = min(max_limit, MAX_PAGE_SIZE)
|
||||||
|
|
||||||
if self.limit_query_param:
|
if self.limit_query_param:
|
||||||
MAX_PAGE_SIZE = get_config().MAX_PAGE_SIZE
|
|
||||||
if MAX_PAGE_SIZE:
|
|
||||||
MAX_PAGE_SIZE = max(MAX_PAGE_SIZE, self.default_limit)
|
|
||||||
try:
|
try:
|
||||||
limit = int(request.query_params[self.limit_query_param])
|
limit = int(request.query_params[self.limit_query_param])
|
||||||
if limit < 0:
|
if limit < 0:
|
||||||
raise ValueError()
|
raise ValueError()
|
||||||
# Enforce maximum page size, if defined
|
|
||||||
if MAX_PAGE_SIZE:
|
if MAX_PAGE_SIZE:
|
||||||
return MAX_PAGE_SIZE if limit == 0 else min(limit, MAX_PAGE_SIZE)
|
if limit == 0:
|
||||||
return limit
|
max_limit = MAX_PAGE_SIZE
|
||||||
|
else:
|
||||||
|
max_limit = min(MAX_PAGE_SIZE, limit)
|
||||||
|
else:
|
||||||
|
max_limit = limit
|
||||||
except (KeyError, ValueError):
|
except (KeyError, ValueError):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
return self.default_limit
|
return max_limit
|
||||||
|
|
||||||
def get_queryset_count(self, queryset):
|
def get_queryset_count(self, queryset):
|
||||||
return queryset.count()
|
return queryset.count()
|
||||||
|
|||||||
@ -149,14 +149,13 @@ class APIPaginationTestCase(APITestCase):
|
|||||||
def test_default_page_size_with_small_max_page_size(self):
|
def test_default_page_size_with_small_max_page_size(self):
|
||||||
response = self.client.get(self.url, format='json', **self.header)
|
response = self.client.get(self.url, format='json', **self.header)
|
||||||
page_size = get_config().MAX_PAGE_SIZE
|
page_size = get_config().MAX_PAGE_SIZE
|
||||||
paginate_count = get_config().PAGINATE_COUNT
|
|
||||||
self.assertLess(page_size, 100, "Default page size not sufficient for data set")
|
self.assertLess(page_size, 100, "Default page size not sufficient for data set")
|
||||||
|
|
||||||
self.assertHttpStatus(response, status.HTTP_200_OK)
|
self.assertHttpStatus(response, status.HTTP_200_OK)
|
||||||
self.assertEqual(response.data['count'], 100)
|
self.assertEqual(response.data['count'], 100)
|
||||||
self.assertTrue(response.data['next'].endswith(f'?limit={paginate_count}&offset={paginate_count}'))
|
self.assertTrue(response.data['next'].endswith(f'?limit={page_size}&offset={page_size}'))
|
||||||
self.assertIsNone(response.data['previous'])
|
self.assertIsNone(response.data['previous'])
|
||||||
self.assertEqual(len(response.data['results']), paginate_count)
|
self.assertEqual(len(response.data['results']), page_size)
|
||||||
|
|
||||||
def test_custom_page_size(self):
|
def test_custom_page_size(self):
|
||||||
response = self.client.get(f'{self.url}?limit=10', format='json', **self.header)
|
response = self.client.get(f'{self.url}?limit=10', format='json', **self.header)
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user