blob: ab3a162185162be7b24a996688f5d42526c5dc83 [file] [log] [blame]
# Copyright 2017 Sandvine
#
# 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 pytest
import pprint
import time
from osmclient.common import utils
class TestClass(object):
@pytest.fixture(scope='function')
def cleanup_test_vnf(self,osm,request):
vnfd_file_list = osm.vnfd_descriptors_list
nsd_file_list = osm.nsd_descriptors_list
# cleanup all ns/packages that might have been left around
def teardown():
# first delete all nsd's
for file in nsd_file_list:
try:
desc = osm.get_api().package.get_key_val_from_pkg(file)
ns_name=osm.ns_name_prefix+desc['name']
osm.get_api().ns.delete(ns_name)
except:
pass
# delete all nsd packages
for file in nsd_file_list:
try:
desc = osm.get_api().package.get_key_val_from_pkg(file)
osm.get_api().nsd.delete(desc['name'])
except:
pass
# delete all vnfd packages
for file in vnfd_file_list:
try:
desc = osm.get_api().package.get_key_val_from_pkg(file)
osm.get_api().vnfd.delete(desc['name'])
except:
pass
request.addfinalizer(teardown)
def vnf_upload_packages(self, osm, vnfd_file_list, nsd_file_list ):
vnfd_descriptors=[]
for file in vnfd_file_list:
assert not osm.get_api().package.upload(file)
assert not osm.get_api().package.wait_for_upload(file)
desc = osm.get_api().package.get_key_val_from_pkg(file)
assert desc
vnfd_descriptors.append(desc)
nsd_descriptors=[]
for file in nsd_file_list:
assert not osm.get_api().package.upload(file)
assert not osm.get_api().package.wait_for_upload(file)
desc = osm.get_api().package.get_key_val_from_pkg(file)
assert desc
nsd_descriptors.append(desc)
# TODO/HACK: need to figure out why this is necessary.
# vnfd/nsd is there (seen on ping_pong), but the ns fails that nsd is not there,
# another way to check if the nsd is really ready via API?
time.sleep(5)
def vnf_test(self,osm, openstack, vim, vmware, vnfd_file_list, nsd_file_list, ns_scale=False):
# FIXME: need sleep after vim creation. Need a way to validate vim is ready to handle requests
time.sleep(20)
for file in nsd_file_list:
nsd_desc = osm.get_api().package.get_key_val_from_pkg(file)
ns_name=osm.ns_name_prefix+nsd_desc['name']
assert osm.get_api().ns.create(nsd_desc['name'],ns_name,vim.vim_name)
# commenting the init check as sometime it is going to running state very fast
# if not utils.wait_for_value(lambda: osm.get_api().ns.get_field(ns_name,'operational-status'),result='init', wait_time=30):
# nsr=osm.get_api().ns.get(ns_name)
# pprint.pprint(nsr)
# assert True, "operational-status != init"
# make sure ns is running
if not utils.wait_for_value(lambda: osm.get_api().ns.get_field(ns_name,'operational-status'),result='running',wait_time=240):
nsr=osm.get_api().ns.get(ns_name)
pprint.pprint(nsr)
assert True, "operational-status != running"
if ns_scale:
# for each descriptor, scale it
for scale in nsd_desc['scaling-group-descriptor']:
# scale it.
assert not osm.get_api().ns.scale(ns_name, scale['name'], 1)
# ensure ns is scaling-out
assert utils.wait_for_value(lambda: osm.get_api().ns.get_field(ns_name,'operational-status'),result='scaling-out',wait_time=120)
# wait for ns to be in running-state
assert utils.wait_for_value(lambda: osm.get_api().ns.get_field(ns_name,'operational-status'),result='running',wait_time=300)
time.sleep(10)
assert not osm.get_api().ns.delete(ns_name)
#wait for the ns to delete
try:
utils.wait_for_value( lambda: osm.get_api().ns.get(ns_name), result=False, wait_time=180)
except:
print("Exception: Failed to get NAME after NS DELETE ... ")
#TODO find the reason for 502 exception from osmclient/nbi
try:
assert not osm.get_api().nsd.delete(nsd_desc['name'])
except:
print("Exception: NSD Delete exception ...due to 502 error")
time.sleep(10)
for file in vnfd_file_list:
vnfd_desc = osm.get_api().package.get_key_val_from_pkg(file)
assert not osm.get_api().vnfd.delete(vnfd_desc['name'])
@pytest.mark.openstack
@pytest.mark.vnf
@pytest.mark.vmware
def test_vnf(self,osm, vim, openstack, vmware, cleanup_test_vnf):
vnfd_file_list = osm.vnfd_descriptors_list
nsd_file_list = osm.nsd_descriptors_list
self.vnf_upload_packages(osm, vnfd_file_list, nsd_file_list )
self.vnf_test(osm,openstack, vim, vmware, vnfd_file_list, nsd_file_list)
@pytest.mark.openstack
@pytest.mark.ns_scale
@pytest.mark.vmware
def test_scale_vnf(self,osm, vim, openstack, vmware, cleanup_test_vnf):
vnfd_file_list = osm.vnfd_descriptors_list
nsd_file_list = osm.nsd_descriptors_list
self.vnf_upload_packages(osm, vnfd_file_list, nsd_file_list )
self.vnf_test(osm,openstack, vim, vmware, vnfd_file_list, nsd_file_list, ns_scale=True)