# Folder where test results should be exported
ENV ROBOT_REPORT_FOLDER=/robot-systest/results
+# Kubeconfig file
+ENV K8S_CREDENTIALS=/root/.kube/config
+
ENV LC_ALL=C.UTF-8
ENV LANG=C.UTF-8
add-apt-repository -y ppa:rmescandon/yq && apt update && apt install yq git iputils-ping ssh -y
pip install haikunator requests robotframework robotframework-seleniumlibrary robotframework-requests robotframework-jsonlibrary \
robotframework-sshlibrary
+ snap install charm
# Download community packages
git clone https://osm.etsi.org/gitlab/vnf-onboarding/osm-packages.git ${PACKAGES_FOLDER}
```
envfile.rc
```bash
- # VIM setup
+ # VIM Setup
OS_USERNAME=<openstack_username>
OS_PASSWORD=<openstack_password>
OS_TENANT_NAME=<openstack_tenant_name>
OS_AUTH_URL=<openstack_authorization_url>
OS_TENANT_ID=<openstack_tenant_id>
+
+ # OSM Setup
OSM_HOSTNAME=<osm_ip_address>
VIM_TARGET=<osm_vim_name>
VIM_MGMT_NET=<osm_vim_mgmt_name>
+ # Clouds file datacenter
+ OS_CLOUD=<datacenter_in_clouds_file>
+
+ # K8S config file
+ K8S_CREDENTIALS=<path_to_kubeconfig>
+
# The following set of environment variables will be used in host
# of the robot framework. Not needed for docker execution
* <path_to_reports> [OPTIONAL]: It is the absolute path to reports location in the host
* <path_to_clouds.yaml> [OPTIONAL]: It is the absolute path to the clouds.yaml file in the host
+* <path_to_kubeconfig> [OPTIONAL]: It is the kubeconfig file to be used for k8s clusters
```bash
docker run --rm=true -t osmtests --env-file <env_file> \
- -v <path_to_reports>:/reports osmtests -v <path_to_clouds.yaml>:/robot-systest/clouds.yaml \
- -v <path_to_kubeconfig>:/robot-systest/kubeconfig.yaml
- -o <osmclient_version> -p <package_branch> -t <testing_tags>
+ -v <path_to_reports>:/reports osmtests \
+ -v <path_to_clouds.yaml>:/robot-systest/clouds.yaml \
+ -v <path_to_kubeconfig>:/root/.kube/config \
+ -o <osmclient_version> \
+ -p <package_branch> \
+ -t <testing_tags>
```
1. Running the tests manually:
--- /dev/null
+clouds:
+ openstack:
+ auth:
+ auth_url:
+ project_name:
+ username:
+ password:
+ user_domain_name:
+ project_domain_name:
+++ /dev/null
-clouds:
- openstack:
- auth:
- auth_url: http://172.21.247.1:5000/v3
- project_name: fvicens
- username: fvicens
- password: fvicens19
- user_domain_name: Default
- project_domain_name: Default
--- /dev/null
+# 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.
+
+# VIM setup
+OS_USERNAME=
+OS_PASSWORD=
+OS_TENANT_NAME=
+OS_AUTH_URL=
+OS_TENANT_ID=
+
+# OSM Setup
+OSM_HOSTNAME=
+VIM_TARGET=
+VIM_MGMT_NET=
+
+# Robot setup
+ENVIRONMENTS_FOLDER=environments
+PACKAGES_FOLDER=/robot-systest/osm-packages
+
+# Clouds file datacenter
+OS_CLOUD=openstack
+
+LC_ALL=C.UTF-8
+LANG=C.UTF-8
+++ /dev/null
-# VIM setup
-OS_USERNAME=fvicens
-OS_PASSWORD=fvicens19
-OS_TENANT_NAME=admin
-OS_AUTH_URL=https://172.21.247.1:5000/v3
-OS_TENANT_ID=fvicens
-OSM_HOSTNAME=172.21.248.28
-VIM_TARGET=osm
-VIM_MGMT_NET=osm-ext
-ENVIRONMENTS_FOLDER=environments
-PACKAGES_FOLDER=/robot-systest/osm-packages
-OS_CLOUD=openstack
-
-LC_ALL=C.UTF-8
-LANG=C.UTF-8
--- /dev/null
+# Copyright 2020 Canonical Ltd.
+#
+# 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.
+
+*** Variables ***
+${success_return_code} 0
+${k8scluster_launch_max_wait_time} 2min
+${k8scluster_launch_pol_time} 30sec
+${k8scluster_delete_max_wait_time} 2min
+${k8scluster_delete_pol_time} 15sec
+
+*** Keywords ***
+Create K8s Cluster
+ [Arguments] ${k8scluster_creds} ${k8scluster_version} ${k8scluster_vim} ${k8scluster_net} ${k8scluster_name}
+ ${rc} ${stdout}= Run and Return RC and Output osm k8scluster-add --creds ${k8scluster_creds} --version ${k8scluster_version} --vim ${k8scluster_vim} --k8s-nets '{"net1": "${k8scluster_net}"}' ${k8scluster_name} --description "Robot cluster"
+ log ${stdout}
+ Should Be Equal As Integers ${rc} ${success_return_code}
+ WAIT UNTIL KEYWORD SUCCEEDS ${k8scluster_launch_max_wait_time} ${k8scluster_launch_pol_time} Check For K8s Cluster To Be Ready ${k8scluster_name}
+ [Return] ${stdout}
+
+Delete K8s Cluster
+ [Arguments] ${k8scluster_name}
+ ${rc} ${stdout}= Run and Return RC and Output osm k8scluster-delete ${k8scluster_name}
+ Should Be Equal As Integers ${rc} ${success_return_code}
+ WAIT UNTIL KEYWORD SUCCEEDS ${k8scluster_delete_max_wait_time} ${k8scluster_delete_pol_time} Check For K8s Cluster To Be Deleted ${k8scluster_name}
+
+Get K8s Cluster
+ ${rc} ${stdout}= Run and Return RC and Output osm k8scluster-list
+ Should Be Equal As Integers ${rc} ${success_return_code}
+ log ${stdout}
+ [Return] ${stdout}
+
+Check for K8s Cluster
+ [Arguments] ${k8scluster_name}
+ ${rc} ${stdout}= Run and Return RC and Output osm k8scluster-list --filter name="${k8scluster_name}"
+ Should Be Equal As Integers ${rc} ${success_return_code}
+ [Return] ${stdout}
+
+Check For K8s Cluster To Be Deleted
+ [Arguments] ${k8scluster_name}
+ ${rc} ${stdout}= Run and Return RC and Output osm k8scluster-list --filter name="${k8scluster_name}" | awk '{print $2}' | grep ${k8scluster_name}
+ Should Be Empty ${stdout}
+
+Check For K8s Cluster To Be Ready
+ [Arguments] ${k8scluster_name}
+ ${rc} ${stdout}= Run and Return RC and Output osm k8scluster-list --filter name="${k8scluster_name}" --filter _admin.operationalState="ENABLED" | awk '{print $2}' | grep ${k8scluster_name}
+ Should Be Equal As Integers ${rc} ${success_return_code}
+ Should Be Equal As Strings ${stdout} ${k8scluster_name}
--- /dev/null
+# Copyright 2020 Canonical Ltd.
+#
+# 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.
+
+from pathlib import Path
+
+# Get ${HOME} from local machine
+home = str(Path.home())
+# K8s cluster name
+k8scluster_name = 'k8s-test'
+k8scluster_version = 'v1'
+# SSH keys to be used
+publickey = home + '/.ssh/id_rsa.pub'
+privatekey = home + '/.ssh/id_rsa'
k8scluster_name = 'k8s-test'
k8scluster_version = 'v1'
# NS and VNF descriptor package files
-vnfd_pkg = 'hackfest_simple_k8s_vnfd.tar.gz'
-nsd_pkg = 'hackfest_simple_k8s_nsd.tar.gz'
+vnfd_pkg = 'hackfest_simple_k8s_vnf'
+nsd_pkg = 'hackfest_simple_k8s_ns'
# NS and VNF descriptor package files
-vnfd_name = 'hackfest-simple-k8s-vnfd'
-nsd_name = 'hackfest-simple-k8s-nsd'
+vnfd_name = 'hackfest-simple-k8s-vnf'
+nsd_name = 'hackfest-simple-k8s-ns'
# NS instance name
ns_name = 'simple-k8s'
# SSH keys to be used
Usage:
docker run --rm=true -t osmtests --env-file <env_file> \\
- -v <path_to_reports>:/reports osmtests -v <path_to_clouds.yaml>:/robot-systest/clouds.yaml \\
- -v <path_to_kubeconfig>:/robot-systest/kubeconfig.yaml \\
- -o <osmclient_version> -p <package_branch> -t <testing_tags>
+ -v <path_to_reports>:/reports osmtests \\
+ -v <path_to_clouds.yaml>:/robot-systest/clouds.yaml \\
+ -v <path_to_kubeconfig>:/root/.kube/config \\
+ -o <osmclient_version> \\
+ -p <package_branch> \\
+ -t <testing_tags>
Options:
--env-file: It is the environmental file where is described the OSM target and VIM
Volumes:
<path_to_reports> [OPTIONAL]: It is the absolute path to reports location in the host
- <path_to_clouds.yaml> [OPTIONAL]: It is the absolute path to the clouds.yaml file in the host"
+ <path_to_clouds.yaml> [OPTIONAL]: It is the absolute path to the clouds.yaml file in the host
+ <path_to_kubeconfig> [OPTIONAL]: It is the kubeconfig file to be used for k8s clusters"
exit 0
;;
--- /dev/null
+# Copyright 2020 Canonical Ltd.
+#
+# 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 ***
+Library OperatingSystem
+Library String
+Library Collections
+Library Process
+
+Resource %{ROBOT_DEVOPS_FOLDER}/lib/k8scluster_lib.robot
+
+Variables %{ROBOT_DEVOPS_FOLDER}/resources/k8s_02-k8scluster_creation_data.py
+
+Suite Teardown Run Keyword And Ignore Error Test Cleanup
+
+*** Test Cases ***
+Add K8s Cluster To OSM
+ [Tags] k8scluster sanity regression
+ Create K8s Cluster %{K8S_CREDENTIALS} ${k8scluster_version} %{VIM_TARGET} %{VIM_MGMT_NET} ${k8scluster_name}
+
+List K8s Clusters
+ [Tags] k8scluster sanity regression
+ ${stdout}= Get K8s Cluster
+ Log To Console \n${stdout}
+
+Remove K8s Cluster from OSM
+ [Tags] k8scluster sanity regression
+ Delete K8s Cluster ${k8scluster_name}
+
+*** Keywords ***
+Test Cleanup
+ [Documentation] Test Suit Cleanup: Deleting K8s Cluster
+ Run Keyword If Test Failed Delete K8s Cluster ${k8scluster_name}
*** Test Cases ***
Create Simple K8s VNF Descriptor
- [Tags] simple_k8s
+ [Tags] simple_k8s sanity regression
Create VNFD '%{PACKAGES_FOLDER}/${vnfd_pkg}'
Create Simple K8s Descriptor
- [Tags] simple_k8s
+ [Tags] simple_k8s sanity regression
Create NSD '%{PACKAGES_FOLDER}/${nsd_pkg}'
Add K8s Cluster To OSM
- [Tags] k8scluster
+ [Tags] k8scluster sanity regression
Create K8s Cluster %{K8S_CREDENTIALS} ${k8scluster_version} %{VIM_TARGET} %{VIM_MGMT_NET} ${k8scluster_name}
Network Service K8s Instance Test
- [Tags] simple_k8s
+ [Tags] simple_k8s sanity regression
${id}= Create Network Service ${nsd_name} %{VIM_TARGET} ${ns_name} ${ns_config} ${publickey}
Set Suite Variable ${ns_id} ${id}
Delete NS K8s Instance Test
- [Tags] simple_k8s cleanup
+ [Tags] simple_k8s sanity regression cleanup
Delete NS ${ns_name}
Remove K8s Cluster from OSM
- [Tags] k8scluster
+ [Tags] k8scluster sanity regression
Delete K8s Cluster ${k8scluster_name}
Delete NS Descriptor Test
- [Tags] simple_k8s cleanup
+ [Tags] simple_k8s sanity regression cleanup
Delete NSD ${nsd_name}
Delete VNF Descriptor Test
- [Tags] simple_k8s cleanup
+ [Tags] simple_k8s sanity regression cleanup
Delete VNFD ${vnfd_name}