+*** Comments ***
+# Copyright 2019 Tech Mahindra Limited
+#
+# 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.
+
+
+*** Settings ***
+Documentation Library providing keywords for CRUD operations over VNFD / VNF packages with OSM client.
+Library OperatingSystem
+Library String
+
+
+*** Variables ***
+${SUCCESS_RETURN_CODE} 0
+${FAILURE_RETURN_CODE} 1
+${VNFD_DELETE_MAX_WAIT_TIME} 1min
+${VNFD_DELETE_POL_TIME} 15sec
+
+
+*** Keywords ***
+Get VNFDs List
+ [Documentation] Get the list of VNF packages and log it.
+ ${rc} ${stdout}= Run And Return Rc And Output osm vnfpkg-list
+ Log ${stdout}
+ Log ${rc}
+ Should Be Equal As Integers ${rc} ${SUCCESS_RETURN_CODE}
+
+Create VNFD
+ [Documentation] Onboards ("creates") a NF Package into OSM.
+ ... - Parameters:
+ ... - vnfd_pkg: Name (and location) of the NF Package
+ ... - overrides (optional): String with options to override the EPA and/or interface properties of the Package.
+ ... This is very useful to allow to deploy e.g. non-EPA packages in EPA VIMs (or vice-versa).
+ ... Valid strings are the same as in the command. E.g.:
+ ... - `--override-epa`: adds EPA attributes to all VDUs.
+ ... - `--override-nonepa`: removes all EPA attributes from all VDUs.
+ ... - `--override-paravirt`: converts all interfaces to `PARAVIRT`. This one can be combined with
+ ... the others above (e.g. '--override-nonepa --override-paravirt').
+ ... - Relevant environment variables:
+ ... - OVERRIDES: If the environment variable "OVERRIDES" exists, it prevails over the value in the argument.
+ ... This is often more convenient to enforce the same behaviour for every test run in a given VIM.
+ [Arguments] ${vnfd_pkg} ${overrides}=${EMPTY}
+ # If env variable "OVERRIDES" exists, it prevails over the value in the argument
+ ${overrides}= Get Environment Variable OVERRIDES default=${overrides}
+ # Proceeds with the onboarding with the appropriate arguments
+ ${rc} ${stdout}= Run And Return Rc And Output osm vnfpkg-create ${overrides} ${vnfd_pkg}
+ Log ${stdout}
+ Should Be Equal As Integers ${rc} ${SUCCESS_RETURN_CODE}
+ ${lines}= Get Line Count ${stdout}
+ ${last}= Evaluate ${lines} - 1
+ ${id}= Get Line ${stdout} ${last}
+ RETURN ${id}
+
+Update VNFD
+ [Documentation] Onboard ("Update") a NF Package into OSM.
+ ... - Parameters:
+ ... - vnfd_pkg: Name (and location) of the NF Package
+ ... - vnfd_name: Name of the existing NF Package
+ [Arguments] ${vnfd_pkg} ${vnfd_name}
+ # Proceeds with the onboarding with the appropriate arguments
+ ${rc} ${stdout}= Run And Return Rc And Output osm vnfpkg-update --content ${vnfd_pkg} ${vnfd_name}
+ Log ${stdout}
+ Should Be Equal As Integers ${rc} ${SUCCESS_RETURN_CODE}
+ ${lines}= Get Line Count ${stdout}
+ ${last}= Evaluate ${lines} - 1
+ ${id}= Get Line ${stdout} ${last}
+ RETURN ${id}
+
+Create VNFD Overriding Fields
+ [Documentation] Onboards ("creates") a NF Package into OSM.
+ ... - Parameters:
+ ... - vnfd_pkg: Name (and location) of the NF Package
+ ... - override_fields: String with options to override fields in descriptor, format: "key1.key2...=value[;key3...=value;...]"
+ ... - overrides (optional): String with options to override the EPA and/or interface properties of the Package.
+ ... This is very useful to allow to deploy e.g. non-EPA packages in EPA VIMs (or vice-versa).
+ ... Valid strings are the same as in the command. E.g.:
+ ... - `--override-epa`: adds EPA attributes to all VDUs.
+ ... - `--override-nonepa`: removes all EPA attributes from all VDUs.
+ ... - `--override-paravirt`: converts all interfaces to `PARAVIRT`. This one can be combined with
+ ... the others above (e.g. '--override-nonepa --override-paravirt').
+ ... - Relevant environment variables:
+ ... - OVERRIDES: If the environment variable "OVERRIDES" exists, it prevails over the value in the argument.
+ ... This is often more convenient to enforce the same behaviour for every test run in a given VIM.
+ [Arguments] ${vnfd_pkg} ${override_fields} ${overrides}=${EMPTY}
+ # If env variable "OVERRIDES" exists, it prevails over the value in the argument
+ ${overrides}= Get Environment Variable OVERRIDES default=${overrides}
+ # Proceeds with the onboarding with the appropriate arguments
+ ${rc} ${stdout}= Run And Return Rc And Output osm vnfpkg-create ${overrides} ${vnfd_pkg} --override '${override_fields}'
+ Log ${stdout}
+ Should Be Equal As Integers ${rc} ${SUCCESS_RETURN_CODE}
+ ${lines}= Get Line Count ${stdout}
+ ${last}= Evaluate ${lines} - 1
+ ${id}= Get Line ${stdout} ${last}
+ RETURN ${id}
+
+Delete VNFD
+ [Documentation] Delete a VNF package from OSM.
+ [Arguments] ${vnfd_id}
+ ${rc} ${stdout}= Run And Return Rc And Output osm vnfpkg-delete ${vnfd_id}
+ Log ${stdout}
+ Should Be Equal As Integers ${rc} ${SUCCESS_RETURN_CODE}
+ Wait Until Keyword Succeeds ${VNFD_DELETE_MAX_WAIT_TIME} ${VNFD_DELETE_POL_TIME} Check For VNFD ${vnfd_id}
+
+Assert Failure Delete VNFD
+ [Documentation] Deletes a NF Package that cannot be deleted and asserts the failure
+ [Arguments] ${vnfd_id}
+ ${rc} ${stdout}= Run And Return Rc And Output osm vnfpkg-delete ${vnfd_id}
+ Log ${stdout}
+ Should Be Equal As Integers ${rc} ${FAILURE_RETURN_CODE}
+ Should Contain ${stdout} 409 msg=Expected Conflict values=False
+ Wait Until Keyword Succeeds ${VNFD_DELETE_MAX_WAIT_TIME} ${VNFD_DELETE_POL_TIME} Check For VNFD ${vnfd_id} True
+
+Check For VNFD
+ [Documentation] Check that a VNF package exists in OSM.
+ [Arguments] ${vnfd_id} ${exists}=False
+ ${rc} ${stdout}= Run And Return Rc And Output osm vnfpkg-list | awk '{print $2}' | grep ${vnfd_id}
+ Log ${rc},${stdout}
+ IF ${exists}
+ Should Be Equal As Strings ${stdout} ${vnfd_id}
+ ELSE
+ Should Not Be Equal As Strings ${stdout} ${vnfd_id}
+ END