summaryrefslogtreecommitdiffstats
path: root/lcm
diff options
context:
space:
mode:
Diffstat (limited to 'lcm')
-rw-r--r--lcm/lcm/nf/tests/test_change_ext_conn.py59
-rw-r--r--lcm/lcm/nf/tests/test_change_flavour.py27
-rw-r--r--lcm/lcm/nf/tests/test_scale_vnf.py7
-rw-r--r--lcm/lcm/nf/tests/test_scale_vnf_to_level.py35
-rw-r--r--lcm/lcm/nf/urls.py8
5 files changed, 124 insertions, 12 deletions
diff --git a/lcm/lcm/nf/tests/test_change_ext_conn.py b/lcm/lcm/nf/tests/test_change_ext_conn.py
index 21200f15..f91f2195 100644
--- a/lcm/lcm/nf/tests/test_change_ext_conn.py
+++ b/lcm/lcm/nf/tests/test_change_ext_conn.py
@@ -15,18 +15,71 @@ from django.test import TestCase
from rest_framework import status
from rest_framework.test import APIClient
+from lcm.pub.database.models import NfInstModel
+
class TestChangeExtConn(TestCase):
def setUp(self):
self.client = APIClient()
+ NfInstModel(nfinstid='12345',
+ nf_name='VNF1',
+ nf_desc="VNF DESC",
+ vnfdid="1",
+ netype="XGW",
+ vendor="ZTE",
+ vnfSoftwareVersion="V1",
+ version="V1",
+ package_id="2",
+ status='NOT_INSTANTIATED').save()
+ self.req_data = {
+ "extVirtualLinks": [{
+ "id": "string",
+ "resourceId": "329efb86-5cbb-4fc0-bc7c-6ea28f9d7389",
+ "resourceSubnetId": "429efb86-5cbb-4fc0-bc7c-6ea28f9d7389",
+ "extCps": [{
+ "cpdId": "ext_cp",
+ "cpConfig": [{
+ "cpInstanceId": "",
+ "cpProtocolData": [{
+ "layerProtocol": "IP_OVER_ETHERNET",
+ "ipOverEthernet": {
+ "ipAddresses": [{
+ "type": "IPV4",
+ "numDynamicAddresses": 0,
+ "subnetId": "59e9ffa9-b67e-4c05-b191-ed179007536e"
+ }]
+ }
+ }]
+ }]
+ }],
+ "extLinkPorts": []
+ }],
+ "vimConnectionInfo": [{
+ "id": "tecs_RegionOne",
+ "vimType": "openstack",
+ "vimId": "tecs_RegionOne",
+ "accessInfo": {
+ "tenant": "admin"
+ }
+ }],
+ "additionalParams": {
+ "vmid": "552ea058-6441-4de5-b4c1-b0a52c7557e8"
+ }
+ }
def tearDown(self):
- pass
+ NfInstModel.objects.filter(nfinstid='12345').delete()
def test_change_ext_conn_not_found(self):
- req_data = {}
url = "/api/vnflcm/v1/vnf_instances/12/change_ext_conn"
response = self.client.post(url,
- data=req_data,
+ data=self.req_data,
format='json')
self.failUnlessEqual(status.HTTP_404_NOT_FOUND, response.status_code)
+
+ def test_change_ext_conn_conflict(self):
+ url = "/api/vnflcm/v1/vnf_instances/12345/change_ext_conn"
+ response = self.client.post(url,
+ data=self.req_data,
+ format='json')
+ self.failUnlessEqual(status.HTTP_409_CONFLICT, response.status_code)
diff --git a/lcm/lcm/nf/tests/test_change_flavour.py b/lcm/lcm/nf/tests/test_change_flavour.py
index b4330a35..75d06336 100644
--- a/lcm/lcm/nf/tests/test_change_flavour.py
+++ b/lcm/lcm/nf/tests/test_change_flavour.py
@@ -15,18 +15,39 @@ from django.test import TestCase
from rest_framework import status
from rest_framework.test import APIClient
+from lcm.pub.database.models import NfInstModel
+
class TestFlavour(TestCase):
def setUp(self):
self.client = APIClient()
+ NfInstModel(nfinstid='12345',
+ nf_name='VNF1',
+ nf_desc="VNF DESC",
+ vnfdid="1",
+ netype="XGW",
+ vendor="ZTE",
+ vnfSoftwareVersion="V1",
+ version="V1",
+ package_id="2",
+ status='NOT_INSTANTIATED').save()
+ self.req_data = {
+ "newFlavourId": "myFlavour_new"
+ }
def tearDown(self):
- pass
+ NfInstModel.objects.filter(nfinstid='12345').delete()
def test_change_flavour_not_found(self):
- req_data = {}
url = "/api/vnflcm/v1/vnf_instances/12/change_flavour"
response = self.client.post(url,
- data=req_data,
+ data=self.req_data,
format='json')
self.failUnlessEqual(status.HTTP_404_NOT_FOUND, response.status_code)
+
+ def test_change_flavour_conflict(self):
+ url = "/api/vnflcm/v1/vnf_instances/12345/change_flavour"
+ response = self.client.post(url,
+ data=self.req_data,
+ format='json')
+ self.failUnlessEqual(status.HTTP_409_CONFLICT, response.status_code)
diff --git a/lcm/lcm/nf/tests/test_scale_vnf.py b/lcm/lcm/nf/tests/test_scale_vnf.py
index f8bb6c5d..0024840c 100644
--- a/lcm/lcm/nf/tests/test_scale_vnf.py
+++ b/lcm/lcm/nf/tests/test_scale_vnf.py
@@ -19,14 +19,17 @@ from rest_framework.test import APIClient
class TestNfScale(TestCase):
def setUp(self):
self.client = APIClient()
+ self.req_data = {
+ "type": "SCALE_IN",
+ "aspectId": "sunshine_aspect"
+ }
def tearDown(self):
pass
def test_scale_vnf_not_found(self):
- req_data = {}
url = "/api/vnflcm/v1/vnf_instances/12/scale"
response = self.client.post(url,
- data=req_data,
+ data=self.req_data,
format='json')
self.failUnlessEqual(status.HTTP_404_NOT_FOUND, response.status_code)
diff --git a/lcm/lcm/nf/tests/test_scale_vnf_to_level.py b/lcm/lcm/nf/tests/test_scale_vnf_to_level.py
new file mode 100644
index 00000000..c4298d85
--- /dev/null
+++ b/lcm/lcm/nf/tests/test_scale_vnf_to_level.py
@@ -0,0 +1,35 @@
+# Copyright (C) 2019 ZTE. 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.
+from django.test import TestCase
+from rest_framework import status
+from rest_framework.test import APIClient
+
+
+class TestNfScaleToLevel(TestCase):
+ def setUp(self):
+ self.client = APIClient()
+ self.req_data = {
+ "instantiationLevelId": "instantiation_level_2",
+ "scaleInfo": []
+ }
+
+ def tearDown(self):
+ pass
+
+ def test_scale_vnf_to_level_not_found(self):
+ url = "/api/vnflcm/v1/vnf_instances/12/scale_to_level"
+ response = self.client.post(url,
+ data=self.req_data,
+ format='json')
+ self.failUnlessEqual(status.HTTP_404_NOT_FOUND, response.status_code)
diff --git a/lcm/lcm/nf/urls.py b/lcm/lcm/nf/urls.py
index 88d78fb3..3fdb3433 100644
--- a/lcm/lcm/nf/urls.py
+++ b/lcm/lcm/nf/urls.py
@@ -34,10 +34,10 @@ urlpatterns = [
url(r'^api/vnflcm/v1/vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/terminate$', TerminateVnfView.as_view()),
url(r'^api/vnflcm/v1/vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/heal$', HealVnfView.as_view()),
url(r'^api/vnflcm/v1/vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/operate$', OperateVnfView.as_view()),
- url(r'^vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/scale$', ScaleVnfView.as_view()),
- url(r'^vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/scale_to_level$', ScaleVnfToLevelView.as_view()),
- url(r'^vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/change_flavour$', ChangeVnfFlavourView.as_view()),
- url(r'^vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/change_ext_conn$', ChangeExtConnView.as_view()),
+ url(r'^api/vnflcm/v1/vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/scale$', ScaleVnfView.as_view()),
+ url(r'^api/vnflcm/v1/vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/scale_to_level$', ScaleVnfToLevelView.as_view()),
+ url(r'^api/vnflcm/v1/vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/change_flavour$', ChangeVnfFlavourView.as_view()),
+ url(r'^api/vnflcm/v1/vnf_instances/(?P<instanceid>[0-9a-zA-Z_-]+)/change_ext_conn$', ChangeExtConnView.as_view()),
url(r'^api/vnflcm/v1/vnf_lcm_op_occs$', QueryMultiVnfLcmOpOccs.as_view()),
url(r'^api/vnflcm/v1/vnf_lcm_op_occs/(?P<lcmopoccid>[0-9a-zA-Z_-]+)$', QuerySingleVnfLcmOpOcc.as_view()),
]