f1a6d87bc33f7e7670d9ea5796117187d1965c20
[osm/tests.git] / robot-systest / testsuite / k8s_06-k8s_secure_key_management.robot
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
4 #
5 #       http://www.apache.org/licenses/LICENSE-2.0
6 #
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.
12
13 *** Settings ***
14 Documentation     [K8s-06] K8s Secure Key Management.
15
16 Library   OperatingSystem
17 Library   SSHLibrary
18
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
23
24 Force Tags   k8s_06   cluster_ee_config   cluster_k8s_charms   daily   regression
25
26 Suite Teardown   Run Keyword And Ignore Error   Suite Cleanup
27
28
29 *** Variables ***
30 # NS and VNF descriptor package folder and ids
31 ${vnfd_pkg}   charm-packages/nopasswd_k8s_proxy_charm_vnf
32 ${vnfd_name}   nopasswd_k8s_proxy_charm-vnf
33 ${nsd_pkg}   charm-packages/nopasswd_k8s_proxy_charm_ns
34 ${nsd_name}   nopasswd_k8s_proxy_charm-ns
35
36 # NS instance name and configuration
37 ${ns_name}   k8s_06-nopasswd_k8s_proxy_charm
38 ${ns_config}   {vld: [ {name: mgmtnet, vim-network-name: %{VIM_MGMT_NET}} ] }
39 ${ns_timeout}   15min
40
41 # SSH keys and username to be used
42 ${publickey}   %{HOME}/.ssh/id_rsa.pub
43 ${privatekey}   %{HOME}/.ssh/id_rsa
44 ${username}   ubuntu
45 ${password}   ${EMPTY}
46
47 ${action_name}   touch
48 ${vnf_member_index_1}   1
49 ${vnf_member_index_2}   2
50 ${day_1_file_name}   /home/ubuntu/first-touch
51 ${day_2_file_name_1}   /home/ubuntu/mytouch1
52 ${day_2_file_name_2}   /home/ubuntu/mytouch2
53 ${ns_timeout}   15min
54
55
56 *** Test Cases ***
57 Create Charm VNF Descriptor
58     [Tags]   prepare
59     Create VNFD  '%{PACKAGES_FOLDER}/${vnfd_pkg}'
60
61
62 Create Charm NS Descriptor
63     [Tags]   prepare
64     Create NSD  '%{PACKAGES_FOLDER}/${nsd_pkg}'
65
66
67 Instantiate Charm Network Service
68     [Tags]   prepare
69     ${id}=  Create Network Service  ${nsd_name}  %{VIM_TARGET}  ${ns_name}  ${ns_config}  ${publickey}  ${ns_timeout}
70
71 Get Ns Id
72     [Tags]   verify
73     ${id}=   Get Ns Id   ${ns_name}
74     Set Suite Variable   ${ns_id}   ${id}
75
76 Get Management Ip Addresses
77     [Tags]   verify
78     ${ip_addr_1}  Get Vnf Management Ip Address  ${ns_id}  ${vnf_member_index_1}
79     log  ${ip_addr_1}
80     Set Suite Variable  ${vnf_1_ip_addr}  ${ip_addr_1}
81     ${ip_addr_2}  Get Vnf Management Ip Address  ${ns_id}  ${vnf_member_index_2}
82     log  ${ip_addr_2}
83     Set Suite Variable  ${vnf_2_ip_addr}  ${ip_addr_2}
84
85
86 Test SSH Access
87     [Tags]   verify
88     Variable Should Exist  ${vnf_1_ip_addr}  msg=IP address of the management VNF '${vnf_member_index_1}' is not available
89     Variable Should Exist  ${vnf_2_ip_addr}  msg=IP address of the management VNF '${vnf_member_index_2}' is not available
90     Sleep  30s  Waiting ssh daemon to be up
91     Test SSH Connection  ${vnf_1_ip_addr}  ${username}  ${password}  ${privatekey}
92     Test SSH Connection  ${vnf_2_ip_addr}  ${username}  ${password}  ${privatekey}
93
94
95 Check Remote Files Created Via Day 1 Operations
96     [Tags]   verify
97     [Documentation]     The Charm VNF has a Day 1 operation that creates a file named ${day_1_file_name}.
98     ...                 This test checks whether that files have been created or not.
99
100     Check If remote File Exists  ${vnf_1_ip_addr}  ${username}  ${password}  ${privatekey}  ${day_1_file_name}
101     Check If remote File Exists  ${vnf_2_ip_addr}  ${username}  ${password}  ${privatekey}  ${day_1_file_name}
102
103
104 Execute Day 2 Operations
105     [Tags]   verify
106     [Documentation]     Performs one Day 2 operation per VNF that creates a new file.
107
108     Variable Should Exist  ${ns_id}  msg=Network service instance is not available
109     ${ns_op_id_1}=  Execute NS Action  ${ns_name}  ${action_name}  ${vnf_member_index_1}  filename=${day_2_file_name_1}
110     ${ns_op_id_2}=  Execute NS Action  ${ns_name}  ${action_name}  ${vnf_member_index_2}  filename=${day_2_file_name_2}
111
112
113 Check Remote Files Created Via Day 2 Operations
114     [Tags]   verify
115     [Documentation]     Check whether the files created in the previous test via Day 2 operations exist or not.
116
117     Check If remote File Exists  ${vnf_1_ip_addr}  ${username}  ${password}  ${privatekey}  ${day_2_file_name_1}
118     Check If remote File Exists  ${vnf_2_ip_addr}  ${username}  ${password}  ${privatekey}  ${day_2_file_name_2}
119
120
121 Delete NS Instance
122     [Tags]   cleanup
123
124     Delete NS  ${ns_name}
125
126
127 Delete NS Descriptor
128     [Tags]   cleanup
129
130     Delete NSD  ${nsd_name}
131
132
133 Delete VNF Descriptor
134     [Tags]   cleanup
135
136     Delete VNFD  ${vnfd_name}
137
138
139 *** Keywords ***
140 Suite Cleanup
141     [Documentation]  Test Suite Cleanup: Deleting descriptors and NS instance
142
143     Run Keyword If Any Tests Failed  Delete NS  ${ns_name}
144
145     Run Keyword If Any Tests Failed  Delete NSD  ${nsd_name}
146
147     Run Keyword If Any Tests Failed  Delete VNFD  ${vnfd_name}
148