Merge "Exclude build request marker from server listing"

This commit is contained in:
Zuul 2018-12-20 04:12:34 +00:00 committed by Gerrit Code Review
commit e4fc59d7e3
2 changed files with 15 additions and 9 deletions

View File

@ -445,7 +445,10 @@ class BuildRequestList(base.ObjectListBase, base.NovaObject):
if marker: if marker:
for i, build_req in enumerate(sorted_build_reqs): for i, build_req in enumerate(sorted_build_reqs):
if build_req.instance.uuid == marker: if build_req.instance.uuid == marker:
marker_index = i # The marker is the last seen item in the last page, so
# we increment the index to the next item immediately
# after the marker so the marker is not returned.
marker_index = i + 1
break break
else: else:
raise exception.MarkerNotFound(marker=marker) raise exception.MarkerNotFound(marker=marker)

View File

@ -520,11 +520,14 @@ class BuildRequestListTestCase(test.NoDBTestCase):
sort_dirs=['asc']) sort_dirs=['asc'])
self.assertIsInstance(req_list, objects.BuildRequestList) self.assertIsInstance(req_list, objects.BuildRequestList)
self.assertEqual(2, len(req_list)) self.assertEqual(1, len(req_list))
for i, req in enumerate(reqs[1:]): req = req_list[0]
self.assertEqual(req.instance_uuid, req_list[i].instance_uuid) expected_req = reqs[2]
objects.base.obj_equal_prims(req.instance, # The returned build request should be the last one in the reqs list
req_list[i].instance) # since the marker is the 2nd item in the list (of 3).
self.assertEqual(expected_req.instance_uuid, req.instance_uuid)
objects.base.obj_equal_prims(expected_req.instance,
req.instance)
def test_get_by_filters_marker_not_found(self): def test_get_by_filters_marker_not_found(self):
self._create_req() self._create_req()
@ -565,7 +568,7 @@ class BuildRequestListTestCase(test.NoDBTestCase):
self.assertIsInstance(req_list, objects.BuildRequestList) self.assertIsInstance(req_list, objects.BuildRequestList)
self.assertEqual(2, len(req_list)) self.assertEqual(2, len(req_list))
for i, req in enumerate(reqs[1:3]): for i, req in enumerate(reqs[2:]):
self.assertEqual(req.instance_uuid, req_list[i].instance_uuid) self.assertEqual(req.instance_uuid, req_list[i].instance_uuid)
objects.base.obj_equal_prims(req.instance, objects.base.obj_equal_prims(req.instance,
req_list[i].instance) req_list[i].instance)
@ -585,8 +588,8 @@ class BuildRequestListTestCase(test.NoDBTestCase):
sort_keys=['id'], sort_dirs=['asc']) sort_keys=['id'], sort_dirs=['asc'])
self.assertIsInstance(req_list, objects.BuildRequestList) self.assertIsInstance(req_list, objects.BuildRequestList)
self.assertEqual(3, len(req_list)) self.assertEqual(2, len(req_list))
for i, req in enumerate(reqs[1:]): for i, req in enumerate(reqs[2:]):
self.assertEqual(req.instance_uuid, req_list[i].instance_uuid) self.assertEqual(req.instance_uuid, req_list[i].instance_uuid)
objects.base.obj_equal_prims(req.instance, objects.base.obj_equal_prims(req.instance,
req_list[i].instance) req_list[i].instance)