Fix vfc-nfvo-lcm ns creation unit test 03/18203/1
authorying.yunlong <ying.yunlong@zte.com.cn>
Wed, 11 Oct 2017 08:20:49 +0000 (16:20 +0800)
committerying.yunlong <ying.yunlong@zte.com.cn>
Wed, 11 Oct 2017 08:20:49 +0000 (16:20 +0800)
Change-Id: I7d2f9684315391ca8e9433234e02b4e3ebd96abb
Issue-ID: VFC-524
Signed-off-by: ying.yunlong <ying.yunlong@zte.com.cn>
lcm/ns/tests/test_ns_create.py
lcm/ns/views.py
lcm/settings.py

index 7f6c7da..55397bb 100644 (file)
 # 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 json
 import uuid
 
 import mock
 from django.test import TestCase, Client
 from rest_framework import status
+from rest_framework.test import APIClient
 
 from lcm.ns.ns_create import CreateNSService
 from lcm.pub.database.models import NSInstModel
 from lcm.pub.exceptions import NSLCMException
+from lcm.pub.utils import restcall
 
 
 class TestNsInstantiate(TestCase):
     def setUp(self):
         self.client = Client()
+        self.client1 = APIClient()
         self.nsd_id = str(uuid.uuid4())
         self.ns_package_id = str(uuid.uuid4())
 
     def tearDown(self):
         NSInstModel.objects.all().delete()
 
-    @mock.patch.object(restcall, 'call_req')
-    def test_create_ns(self, mock_call_req):
-        nspackage_info = {
-            "csarId": self.ns_package_id,
-            "packageInfo": {}
-        }
-        r1_query_nspackage_from_catalog = [0, json.JSONEncoder().encode(nspackage_info), '201']
-        r2_create_ns_to_aai = [0, json.JSONEncoder().encode({}), '201']
-        mock_call_req.side_effect = [r1_query_nspackage_from_catalog, r2_create_ns_to_aai]
-        data = {
-            "context": {
-                "global-customer-id": "global-customer-id-test1",
-                "service-type": "service-type-test1"
-            },
-            "csarId": self.nsd_id,
-            "nsName": "ns",
-            "description": "description"
-        }
-    #     response = self.client.post("/api/nslcm/v1/ns", data=data, format='json')
-        self.failUnlessEqual(status.HTTP_201_CREATED, response.status_code)
+    @mock.patch.object(restcall, 'call_req')
+    def test_create_ns(self, mock_call_req):
+        nspackage_info = {
+            "csarId": self.ns_package_id,
+            "packageInfo": {}
+        }
+        r1_query_nspackage_from_catalog = [0, json.JSONEncoder().encode(nspackage_info), '201']
+        r2_create_ns_to_aai = [0, json.JSONEncoder().encode({}), '201']
+        mock_call_req.side_effect = [r1_query_nspackage_from_catalog, r2_create_ns_to_aai]
+        data = {
+            "context": {
+                "global-customer-id": "global-customer-id-test1",
+                "service-type": "service-type-test1"
+            },
+            "csarId": self.nsd_id,
+            "nsName": "ns",
+            "description": "description"
+        }
+        response = self.client1.post("/api/nslcm/v1/ns", data=data, format='json')
+        self.failUnlessEqual(status.HTTP_201_CREATED, response.status_code)
 
     @mock.patch.object(CreateNSService, "do_biz")
     def test_create_ns_empty_data(self, mock_do_biz):
         mock_do_biz.side_effect = Exception("Exception in CreateNS.")
-
         data = {}
-
         response = self.client.post("/api/nslcm/v1/ns", data=data)
         self.assertEqual(response.data["error"], "Exception in CreateNS.")
         self.assertEqual(response.status_code, status.HTTP_500_INTERNAL_SERVER_ERROR)
@@ -67,12 +69,11 @@ class TestNsInstantiate(TestCase):
     def test_create_ns_non_existing_nsd(self, mock_do_biz):
         mock_do_biz.side_effect = NSLCMException("nsd not exists.")
         new_nsd_id = '1'
-
         data = {
             'nsdid': new_nsd_id,
             'nsname': 'ns',
-            'description': 'description'}
-
+            'description': 'description'
+        }
         response = self.client.post("/api/nslcm/v1/ns", data=data)
         self.assertEqual(response.data["error"], "nsd not exists.")
         self.assertEqual(response.status_code, status.HTTP_500_INTERNAL_SERVER_ERROR)
index f87a6eb..4c403d1 100644 (file)
@@ -61,6 +61,7 @@ class CreateNSView(APIView):
         try:
             ns_inst_id = CreateNSService(csar_id, ns_name, description, context).do_biz()
         except Exception as e:
+            logger.error(traceback.format_exc())
             logger.error("Exception in CreateNS: %s", e.message)
             return Response(data={'error': e.message}, status=status.HTTP_500_INTERNAL_SERVER_ERROR)
         logger.debug("CreateNSView::post::ret={'nsInstanceId':%s}", ns_inst_id)
index 8f9f732..9a095b3 100644 (file)
@@ -72,7 +72,7 @@ REST_FRAMEWORK = {
     'DEFAULT_PARSER_CLASSES': (
         'rest_framework.parsers.JSONParser',
         'rest_framework.parsers.MultiPartParser',
-        'rest_framework.parsers.FormParser',
+        'rest_framework.parsers.FormParser',
         # 'rest_framework.parsers.FileUploadParser',
     )
 }