add orchestra_clearwaterims testcase
authorMichael Pauls <michael.pauls@fokus.fraunhofer.de>
Wed, 9 Aug 2017 00:42:46 +0000 (02:42 +0200)
committerMichael Pauls <michael.pauls@fokus.fraunhofer.de>
Thu, 10 Aug 2017 16:22:02 +0000 (18:22 +0200)
-rename testcase orchestra_ims to orchestra_openims
-add orchestra_clearwaterims testcase
-add unit tests

Change-Id: I5291f84068915fa15e3fb7b63c5dbd0daec0acca
Signed-off-by: Michael Pauls <michael.pauls@fokus.fraunhofer.de>
functest/ci/config_functest.yaml
functest/ci/testcases.yaml
functest/opnfv_tests/vnf/ims/orchestra.yaml [new file with mode: 0644]
functest/opnfv_tests/vnf/ims/orchestra_clearwaterims.py [new file with mode: 0644]
functest/opnfv_tests/vnf/ims/orchestra_ims.yaml [deleted file]
functest/opnfv_tests/vnf/ims/orchestra_openims.py [moved from functest/opnfv_tests/vnf/ims/orchestra_ims.py with 77% similarity]
functest/tests/unit/vnf/ims/test_orchestra_clearwaterims.py [new file with mode: 0644]
functest/tests/unit/vnf/ims/test_orchestra_openims.py [moved from functest/tests/unit/vnf/ims/test_orchestra_ims.py with 81% similarity]

index 31ce4b9..2208426 100644 (file)
@@ -134,10 +134,14 @@ vnf:
         tenant_name: cloudify_ims
         tenant_description: vIMS
         config: cloudify_ims.yaml
-    orchestra_ims:
-        tenant_name: orchestra_ims
-        tenant_description: ims deployed with openbaton
-        config: orchestra_ims.yaml
+    orchestra_openims:
+        tenant_name: orchestra_openims
+        tenant_description: OpenIMS deployed with Open Baton
+        config: orchestra.yaml
+    orchestra_clearwaterims:
+        tenant_name: orchestra_clearwaterims
+        tenant_description: Clearwater IMS deployed with Open Baton
+        config: orchestra.yaml
     opera_ims:
         tenant_name: opera_ims
         tenant_description: ims deployed with open-o
index 99c0cc2..d93e9eb 100644 (file)
@@ -542,19 +542,32 @@ tiers:
                     class: 'AaaVnf'
 
             -
-                case_name: orchestra_ims
-                enabled: true
+                case_name: orchestra_openims
                 project_name: functest
                 criteria: 100
                 blocking: false
                 description: >-
-                    VNF deployment with OpenBaton (Orchestra)
+                    OpenIMS VNF deployment with Open Baton (Orchestra)
                 dependencies:
                     installer: ''
                     scenario: 'os-nosdn-nofeature-ha'
                 run:
-                    module: 'functest.opnfv_tests.vnf.ims.orchestra_ims'
-                    class: 'ImsVnf'
+                    module: 'functest.opnfv_tests.vnf.ims.orchestra_openims'
+                    class: 'OpenImsVnf'
+
+            -
+                case_name: orchestra_clearwaterims
+                project_name: functest
+                criteria: 100
+                blocking: false
+                description: >-
+                    ClearwaterIMS VNF deployment with Open Baton (Orchestra)
+                dependencies:
+                    installer: ''
+                    scenario: 'os-nosdn-nofeature-ha'
+                run:
+                    module: 'functest.opnfv_tests.vnf.ims.orchestra_clearwaterims'
+                    class: 'ClearwaterImsVnf'
 
             -
                 case_name: opera_vims
diff --git a/functest/opnfv_tests/vnf/ims/orchestra.yaml b/functest/opnfv_tests/vnf/ims/orchestra.yaml
new file mode 100644 (file)
index 0000000..7b43c00
--- /dev/null
@@ -0,0 +1,61 @@
+tenant_images:
+    orchestrator:
+        ubuntu-14.04-server-cloudimg-amd64-disk1: http://cloud-images.ubuntu.com/trusty/current/trusty-server-cloudimg-amd64-disk1.img
+    orchestra_openims:
+        openims: http://marketplace.openbaton.org:8082/api/v1/images/52e2ccc0-1dce-4663-894d-28aab49323aa/img
+    orchestra_clearwaterims:
+        ubuntu-14.04-server-cloudimg-amd64-disk1: http://cloud-images.ubuntu.com/trusty/current/trusty-server-cloudimg-amd64-disk1.img
+mano:
+    name: OpenBaton
+    version: '3.2.0'
+    requirements:
+        flavor:
+          name: openbaton
+          ram_min: 4096
+          disk: 5
+          vcpus: 2
+        image: 'ubuntu-14.04-server-cloudimg-amd64-disk1'
+    bootstrap:
+        url: http://get.openbaton.org/bootstraps/bootstrap_3.2.0_opnfv/bootstrap
+        config:
+            url: http://get.openbaton.org/bootstraps/bootstrap_3.2.0_opnfv/bootstrap-config-file
+    gvnfm:
+        userdata:
+            url: https://raw.githubusercontent.com/openbaton/generic-vnfm/3.2.0/src/main/resources/user-data.sh
+    credentials:
+        username: admin
+        password: openbaton
+
+orchestra_openims:
+    name: OpenIMS
+    descriptor:
+        url: http://marketplace.openbaton.org:8082/api/v1/nsds/fokus/OpenImsCore/3.2.0/json
+    requirements:
+        flavor:
+          name: m1.small
+          ram_min: 2048
+          disk: 5
+          vcpus: 2
+    test:
+        scscf:
+            ports: [3870, 6060]
+        pcscf:
+            ports: [4060]
+        icscf:
+            ports: [3869, 5060]
+        fhoss:
+            ports: [3868]
+        bind9:
+            ports: []
+
+orchestra_clearwaterims:
+    name: Clearwater IMS
+    descriptor:
+        url: http://marketplace.openbaton.org:8082/api/v1/nsds/fokus/ClearwaterIMS/3.2.0/json
+    requirements:
+        flavor:
+          name: m1.small
+          ram_min: 2048
+          disk: 5
+          vcpus: 2
+    test:
\ No newline at end of file
diff --git a/functest/opnfv_tests/vnf/ims/orchestra_clearwaterims.py b/functest/opnfv_tests/vnf/ims/orchestra_clearwaterims.py
new file mode 100644 (file)
index 0000000..9e14711
--- /dev/null
@@ -0,0 +1,684 @@
+#!/usr/bin/env python
+
+# Copyright (c) 2016 Orange and others.
+#
+# All rights reserved. This program and the accompanying materials
+# are made available under the terms of the Apache License, Version 2.0
+# which accompanies this distribution, and is available at
+# http://www.apache.org/licenses/LICENSE-2.0
+
+"""Orchestra Clearwater IMS testcase implementation."""
+
+import json
+import logging
+import os
+import socket
+import time
+import pkg_resources
+import yaml
+
+from snaps.openstack.create_image import OpenStackImage, ImageSettings
+from snaps.openstack.create_flavor import OpenStackFlavor, FlavorSettings
+from snaps.openstack.create_security_group import (
+    OpenStackSecurityGroup,
+    SecurityGroupSettings,
+    SecurityGroupRuleSettings,
+    Direction,
+    Protocol)
+from snaps.openstack.create_network import (
+    OpenStackNetwork,
+    NetworkSettings,
+    SubnetSettings,
+    PortSettings)
+from snaps.openstack.create_router import OpenStackRouter, RouterSettings
+from snaps.openstack.os_credentials import OSCreds
+from snaps.openstack.create_instance import (
+    VmInstanceSettings,
+    OpenStackVmInstance)
+from functest.opnfv_tests.openstack.snaps import snaps_utils
+
+import functest.core.vnf as vnf
+import functest.utils.openstack_utils as os_utils
+from functest.utils.constants import CONST
+
+from org.openbaton.cli.errors.errors import NfvoException
+from org.openbaton.cli.agents.agents import MainAgent
+
+
+__author__ = "Pauls, Michael <michael.pauls@fokus.fraunhofer.de>"
+# ----------------------------------------------------------
+#
+#               UTILS
+#
+# -----------------------------------------------------------
+
+
+def get_config(parameter, file_path):
+    """
+    Get config parameter.
+
+    Returns the value of a given parameter in file.yaml
+    parameter must be given in string format with dots
+    Example: general.openstack.image_name
+    """
+    with open(file_path) as config_file:
+        file_yaml = yaml.safe_load(config_file)
+    config_file.close()
+    value = file_yaml
+    for element in parameter.split("."):
+        value = value.get(element)
+        if value is None:
+            raise ValueError("The parameter %s is not defined in"
+                             " reporting.yaml", parameter)
+    return value
+
+
+def servertest(host, port):
+    """Method to test that a server is reachable at IP:port"""
+    args = socket.getaddrinfo(host, port, socket.AF_INET, socket.SOCK_STREAM)
+    for family, socktype, proto, canonname, sockaddr in args:
+        sock = socket.socket(family, socktype, proto)
+        try:
+            sock.connect(sockaddr)
+        except socket.error:
+            return False
+        else:
+            sock.close()
+            return True
+
+
+def get_userdata(orchestrator=dict):
+    """Build userdata for Open Baton machine"""
+    userdata = "#!/bin/bash\n"
+    userdata += "echo \"Executing userdata...\"\n"
+    userdata += "set -x\n"
+    userdata += "set -e\n"
+    userdata += "echo \"Set nameserver to '8.8.8.8'...\"\n"
+    userdata += "echo \"nameserver   8.8.8.8\" >> /etc/resolv.conf\n"
+    userdata += "echo \"Install curl...\"\n"
+    userdata += "apt-get install curl\n"
+    userdata += "echo \"Inject public key...\"\n"
+    userdata += ("echo \"ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCuPXrV3"
+                 "geeHc6QUdyUr/1Z+yQiqLcOskiEGBiXr4z76MK4abiFmDZ18OMQlc"
+                 "fl0p3kS0WynVgyaOHwZkgy/DIoIplONVr2CKBKHtPK+Qcme2PVnCtv"
+                 "EqItl/FcD+1h5XSQGoa+A1TSGgCod/DPo+pes0piLVXP8Ph6QS1k7S"
+                 "ic7JDeRQ4oT1bXYpJ2eWBDMfxIWKZqcZRiGPgMIbJ1iEkxbpeaAd9O"
+                 "4MiM9nGCPESmed+p54uYFjwEDlAJZShcAZziiZYAvMZhvAhe6USljc"
+                 "7YAdalAnyD/jwCHuwIrUw/lxo7UdNCmaUxeobEYyyFA1YVXzpNFZya"
+                 "XPGAAYIJwEq/ openbaton@opnfv\" >> /home/ubuntu/.ssh/aut"
+                 "horized_keys\n")
+    userdata += "echo \"Download bootstrap...\"\n"
+    userdata += ("curl -s %s "
+                 "> ./bootstrap\n" % orchestrator['bootstrap']['url'])
+    userdata += ("curl -s %s" "> ./config_file\n" %
+                 orchestrator['bootstrap']['config']['url'])
+    userdata += ("echo \"Disable usage of mysql...\"\n")
+    userdata += "sed -i s/mysql=.*/mysql=no/g /config_file\n"
+    userdata += ("echo \"Setting 'rabbitmq_broker_ip' to '%s'\"\n"
+                 % orchestrator['details']['fip'].ip)
+    userdata += ("sed -i s/rabbitmq_broker_ip=localhost/rabbitmq_broker_ip"
+                 "=%s/g /config_file\n" % orchestrator['details']['fip'].ip)
+    userdata += "echo \"Set autostart of components to 'false'\"\n"
+    userdata += "export OPENBATON_COMPONENT_AUTOSTART=false\n"
+    userdata += "echo \"Execute bootstrap...\"\n"
+    bootstrap = "sh ./bootstrap release -configFile=./config_file"
+    userdata += bootstrap + "\n"
+    userdata += "echo \"Setting 'nfvo.plugin.timeout' to '300000'\"\n"
+    userdata += ("echo \"nfvo.plugin.timeout=600000\" >> "
+                 "/etc/openbaton/openbaton-nfvo.properties\n")
+    userdata += (
+        "wget %s -O /etc/openbaton/openbaton-vnfm-generic-user-data.sh\n" %
+        orchestrator['gvnfm']['userdata']['url'])
+    userdata += "sed -i '113i"'\ \ \ \ '"sleep 60' " \
+                "/etc/openbaton/openbaton-vnfm-generic-user-data.sh\n"
+    userdata += "echo \"Starting NFVO\"\n"
+    userdata += "service openbaton-nfvo restart\n"
+    userdata += "echo \"Starting Generic VNFM\"\n"
+    userdata += "service openbaton-vnfm-generic restart\n"
+    userdata += "echo \"...end of userdata...\"\n"
+    return userdata
+
+
+class ClearwaterImsVnf(vnf.VnfOnBoarding):
+    """Clearwater IMS VNF deployed with openBaton orchestrator"""
+
+    logger = logging.getLogger(__name__)
+
+    def __init__(self, **kwargs):
+        if "case_name" not in kwargs:
+            kwargs["case_name"] = "orchestra_clearwaterims"
+        super(ClearwaterImsVnf, self).__init__(**kwargs)
+        # self.logger = logging.getLogger("functest.ci.run_tests.orchestra")
+        self.logger.info("kwargs %s", (kwargs))
+
+        self.case_dir = pkg_resources.resource_filename(
+            'functest', 'opnfv_tests/vnf/ims/')
+        self.data_dir = CONST.__getattribute__('dir_ims_data')
+        self.test_dir = CONST.__getattribute__('dir_repo_vims_test')
+        self.created_resources = []
+        self.logger.info("%s VNF onboarding test starting", self.case_name)
+
+        try:
+            self.config = CONST.__getattribute__(
+                'vnf_{}_config'.format(self.case_name))
+        except BaseException:
+            raise Exception("Orchestra VNF config file not found")
+        config_file = self.case_dir + self.config
+
+        self.mano = dict(
+            get_config("mano", config_file),
+            details={}
+        )
+        self.logger.debug("Orchestrator configuration %s", self.mano)
+
+        self.details['orchestrator'] = dict(
+            name=self.mano['name'],
+            version=self.mano['version'],
+            status='ERROR',
+            result=''
+        )
+
+        self.vnf = dict(
+            get_config(self.case_name, config_file),
+        )
+        self.logger.debug("VNF configuration: %s", self.vnf)
+
+        self.details['vnf'] = dict(
+            name=self.vnf['name'],
+        )
+
+        self.details['test_vnf'] = dict(
+            name=self.case_name,
+        )
+
+        # Orchestra base Data directory creation
+        if not os.path.exists(self.data_dir):
+            os.makedirs(self.data_dir)
+
+        self.images = get_config(
+            "tenant_images.%s" %
+            self.case_name, config_file)
+        self.images.update(
+            get_config(
+                "tenant_images.%s" %
+                self.case_name,
+                config_file))
+        self.snaps_creds = None
+
+    def prepare(self):
+        """Prepare testscase (Additional pre-configuration steps)."""
+        super(ClearwaterImsVnf, self).prepare()
+
+        self.logger.info("Additional pre-configuration steps")
+        self.logger.info("creds %s", (self.creds))
+
+        self.snaps_creds = OSCreds(
+            username=self.creds['username'],
+            password=self.creds['password'],
+            auth_url=self.creds['auth_url'],
+            project_name=self.creds['tenant'],
+            identity_api_version=int(os_utils.get_keystone_client_version()))
+
+        self.prepare_images()
+        self.prepare_flavor()
+        self.prepare_security_groups()
+        self.prepare_network()
+        self.prepare_floating_ip()
+
+    def prepare_images(self):
+        """Upload images if they doen't exist yet"""
+        self.logger.info("Upload images if they doen't exist yet")
+        for image_name, image_url in self.images.iteritems():
+            self.logger.info("image: %s, url: %s", image_name, image_url)
+            if image_url and image_name:
+                image = OpenStackImage(
+                    self.snaps_creds,
+                    ImageSettings(name=image_name,
+                                  image_user='cloud',
+                                  img_format='qcow2',
+                                  url=image_url))
+                image.create()
+                # self.created_resources.append(image);
+
+    def prepare_security_groups(self):
+        """Create Open Baton security group if it doesn't exist yet"""
+        self.logger.info(
+            "Creating security group for Open Baton if not yet existing...")
+        sg_rules = list()
+        sg_rules.append(
+            SecurityGroupRuleSettings(
+                sec_grp_name="orchestra-sec-group-allowall",
+                direction=Direction.ingress,
+                protocol=Protocol.tcp,
+                port_range_min=1,
+                port_range_max=65535))
+        sg_rules.append(
+            SecurityGroupRuleSettings(
+                sec_grp_name="orchestra-sec-group-allowall",
+                direction=Direction.egress,
+                protocol=Protocol.tcp,
+                port_range_min=1,
+                port_range_max=65535))
+        sg_rules.append(
+            SecurityGroupRuleSettings(
+                sec_grp_name="orchestra-sec-group-allowall",
+                direction=Direction.ingress,
+                protocol=Protocol.udp,
+                port_range_min=1,
+                port_range_max=65535))
+        sg_rules.append(
+            SecurityGroupRuleSettings(
+                sec_grp_name="orchestra-sec-group-allowall",
+                direction=Direction.egress,
+                protocol=Protocol.udp,
+                port_range_min=1,
+                port_range_max=65535))
+        sg_rules.append(
+            SecurityGroupRuleSettings(
+                sec_grp_name="orchestra-sec-group-allowall",
+                direction=Direction.ingress,
+                protocol=Protocol.icmp))
+        sg_rules.append(
+            SecurityGroupRuleSettings(
+                sec_grp_name="orchestra-sec-group-allowall",
+                direction=Direction.egress,
+                protocol=Protocol.icmp))
+        # sg_rules.append(
+        #     SecurityGroupRuleSettings(
+        #         sec_grp_name="orchestra-sec-group-allowall",
+        #         direction=Direction.ingress,
+        #         protocol=Protocol.icmp,
+        #         port_range_min=-1,
+        #         port_range_max=-1))
+        # sg_rules.append(
+        #     SecurityGroupRuleSettings(
+        #         sec_grp_name="orchestra-sec-group-allowall",
+        #         direction=Direction.egress,
+        #         protocol=Protocol.icmp,
+        #         port_range_min=-1,
+        #         port_range_max=-1))
+
+        security_group = OpenStackSecurityGroup(
+            self.snaps_creds,
+            SecurityGroupSettings(
+                name="orchestra-sec-group-allowall",
+                rule_settings=sg_rules))
+
+        security_group_info = security_group.create()
+        self.created_resources.append(security_group)
+        self.mano['details']['sec_group'] = security_group_info.name
+        self.logger.info(
+            "Security group orchestra-sec-group-allowall prepared")
+
+    def prepare_flavor(self):
+        """Create Open Baton flavor if it doesn't exist yet"""
+        self.logger.info(
+            "Create Flavor for Open Baton NFVO if not yet existing")
+
+        flavor_settings = FlavorSettings(
+            name=self.mano['requirements']['flavor']['name'],
+            ram=self.mano['requirements']['flavor']['ram_min'],
+            disk=self.mano['requirements']['flavor']['disk'],
+            vcpus=self.mano['requirements']['flavor']['vcpus'])
+        flavor = OpenStackFlavor(self.snaps_creds, flavor_settings)
+        flavor_info = flavor.create()
+        self.created_resources.append(flavor)
+        self.mano['details']['flavor'] = {}
+        self.mano['details']['flavor']['name'] = flavor_settings.name
+        self.mano['details']['flavor']['id'] = flavor_info.id
+
+    def prepare_network(self):
+        """Create network/subnet/router if they doen't exist yet"""
+        self.logger.info(
+            "Creating network/subnet/router if they doen't exist yet...")
+        subnet_settings = SubnetSettings(
+            name='%s_subnet' %
+            self.case_name,
+            cidr="192.168.100.0/24")
+        network_settings = NetworkSettings(
+            name='%s_net' %
+            self.case_name,
+            subnet_settings=[subnet_settings])
+        orchestra_network = OpenStackNetwork(
+            self.snaps_creds, network_settings)
+        orchestra_network_info = orchestra_network.create()
+        self.mano['details']['network'] = {}
+        self.mano['details']['network']['id'] = orchestra_network_info.id
+        self.mano['details']['network']['name'] = orchestra_network_info.name
+        self.mano['details']['external_net_name'] = snaps_utils.\
+            get_ext_net_name(self.snaps_creds)
+        self.created_resources.append(orchestra_network)
+        orchestra_router = OpenStackRouter(
+            self.snaps_creds,
+            RouterSettings(
+                name='%s_router' %
+                self.case_name,
+                external_gateway=self.mano['details']['external_net_name'],
+                internal_subnets=[
+                    subnet_settings.name]))
+        orchestra_router.create()
+        self.created_resources.append(orchestra_router)
+        self.logger.info("Created network and router for Open Baton NFVO...")
+
+    def prepare_floating_ip(self):
+        """Select/Create Floating IP if it doesn't exist yet"""
+        self.logger.info("Retrieving floating IP for Open Baton NFVO")
+        neutron_client = snaps_utils.neutron_utils.neutron_client(
+            self.snaps_creds)
+        # Finding Tenant ID to check to which tenant the Floating IP belongs
+        tenant_id = os_utils.get_tenant_id(
+            os_utils.get_keystone_client(self.creds),
+            self.tenant_name)
+        # Use os_utils to retrieve complete information of Floating IPs
+        floating_ips = os_utils.get_floating_ips(neutron_client)
+        my_floating_ips = []
+        # Filter Floating IPs with tenant id
+        for floating_ip in floating_ips:
+            # self.logger.info("Floating IP: %s", floating_ip)
+            if floating_ip.get('tenant_id') == tenant_id:
+                my_floating_ips.append(floating_ip.get('floating_ip_address'))
+        # Select if Floating IP exist else create new one
+        if len(my_floating_ips) >= 1:
+            # Get Floating IP object from snaps for clean up
+            snaps_floating_ips = snaps_utils.neutron_utils.get_floating_ips(
+                neutron_client)
+            for my_floating_ip in my_floating_ips:
+                for snaps_floating_ip in snaps_floating_ips:
+                    if snaps_floating_ip.ip == my_floating_ip:
+                        self.mano['details']['fip'] = snaps_floating_ip
+                        self.logger.info(
+                            "Selected floating IP for Open Baton NFVO %s",
+                            (self.mano['details']['fip'].ip))
+                        break
+                if self.mano['details']['fip'] is not None:
+                    break
+        else:
+            self.logger.info("Creating floating IP for Open Baton NFVO")
+            self.mano['details']['fip'] = snaps_utils.neutron_utils.\
+                create_floating_ip(
+                    neutron_client,
+                    self.mano['details']['external_net_name'])
+            self.logger.info(
+                "Created floating IP for Open Baton NFVO %s",
+                (self.mano['details']['fip'].ip))
+
+    def get_vim_descriptor(self):
+        """"Create VIM descriptor to be used for onboarding"""
+        self.logger.info(
+            "Building VIM descriptor with PoP creds: %s",
+            self.creds)
+        # Depending on API version either tenant ID or project name must be
+        # used
+        if os_utils.is_keystone_v3():
+            self.logger.info(
+                "Using v3 API of OpenStack... -> Using OS_PROJECT_ID")
+            project_id = os_utils.get_tenant_id(
+                os_utils.get_keystone_client(),
+                self.creds.get("project_name"))
+        else:
+            self.logger.info(
+                "Using v2 API of OpenStack... -> Using OS_TENANT_NAME")
+            project_id = self.creds.get("tenant_name")
+        self.logger.debug("VIM project/tenant id: %s", project_id)
+        vim_json = {
+            "name": "vim-instance",
+            "authUrl": self.creds.get("auth_url"),
+            "tenant": project_id,
+            "username": self.creds.get("username"),
+            "password": self.creds.get("password"),
+            "securityGroups": [
+                self.mano['details']['sec_group']
+            ],
+            "type": "openstack",
+            "location": {
+                "name": "opnfv",
+                "latitude": "52.525876",
+                "longitude": "13.314400"
+            }
+        }
+        self.logger.info("Built VIM descriptor: %s", vim_json)
+        return vim_json
+
+    def deploy_orchestrator(self):
+        self.logger.info("Deploying Open Baton...")
+        self.logger.info("Details: %s", self.mano['details'])
+        start_time = time.time()
+
+        self.logger.info("Creating orchestra instance...")
+        userdata = get_userdata(self.mano)
+        self.logger.info("flavor: %s\n"
+                         "image: %s\n"
+                         "network_id: %s\n",
+                         self.mano['details']['flavor']['name'],
+                         self.mano['requirements']['image'],
+                         self.mano['details']['network']['id'])
+        self.logger.debug("userdata: %s\n", userdata)
+        # setting up image
+        image_settings = ImageSettings(
+            name=self.mano['requirements']['image'],
+            image_user='ubuntu',
+            exists=True)
+        # setting up port
+        port_settings = PortSettings(
+            name='%s_port' % self.case_name,
+            network_name=self.mano['details']['network']['name'])
+        # build configuration of vm
+        orchestra_settings = VmInstanceSettings(
+            name=self.case_name,
+            flavor=self.mano['details']['flavor']['name'],
+            port_settings=[port_settings],
+            security_group_names=[self.mano['details']['sec_group']],
+            userdata=userdata)
+        orchestra_vm = OpenStackVmInstance(self.snaps_creds,
+                                           orchestra_settings,
+                                           image_settings)
+
+        orchestra_vm.create()
+        self.created_resources.append(orchestra_vm)
+        self.mano['details']['id'] = orchestra_vm.get_vm_info()['id']
+        self.logger.info(
+            "Created orchestra instance: %s",
+            self.mano['details']['id'])
+
+        self.logger.info("Associating floating ip: '%s' to VM '%s' ",
+                         self.mano['details']['fip'].ip,
+                         self.case_name)
+        nova_client = os_utils.get_nova_client()
+        if not os_utils.add_floating_ip(
+                nova_client,
+                self.mano['details']['id'],
+                self.mano['details']['fip'].ip):
+            duration = time.time() - start_time
+            self.details["orchestrator"].update(
+                status='FAIL', duration=duration)
+            self.logger.error("Cannot associate floating IP to VM.")
+            return False
+
+        self.logger.info("Waiting for Open Baton NFVO to be up and running...")
+        timeout = 0
+        while timeout < 200:
+            if servertest(
+                    self.mano['details']['fip'].ip,
+                    "8080"):
+                break
+            else:
+                self.logger.info(
+                    "Open Baton NFVO is not started yet (%ss)",
+                    (timeout * 5))
+                time.sleep(5)
+                timeout += 1
+
+        if timeout >= 200:
+            duration = time.time() - start_time
+            self.details["orchestrator"].update(
+                status='FAIL', duration=duration)
+            self.logger.error("Open Baton is not started correctly")
+            return False
+
+        self.logger.info("Waiting for all components to be up and running...")
+        time.sleep(60)
+        duration = time.time() - start_time
+        self.details["orchestrator"].update(status='PASS', duration=duration)
+        self.logger.info("Deploy Open Baton NFVO: OK")
+        return True
+
+    def deploy_vnf(self):
+        start_time = time.time()
+        self.logger.info("Deploying %s...", self.vnf['name'])
+
+        main_agent = MainAgent(
+            nfvo_ip=self.mano['details']['fip'].ip,
+            nfvo_port=8080,
+            https=False,
+            version=1,
+            username=self.mano['credentials']['username'],
+            password=self.mano['credentials']['password'])
+
+        self.logger.info(
+            "Create %s Flavor if not existing", self.vnf['name'])
+        flavor_settings = FlavorSettings(
+            name=self.vnf['requirements']['flavor']['name'],
+            ram=self.vnf['requirements']['flavor']['ram_min'],
+            disk=self.vnf['requirements']['flavor']['disk'],
+            vcpus=self.vnf['requirements']['flavor']['vcpus'])
+        flavor = OpenStackFlavor(self.snaps_creds, flavor_settings)
+        flavor_info = flavor.create()
+        self.logger.debug("Flavor id: %s", flavor_info.id)
+
+        self.logger.info("Getting project 'default'...")
+        project_agent = main_agent.get_agent("project", "")
+        for project in json.loads(project_agent.find()):
+            if project.get("name") == "default":
+                self.mano['details']['project_id'] = project.get("id")
+                self.logger.info("Found project 'default': %s", project)
+                break
+
+        vim_json = self.get_vim_descriptor()
+        self.logger.info("Registering VIM: %s", vim_json)
+
+        main_agent.get_agent(
+            "vim", project_id=self.mano['details']['project_id']).create(
+                entity=json.dumps(vim_json))
+
+        market_agent = main_agent.get_agent(
+            "market", project_id=self.mano['details']['project_id'])
+
+        try:
+            self.logger.info("sending: %s", self.vnf['descriptor']['url'])
+            nsd = market_agent.create(entity=self.vnf['descriptor']['url'])
+            if nsd.get('id') is None:
+                self.logger.error("NSD not onboarded correctly")
+                duration = time.time() - start_time
+                self.details["vnf"].update(status='FAIL', duration=duration)
+                return False
+            self.mano['details']['nsd_id'] = nsd.get('id')
+            self.logger.info("Onboarded NSD: " + nsd.get("name"))
+
+            nsr_agent = main_agent.get_agent(
+                "nsr", project_id=self.mano['details']['project_id'])
+
+            self.mano['details']['nsr'] = nsr_agent.create(
+                self.mano['details']['nsd_id'])
+        except NfvoException as exc:
+            self.logger.error(exc.message)
+            duration = time.time() - start_time
+            self.details["vnf"].update(status='FAIL', duration=duration)
+            return False
+
+        if self.mano['details']['nsr'].get('code') is not None:
+            self.logger.error(
+                "%s cannot be deployed: %s -> %s",
+                self.vnf['name'],
+                self.mano['details']['nsr'].get('code'),
+                self.mano['details']['nsr'].get('message'))
+            self.logger.error("%s cannot be deployed", self.vnf['name'])
+            duration = time.time() - start_time
+            self.details["vnf"].update(status='FAIL', duration=duration)
+            return False
+
+        timeout = 0
+        self.logger.info("Waiting for NSR to go to ACTIVE...")
+        while self.mano['details']['nsr'].get("status") != 'ACTIVE' \
+                and self.mano['details']['nsr'].get("status") != 'ERROR':
+            timeout += 1
+            self.logger.info("NSR is not yet ACTIVE... (%ss)", 5 * timeout)
+            if timeout == 300:
+                self.logger.error("INACTIVE NSR after %s sec..", 5 * timeout)
+                duration = time.time() - start_time
+                self.details["vnf"].update(status='FAIL', duration=duration)
+                return False
+            time.sleep(5)
+            self.mano['details']['nsr'] = json.loads(
+                nsr_agent.find(self.mano['details']['nsr'].get('id')))
+
+        duration = time.time() - start_time
+        if self.mano['details']['nsr'].get("status") == 'ACTIVE':
+            self.details["vnf"].update(status='PASS', duration=duration)
+            self.logger.info("Sleep for 60s to ensure that all "
+                             "services are up and running...")
+            time.sleep(60)
+            result = True
+        else:
+            self.details["vnf"].update(status='FAIL', duration=duration)
+            self.logger.error("NSR: %s", self.mano['details'].get('nsr'))
+            result = False
+        return result
+
+    def test_vnf(self):
+        self.logger.info(
+            "Testing VNF Clearwater IMS is not yet implemented...")
+        start_time = time.time()
+
+        duration = time.time() - start_time
+        self.details["test_vnf"].update(status='PASS', duration=duration)
+        self.logger.info("Test VNF: OK")
+        return True
+
+    def clean(self):
+        self.logger.info("Cleaning %s...", self.case_name)
+        try:
+            main_agent = MainAgent(
+                nfvo_ip=self.mano['details']['fip'].ip,
+                nfvo_port=8080,
+                https=False,
+                version=1,
+                username=self.mano['credentials']['username'],
+                password=self.mano['credentials']['password'])
+            self.logger.info("Terminating %s...", self.vnf['name'])
+            if (self.mano['details'].get('nsr')):
+                main_agent.get_agent(
+                    "nsr",
+                    project_id=self.mano['details']['project_id']).delete(
+                        self.mano['details']['nsr'].get('id'))
+                self.logger.info("Sleeping 60 seconds...")
+                time.sleep(60)
+            else:
+                self.logger.info("No need to terminate the VNF...")
+            # os_utils.delete_instance(nova_client=os_utils.get_nova_client(),
+            #                          instance_id=self.mano_instance_id)
+        except (NfvoException, KeyError) as exc:
+            self.logger.error('Unexpected error cleaning - %s', exc)
+
+        try:
+            neutron_client = os_utils.get_neutron_client(self.creds)
+            self.logger.info("Deleting Open Baton Port...")
+            port = snaps_utils.neutron_utils.get_port_by_name(
+                neutron_client, '%s_port' % self.case_name)
+            snaps_utils.neutron_utils.delete_port(neutron_client, port)
+            time.sleep(10)
+        except Exception as exc:
+            self.logger.error('Unexpected error cleaning - %s', exc)
+        try:
+            self.logger.info("Deleting Open Baton Floating IP...")
+            snaps_utils.neutron_utils.delete_floating_ip(
+                neutron_client, self.mano['details']['fip'])
+        except Exception as exc:
+            self.logger.error('Unexpected error cleaning - %s', exc)
+
+        for resource in reversed(self.created_resources):
+            try:
+                self.logger.info("Cleaning %s", str(resource))
+                resource.clean()
+            except Exception as exc:
+                self.logger.error('Unexpected error cleaning - %s', exc)
+        super(ClearwaterImsVnf, self).clean()
diff --git a/functest/opnfv_tests/vnf/ims/orchestra_ims.yaml b/functest/opnfv_tests/vnf/ims/orchestra_ims.yaml
deleted file mode 100644 (file)
index 9deb11c..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-tenant_images:
-    ubuntu_14.04: http://cloud-images.ubuntu.com/trusty/current/trusty-server-cloudimg-amd64-disk1.img
-    openims: http://marketplace.openbaton.org:8082/api/v1/images/52e2ccc0-1dce-4663-894d-28aab49323aa/img
-orchestrator:
-    name: openbaton
-    version: '3.2.0'
-    requirements:
-        flavor:
-          name: orchestra
-          ram_min: 4096
-          disk: 5
-          vcpus: 2
-        os_image: 'ubuntu_14.04'
-    bootstrap:
-        url: http://get.openbaton.org/bootstraps/bootstrap_3.2.0_opnfv/bootstrap
-        config:
-            url: http://get.openbaton.org/bootstraps/bootstrap_3.2.0_opnfv/bootstrap-config-file
-    gvnfm:
-        userdata:
-            url: https://raw.githubusercontent.com/openbaton/generic-vnfm/3.2.0/src/main/resources/user-data.sh
-    credentials:
-        username: admin
-        password: openbaton
-vnf:
-    name: openims
-    descriptor:
-        url: http://marketplace.openbaton.org:8082/api/v1/nsds/fokus/OpenImsCore/3.2.0/json
-    requirements:
-        flavor:
-          name: m1.small
-          ram_min: 2048
-          disk: 5
-          vcpus: 2
-
-vIMS:
-    scscf:
-        ports: [3870, 6060]
-    pcscf:
-        ports: [4060]
-    icscf:
-        ports: [3869, 5060]
-    fhoss:
-        ports: [3868]
-    bind9:
-        ports: []
\ No newline at end of file
@@ -139,16 +139,16 @@ def get_userdata(orchestrator=dict):
     return userdata
 
 
-class ImsVnf(vnf.VnfOnBoarding):
+class OpenImsVnf(vnf.VnfOnBoarding):
     """OpenIMS VNF deployed with openBaton orchestrator"""
 
-    logger = logging.getLogger(__name__)
+    logger = logging.getLogger(__name__)
 
     def __init__(self, **kwargs):
         if "case_name" not in kwargs:
-            kwargs["case_name"] = "orchestra_ims"
-        super(ImsVnf, self).__init__(**kwargs)
-        self.logger = logging.getLogger("functest.ci.run_tests.orchestra")
+            kwargs["case_name"] = "orchestra_openims"
+        super(OpenImsVnf, self).__init__(**kwargs)
+        self.logger = logging.getLogger("functest.ci.run_tests.orchestra")
         self.logger.info("kwargs %s", (kwargs))
 
         self.case_dir = pkg_resources.resource_filename(
@@ -156,7 +156,7 @@ class ImsVnf(vnf.VnfOnBoarding):
         self.data_dir = CONST.__getattribute__('dir_ims_data')
         self.test_dir = CONST.__getattribute__('dir_repo_vims_test')
         self.created_resources = []
-        self.logger.info("Orchestra IMS VNF onboarding test starting")
+        self.logger.info("%s VNF onboarding test starting", self.case_name)
 
         try:
             self.config = CONST.__getattribute__(
@@ -165,48 +165,45 @@ class ImsVnf(vnf.VnfOnBoarding):
             raise Exception("Orchestra VNF config file not found")
         config_file = self.case_dir + self.config
 
-        self.baton = dict(
-            requirements=get_config("orchestrator.requirements", config_file),
-            credentials=get_config("orchestrator.credentials", config_file),
-            bootstrap=get_config("orchestrator.bootstrap", config_file),
-            gvnfm=get_config("orchestrator.gvnfm", config_file),
+        self.mano = dict(
+            get_config("mano", config_file),
+            details={}
         )
-        self.logger.debug("Orchestrator configuration %s", self.baton)
+        self.logger.debug("Orchestrator configuration %s", self.mano)
 
         self.details['orchestrator'] = dict(
-            name=get_config("orchestrator.name", config_file),
-            version=get_config("orchestrator.version", config_file),
+            name=self.mano['name'],
+            version=self.mano['version'],
             status='ERROR',
             result=''
         )
-        self.baton['details'] = {}
-        self.baton['details']['image'] = self.baton['requirements']['os_image']
-        self.baton['details']['name'] = self.details['orchestrator']['name']
 
         self.vnf = dict(
-            descriptor=get_config("vnf.descriptor", config_file),
-            requirements=get_config("vnf.requirements", config_file)
+            get_config(self.case_name, config_file),
         )
+        self.logger.debug("VNF configuration: %s", self.vnf)
+
         self.details['vnf'] = dict(
-            name=get_config("vnf.name", config_file),
+            name=self.vnf['name'],
         )
-        self.logger.debug("VNF configuration: %s", self.vnf)
 
         self.details['test_vnf'] = dict(
-            name="openims-test",
+            name=self.case_name,
         )
 
-        # vIMS Data directory creation
+        # Orchestra base Data directory creation
         if not os.path.exists(self.data_dir):
             os.makedirs(self.data_dir)
 
-        self.images = get_config("tenant_images", config_file)
-        self.ims_conf = get_config("vIMS", config_file)
+        self.images = get_config("tenant_images.%s" %
+                                 self.case_name, config_file)
+        self.images.update(get_config("tenant_images.%s" %
+                                      self.case_name, config_file))
         self.snaps_creds = None
 
     def prepare(self):
         """Prepare testscase (Additional pre-configuration steps)."""
-        super(ImsVnf, self).prepare()
+        super(OpenImsVnf, self).prepare()
 
         self.logger.info("Additional pre-configuration steps")
         self.logger.info("creds %s", (self.creds))
@@ -272,6 +269,16 @@ class ImsVnf(vnf.VnfOnBoarding):
                 protocol=Protocol.udp,
                 port_range_min=1,
                 port_range_max=65535))
+        sg_rules.append(
+            SecurityGroupRuleSettings(
+                sec_grp_name="orchestra-sec-group-allowall",
+                direction=Direction.ingress,
+                protocol=Protocol.icmp))
+        sg_rules.append(
+            SecurityGroupRuleSettings(
+                sec_grp_name="orchestra-sec-group-allowall",
+                direction=Direction.egress,
+                protocol=Protocol.icmp))
         # sg_rules.append(
         #     SecurityGroupRuleSettings(
         #         sec_grp_name="orchestra-sec-group-allowall",
@@ -295,7 +302,7 @@ class ImsVnf(vnf.VnfOnBoarding):
 
         security_group_info = security_group.create()
         self.created_resources.append(security_group)
-        self.baton['details']['sec_group'] = security_group_info.name
+        self.mano['details']['sec_group'] = security_group_info.name
         self.logger.info(
             "Security group orchestra-sec-group-allowall prepared")
 
@@ -305,16 +312,16 @@ class ImsVnf(vnf.VnfOnBoarding):
             "Create Flavor for Open Baton NFVO if not yet existing")
 
         flavor_settings = FlavorSettings(
-            name=self.baton['requirements']['flavor']['name'],
-            ram=self.baton['requirements']['flavor']['ram_min'],
-            disk=self.baton['requirements']['flavor']['disk'],
-            vcpus=self.baton['requirements']['flavor']['vcpus'])
+            name=self.mano['requirements']['flavor']['name'],
+            ram=self.mano['requirements']['flavor']['ram_min'],
+            disk=self.mano['requirements']['flavor']['disk'],
+            vcpus=self.mano['requirements']['flavor']['vcpus'])
         flavor = OpenStackFlavor(self.snaps_creds, flavor_settings)
         flavor_info = flavor.create()
         self.created_resources.append(flavor)
-        self.baton['details']['flavor'] = {}
-        self.baton['details']['flavor']['name'] = flavor_settings.name
-        self.baton['details']['flavor']['id'] = flavor_info.id
+        self.mano['details']['flavor'] = {}
+        self.mano['details']['flavor']['name'] = flavor_settings.name
+        self.mano['details']['flavor']['id'] = flavor_info.id
 
     def prepare_network(self):
         """Create network/subnet/router if they doen't exist yet"""
@@ -322,27 +329,27 @@ class ImsVnf(vnf.VnfOnBoarding):
             "Creating network/subnet/router if they doen't exist yet...")
         subnet_settings = SubnetSettings(
             name='%s_subnet' %
-            self.baton['details']['name'],
+            self.case_name,
             cidr="192.168.100.0/24")
         network_settings = NetworkSettings(
             name='%s_net' %
-            self.baton['details']['name'],
+            self.case_name,
             subnet_settings=[subnet_settings])
         orchestra_network = OpenStackNetwork(
             self.snaps_creds, network_settings)
         orchestra_network_info = orchestra_network.create()
-        self.baton['details']['network'] = {}
-        self.baton['details']['network']['id'] = orchestra_network_info.id
-        self.baton['details']['network']['name'] = orchestra_network_info.name
-        self.baton['details']['external_net_name'] = \
+        self.mano['details']['network'] = {}
+        self.mano['details']['network']['id'] = orchestra_network_info.id
+        self.mano['details']['network']['name'] = orchestra_network_info.name
+        self.mano['details']['external_net_name'] = \
             snaps_utils.get_ext_net_name(self.snaps_creds)
         self.created_resources.append(orchestra_network)
         orchestra_router = OpenStackRouter(
             self.snaps_creds,
             RouterSettings(
                 name='%s_router' %
-                self.baton['details']['name'],
-                external_gateway=self.baton['details']['external_net_name'],
+                self.case_name,
+                external_gateway=self.mano['details']['external_net_name'],
                 internal_subnets=[
                     subnet_settings.name]))
         orchestra_router.create()
@@ -374,21 +381,21 @@ class ImsVnf(vnf.VnfOnBoarding):
             for my_floating_ip in my_floating_ips:
                 for snaps_floating_ip in snaps_floating_ips:
                     if snaps_floating_ip.ip == my_floating_ip:
-                        self.baton['details']['fip'] = snaps_floating_ip
+                        self.mano['details']['fip'] = snaps_floating_ip
                         self.logger.info(
                             "Selected floating IP for Open Baton NFVO %s",
-                            (self.baton['details']['fip'].ip))
+                            (self.mano['details']['fip'].ip))
                         break
-                if self.baton['details']['fip'] is not None:
+                if self.mano['details']['fip'] is not None:
                     break
         else:
             self.logger.info("Creating floating IP for Open Baton NFVO")
-            self.baton['details']['fip'] = \
-                snaps_utils.neutron_utils.create_floating_ip(
-                    neutron_client, self.baton['details']['external_net_name'])
+            self.mano['details']['fip'] = (
+                snaps_utils.neutron_utils. create_floating_ip(
+                    neutron_client, self.mano['details']['external_net_name']))
             self.logger.info(
                 "Created floating IP for Open Baton NFVO %s",
-                (self.baton['details']['fip'].ip))
+                (self.mano['details']['fip'].ip))
 
     def get_vim_descriptor(self):
         """"Create VIM descriptor to be used for onboarding"""
@@ -415,7 +422,7 @@ class ImsVnf(vnf.VnfOnBoarding):
             "username": self.creds.get("username"),
             "password": self.creds.get("password"),
             "securityGroups": [
-                self.baton['details']['sec_group']
+                self.mano['details']['sec_group']
             ],
             "type": "openstack",
             "location": {
@@ -428,34 +435,34 @@ class ImsVnf(vnf.VnfOnBoarding):
         return vim_json
 
     def deploy_orchestrator(self):
-        self.logger.info("Deploying orchestrator Open Baton ...")
-        self.logger.info("Details: %s", self.baton['details'])
+        self.logger.info("Deploying Open Baton...")
+        self.logger.info("Details: %s", self.mano['details'])
         start_time = time.time()
 
         self.logger.info("Creating orchestra instance...")
-        userdata = get_userdata(self.baton)
+        userdata = get_userdata(self.mano)
         self.logger.info("flavor: %s\n"
                          "image: %s\n"
                          "network_id: %s\n",
-                         self.baton['details']['flavor']['name'],
-                         self.baton['details']['image'],
-                         self.baton['details']['network']['id'])
+                         self.mano['details']['flavor']['name'],
+                         self.mano['requirements']['image'],
+                         self.mano['details']['network']['id'])
         self.logger.debug("userdata: %s\n", userdata)
         # setting up image
         image_settings = ImageSettings(
-            name=self.baton['details']['image'],
+            name=self.mano['requirements']['image'],
             image_user='ubuntu',
             exists=True)
         # setting up port
         port_settings = PortSettings(
-            name='%s_port' % self.baton['details']['name'],
-            network_name=self.baton['details']['network']['name'])
+            name='%s_port' % self.case_name,
+            network_name=self.mano['details']['network']['name'])
         # build configuration of vm
         orchestra_settings = VmInstanceSettings(
-            name=self.baton['details']['name'],
-            flavor=self.baton['details']['flavor']['name'],
+            name=self.case_name,
+            flavor=self.mano['details']['flavor']['name'],
             port_settings=[port_settings],
-            security_group_names=[self.baton['details']['sec_group']],
+            security_group_names=[self.mano['details']['sec_group']],
             userdata=userdata)
         orchestra_vm = OpenStackVmInstance(self.snaps_creds,
                                            orchestra_settings,
@@ -463,19 +470,19 @@ class ImsVnf(vnf.VnfOnBoarding):
 
         orchestra_vm.create()
         self.created_resources.append(orchestra_vm)
-        self.baton['details']['id'] = orchestra_vm.get_vm_info()['id']
+        self.mano['details']['id'] = orchestra_vm.get_vm_info()['id']
         self.logger.info(
             "Created orchestra instance: %s",
-            self.baton['details']['id'])
+            self.mano['details']['id'])
 
         self.logger.info("Associating floating ip: '%s' to VM '%s' ",
-                         self.baton['details']['fip'].ip,
-                         self.baton['details']['name'])
+                         self.mano['details']['fip'].ip,
+                         self.case_name)
         nova_client = os_utils.get_nova_client()
         if not os_utils.add_floating_ip(
                 nova_client,
-                self.baton['details']['id'],
-                self.baton['details']['fip'].ip):
+                self.mano['details']['id'],
+                self.mano['details']['fip'].ip):
             duration = time.time() - start_time
             self.details["orchestrator"].update(
                 status='FAIL', duration=duration)
@@ -486,7 +493,7 @@ class ImsVnf(vnf.VnfOnBoarding):
         timeout = 0
         while timeout < 200:
             if servertest(
-                    self.baton['details']['fip'].ip,
+                    self.mano['details']['fip'].ip,
                     "8080"):
                 break
             else:
@@ -511,18 +518,18 @@ class ImsVnf(vnf.VnfOnBoarding):
 
     def deploy_vnf(self):
         start_time = time.time()
-        self.logger.info("Deploying OpenIMS...")
+        self.logger.info("Deploying %s...", self.vnf['name'])
 
         main_agent = MainAgent(
-            nfvo_ip=self.baton['details']['fip'].ip,
+            nfvo_ip=self.mano['details']['fip'].ip,
             nfvo_port=8080,
             https=False,
             version=1,
-            username=self.baton['credentials']['username'],
-            password=self.baton['credentials']['password'])
+            username=self.mano['credentials']['username'],
+            password=self.mano['credentials']['password'])
 
         self.logger.info(
-            "Check if openims Flavor is available, if not, create one")
+            "Create %s Flavor if not existing", self.vnf['name'])
         flavor_settings = FlavorSettings(
             name=self.vnf['requirements']['flavor']['name'],
             ram=self.vnf['requirements']['flavor']['ram_min'],
@@ -536,7 +543,7 @@ class ImsVnf(vnf.VnfOnBoarding):
         project_agent = main_agent.get_agent("project", "")
         for project in json.loads(project_agent.find()):
             if project.get("name") == "default":
-                self.baton['details']['project_id'] = project.get("id")
+                self.mano['details']['project_id'] = project.get("id")
                 self.logger.info("Found project 'default': %s", project)
                 break
 
@@ -544,11 +551,11 @@ class ImsVnf(vnf.VnfOnBoarding):
         self.logger.info("Registering VIM: %s", vim_json)
 
         main_agent.get_agent(
-            "vim", project_id=self.baton['details']['project_id']).create(
+            "vim", project_id=self.mano['details']['project_id']).create(
                 entity=json.dumps(vim_json))
 
         market_agent = main_agent.get_agent(
-            "market", project_id=self.baton['details']['project_id'])
+            "market", project_id=self.mano['details']['project_id'])
 
         try:
             self.logger.info("sending: %s", self.vnf['descriptor']['url'])
@@ -558,47 +565,48 @@ class ImsVnf(vnf.VnfOnBoarding):
                 duration = time.time() - start_time
                 self.details["vnf"].update(status='FAIL', duration=duration)
                 return False
-            self.baton['details']['nsd_id'] = nsd.get('id')
+            self.mano['details']['nsd_id'] = nsd.get('id')
             self.logger.info("Onboarded NSD: " + nsd.get("name"))
 
             nsr_agent = main_agent.get_agent(
-                "nsr", project_id=self.baton['details']['project_id'])
+                "nsr", project_id=self.mano['details']['project_id'])
 
-            self.baton['details']['nsr'] = nsr_agent.create(
-                self.baton['details']['nsd_id'])
+            self.mano['details']['nsr'] = nsr_agent.create(
+                self.mano['details']['nsd_id'])
         except NfvoException as exc:
             self.logger.error(exc.message)
             duration = time.time() - start_time
             self.details["vnf"].update(status='FAIL', duration=duration)
             return False
 
-        if self.baton['details']['nsr'].get('code') is not None:
+        if self.mano['details']['nsr'].get('code') is not None:
             self.logger.error(
-                "vIMS cannot be deployed: %s -> %s",
-                self.baton['details']['nsr'].get('code'),
-                self.baton['details']['nsr'].get('message'))
-            self.logger.error("vIMS cannot be deployed")
+                "%s cannot be deployed: %s -> %s",
+                self.vnf['name'],
+                self.mano['details']['nsr'].get('code'),
+                self.mano['details']['nsr'].get('message'))
+            self.logger.error("%s cannot be deployed", self.vnf['name'])
             duration = time.time() - start_time
             self.details["vnf"].update(status='FAIL', duration=duration)
             return False
 
         timeout = 0
         self.logger.info("Waiting for NSR to go to ACTIVE...")
-        while self.baton['details']['nsr'].get("status") != 'ACTIVE' \
-                and self.baton['details']['nsr'].get("status") != 'ERROR':
+        while self.mano['details']['nsr'].get("status") != 'ACTIVE' \
+                and self.mano['details']['nsr'].get("status") != 'ERROR':
             timeout += 1
             self.logger.info("NSR is not yet ACTIVE... (%ss)", 5 * timeout)
-            if timeout == 150:
+            if timeout == 300:
                 self.logger.error("INACTIVE NSR after %s sec..", 5 * timeout)
                 duration = time.time() - start_time
                 self.details["vnf"].update(status='FAIL', duration=duration)
                 return False
             time.sleep(5)
-            self.baton['details']['nsr'] = json.loads(
-                nsr_agent.find(self.baton['details']['nsr'].get('id')))
+            self.mano['details']['nsr'] = json.loads(
+                nsr_agent.find(self.mano['details']['nsr'].get('id')))
 
         duration = time.time() - start_time
-        if self.baton['details']['nsr'].get("status") == 'ACTIVE':
+        if self.mano['details']['nsr'].get("status") == 'ACTIVE':
             self.details["vnf"].update(status='PASS', duration=duration)
             self.logger.info("Sleep for 60s to ensure that all "
                              "services are up and running...")
@@ -606,7 +614,7 @@ class ImsVnf(vnf.VnfOnBoarding):
             result = True
         else:
             self.details["vnf"].update(status='FAIL', duration=duration)
-            self.logger.error("NSR: %s", self.baton['details'].get('nsr'))
+            self.logger.error("NSR: %s", self.mano['details'].get('nsr'))
             result = False
         return result
 
@@ -615,11 +623,11 @@ class ImsVnf(vnf.VnfOnBoarding):
         start_time = time.time()
         self.logger.info(
             "Testing if %s works properly...",
-            self.baton['details']['nsr'].get('name'))
-        for vnfr in self.baton['details']['nsr'].get('vnfr'):
+            self.mano['details']['nsr'].get('name'))
+        for vnfr in self.mano['details']['nsr'].get('vnfr'):
             self.logger.info(
                 "Checking ports %s of VNF %s",
-                self.ims_conf.get(vnfr.get('name')).get('ports'),
+                self.vnf['test'][vnfr.get('name')]['ports'],
                 vnfr.get('name'))
             for vdu in vnfr.get('vdu'):
                 for vnfci in vdu.get('vnfc_instance'):
@@ -631,8 +639,8 @@ class ImsVnf(vnf.VnfOnBoarding):
                             "Testing %s:%s",
                             vnfci.get('hostname'),
                             floating_ip.get('ip'))
-                        for port in self.ims_conf.get(
-                                vnfr.get('name')).get('ports'):
+                        for port in self.vnf['test'][vnfr.get(
+                                'name')]['ports']:
                             if servertest(floating_ip.get('ip'), port):
                                 self.logger.info(
                                     "VNFC instance %s is reachable at %s:%s",
@@ -662,32 +670,43 @@ class ImsVnf(vnf.VnfOnBoarding):
         return True
 
     def clean(self):
-        self.logger.info("Cleaning...")
+        self.logger.info("Cleaning %s...", self.case_name)
         try:
             main_agent = MainAgent(
-                nfvo_ip=self.baton['details']['fip'].ip,
+                nfvo_ip=self.mano['details']['fip'].ip,
                 nfvo_port=8080,
                 https=False,
                 version=1,
-                username=self.baton['credentials']['username'],
-                password=self.baton['credentials']['password'])
-            self.logger.info("Terminating OpenIMS VNF...")
-            if (self.baton['details'].get('nsr')):
+                username=self.mano['credentials']['username'],
+                password=self.mano['credentials']['password'])
+            self.logger.info("Terminating %s...", self.vnf['name'])
+            if (self.mano['details'].get('nsr')):
                 main_agent.get_agent(
                     "nsr",
-                    project_id=self.baton['details']['project_id'])\
-                    .delete(self.baton['details']['nsr'].get('id'))
-                self.logger.info("Waiting 60sec for terminating OpenIMS VNF..")
+                    project_id=self.mano['details']['project_id']).\
+                        delete(self.mano['details']['nsr'].get('id'))
+                self.logger.info("Sleeping 60 seconds...")
                 time.sleep(60)
+            else:
+                self.logger.info("No need to terminate the VNF...")
             # os_utils.delete_instance(nova_client=os_utils.get_nova_client(),
-            #                          instance_id=self.baton_instance_id)
+            #                          instance_id=self.mano_instance_id)
         except (NfvoException, KeyError) as exc:
             self.logger.error('Unexpected error cleaning - %s', exc)
 
         try:
             neutron_client = os_utils.get_neutron_client(self.creds)
+            self.logger.info("Deleting Open Baton Port...")
+            port = snaps_utils.neutron_utils.get_port_by_name(
+                neutron_client, '%s_port' % self.case_name)
+            snaps_utils.neutron_utils.delete_port(neutron_client, port)
+            time.sleep(10)
+        except Exception as exc:
+            self.logger.error('Unexpected error cleaning - %s', exc)
+        try:
+            self.logger.info("Deleting Open Baton Floating IP...")
             snaps_utils.neutron_utils.delete_floating_ip(
-                neutron_client, self.baton['details']['fip'])
+                neutron_client, self.mano['details']['fip'])
         except Exception as exc:
             self.logger.error('Unexpected error cleaning - %s', exc)
 
@@ -697,4 +716,4 @@ class ImsVnf(vnf.VnfOnBoarding):
                 resource.clean()
             except Exception as exc:
                 self.logger.error('Unexpected error cleaning - %s', exc)
-        super(ImsVnf, self).clean()
+        super(OpenImsVnf, self).clean()
diff --git a/functest/tests/unit/vnf/ims/test_orchestra_clearwaterims.py b/functest/tests/unit/vnf/ims/test_orchestra_clearwaterims.py
new file mode 100644 (file)
index 0000000..ef227ca
--- /dev/null
@@ -0,0 +1,227 @@
+#!/usr/bin/env python
+
+# All rights reserved. This program and the accompanying materials
+# are made available under the terms of the Apache License, Version 2.0
+# which accompanies this distribution, and is available at
+# http://www.apache.org/licenses/LICENSE-2.0
+
+"""Test module for orchestra_clearwaterims"""
+
+import logging
+import unittest
+
+import mock
+from snaps.openstack.os_credentials import OSCreds
+
+from functest.core import vnf
+from functest.opnfv_tests.vnf.ims import orchestra_clearwaterims
+
+
+class OrchestraClearwaterImsTesting(unittest.TestCase):
+    """Test class for orchestra_clearwaterims"""
+    def setUp(self):
+
+        self.tenant = 'orchestra_clearwaterims'
+        self.creds = {'username': 'mocked_username',
+                      'password': 'mocked_password'}
+        self.tenant_images = {
+            'image1': 'mocked_image_url_1',
+            'image2': 'mocked_image_url_2'
+        }
+        self.mano = {
+            'name': 'openbaton',
+            'version': '3.2.0',
+            'object': 'foo',
+            'requirements': {
+                'flavor': {
+                    'name': 'mocked_flavor',
+                    'ram_min': 4096,
+                    'disk': 5,
+                    'vcpus': 2
+                },
+                'os_image': 'mocked_image'
+            },
+            'bootstrap': {
+                'url': 'mocked_bootstrap_url',
+                'config': {
+                    'url': 'mocked_config_url'}
+            },
+            'gvnfm': {
+                'userdata': {
+                    'url': 'mocked_userdata_url'
+                }
+            },
+            'credentials': {
+                'username': 'mocked_username',
+                'password': 'mocked_password'
+            }
+        }
+        self.vnf = {
+            'name': 'openims',
+            'descriptor': {
+                'url': 'mocked_descriptor_url'
+            },
+            'requirements': {
+                'flavor': {
+                    'name': 'mocked_flavor',
+                    'ram_min': 2048,
+                    'disk': 5,
+                    'vcpus': 2}
+            }
+        }
+        self.clearwaterims = {
+            'scscf': {
+                'ports': [3870, 6060]
+            },
+            'pcscf': {
+                'ports': [4060]
+            },
+            'icscf': {
+                'ports': [3869, 5060]
+            },
+            'fhoss': {
+                'ports': [3868]
+            },
+            'bind9': {
+                'ports': []
+            }
+        }
+        with mock.patch('functest.opnfv_tests.vnf.ims.orchestra_clearwaterims.'
+                        'os.makedirs'),\
+            mock.patch('functest.opnfv_tests.vnf.ims.orchestra_clearwaterims.'
+                       'get_config', return_value={
+                           'orchestrator': self.mano,
+                           'name': self.mano['name'],
+                           'version': self.mano['version'],
+                           'requirements': self.mano['requirements'],
+                           'credentials': self.mano['credentials'],
+                           'bootstrap': self.mano['bootstrap'],
+                           'gvnfm': self.mano['gvnfm'],
+                           'os_image': self.mano['requirements']['os_image'],
+                           'flavor': self.mano['requirements']['flavor'],
+                           'url': self.mano['bootstrap']['url'],
+                           'config': self.mano['bootstrap']['config'],
+                           'tenant_images': self.tenant_images,
+                           'vnf': self.vnf,
+                           'orchestra_clearwaterims': self.clearwaterims}):
+            self.ims_vnf = orchestra_clearwaterims.ClearwaterImsVnf()
+
+        self.details = {'orchestrator': {'status': 'PASS', 'duration': 120},
+                        'vnf': {},
+                        'test_vnf': {}}
+
+    @mock.patch('functest.core.vnf.os_utils.get_keystone_client',
+                return_value='test')
+    @mock.patch('functest.core.vnf.os_utils.get_or_create_tenant_for_vnf',
+                return_value=True)
+    @mock.patch('functest.core.vnf.os_utils.get_or_create_user_for_vnf',
+                return_value=True)
+    @mock.patch('functest.core.vnf.os_utils.get_credentials',
+                return_value={'auth_url': 'test/v1'})
+    @mock.patch(
+        'functest.utils.openstack_utils.get_tenant_id',
+        return_value={'mocked_tenant_id'})
+    @mock.patch(
+        'functest.utils.openstack_utils.get_floating_ips',
+        return_value=[])
+    @mock.patch('snaps.openstack.create_image.OpenStackImage.create')
+    @mock.patch('snaps.openstack.create_flavor.OpenStackFlavor.create')
+    @mock.patch(
+        'snaps.openstack.create_security_group.OpenStackSecurityGroup.create')
+    @mock.patch('snaps.openstack.create_network.OpenStackNetwork.create')
+    @mock.patch('snaps.openstack.create_router.OpenStackRouter.create')
+    @mock.patch(
+        'functest.opnfv_tests.openstack.snaps.snaps_utils.get_ext_net_name')
+    @mock.patch(
+        'functest.opnfv_tests.openstack.snaps.'
+        'snaps_utils.neutron_utils.create_floating_ip')
+    def test_prepare_default(self, *args):
+        """Testing prepare function without any exceptions expected"""
+        self.assertIsNone(self.ims_vnf.prepare())
+        args[4].assert_called_once_with()
+
+    @mock.patch('functest.core.vnf.os_utils.get_keystone_client',
+                return_value='test')
+    @mock.patch('functest.core.vnf.os_utils.get_or_create_tenant_for_vnf',
+                return_value=True)
+    @mock.patch('functest.core.vnf.os_utils.get_or_create_user_for_vnf',
+                return_value=True)
+    @mock.patch('functest.core.vnf.os_utils.get_credentials',
+                return_value={'auth_url': 'test/no_v'})
+    @mock.patch('snaps.openstack.create_image.OpenStackImage.create')
+    def test_prepare_bad_auth_url(self, *args):
+        """Testing prepare function with bad auth url"""
+        with self.assertRaises(Exception):
+            self.ims_vnf.image_creator(
+                OSCreds(username='user', password='pass', auth_url='url',
+                        project_name='project', identity_api_version=3),
+                mock.Mock())
+            args[0].assert_not_called()
+
+    def test_prepare_missing_param(self):
+        """Testing prepare function with missing param"""
+        with self.assertRaises(vnf.VnfPreparationException):
+            self.ims_vnf.prepare()
+
+    @mock.patch('functest.core.vnf.os_utils.get_keystone_client',
+                side_effect=Exception)
+    def test_prepare_keystone_exception(self, *args):
+        """Testing prepare function with keystone exception"""
+        with self.assertRaises(vnf.VnfPreparationException):
+            self.ims_vnf.prepare()
+        args[0].assert_called_once_with()
+
+    @mock.patch('functest.core.vnf.os_utils.get_keystone_client',
+                return_value='test')
+    @mock.patch('functest.core.vnf.os_utils.get_or_create_tenant_for_vnf',
+                side_effect=Exception)
+    def test_prepare_tenant_exception(self, *args):
+        """Testing prepare function with tenant exception"""
+        with self.assertRaises(vnf.VnfPreparationException):
+            self.ims_vnf.prepare()
+            args[1].assert_called_once_with()
+
+    @mock.patch('functest.core.vnf.os_utils.get_keystone_client',
+                return_value='test')
+    @mock.patch('functest.core.vnf.os_utils.get_or_create_tenant_for_vnf',
+                return_value=True)
+    @mock.patch('functest.core.vnf.os_utils.get_or_create_user_for_vnf',
+                side_effect=Exception)
+    def test_prepare_user_exception(self, *args):
+        """Testing prepare function with user exception"""
+        with self.assertRaises(vnf.VnfPreparationException):
+            self.ims_vnf.prepare()
+        args[2].assert_called_once_with()
+
+    @mock.patch('functest.core.vnf.os_utils.get_keystone_client',
+                return_value='test')
+    @mock.patch('functest.core.vnf.os_utils.get_or_create_tenant_for_vnf',
+                return_value=True)
+    @mock.patch('functest.core.vnf.os_utils.get_or_create_user_for_vnf',
+                return_value=True)
+    @mock.patch('functest.core.vnf.os_utils.get_credentials',
+                side_effect=Exception)
+    def test_prepare_credentials_exception(self, *args):
+        """Testing prepare function with credentials exception"""
+        with self.assertRaises(vnf.VnfPreparationException):
+            self.ims_vnf.prepare()
+        args[0].assert_called_once_with()
+
+    # # @mock.patch('functest.opnfv_tests.vnf.
+        # ims.orchestra_clearwaterims.get_userdata')
+    # def test_deploy_orchestrator(self, *args):
+    #     floating_ip = FloatingIp
+    #     floating_ip.ip = 'mocked_ip'
+    #     details = {'fip':floating_ip,'flavor':{'name':'mocked_name'}}
+    #     self.mano['details'] = details
+    #     with mock.patch.dict(self.mano, {'details':
+    #     {'fip':floating_ip,'flavor':{'name':'mocked_name'}}}):
+    #     # with mock.patch.dict(self.mano, details):
+    #         orchestra_clearwaterims.get_userdata(self.mano)
+    #     self.assertIsNone(self.ims_vnf.deploy_orchestrator())
+    #     args[4].assert_called_once_with()
+
+
+if __name__ == "__main__":
+    logging.disable(logging.CRITICAL)
+    unittest.main(verbosity=2)
@@ -5,29 +5,30 @@
 # which accompanies this distribution, and is available at
 # http://www.apache.org/licenses/LICENSE-2.0
 
-"""Test module for orchestra_ims"""
+"""Test module for orchestra_openims"""
 
 import logging
 import unittest
 
 import mock
+from snaps.openstack.os_credentials import OSCreds
 
 from functest.core import vnf
-from functest.opnfv_tests.vnf.ims import orchestra_ims
+from functest.opnfv_tests.vnf.ims import orchestra_openims
 
 
-class OrchestraImsTesting(unittest.TestCase):
-    """Test class for orchestra_ims"""
+class OrchestraOpenImsTesting(unittest.TestCase):
+    """Test class for orchestra_openims"""
     def setUp(self):
 
-        self.tenant = 'orchestra_ims'
+        self.tenant = 'orchestra_openims'
         self.creds = {'username': 'mocked_username',
                       'password': 'mocked_password'}
         self.tenant_images = {
             'image1': 'mocked_image_url_1',
             'image2': 'mocked_image_url_2'
         }
-        self.orchestrator = {
+        self.mano = {
             'name': 'openbaton',
             'version': '3.2.0',
             'object': 'foo',
@@ -68,7 +69,7 @@ class OrchestraImsTesting(unittest.TestCase):
                     'vcpus': 2}
             }
         }
-        self.vIMS = {
+        self.openims = {
             'scscf': {
                 'ports': [3870, 6060]
             },
@@ -85,27 +86,27 @@ class OrchestraImsTesting(unittest.TestCase):
                 'ports': []
             }
         }
-        with mock.patch('functest.opnfv_tests.vnf.ims.orchestra_ims.'
+        with mock.patch('functest.opnfv_tests.vnf.ims.orchestra_openims.'
                         'os.makedirs'),\
-            mock.patch('functest.opnfv_tests.vnf.ims.orchestra_ims.'
+            mock.patch('functest.opnfv_tests.vnf.ims.orchestra_openims.'
                        'get_config', return_value={
-                           'orchestrator': self.orchestrator,
-                           'name': self.orchestrator['name'],
-                           'version': self.orchestrator['version'],
-                           'requirements': self.orchestrator['requirements'],
-                           'credentials': self.orchestrator['credentials'],
-                           'bootstrap': self.orchestrator['bootstrap'],
-                           'gvnfm': self.orchestrator['gvnfm'],
+                           'orchestrator': self.mano,
+                           'name': self.mano['name'],
+                           'version': self.mano['version'],
+                           'requirements': self.mano['requirements'],
+                           'credentials': self.mano['credentials'],
+                           'bootstrap': self.mano['bootstrap'],
+                           'gvnfm': self.mano['gvnfm'],
                            'os_image':
-                               self.orchestrator['requirements']['os_image'],
+                               self.mano['requirements']['os_image'],
                            'flavor':
-                               self.orchestrator['requirements']['flavor'],
-                           'url': self.orchestrator['bootstrap']['url'],
-                           'config': self.orchestrator['bootstrap']['config'],
+                               self.mano['requirements']['flavor'],
+                           'url': self.mano['bootstrap']['url'],
+                           'config': self.mano['bootstrap']['config'],
                            'tenant_images': self.tenant_images,
                            'vnf': self.vnf,
-                           'vIMS': self.vIMS}):
-            self.ims_vnf = orchestra_ims.ImsVnf()
+                           'orchestra_openims': self.openims}):
+            self.ims_vnf = orchestra_openims.OpenImsVnf()
 
         self.details = {'orchestrator': {'status': 'PASS', 'duration': 120},
                         'vnf': {},
@@ -153,7 +154,10 @@ class OrchestraImsTesting(unittest.TestCase):
     def test_prepare_bad_auth_url(self, *args):
         """Testing prepare function with bad auth url"""
         with self.assertRaises(Exception):
-            self.ims_vnf.prepare()
+            self.ims_vnf.image_creator(
+                OSCreds(username='user', password='pass', auth_url='url',
+                        project_name='project', identity_api_version=3),
+                mock.Mock())
             args[0].assert_not_called()
 
     def test_prepare_missing_param(self):
@@ -205,16 +209,17 @@ class OrchestraImsTesting(unittest.TestCase):
             self.ims_vnf.prepare()
         args[0].assert_called_once_with()
 
-    # # @mock.patch('functest.opnfv_tests.vnf.ims.orchestra_ims.get_userdata')
+    # # @mock.patch('functest.opnfv_tests.
+        # vnf.ims.orchestra_openims.get_userdata')
     # def test_deploy_orchestrator(self, *args):
     #     floating_ip = FloatingIp
     #     floating_ip.ip = 'mocked_ip'
     #     details = {'fip':floating_ip,'flavor':{'name':'mocked_name'}}
-    #     self.orchestrator['details'] = details
-    #     with mock.patch.dict(self.orchestrator, {'details':
+    #     self.mano['details'] = details
+    #     with mock.patch.dict(self.mano, {'details':
     #     {'fip':floating_ip,'flavor':{'name':'mocked_name'}}}):
-    #     # with mock.patch.dict(self.orchestrator, details):
-    #         orchestra_ims.get_userdata(self.orchestrator)
+    #     # with mock.patch.dict(self.mano, details):
+    #         orchestra_openims.get_userdata(self.mano)
     #     self.assertIsNone(self.ims_vnf.deploy_orchestrator())
     #     args[4].assert_called_once_with()