1 # Licensed under the Apache License, Version 2.0 (the "License");
2 # you may not use this file except in compliance with the License.
3 # You may obtain a copy of the License at
5 # http://www.apache.org/licenses/LICENSE-2.0
7 # Unless required by applicable law or agreed to in writing, software
8 # distributed under the License is distributed on an "AS IS" BASIS,
9 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
10 # See the License for the specific language governing permissions and
11 # limitations under the License.
14 Documentation [BASIC-06] VNF with Charm.
16 Library OperatingSystem
19 Resource %{ROBOT_DEVOPS_FOLDER}/lib/vnfd_lib.robot
20 Resource %{ROBOT_DEVOPS_FOLDER}/lib/nsd_lib.robot
21 Resource %{ROBOT_DEVOPS_FOLDER}/lib/ns_lib.robot
22 Resource %{ROBOT_DEVOPS_FOLDER}/lib/ssh_lib.robot
24 Force Tags basic_06 cluster_ee_config daily regression
26 Suite Teardown Run Keyword And Ignore Error Suite Cleanup
30 # NS and VNF descriptor package folder and ids
31 ${vnfd_pkg} charm-packages/ha_proxy_charm_vnf
32 ${vnfd_name} ha_proxy_charm-vnf
33 ${nsd_pkg} charm-packages/ha_proxy_charm_ns
34 ${nsd_name} ha_proxy_charm-ns
36 # NS instance name and configuration
37 ${ns_name} basic_06_charm_test
38 ${ns_config} {vld: [ {name: mgmtnet, vim-network-name: %{VIM_MGMT_NET}} ] }
40 # SSH keys and username to be used
41 ${publickey} %{HOME}/.ssh/id_rsa.pub
42 ${privatekey} %{HOME}/.ssh/id_rsa
47 ${vnf_member_index_1} vnf1
48 ${vnf_member_index_2} vnf2
49 ${day_1_file_name} /home/ubuntu/first-touch
50 ${day_2_file_name_1} /home/ubuntu/mytouch1
51 ${day_2_file_name_2} /home/ubuntu/mytouch2
56 Create Charm VNF Descriptor
58 Create VNFD '%{PACKAGES_FOLDER}/${vnfd_pkg}'
61 Create Charm NS Descriptor
63 Create NSD '%{PACKAGES_FOLDER}/${nsd_pkg}'
66 Instantiate Charm Network Service
68 ${id}= Create Network Service ${nsd_name} %{VIM_TARGET} ${ns_name} ${ns_config} ${publickey} ${ns_timeout}
69 Set Suite Variable ${ns_id} ${id}
72 Get Management Ip Addresses
74 ${ip_addr_1} Get Vnf Management Ip Address ${ns_id} ${vnf_member_index_1}
76 Set Suite Variable ${vnf_1_ip_addr} ${ip_addr_1}
77 ${ip_addr_2} Get Vnf Management Ip Address ${ns_id} ${vnf_member_index_2}
79 Set Suite Variable ${vnf_2_ip_addr} ${ip_addr_2}
84 Variable Should Exist ${vnf_1_ip_addr} msg=IP address of the management VNF '${vnf_member_index_1}' is not available
85 Variable Should Exist ${vnf_2_ip_addr} msg=IP address of the management VNF '${vnf_member_index_2}' is not available
86 Sleep 30s Waiting ssh daemon to be up
87 Test SSH Connection ${vnf_1_ip_addr} ${username} ${password} ${privatekey}
88 Test SSH Connection ${vnf_2_ip_addr} ${username} ${password} ${privatekey}
91 Check Remote Files Created Via Day 1 Operations
92 [Documentation] The Charm VNF has a Day 1 operation that creates a file named ${day_1_file_name}.
93 ... This test checks whether that files have been created or not.
95 Check If remote File Exists ${vnf_1_ip_addr} ${username} ${password} ${privatekey} ${day_1_file_name}
96 Check If remote File Exists ${vnf_2_ip_addr} ${username} ${password} ${privatekey} ${day_1_file_name}
99 Execute Day 2 Operations
100 [Documentation] Performs one Day 2 operation per VNF that creates a new file.
102 Variable Should Exist ${ns_id} msg=Network service instance is not available
103 ${ns_op_id_1}= Execute NS Action ${ns_name} ${action_name} ${vnf_member_index_1} filename=${day_2_file_name_1}
104 ${ns_op_id_2}= Execute NS Action ${ns_name} ${action_name} ${vnf_member_index_2} filename=${day_2_file_name_2}
107 Check Remote Files Created Via Day 2 Operations
108 [Documentation] Check whether the files created in the previous test via Day 2 operations exist or not.
110 Check If remote File Exists ${vnf_1_ip_addr} ${username} ${password} ${privatekey} ${day_2_file_name_1}
111 Check If remote File Exists ${vnf_2_ip_addr} ${username} ${password} ${privatekey} ${day_2_file_name_2}
123 Delete NSD ${nsd_name}
126 Delete VNF Descriptor
129 Delete VNFD ${vnfd_name}
134 [Documentation] Test Suite Cleanup: Deleting descriptors and NS instance
136 Run Keyword If Any Tests Failed Delete NS ${ns_name}
138 Run Keyword If Any Tests Failed Delete NSD ${nsd_name}
140 Run Keyword If Any Tests Failed Delete VNFD ${vnfd_name}