...Test title: GET Individual VNF Package Subscription
...Test objective: The objective is to test the retrieval of individual VNF package subscription and perform a JSON schema and content validation of the returned subscription data structure
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.8.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Get Individual VNF Package Subscription
Check HTTP Response Status Code Is200
Check HTTP Response Body Json Schema IsPkgmSubscription
Check HTTP Response Body Subscription Identifier matches the requested Subscription
GET Subscription - Negative (Not Found)
LogTrying to perform a request on a subscriptionID which doesn't exist
Set Headers{"Accept": "${ACCEPT_JSON}"}
Run Keyword If${AUTH_USAGE}== 1Set Headers{"Authorization": "${AUTHORIZATION}"}
GET Individual VNF Package Subscription with invalid resource identifier
[Documentation]Test ID: 7.3.3.7.2
...Test title: GET Individual VNF Package Subscription with invalid resource identifier
...Test objective: The objective is to test that the retrieval of an individual VNF package subscription fails when using an invalid resource identifier
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.8.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
GET individual VNF Package Subscription with invalid resource identifier
Check HTTP Response Status Code Is404
DELETE Subscription
LogTrying to perform a DELETE on a subscriptionId
Set Headers{"Accept": "${ACCEPT_JSON}"}
Run Keyword If${AUTH_USAGE}== 1Set Headers{"Authorization": "${AUTHORIZATION}"}
...Test objective: The objective is to test that the deletion of an individual VNF package subscription fails when using an invalid resource identifier
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.8.3.5 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Send Delete request for individual VNF Package Subscription with invalid resource identifier
Check HTTP Response Status Code Is404
DELETE Subscription - Negative (Not Found)
LogTrying to perform a DELETE on a subscriptionId which doesn't exist
Set Headers{"Accept": "${ACCEPT_JSON}"}
Run Keyword If${AUTH_USAGE}== 1Set Headers{"Authorization": "${AUTHORIZATION}"}
@@ -13,12 +13,28 @@ Suite Teardown Terminate All Processes kill=true
*** Test Cases ***
Get All VNF Package Subscriptions
[Documentation]Test ID: 7.3.3.6.1
...Test title: GET all VNF Package Subscriptions
...Test objective: The objective is to test the retrieval of all VNF package subscriptions and perform a JSON schema validation of the returned subscriptions data structure
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.7.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Get all VNF Package Subscriptions
Check HTTP Response Status Code Is200
Check HTTP Response Body Json Schema IsPkgmSubscriptions
Get VNF Package Subscriptions with attribute-based filter
[Documentation]Test ID: 7.3.3.6.2
...Test title: Get VNF Package Subscriptions with attribute-based filter
...Test objective: The objective is to test the retrieval of VNF package subscriptions using attribute-based filter, perform a JSON schema validation of the collected data structure, and verify that the retrieved information matches the issued attribute-based filters
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.7.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Get VNF Package Subscriptions with attribute-based filters
Check HTTP Response Status Code Is200
Check HTTP Response Body Json Schema IsPkgmSubscription
...
...
@@ -26,55 +42,112 @@ Get VNF Package Subscriptions with attribute-based filter
Get VNF Package Subscriptions with invalid attribute-based filter
[Documentation]Test ID: 7.3.3.6.3
...Test title: Get VNF Package Subscriptions with attribute-based filters
...Test objective: The objective is to test that the retrieval of VNF package subscriptions fails when using invalid attribute-based filters, and perform the JSON schema validation of the failed operation HTTP response.
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.7.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Get VNF Package Subscriptions with invalid attribute-based filters
Check HTTP Response Status Code Is400
Check HTTP Response Body Json Schema IsProblemDetails
GET VNF Package Subscription with invalid resource endpoint
[Documentation]Test ID: 7.3.3.6.4
...Test title: GET VNF Package Subscription with invalid resource endpoint
...Test objective: The objective is to test that the retrieval of all VNF package subscriptions fails when using invalid resource endpoint.
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.7.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Get VNF Package Subscriptions with invalid resource endpoint
Check HTTP Response Status Code Is404
Create new VNF Package subscription
[Documentation]Test ID 7.3.3.6.5
...Test title: Create new VNF Package subscription
...Test objective: The objective is to test the creation of a new VNF package subscription and perform a JSON schema and content validation of the returned subscription data structure
...Pre-conditions: none
...Reference:section 10.4.7.3.1 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: The VNF package subscription is successfully set and it matches the issued subscription
Send Post Request for VNF Package Subscription
Check HTTP Response Status Code Is201
Check HTTP Response Body Json Schema IsPkgmSubscription
Check HTTP Response Body Matches the Subscription
Check HTTP Response Body PkgmSubscription Attributes Values Match the Issued Subscription
Check Postcondition VNF Package Subscription Is Set
Create duplicated VNF Package subscription with duplication handler
Create duplicated VNF Package subscription with NFVO not creating duplicated subscriptions
[Tags]no-duplicated-subs
[Documentation]Test ID 7.3.3.6.6
...Test title: Create duplicated VNF Package subscription with NFVO not creating duplicated subscriptions
...Test objective: The objective is to test the attempt of a creation of a duplicated VNF package subscription and check that no new subscription is created by the NFVO and a link to the original subscription is returned
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.7.3.1 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: The NFVO does not support the creation of duplicated subscriptions
...Post-Conditions: The existing VNF package subscription returned is available in the NFVO
Send Post Request for Duplicated VNF Package Subscription
Check HTTP Response Status Code Is303
Check HTTP Response Body Is Empty
Check HTTP Response Header ContainsLocation
Check Postcondition VNF Package Subscription Is SetLocation
Check Postcondition Subscription Resource Returned in Location Header Is Available
Create duplicated VNF Package subscription without duplication handler
Create duplicated VNF Package subscription with NFVO creating duplicated subscriptions
...Test objective: The objective is to test the creation of a duplicated VNF package subscription and perform a JSON schema and content validation of the returned duplicated subscription data structure
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.7.3.1 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: The NFVO supports the creation of duplicated subscriptions
...Post-Conditions: The duplicated VNF package subscription is successfully set and it matches the issued subscription
Send Post Request for Duplicated VNF Package Subscription
Check HTTP Response Status Code Is201
Check HTTP Response Body Json Schema IsPmSubscription
Check HTTP Response Body Matches the Subscription
Check HTTP Response Body Json Schema IsPkgmSubscription
Check HTTP Response Body PkgmSubscription Attributes Values Match the Issued Subscription
Check Postcondition VNF Package Subscription Is Set
PUT VNF Package Subscriptions - Method not implemented
[Documentation]Test ID 7.3.3.6.8
...Test title: PUT VNF Package Subscriptions - Method not implemented
...Test objective: The objective is to test that PUT method is not allowed to modify VNF package subscriptions
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.7.3.3 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Send Put Request for VNF Package Subscriptions
Check HTTP Response Status Code Is405
PATCH VNF Package Subscriptions - Method not implemented
[Documentation]Test ID 7.3.3.6.9
...Test title: PATCH VNF Package Subscriptions - Method not implemented
...Test objective: The objective is to test that PATCH method is not allowed to update VNF package subscriptions
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.7.3.4 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Send Patch Request for VNF Package Subscriptions
Check HTTP Response Status Code Is405
DELETE VNF Package Subscriptions - Method not implemented
[Documentation]Test ID 7.3.3.6.10
...Test title: DELETE VNF Package Subscriptions - Method not implemented
...Test objective: The objective is to test that DELETE method is not allowed to delete VNF package subscriptions
...Pre-conditions: At least one VNF package subscription is available in the NFVO.
...Reference:section 10.4.7.3.5 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: The VNF package subscriptions are not deleted by the failed operation
Get single file VNFD in Individual VNF Package in Plain Format
[Documentation]Test ID: 7.3.3.4.1
...Test title: Get VNFD in Individual VNF Package in Plain Format
...Test objective: The objective is to test the retrieval of the VNFD in plain format for an individual VNF package and perform a validation that returned content is in plain format
...Pre-conditions: One or more VNF packages are onboarded in the NFVO.
...Reference: section 10.4.4.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: The VNFD is implemented as a single file
...Post-Conditions: none
Get single file VNFD in Individual VNF Package in Plain Format
...Test title: Get VNFD in Individual VNF Package in Zip Format
...Test objective: The objective is to test the retrieval of the VNFD in zip format for an individual VNF package and perform a validation that returned content is in zip format
...Pre-conditions: One or more VNF packages are onboarded in the NFVO.
Get single file VNFD in Individual VNF Package in Plain or Zip Format
[Documentation]Test ID: 7.3.3.4.3
...Test title: Get single file VNFD in Individual VNF Package in Plain or Zip Format
...Test objective: The objective is to test the retrieval of the single file VNFD for an individual VNF package when requesting both Plain and Zip format to NFVO, and perform a validation that returned content is in plain or zip format
...Pre-conditions: One or more VNF packages are onboarded in the NFVO.
...Reference: section 10.4.4.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: The VNFD is implemented as a single file
...Post-Conditions: none
Get single file VNFD in Individual VNF Package in Plain or Zip Format
Check HTTP Response Status Code Is200
Check HTTP Response Header Content-Type Is Any oftext/plainapplication/zip
Get multi file VNFD in Individual VNF Package in Plain or Zip Format
[Documentation]Test ID: 7.3.3.4.4
...Test title: Get multi file VNFD in Individual VNF Package in Plain or Zip Format
...Test objective: The objective is to test the retrieval of the multi file VNFD for an individual VNF package when requesting both Plain and Zip format to NFVO, and perform a validation that returned content is in zip format
...Pre-conditions: One or more VNF packages are onboarded in the NFVO.
...Reference: section 10.4.4.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: The VNFD is implemented as a multi file
...Post-Conditions: none
Get multi file VNFD in Individual VNF Package in Plain or Zip Format
GET VNFD in Individual VNF Package - Negative (PLAIN/ZIP)
LogTrying to get a negative case performing a get on a VNFD from a given VNF Package present in the NFVO Catalogue. Accept will be text/plain but VNFD is composed my multiple files.
Set Headers{"Accept": "${ACCEPT_PLAIN}"}
Run Keyword If${AUTH_USAGE}== 1Set Headers{"Authorization": "${AUTHORIZATION}"}
Get multi file VNFD in Individual VNF Package in Plain Format
[Documentation]Test ID: 7.3.3.4.5
...Test title: Get multi file VNFD in Individual VNF Package in Plain Format
...Test objective: The objective is to test that the retrieval of the multi file VNFD for an individual VNF package fails when requesting it in Plain format, and perform a validation of the JSON schema validation of the failed operation HTTP response
...Pre-conditions: One or more VNF packages are onboarded in the NFVO.
...Reference: section 10.4.4.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: The VNFD is implemented as a multi file
...Post-Conditions: none
Get multi file VNFD in Individual VNF Package in Plain Format
Check HTTP Response Status Code Is406
Check HTTP Response Body Json Schema IsProblemDetails
GET VNFD in Individual VNF Package - Negative (Not Found)
LogTrying to perform a negative get, using an erroneous package ID
Set Headers{"Accept": "${ACCEPT_PLAIN}"}
Set Headers{"Accept": "${ACCEPT_ZIP}"}
Run Keyword If${AUTH_USAGE}== 1Set Headers{"Authorization": "${AUTHORIZATION}"}
Get VNFD in Individual VNF Package with invalid resource identifier
[Documentation]Test ID: 7.3.3.4.6
...Test title: Get VNFD in Individual VNF Package with invalid resource identifier
...Test objective: The objective is to test that the retrieval of the VNFD for an individual VNF package content fails when using an invalid resource identifier
...Pre-conditions: none
...Reference: section 10.4.4.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Get VNFD in Individual VNF Package with invalid resource identifier
Check HTTP Response Status Code Is404
GET VNFD in Individual VNF Package - Negative (onboardingState issue)
LogTrying to get a VNFD from a given VNF Package present in the NFVO Catalogue
Set Headers{"Accept": "${ACCEPT_PLAIN}"}
Set Headers{"Accept": "${ACCEPT_ZIP}"}
Run Keyword If${AUTH_USAGE}== 1Set Headers{"Authorization": "${AUTHORIZATION}"}
Get VNFD in Individual VNF Package Content with conflict due to onboarding state
[Documentation]Test ID: 7.3.3.4.7
...Test title: Get VNFD in Individual VNF Package Content with conflict due to onboarding state
...Test objective: The objective is to test that the retrieval of the VNFD for an individual VNF package content fails due to a conflict when the VNF Package is not in onboarding state ONBOARDED in the NFVO. The test also performs a validation of the JSON schema validation of the failed operation HTTP response
...Pre-conditions: The onboarding state of the VNF package for which the VNFD is requested is different from ONBOARDED.
...Reference: section 10.4.4.3.2 - SOL003 v2.4.1
...Config ID: Config_prod_NFVO
...Applicability: none
...Post-Conditions: none
Get VNFD in Individual VNF Package Content with conflict due to onboarding state
Check HTTP Response Status Code Is409
Check HTTP Response Body Json Schema IsProblemDetails
POST VNFD in Individual VNF Package (Method not implemented)
LogTrying to perform a POST (method should not be implemented)
Set Headers{"Accept": "${ACCEPT_ZIP}"}
Run Keyword If${AUTH_USAGE}== 1Set Headers{"Authorization": "${AUTHORIZATION}"}