Fix in "vnflcm op list" CLI with exclude-fields
"vnflcm op list" with "--exclude-fields" is not excluding parameters from CLI result. Closes-Bug: 1953377 Change-Id: If47beccfbab4b85173bbe159905d0605e721cedd
This commit is contained in:
@@ -242,9 +242,12 @@ class ListVnfLcmOp(command.Lister):
|
|||||||
)
|
)
|
||||||
return parser
|
return parser
|
||||||
|
|
||||||
def get_attributes(self):
|
def get_attributes(self, exclude=None):
|
||||||
"""Get attributes.
|
"""Get attributes.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
exclude([exclude]): a list of fields which needs to exclude.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
attributes([attributes]): a list of table entry definitions.
|
attributes([attributes]): a list of table entry definitions.
|
||||||
Each entry should be a tuple consisting of
|
Each entry should be a tuple consisting of
|
||||||
@@ -270,10 +273,13 @@ class ListVnfLcmOp(command.Lister):
|
|||||||
]
|
]
|
||||||
|
|
||||||
attributes = []
|
attributes = []
|
||||||
|
if exclude is None:
|
||||||
|
exclude = []
|
||||||
|
|
||||||
for field in fields:
|
for field in fields:
|
||||||
|
if field['value'] not in exclude:
|
||||||
attributes.extend([(field['key'], field['value'],
|
attributes.extend([(field['key'], field['value'],
|
||||||
tacker_osc_utils.LIST_BOTH)])
|
tacker_osc_utils.LIST_BOTH)])
|
||||||
|
|
||||||
return tuple(attributes)
|
return tuple(attributes)
|
||||||
|
|
||||||
def take_action(self, parsed_args):
|
def take_action(self, parsed_args):
|
||||||
@@ -301,7 +307,7 @@ class ListVnfLcmOp(command.Lister):
|
|||||||
client = self.app.client_manager.tackerclient
|
client = self.app.client_manager.tackerclient
|
||||||
vnflcm_op_occs = client.list_vnf_lcm_op_occs(**params)
|
vnflcm_op_occs = client.list_vnf_lcm_op_occs(**params)
|
||||||
headers, columns = tacker_osc_utils.get_column_definitions(
|
headers, columns = tacker_osc_utils.get_column_definitions(
|
||||||
self.get_attributes(),
|
self.get_attributes(exclude=exclude_fields),
|
||||||
long_listing=True)
|
long_listing=True)
|
||||||
|
|
||||||
dictionary_properties = (utils.get_dict_properties(
|
dictionary_properties = (utils.get_dict_properties(
|
||||||
|
@@ -26,7 +26,7 @@ from tackerclient.tests.unit.osc.v1.fixture_data import client
|
|||||||
from tackerclient.tests.unit.osc.v1 import vnflcm_op_occs_fakes
|
from tackerclient.tests.unit.osc.v1 import vnflcm_op_occs_fakes
|
||||||
|
|
||||||
|
|
||||||
def _get_columns_vnflcm_op_occs(action='show'):
|
def _get_columns_vnflcm_op_occs(action='show', parameter=None):
|
||||||
|
|
||||||
if action == 'fail':
|
if action == 'fail':
|
||||||
return ['ID', 'Operation State', 'State Entered Time',
|
return ['ID', 'Operation State', 'State Entered Time',
|
||||||
@@ -34,6 +34,9 @@ def _get_columns_vnflcm_op_occs(action='show'):
|
|||||||
'Is Automatic Invocation', 'Is Cancel Pending',
|
'Is Automatic Invocation', 'Is Cancel Pending',
|
||||||
'Error', 'Links']
|
'Error', 'Links']
|
||||||
elif action == 'list':
|
elif action == 'list':
|
||||||
|
if parameter is not None:
|
||||||
|
return ['ID', 'Operation']
|
||||||
|
else:
|
||||||
return ['ID', 'Operation State', 'VNF Instance ID',
|
return ['ID', 'Operation State', 'VNF Instance ID',
|
||||||
'Operation']
|
'Operation']
|
||||||
else:
|
else:
|
||||||
@@ -496,6 +499,36 @@ class TestListVnfLcmOp(TestVnfLcm):
|
|||||||
self.list_vnflcm_op_occ.take_action,
|
self.list_vnflcm_op_occ.take_action,
|
||||||
parsed_args)
|
parsed_args)
|
||||||
|
|
||||||
|
def test_take_action_with_exclude_fields(self):
|
||||||
|
|
||||||
|
vnflcm_op_occs_obj = vnflcm_op_occs_fakes.create_vnflcm_op_occs(
|
||||||
|
count=3)
|
||||||
|
parsed_args = self.check_parser(
|
||||||
|
self.list_vnflcm_op_occ,
|
||||||
|
["--exclude-fields", 'VNF Instance ID,Operation State'],
|
||||||
|
[('exclude_fields', 'VNF Instance ID,Operation State')])
|
||||||
|
self.requests_mock.register_uri(
|
||||||
|
'GET', os.path.join(
|
||||||
|
self.url,
|
||||||
|
'vnflcm/v1/vnf_lcm_op_occs?'
|
||||||
|
'exclude-fields=VNF Instance ID,Operation State'),
|
||||||
|
json=vnflcm_op_occs_obj, headers=self.header)
|
||||||
|
actual_columns, data = self.list_vnflcm_op_occ.take_action(parsed_args)
|
||||||
|
headers, columns = tacker_osc_utils.get_column_definitions(
|
||||||
|
self.list_vnflcm_op_occ.get_attributes(
|
||||||
|
exclude=['VNF Instance ID', 'Operation State']),
|
||||||
|
long_listing=True)
|
||||||
|
expected_data = []
|
||||||
|
for vnflcm_op_occ_obj_idx in vnflcm_op_occs_obj:
|
||||||
|
expected_data.append(
|
||||||
|
vnflcm_op_occs_fakes.get_vnflcm_op_occ_data(
|
||||||
|
vnflcm_op_occ_obj_idx, columns=columns))
|
||||||
|
|
||||||
|
self.assertCountEqual(_get_columns_vnflcm_op_occs(
|
||||||
|
action='list', parameter="exclude_fields"),
|
||||||
|
actual_columns)
|
||||||
|
self.assertListItemsEqual(expected_data, list(data))
|
||||||
|
|
||||||
|
|
||||||
class TestShowVnfLcmOp(TestVnfLcm):
|
class TestShowVnfLcmOp(TestVnfLcm):
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user