Add --vnfd-name option to vnf-create command

* Added support for vnfd-name in place of the vnfd-id when
    creating a VNF.  The vnfd-id and vnfd-name are now mutually
    exclusive parameters but one of them is required to be
    specified.  An appropriate error will print if neither is
    provided.

  * If the vnfd-name is specified the code will retrieve the
    associated vnfd-id and pass it to the create method as if it
    had been specified on the command line.

Change-Id: Ia62a33ee821e0fc89a167755aa55beac94d36c57
Closes-Bug: 1474983
This commit is contained in:
Bob HADDLETON 2015-07-15 15:23:35 -05:00
parent cc5e786f08
commit 16b9bc91ef

View File

@ -47,10 +47,13 @@ class CreateVNF(tackerV10.CreateCommand):
parser.add_argument( parser.add_argument(
'--name', '--name',
help='Set a name for the vnf') help='Set a name for the vnf')
parser.add_argument( group = parser.add_mutually_exclusive_group(required=True)
group.add_argument(
'--vnfd-id', '--vnfd-id',
required=True, help='VNFD ID to use as template to create VNF')
help='vnfd id to instantiate vnf based on') group.add_argument(
'--vnfd-name',
help='VNFD Name to use as template to create VNF')
parser.add_argument( parser.add_argument(
'--config-file', '--config-file',
help='specify config yaml file') help='specify config yaml file')
@ -66,6 +69,15 @@ class CreateVNF(tackerV10.CreateCommand):
body[self.resource]['config'] = config_yaml body[self.resource]['config'] = config_yaml
if parsed_args.config: if parsed_args.config:
body[self.resource]['config'] = parsed_args.config body[self.resource]['config'] = parsed_args.config
if parsed_args.vnfd_name:
tacker_client = self.get_client()
tacker_client.format = parsed_args.request_format
_id = tackerV10.find_resourceid_by_name_or_id(
tacker_client, 'vnfd',
parsed_args.vnfd_name)
parsed_args.vnfd_id = _id
tackerV10.update_dict(parsed_args, body[self.resource], tackerV10.update_dict(parsed_args, body[self.resource],
['tenant_id', 'name', 'vnfd_id']) ['tenant_id', 'name', 'vnfd_id'])