| *** Comments *** |
| # 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. |
| |
| |
| *** Settings *** |
| Documentation [BASIC-06] VNF with Charm. |
| |
| Library OperatingSystem |
| Library SSHLibrary |
| |
| Resource ../lib/vnfd_lib.resource |
| Resource ../lib/nsd_lib.resource |
| Resource ../lib/ns_lib.resource |
| Resource ../lib/ns_operation_lib.resource |
| Resource ../lib/ssh_lib.resource |
| Resource ../lib/juju_lib.resource |
| |
| Test Tags basic_06 cluster_ee_config regression azure |
| |
| Suite Teardown Run Keyword And Ignore Error Suite Cleanup |
| |
| |
| *** Variables *** |
| # NS and VNF descriptor package folder and ids |
| ${VNFD_PKG} charm-packages/ha_proxy_charm_vnf |
| ${VNFD_NAME} ha_proxy_charm-vnf |
| ${NSD_PKG} charm-packages/ha_proxy_charm_ns |
| ${NSD_NAME} ha_proxy_charm-ns |
| |
| # NS instance name and configuration |
| ${NS_NAME} basic_06_charm_test |
| ${NS_CONFIG} {vld: [ {name: mgmtnet, vim-network-name: %{VIM_MGMT_NET}} ] } |
| |
| # SSH keys and username to be used |
| ${PUBLICKEY} %{HOME}/.ssh/id_rsa.pub |
| ${PRIVATEKEY} %{HOME}/.ssh/id_rsa |
| ${USERNAME} ubuntu |
| ${PASSWORD} ${EMPTY} |
| |
| ${ACTION_NAME} touch |
| ${VNF_MEMBER_INDEX_1} vnf1 |
| ${VNF_MEMBER_INDEX_2} vnf2 |
| ${DAY_1_FILE_NAME} /home/ubuntu/first-touch |
| ${DAY_2_FILE_NAME_1} /home/ubuntu/mytouch1 |
| ${DAY_2_FILE_NAME_2} /home/ubuntu/mytouch2 |
| ${NS_TIMEOUT} 15min |
| |
| # VNF profile id, execution environment name to check VNF level charm naming |
| ${VNF_PROFILE_ID} vnf1 |
| ${EE_NAME} simple-ee |
| |
| |
| *** Test Cases *** |
| Create Charm VNF Descriptor |
| [Documentation] Upload VNF package for the testsuite. |
| Create VNFD '%{PACKAGES_FOLDER}/${VNFD_PKG}' |
| |
| Create Charm NS Descriptor |
| [Documentation] Upload NS package for the testsuite. |
| Create NSD '%{PACKAGES_FOLDER}/${NSD_PKG}' |
| |
| Instantiate Charm Network Service |
| [Documentation] Instantiates the NS for the testsuite. |
| ${id}= Create Network Service ${NSD_NAME} %{VIM_TARGET} ${NS_NAME} ${NS_CONFIG} ${PUBLICKEY} ${NS_TIMEOUT} |
| Set Suite Variable ${NS_ID} ${id} |
| Set Suite Variable ${MODEL_NAME} ${id} |
| |
| Check VNF Charm Application Name |
| [Documentation] Checks that the charm application name meets the expected length |
| ${vnf_charm_app_name}= Get Application Name VNF Level Charm %{OSM_HOSTNAME} ${USERNAME} ${PASSWORD} %{OSM_RSA_FILE} ${MODEL_NAME} ${VNF_PROFILE_ID} ${EE_NAME} |
| ${length}= Get Length ${vnf_charm_app_name} |
| Should Be True ${length} <50 |
| |
| Get Management Ip Addresses |
| [Documentation] Get the mgmt IP addresses of both VNF of the NS. |
| ${ip_addr_1}= Get Vnf Management Ip Address ${NS_ID} ${VNF_MEMBER_INDEX_1} |
| Log ${ip_addr_1} |
| Set Suite Variable ${VNF_1_IP_ADDR} ${ip_addr_1} |
| ${ip_addr_2}= Get Vnf Management Ip Address ${NS_ID} ${VNF_MEMBER_INDEX_2} |
| Log ${ip_addr_2} |
| Set Suite Variable ${VNF_2_IP_ADDR} ${ip_addr_2} |
| |
| Test SSH Access |
| [Documentation] Check that both VNF are accessible via SSH in their mgmt IP addresses. |
| Variable Should Exist ${VNF_1_IP_ADDR} msg=IP address of the management VNF '${VNF_MEMBER_INDEX_1}' is not available |
| Variable Should Exist ${VNF_2_IP_ADDR} msg=IP address of the management VNF '${VNF_MEMBER_INDEX_2}' is not available |
| Sleep 30s Waiting ssh daemon to be up |
| Test SSH Connection ${VNF_1_IP_ADDR} ${USERNAME} ${PASSWORD} ${PRIVATEKEY} |
| Test SSH Connection ${VNF_2_IP_ADDR} ${USERNAME} ${PASSWORD} ${PRIVATEKEY} |
| |
| Check Remote Files Created Via Day 1 Operations |
| [Documentation] The Charm VNF has a Day 1 operation that creates a file named ${day_1_file_name}. |
| ... This test checks whether that files have been created or not. |
| Check If Remote File Exists ${VNF_1_IP_ADDR} ${USERNAME} ${PASSWORD} ${PRIVATEKEY} ${DAY_1_FILE_NAME} |
| Check If Remote File Exists ${VNF_2_IP_ADDR} ${USERNAME} ${PASSWORD} ${PRIVATEKEY} ${DAY_1_FILE_NAME} |
| |
| Execute Day 2 Operations |
| [Documentation] Performs one Day 2 operation per VNF that creates a new file. |
| Variable Should Exist ${NS_ID} msg=Network service instance is not available |
| ${ns_op_id_1}= Execute NS Action ${NS_NAME} ${ACTION_NAME} ${VNF_MEMBER_INDEX_1} filename=${DAY_2_FILE_NAME_1} |
| Log ${ns_op_id_1} |
| ${ns_op_id_2}= Execute NS Action ${NS_NAME} ${ACTION_NAME} ${VNF_MEMBER_INDEX_2} filename=${DAY_2_FILE_NAME_2} |
| Log ${ns_op_id_2} |
| |
| Check Remote Files Created Via Day 2 Operations |
| [Documentation] Check whether the files created in the previous test via Day 2 operations exist or not. |
| Check If Remote File Exists ${VNF_1_IP_ADDR} ${USERNAME} ${PASSWORD} ${PRIVATEKEY} ${DAY_2_FILE_NAME_1} |
| Check If Remote File Exists ${VNF_2_IP_ADDR} ${USERNAME} ${PASSWORD} ${PRIVATEKEY} ${DAY_2_FILE_NAME_2} |
| |
| Delete NS Instance |
| [Documentation] Delete NS instance. |
| [Tags] cleanup |
| Delete NS ${NS_NAME} |
| |
| Delete NS Descriptor |
| [Documentation] Delete NS package from OSM. |
| [Tags] cleanup |
| Delete NSD ${NSD_NAME} |
| |
| Delete VNF Descriptor |
| [Documentation] Delete VNF package from OSM. |
| [Tags] cleanup |
| Delete VNFD ${VNFD_NAME} |
| |
| |
| *** Keywords *** |
| Suite Cleanup |
| [Documentation] Test Suite Cleanup: Deleting descriptors and NS instance |
| Run Keyword If Any Tests Failed Delete NS ${NS_NAME} |
| Run Keyword If Any Tests Failed Delete NSD ${NSD_NAME} |
| Run Keyword If Any Tests Failed Delete VNFD ${VNFD_NAME} |