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:
parent
c77a51a05a
commit
b6a47992e7
@ -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
|
||||||
|
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user