Add client support for VNFFG in NFVO
Co-Authored-By: Tim Rozet <trozet@redhat.com> implements blueprint: tacker-vnffg Change-Id: Ic5273319a01b8003e9497fbf7f984972602c7698
This commit is contained in:
parent
647baba801
commit
882f6b6c93
3
releasenotes/notes/vnffg-client-abd7d7f06860b91d.yaml
Normal file
3
releasenotes/notes/vnffg-client-abd7d7f06860b91d.yaml
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
---
|
||||||
|
features:
|
||||||
|
- Add client support for VNFFG.
|
@ -14,3 +14,4 @@ Babel>=2.3.4 # BSD
|
|||||||
oslo.i18n>=2.1.0 # Apache-2.0
|
oslo.i18n>=2.1.0 # Apache-2.0
|
||||||
oslo.utils>=3.16.0 # Apache-2.0
|
oslo.utils>=3.16.0 # Apache-2.0
|
||||||
oslosphinx!=3.4.0,>=2.5.0 # Apache-2.0
|
oslosphinx!=3.4.0,>=2.5.0 # Apache-2.0
|
||||||
|
oslo.serialization>=1.10.0 # Apache-2.0
|
||||||
|
@ -48,6 +48,8 @@ from tackerclient.i18n import _
|
|||||||
from tackerclient.tacker.v1_0.events import events
|
from tackerclient.tacker.v1_0.events import events
|
||||||
from tackerclient.tacker.v1_0 import extension
|
from tackerclient.tacker.v1_0 import extension
|
||||||
from tackerclient.tacker.v1_0.nfvo import vim
|
from tackerclient.tacker.v1_0.nfvo import vim
|
||||||
|
from tackerclient.tacker.v1_0.nfvo import vnffg
|
||||||
|
from tackerclient.tacker.v1_0.nfvo import vnffgd
|
||||||
from tackerclient.tacker.v1_0.vm import vnf
|
from tackerclient.tacker.v1_0.vm import vnf
|
||||||
from tackerclient.tacker.v1_0.vm import vnfd
|
from tackerclient.tacker.v1_0.vm import vnfd
|
||||||
from tackerclient.version import __version__
|
from tackerclient.version import __version__
|
||||||
@ -132,6 +134,26 @@ COMMAND_V1 = {
|
|||||||
'vim-events-list': events.ListVIMEvents,
|
'vim-events-list': events.ListVIMEvents,
|
||||||
'vnfd-events-list': events.ListVNFDEvents,
|
'vnfd-events-list': events.ListVNFDEvents,
|
||||||
|
|
||||||
|
'vnffgd-create': vnffgd.CreateVNFFGD,
|
||||||
|
'vnffgd-delete': vnffgd.DeleteVNFFGD,
|
||||||
|
'vnffgd-list': vnffgd.ListVNFFGD,
|
||||||
|
'vnffgd-show': vnffgd.ShowVNFFGD,
|
||||||
|
'vnffgd-template-show': vnffgd.ShowTemplateVNFFGD,
|
||||||
|
|
||||||
|
'vnffg-create': vnffg.CreateVNFFG,
|
||||||
|
'vnffg-delete': vnffg.DeleteVNFFG,
|
||||||
|
'vnffg-list': vnffg.ListVNFFG,
|
||||||
|
'vnffg-show': vnffg.ShowVNFFG,
|
||||||
|
'vnffg-update': vnffg.UpdateVNFFG,
|
||||||
|
|
||||||
|
'nfp-list': vnffg.ListNFP,
|
||||||
|
'nfp-show': vnffg.ShowNFP,
|
||||||
|
|
||||||
|
'chain-list': vnffg.ListSFC,
|
||||||
|
'chain-show': vnffg.ShowSFC,
|
||||||
|
|
||||||
|
'classifier-list': vnffg.ListFC,
|
||||||
|
'classifier-show': vnffg.ShowFC,
|
||||||
}
|
}
|
||||||
|
|
||||||
COMMANDS = {'1.0': COMMAND_V1}
|
COMMANDS = {'1.0': COMMAND_V1}
|
||||||
|
168
tackerclient/tacker/v1_0/nfvo/vnffg.py
Normal file
168
tackerclient/tacker/v1_0/nfvo/vnffg.py
Normal file
@ -0,0 +1,168 @@
|
|||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
from tackerclient.tacker import v1_0 as tackerV10
|
||||||
|
|
||||||
|
|
||||||
|
_VNFFG = 'vnffg'
|
||||||
|
_NFP = 'nfp'
|
||||||
|
_SFC = 'sfc'
|
||||||
|
_FC = 'classifier'
|
||||||
|
|
||||||
|
|
||||||
|
class ListFC(tackerV10.ListCommand):
|
||||||
|
"""List FCs that belong to a given tenant."""
|
||||||
|
|
||||||
|
resource = _FC
|
||||||
|
list_columns = ['id', 'status', 'nfp_id', 'chain_id']
|
||||||
|
|
||||||
|
|
||||||
|
class ShowFC(tackerV10.ShowCommand):
|
||||||
|
"""Show information of a given FC."""
|
||||||
|
|
||||||
|
resource = _FC
|
||||||
|
|
||||||
|
|
||||||
|
class ListSFC(tackerV10.ListCommand):
|
||||||
|
"""List SFCs that belong to a given tenant."""
|
||||||
|
|
||||||
|
resource = _SFC
|
||||||
|
list_columns = ['id', 'status', 'nfp_id']
|
||||||
|
|
||||||
|
|
||||||
|
class ShowSFC(tackerV10.ShowCommand):
|
||||||
|
"""Show information of a given SFC."""
|
||||||
|
|
||||||
|
resource = _SFC
|
||||||
|
|
||||||
|
|
||||||
|
class ListNFP(tackerV10.ListCommand):
|
||||||
|
"""List NFPs that belong to a given tenant."""
|
||||||
|
|
||||||
|
resource = _NFP
|
||||||
|
list_columns = ['id', 'name', 'status', 'vnffg_id', 'path_id']
|
||||||
|
|
||||||
|
|
||||||
|
class ShowNFP(tackerV10.ShowCommand):
|
||||||
|
"""Show information of a given NFP."""
|
||||||
|
|
||||||
|
resource = _NFP
|
||||||
|
|
||||||
|
|
||||||
|
class ListVNFFG(tackerV10.ListCommand):
|
||||||
|
"""List VNFFGs that belong to a given tenant."""
|
||||||
|
|
||||||
|
resource = _VNFFG
|
||||||
|
list_columns = ['id', 'name', 'description', 'status', 'vnffgd_id']
|
||||||
|
|
||||||
|
|
||||||
|
class ShowVNFFG(tackerV10.ShowCommand):
|
||||||
|
"""Show information of a given VNFFG."""
|
||||||
|
|
||||||
|
resource = _VNFFG
|
||||||
|
|
||||||
|
|
||||||
|
class CreateVNFFG(tackerV10.CreateCommand):
|
||||||
|
"""Create a VNFFG."""
|
||||||
|
|
||||||
|
resource = _VNFFG
|
||||||
|
remove_output_fields = ["attributes"]
|
||||||
|
|
||||||
|
def add_known_arguments(self, parser):
|
||||||
|
parser.add_argument(
|
||||||
|
'name', metavar='NAME',
|
||||||
|
help='Set a name for the VNFFG')
|
||||||
|
vnffgd_group = parser.add_mutually_exclusive_group(required=True)
|
||||||
|
vnffgd_group.add_argument(
|
||||||
|
'--vnffgd-id',
|
||||||
|
help='VNFFGD ID to use as template to create VNFFG')
|
||||||
|
vnffgd_group.add_argument(
|
||||||
|
'--vnffgd-name',
|
||||||
|
help='VNFFGD Name to use as template to create VNFFG')
|
||||||
|
parser.add_argument(
|
||||||
|
'--vnf-mapping',
|
||||||
|
help='List of logical VNFD name to VNF instance name mapping. '
|
||||||
|
'Example: VNF1:my_vnf1,VNF2:my_vnf2')
|
||||||
|
parser.add_argument(
|
||||||
|
'--symmetrical', metavar='{True,False}',
|
||||||
|
help='Should a reverse path be created for the NFP')
|
||||||
|
|
||||||
|
def args2body(self, parsed_args):
|
||||||
|
body = {self.resource: {}}
|
||||||
|
|
||||||
|
tacker_client = self.get_client()
|
||||||
|
tacker_client.format = parsed_args.request_format
|
||||||
|
|
||||||
|
if parsed_args.vnf_mapping:
|
||||||
|
_vnf_mapping = dict()
|
||||||
|
_vnf_mappings = parsed_args.vnf_mapping.split(",")
|
||||||
|
for mapping in _vnf_mappings:
|
||||||
|
vnfd_name, vnf = mapping.split(":", 1)
|
||||||
|
_vnf_mapping[vnfd_name] = \
|
||||||
|
tackerV10.find_resourceid_by_name_or_id(
|
||||||
|
tacker_client, 'vnf', vnf)
|
||||||
|
|
||||||
|
parsed_args.vnf_mapping = _vnf_mapping
|
||||||
|
|
||||||
|
if parsed_args.vnffgd_name:
|
||||||
|
_id = tackerV10.find_resourceid_by_name_or_id(tacker_client,
|
||||||
|
'vnffgd',
|
||||||
|
parsed_args.
|
||||||
|
vnffgd_name)
|
||||||
|
parsed_args.vnffgd_id = _id
|
||||||
|
|
||||||
|
tackerV10.update_dict(parsed_args, body[self.resource],
|
||||||
|
['tenant_id', 'name', 'vnffgd_id',
|
||||||
|
'symmetrical', 'vnf_mapping'])
|
||||||
|
return body
|
||||||
|
|
||||||
|
|
||||||
|
class UpdateVNFFG(tackerV10.UpdateCommand):
|
||||||
|
"""Update a given VNFFG."""
|
||||||
|
|
||||||
|
resource = _VNFFG
|
||||||
|
|
||||||
|
def add_known_arguments(self, parser):
|
||||||
|
parser.add_argument(
|
||||||
|
'--vnf-mapping',
|
||||||
|
help='List of logical VNFD name to VNF instance name mapping. '
|
||||||
|
'Example: VNF1:my_vnf1,VNF2:my_vnf2')
|
||||||
|
parser.add_argument(
|
||||||
|
'--symmetrical', metavar='{True,False}',
|
||||||
|
help='Should a reverse path be created for the NFP')
|
||||||
|
|
||||||
|
def args2body(self, parsed_args):
|
||||||
|
body = {self.resource: {}}
|
||||||
|
|
||||||
|
tacker_client = self.get_client()
|
||||||
|
tacker_client.format = parsed_args.request_format
|
||||||
|
|
||||||
|
if parsed_args.vnf_mapping:
|
||||||
|
_vnf_mapping = dict()
|
||||||
|
_vnf_mappings = parsed_args.vnf_mapping.split(",")
|
||||||
|
for mapping in _vnf_mappings:
|
||||||
|
vnfd_name, vnf = mapping.split(":", 1)
|
||||||
|
_vnf_mapping[vnfd_name] = \
|
||||||
|
tackerV10.find_resourceid_by_name_or_id(
|
||||||
|
tacker_client, 'vnf', vnf)
|
||||||
|
|
||||||
|
parsed_args.vnf_mapping = _vnf_mapping
|
||||||
|
|
||||||
|
tackerV10.update_dict(parsed_args, body[self.resource],
|
||||||
|
['tenant_id', 'vnf_mapping', 'symmetrical'])
|
||||||
|
return body
|
||||||
|
|
||||||
|
|
||||||
|
class DeleteVNFFG(tackerV10.DeleteCommand):
|
||||||
|
"""Delete a given VNFFG."""
|
||||||
|
|
||||||
|
resource = _VNFFG
|
87
tackerclient/tacker/v1_0/nfvo/vnffgd.py
Normal file
87
tackerclient/tacker/v1_0/nfvo/vnffgd.py
Normal file
@ -0,0 +1,87 @@
|
|||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
from __future__ import print_function
|
||||||
|
|
||||||
|
import yaml
|
||||||
|
|
||||||
|
from oslo_serialization import jsonutils
|
||||||
|
|
||||||
|
from tackerclient.i18n import _
|
||||||
|
from tackerclient.tacker import v1_0 as tackerV10
|
||||||
|
|
||||||
|
_VNFFGD = "vnffgd"
|
||||||
|
|
||||||
|
|
||||||
|
class ListVNFFGD(tackerV10.ListCommand):
|
||||||
|
"""List VNFFGDs that belong to a given tenant."""
|
||||||
|
|
||||||
|
resource = _VNFFGD
|
||||||
|
list_columns = ['id', 'name', 'description']
|
||||||
|
|
||||||
|
|
||||||
|
class ShowVNFFGD(tackerV10.ShowCommand):
|
||||||
|
"""Show information of a given VNFFGD."""
|
||||||
|
|
||||||
|
resource = _VNFFGD
|
||||||
|
|
||||||
|
|
||||||
|
class CreateVNFFGD(tackerV10.CreateCommand):
|
||||||
|
"""Create a VNFFGD."""
|
||||||
|
resource = _VNFFGD
|
||||||
|
remove_output_fields = ["attributes"]
|
||||||
|
|
||||||
|
def add_known_arguments(self, parser):
|
||||||
|
group = parser.add_mutually_exclusive_group(required=True)
|
||||||
|
group.add_argument('--vnffgd-file', help='Specify VNFFGD file')
|
||||||
|
group.add_argument('--vnffgd', help='Specify VNFFGD')
|
||||||
|
parser.add_argument(
|
||||||
|
'name', metavar='NAME',
|
||||||
|
help='Set a name for the VNFFGD')
|
||||||
|
parser.add_argument(
|
||||||
|
'--description',
|
||||||
|
help='Set a description for the VNFFGD')
|
||||||
|
|
||||||
|
def args2body(self, parsed_args):
|
||||||
|
body = {self.resource: {}}
|
||||||
|
if parsed_args.vnffgd_file:
|
||||||
|
with open(parsed_args.vnffgd_file) as f:
|
||||||
|
vnffgd = yaml.safe_load(f.read())
|
||||||
|
body[self.resource]['template'] = {'vnffgd': vnffgd}
|
||||||
|
if parsed_args.vnffgd:
|
||||||
|
body[self.resource]['template'] = {
|
||||||
|
'vnffgd': yaml.safe_load(parsed_args.vnffgd)}
|
||||||
|
tackerV10.update_dict(parsed_args, body[self.resource],
|
||||||
|
['tenant_id', 'name', 'description'])
|
||||||
|
return body
|
||||||
|
|
||||||
|
|
||||||
|
class DeleteVNFFGD(tackerV10.DeleteCommand):
|
||||||
|
"""Delete a given VNFFGD."""
|
||||||
|
resource = _VNFFGD
|
||||||
|
|
||||||
|
|
||||||
|
class ShowTemplateVNFFGD(tackerV10.ShowCommand):
|
||||||
|
"""Show template of a given VNFFGD."""
|
||||||
|
resource = _VNFFGD
|
||||||
|
|
||||||
|
def run(self, parsed_args):
|
||||||
|
self.log.debug('run(%s)', parsed_args)
|
||||||
|
template = None
|
||||||
|
data = self.get_data(parsed_args)
|
||||||
|
try:
|
||||||
|
attributes_index = data[0].index('attributes')
|
||||||
|
attributes_json = data[1][attributes_index]
|
||||||
|
template = jsonutils.loads(attributes_json).get('vnffgd', None)
|
||||||
|
except (IndexError, TypeError, ValueError) as e:
|
||||||
|
self.log.debug('Data handling error: %s', str(e))
|
||||||
|
print(template or _('Unable to display VNFFGD template!'))
|
@ -205,7 +205,7 @@ class CLITestV10Base(testtools.TestCase):
|
|||||||
self.mox.StubOutWithMock(cmd, "get_client")
|
self.mox.StubOutWithMock(cmd, "get_client")
|
||||||
self.mox.StubOutWithMock(self.client.httpclient, "request")
|
self.mox.StubOutWithMock(self.client.httpclient, "request")
|
||||||
cmd.get_client().MultipleTimes().AndReturn(self.client)
|
cmd.get_client().MultipleTimes().AndReturn(self.client)
|
||||||
non_admin_status_resources = ['vnfd', 'vnf', 'vim']
|
non_admin_status_resources = ['vnfd', 'vnf', 'vim', 'vnffgd', 'vnffg']
|
||||||
if (resource in non_admin_status_resources):
|
if (resource in non_admin_status_resources):
|
||||||
body = {resource: {}, }
|
body = {resource: {}, }
|
||||||
else:
|
else:
|
||||||
|
104
tackerclient/tests/unit/vm/test_cli10_vnffg.py
Normal file
104
tackerclient/tests/unit/vm/test_cli10_vnffg.py
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
# Copyright 2014 Intel Corporation
|
||||||
|
# All Rights Reserved.
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from tackerclient.tacker.v1_0.nfvo import vnffg
|
||||||
|
from tackerclient.tests.unit import test_cli10
|
||||||
|
|
||||||
|
API_VERSION = "1.0"
|
||||||
|
FORMAT = 'json'
|
||||||
|
TOKEN = 'testtoken'
|
||||||
|
ENDURL = 'localurl'
|
||||||
|
|
||||||
|
|
||||||
|
class CLITestV10VmVNFFGJSON(test_cli10.CLITestV10Base):
|
||||||
|
_RESOURCE = 'vnffg'
|
||||||
|
_RESOURCES = 'vnffgs'
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
plurals = {'vnffgs': 'vnffg'}
|
||||||
|
super(CLITestV10VmVNFFGJSON, self).setUp(plurals=plurals)
|
||||||
|
|
||||||
|
def test_create_vnffg_all_params(self):
|
||||||
|
cmd = vnffg.CreateVNFFG(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
my_id = 'my-id'
|
||||||
|
vnffgd_id = 'vnffgd'
|
||||||
|
vnffg_name = 'fake-vnffg'
|
||||||
|
vnf_mapping = 'VNFD1:VNF1'
|
||||||
|
|
||||||
|
args = [
|
||||||
|
vnffg_name,
|
||||||
|
'--vnffgd-id', vnffgd_id,
|
||||||
|
'--vnf-mapping', vnf_mapping,
|
||||||
|
'--symmetrical', 'True']
|
||||||
|
position_names = ['vnffgd_id', 'vnf_mapping', 'symmetrical']
|
||||||
|
position_values = [vnffgd_id, {"VNFD1": "VNF1"}, 'True']
|
||||||
|
extra_body = {'name': vnffg_name}
|
||||||
|
self._test_create_resource(self._RESOURCE, cmd, None, my_id,
|
||||||
|
args, position_names, position_values,
|
||||||
|
extra_body=extra_body)
|
||||||
|
|
||||||
|
def test_create_vnffg_with_mandatory_params(self):
|
||||||
|
cmd = vnffg.CreateVNFFG(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
my_id = 'my-id'
|
||||||
|
vnffg_name = 'fake-vnffg'
|
||||||
|
vnffgd_id = 'vnffgd'
|
||||||
|
args = [
|
||||||
|
vnffg_name,
|
||||||
|
'--vnffgd-id', vnffgd_id,
|
||||||
|
]
|
||||||
|
position_names = ['vnffgd_id']
|
||||||
|
position_values = [vnffgd_id]
|
||||||
|
extra_body = {'name': vnffg_name}
|
||||||
|
self._test_create_resource(self._RESOURCE, cmd, vnffg_name, my_id,
|
||||||
|
args, position_names, position_values,
|
||||||
|
extra_body=extra_body)
|
||||||
|
|
||||||
|
def test_list_vnffgs(self):
|
||||||
|
cmd = vnffg.ListVNFFG(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
self._test_list_resources(self._RESOURCES, cmd, True)
|
||||||
|
|
||||||
|
def test_list_vnffgs_pagenation(self):
|
||||||
|
cmd = vnffg.ListVNFFG(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
self._test_list_resources(self._RESOURCES, cmd, True)
|
||||||
|
|
||||||
|
def test_show_vnffg_id(self):
|
||||||
|
cmd = vnffg.ShowVNFFG(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
args = ['--fields', 'id', self.test_id]
|
||||||
|
self._test_show_resource(self._RESOURCE, cmd, self.test_id, args,
|
||||||
|
['id'])
|
||||||
|
|
||||||
|
def test_show_vnffg_id_name(self):
|
||||||
|
cmd = vnffg.ShowVNFFG(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
args = ['--fields', 'id', '--fields', 'name', self.test_id]
|
||||||
|
self._test_show_resource(self._RESOURCE, cmd, self.test_id,
|
||||||
|
args, ['id', 'name'])
|
||||||
|
|
||||||
|
def test_update_vnffg(self):
|
||||||
|
cmd = vnffg.UpdateVNFFG(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
my_id = 'my-id'
|
||||||
|
key = 'new_key'
|
||||||
|
value = 'new-value'
|
||||||
|
self._test_update_resource(self._RESOURCE, cmd, my_id,
|
||||||
|
[my_id, '--%s' % key, value],
|
||||||
|
{key: value})
|
||||||
|
|
||||||
|
def test_delete_vnffg(self):
|
||||||
|
cmd = vnffg.DeleteVNFFG(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
my_id = 'my-id'
|
||||||
|
args = [my_id]
|
||||||
|
self._test_delete_resource(self._RESOURCE, cmd, my_id, args)
|
93
tackerclient/tests/unit/vm/test_cli10_vnffgd.py
Normal file
93
tackerclient/tests/unit/vm/test_cli10_vnffgd.py
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
# not use this file except in compliance with the License. You may obtain
|
||||||
|
# a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
||||||
|
# License for the specific language governing permissions and limitations
|
||||||
|
# under the License.
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from tackerclient.tacker.v1_0.nfvo import vnffgd
|
||||||
|
from tackerclient.tests.unit import test_cli10
|
||||||
|
|
||||||
|
|
||||||
|
class CLITestV10VmVNFFGDJSON(test_cli10.CLITestV10Base):
|
||||||
|
_RESOURCE = 'vnffgd'
|
||||||
|
_RESOURCES = 'vnffgds'
|
||||||
|
|
||||||
|
def setUp(self):
|
||||||
|
plurals = {'vnffgds': 'vnffgd'}
|
||||||
|
super(CLITestV10VmVNFFGDJSON, self).setUp(plurals=plurals)
|
||||||
|
|
||||||
|
def test_create_vnffgd_all_params(self):
|
||||||
|
cmd = vnffgd.CreateVNFFGD(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
my_id = 'my-id'
|
||||||
|
name = 'my-name'
|
||||||
|
attr_key = 'vnffgd'
|
||||||
|
attr_val = 'vnffgd'
|
||||||
|
description = 'vnffgd description'
|
||||||
|
args = [
|
||||||
|
name,
|
||||||
|
'--vnffgd', 'vnffgd',
|
||||||
|
'--description', description,
|
||||||
|
]
|
||||||
|
position_names = ['name', 'description']
|
||||||
|
position_values = [name, description]
|
||||||
|
extra_body = {
|
||||||
|
'template': {attr_key: attr_val},
|
||||||
|
}
|
||||||
|
|
||||||
|
self._test_create_resource(self._RESOURCE, cmd, name, my_id,
|
||||||
|
args, position_names, position_values,
|
||||||
|
extra_body=extra_body)
|
||||||
|
|
||||||
|
def test_create_vnffgd_with_mandatory_params(self):
|
||||||
|
cmd = vnffgd.CreateVNFFGD(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
my_id = 'my-id'
|
||||||
|
name = 'my-name'
|
||||||
|
attr_key = 'vnffgd'
|
||||||
|
attr_val = 'vnffgd'
|
||||||
|
args = [
|
||||||
|
name,
|
||||||
|
'--vnffgd', 'vnffgd',
|
||||||
|
]
|
||||||
|
position_names = ['name']
|
||||||
|
position_values = [name]
|
||||||
|
extra_body = {
|
||||||
|
'template': {attr_key: attr_val},
|
||||||
|
}
|
||||||
|
|
||||||
|
self._test_create_resource(self._RESOURCE, cmd, name, my_id,
|
||||||
|
args, position_names, position_values,
|
||||||
|
extra_body=extra_body)
|
||||||
|
|
||||||
|
def test_list_vnffgds(self):
|
||||||
|
cmd = vnffgd.ListVNFFGD(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
self._test_list_resources(self._RESOURCES, cmd, True)
|
||||||
|
|
||||||
|
def test_list_vnffgds_pagenation(self):
|
||||||
|
cmd = vnffgd.ListVNFFGD(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
self._test_list_resources(self._RESOURCES, cmd, True)
|
||||||
|
|
||||||
|
def test_show_vnffgd_id(self):
|
||||||
|
cmd = vnffgd.ShowVNFFGD(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
args = ['--fields', 'id', self.test_id]
|
||||||
|
self._test_show_resource(self._RESOURCE, cmd, self.test_id, args,
|
||||||
|
['id'])
|
||||||
|
|
||||||
|
def test_show_vnffgd_id_name(self):
|
||||||
|
cmd = vnffgd.ShowVNFFGD(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
args = ['--fields', 'id', '--fields', 'name', self.test_id]
|
||||||
|
self._test_show_resource(self._RESOURCE, cmd, self.test_id,
|
||||||
|
args, ['id', 'name'])
|
||||||
|
|
||||||
|
def test_delete_vnffgd(self):
|
||||||
|
cmd = vnffgd.DeleteVNFFGD(test_cli10.MyApp(sys.stdout), None)
|
||||||
|
my_id = 'my-id'
|
||||||
|
args = [my_id]
|
||||||
|
self._test_delete_resource(self._RESOURCE, cmd, my_id, args)
|
@ -346,6 +346,21 @@ class Client(ClientBase):
|
|||||||
events_path = '/events'
|
events_path = '/events'
|
||||||
event_path = '/events/%s'
|
event_path = '/events/%s'
|
||||||
|
|
||||||
|
vnffgds_path = '/vnffgds'
|
||||||
|
vnffgd_path = '/vnffgds/%s'
|
||||||
|
|
||||||
|
vnffgs_path = '/vnffgs'
|
||||||
|
vnffg_path = '/vnffgs/%s'
|
||||||
|
|
||||||
|
nfps_path = '/nfps'
|
||||||
|
nfp_path = '/nfps/%s'
|
||||||
|
|
||||||
|
sfcs_path = '/sfcs'
|
||||||
|
sfc_path = '/sfcs/%s'
|
||||||
|
|
||||||
|
fcs_path = '/classifiers'
|
||||||
|
fc_path = '/classifiers/%s'
|
||||||
|
|
||||||
# API has no way to report plurals, so we have to hard code them
|
# API has no way to report plurals, so we have to hard code them
|
||||||
# EXTED_PLURALS = {}
|
# EXTED_PLURALS = {}
|
||||||
|
|
||||||
@ -487,3 +502,108 @@ class Client(ClientBase):
|
|||||||
@APIParamsCall
|
@APIParamsCall
|
||||||
def show_event(self, event_id, **_params):
|
def show_event(self, event_id, **_params):
|
||||||
return self.get(self.event_path % event_id, params=_params)
|
return self.get(self.event_path % event_id, params=_params)
|
||||||
|
|
||||||
|
_VNFFGD = "vnffgd"
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def create_vnffgd(self, body=None):
|
||||||
|
return self.post(self.vnffgds_path, body)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def list_vnffgds(self, retrieve_all=True, **_params):
|
||||||
|
vnffgds_dict = self.list(self._VNFFGD + 's',
|
||||||
|
self.vnffgds_path,
|
||||||
|
retrieve_all,
|
||||||
|
**_params)
|
||||||
|
for vnffgd in vnffgds_dict['vnffgds']:
|
||||||
|
if 'description' in vnffgd.keys() and \
|
||||||
|
len(vnffgd['description']) > DEFAULT_DESC_LENGTH:
|
||||||
|
vnffgd['description'] = vnffgd['description'][
|
||||||
|
:DEFAULT_DESC_LENGTH]
|
||||||
|
vnffgd['description'] += '...'
|
||||||
|
return vnffgds_dict
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def show_vnffgd(self, vnffgd, **_params):
|
||||||
|
return self.get(self.vnffgd_path % vnffgd, params=_params)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def delete_vnffgd(self, vnffgd):
|
||||||
|
return self.delete(self.vnffgd_path % vnffgd)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def list_vnffgs(self, retrieve_all=True, **_params):
|
||||||
|
vnffgs = self.list('vnffgs', self.vnffgs_path, retrieve_all, **_params)
|
||||||
|
for vnffg in vnffgs['vnffgs']:
|
||||||
|
error_reason = vnffg.get('error_reason', None)
|
||||||
|
if error_reason and \
|
||||||
|
len(error_reason) > DEFAULT_ERROR_REASON_LENGTH:
|
||||||
|
vnffg['error_reason'] = error_reason[
|
||||||
|
:DEFAULT_ERROR_REASON_LENGTH]
|
||||||
|
vnffg['error_reason'] += '...'
|
||||||
|
return vnffgs
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def show_vnffg(self, vnffg, **_params):
|
||||||
|
return self.get(self.vnffg_path % vnffg, params=_params)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def create_vnffg(self, body=None):
|
||||||
|
return self.post(self.vnffgs_path, body=body)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def delete_vnffg(self, vnffg):
|
||||||
|
return self.delete(self.vnffg_path % vnffg)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def update_vnffg(self, vnffg, body=None):
|
||||||
|
return self.put(self.vnffg_path % vnffg, body=body)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def list_sfcs(self, retrieve_all=True, **_params):
|
||||||
|
sfcs = self.list('sfcs', self.sfcs_path, retrieve_all, **_params)
|
||||||
|
for chain in sfcs['sfcs']:
|
||||||
|
error_reason = chain.get('error_reason', None)
|
||||||
|
if error_reason and \
|
||||||
|
len(error_reason) > DEFAULT_ERROR_REASON_LENGTH:
|
||||||
|
chain['error_reason'] = error_reason[
|
||||||
|
:DEFAULT_ERROR_REASON_LENGTH]
|
||||||
|
chain['error_reason'] += '...'
|
||||||
|
return sfcs
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def show_sfc(self, chain, **_params):
|
||||||
|
return self.get(self.sfc_path % chain, params=_params)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def list_nfps(self, retrieve_all=True, **_params):
|
||||||
|
nfps = self.list('nfps', self.nfps_path, retrieve_all, **_params)
|
||||||
|
for nfp in nfps['nfps']:
|
||||||
|
error_reason = nfp.get('error_reason', None)
|
||||||
|
if error_reason and \
|
||||||
|
len(error_reason) > DEFAULT_ERROR_REASON_LENGTH:
|
||||||
|
nfp['error_reason'] = error_reason[
|
||||||
|
:DEFAULT_ERROR_REASON_LENGTH]
|
||||||
|
nfp['error_reason'] += '...'
|
||||||
|
return nfps
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def show_nfp(self, nfp, **_params):
|
||||||
|
return self.get(self.nfp_path % nfp, params=_params)
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def list_classifiers(self, retrieve_all=True, **_params):
|
||||||
|
classifiers = self.list('classifiers', self.fcs_path, retrieve_all,
|
||||||
|
**_params)
|
||||||
|
for classifier in classifiers['classifiers']:
|
||||||
|
error_reason = classifier.get('error_reason', None)
|
||||||
|
if error_reason and \
|
||||||
|
len(error_reason) > DEFAULT_ERROR_REASON_LENGTH:
|
||||||
|
classifier['error_reason'] = error_reason[
|
||||||
|
:DEFAULT_ERROR_REASON_LENGTH]
|
||||||
|
classifier['error_reason'] += '...'
|
||||||
|
return classifiers
|
||||||
|
|
||||||
|
@APIParamsCall
|
||||||
|
def show_classifier(self, classifier, **_params):
|
||||||
|
return self.get(self.fc_path % classifier, params=_params)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user