Fix sorting error when type is different

There was a logical flaw where we compared types
that were different causing a TypeError.

There was also a flaw in that we default to the
name of the action when sorting if the key does
not exist, to compare the data both value should
come from the same key as well otherwise they
should be treated as not equal since the data
cannot be.

Change-Id: Idcb276912582bb097dc5c1c9692facde63d5886b
This commit is contained in:
Tobias Urdin 2023-01-13 10:36:32 +00:00 committed by Arnaud Morin
parent c77a51a05a
commit b6a47992e7
2 changed files with 21 additions and 6 deletions

View File

@ -330,8 +330,8 @@ class ActionsController(rest.RestController, hooks.HookController):
def action_descriptor_sort(a_ds, keys, dirs): def action_descriptor_sort(a_ds, keys, dirs):
def compare_(a_d1, a_d2): def compare_(a_d1, a_d2):
for key, dir in zip(keys, dirs): for key, dir in zip(keys, dirs):
a_d1 = getattr(a_d1, key, a_d1.name) a_d1 = getattr(a_d1, key, None)
a_d2 = getattr(a_d2, key, a_d2.name) a_d2 = getattr(a_d2, key, None)
if a_d1 is None and a_d2 is None: if a_d1 is None and a_d2 is None:
ret = 0 ret = 0
@ -340,7 +340,10 @@ class ActionsController(rest.RestController, hooks.HookController):
elif a_d1 is not None and a_d2 is None: elif a_d1 is not None and a_d2 is None:
ret = 1 ret = 1
else: else:
if type(a_d1) is type(a_d2):
ret = (a_d1 > a_d2) - (a_d1 < a_d2) ret = (a_d1 > a_d2) - (a_d1 < a_d2)
else:
ret = 1
if ret: if ret:
return ret * (1 if dir == 'asc' else -1) return ret * (1 if dir == 'asc' else -1)
return 0 return 0

View File

@ -452,7 +452,8 @@ class TestActionsController(base.APITest):
# Create an adhoc action for the purpose of the test. # Create an adhoc action for the purpose of the test.
adhoc_actions.create_actions(ADHOC_ACTION_YAML) adhoc_actions.create_actions(ADHOC_ACTION_YAML)
resp = self.app.get('/v2/actions?limit=1&sort_keys=id,name') resp = self.app.get(
'/v2/actions?limit=1&sort_keys=created_at&sort_dirs=desc')
self.assertEqual(200, resp.status_int) self.assertEqual(200, resp.status_int)
self.assertIn('next', resp.json) self.assertIn('next', resp.json)
@ -472,14 +473,25 @@ class TestActionsController(base.APITest):
expected_dict = { expected_dict = {
'marker': action_def.id, 'marker': action_def.id,
'limit': 1, 'limit': 1,
'sort_keys': 'id,name', 'sort_keys': 'created_at,id',
'sort_dirs': 'asc,asc' 'sort_dirs': 'desc,asc'
} }
self.assertTrue( self.assertTrue(
set(expected_dict.items()).issubset(set(param_dict.items())) set(expected_dict.items()).issubset(set(param_dict.items()))
) )
def test_get_all_sort_date_asc(self):
adhoc_actions.create_actions(ADHOC_ACTION_YAML)
resp = self.app.get('/v2/actions?sort_keys=created_at&sort_dirs=asc')
self.assertEqual(200, resp.status_int)
def test_get_all_sort_date_desc(self):
adhoc_actions.create_actions(ADHOC_ACTION_YAML_A)
adhoc_actions.create_actions(ADHOC_ACTION_YAML_B)
resp = self.app.get('/v2/actions?sort_keys=created_at&sort_dirs=desc')
self.assertEqual(200, resp.status_int)
def test_get_all_pagination_marker(self): def test_get_all_pagination_marker(self):
adhoc_actions.create_actions(ADHOC_ACTION_YAML_B) adhoc_actions.create_actions(ADHOC_ACTION_YAML_B)
adhoc_actions.create_actions(ADHOC_ACTION_YAML_A) adhoc_actions.create_actions(ADHOC_ACTION_YAML_A)