Commit e9a3dffd authored by aureliano sinatra's avatar aureliano sinatra
Browse files

efactoring SOL002

parent b3c7c4d9
*** Settings *** *** Settings ***
Resource environment/variables.txt Resource environment/variables.txt
Resource VnfLcmOperationKeywords.robot
Library REST ${VNFM_SCHEMA}://${VNFM_HOST}:${VNFM_PORT} Library REST ${VNFM_SCHEMA}://${VNFM_HOST}:${VNFM_PORT}
Library DependencyLibrary Library DependencyLibrary
Library JSONLibrary Library JSONLibrary
...@@ -8,82 +9,92 @@ Documentation This task resource represents the "Cancel operation" operation. ...@@ -8,82 +9,92 @@ Documentation This task resource represents the "Cancel operation" operation.
Suite Setup Check resource existance Suite Setup Check resource existance
*** Test Cases *** *** Test Cases ***
Post Cancel operation task Post Cancel operation task
[Documentation] The POST method initiates cancelling an ongoing VNF lifecycle operation while it is being executed or rolled back, i.e. [Documentation] Test ID: 6.3.5.16.1
... the related "VNF LCM operation occurrence" is either in "PROCESSING" or "ROLLING_BACK" state. ... Test title: POST Cancel operation task
Log Cancel a VNF lifecycle operation if that operation has experienced a temporary failure ... Test objective: The POST method initiates cancelling an ongoing VNF lifecycle operation while it is being executed or rolled back, i.e. the related "VNF LCM operation occurrence" is either in "PROCESSING" or "ROLLING_BACK" state.
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Pre-conditions: the related "VNF LCM operation occurrence" is either in "PROCESSING" or "ROLLING_BACK" state.
Log Cancel a VNF lifecycle operation ... Reference: section 5.4.17.3.1 - SOL002 v2.4.1
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfLcmOpOccId}/cancel ${CancelMode} ... Config ID: Config_prod_VE
Log Validate Status code ... Applicability: none
Integer response status 202 ... Post-Conditions: in response header Location should not be null
${headers}= Output response headers POST Cancel operation task
Should Contain ${headers} Location Check HTTP Response Status Code Is 202
Log Validation OK Check resource has a temporary failure
Post Cancel operation task Conflict (Not-FAILED_TEMP) Post Cancel operation task Conflict
# TODO: Need to set the pre-condition of the test. VNF instance shall be in INSTANTIATED state [Documentation] Test ID: 6.3.5.16.2
[Documentation] Conflict. ... Test title: POST Cancel operation task
... The operation cannot be executed currently, due to a conflict with the state of the VNF instance resource. ... Test objective: The POST method is NOT cancelling an ongoing VNF lifecycle operation due to the fact that the VNF instance resource is not in STARTING, PROCESSING or ROLLING_BACK state
... Typically, this is due to the fact that the VNF instance resource is not in FAILED_TEMP state, ... Pre-conditions: operation is not in STARTING, PROCESSING or ROLLING_BACK state
... or another error handling action is starting, such as retry or rollback. ... Reference: section 5.4.17.3.1 - SOL002 v2.4.1
... The response body shall contain a ProblemDetails structure, in which the �detail� attribute should convey more information about the error. ... Config ID: Config_prod_VE
Depends on test failure Check resource FAILED_TEMP ... Applicability: none
Log Final Fail an operation ... Post-Conditions: in response header Location should not be null
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} POST Cancel operation task
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfLcmOpOccId}/cancel Check HTTP Response Status Code Is 409
Integer response status 409 Check HTTP Response Body Json Schema Is ProblemDetails
Log Status code validated
${problemDetails}= Output response body
Validate Json ProblemDetails.schema.json ${problemDetails}
Log Validation OK
Post Cancel operation task Not Found Post Cancel operation task Not Found
# TODO: Need to create a vnfInstance which's instantiatedVnfInfo.scaleStatus is absent # TODO: Need to create a vnfInstance which's instantiatedVnfInfo.scaleStatus is absent
[Documentation] Not Found [Documentation] Test ID: 6.3.5.16.2
... Error: The API producer did not find a current representation for the target resource or is not willing to disclose that one exists. ... Test title: POST Cancel operation task
... Specifically in case of this task resource, the response code 404 shall also be returned ... Test objective: The objective is to test that POST method cannot cancel a VNF lifecycle operation because the resource is not found
... if the task is not supported for the VNF LCM operation occurrence represented by the parent resource, ... Pre-conditions:
... which means that the task resource consequently does not exist. ... Reference: section 5.4.17.3.1 - SOL002 v2.4.1
... In this case, the response body shall be present, and shall contain a ProblemDetails structure, in which the �detail� attribute shall convey more information about the error. ... Config ID: Config_prod_VE
[Setup] Check Fail not supported ... Applicability: none
log Final fail an operation ... Post-Conditions: in response header Location should not be null
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} POST Cancel operation task
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfLcmOpOccId}/cancel Check HTTP Response Status Code Is 404
Log Validate Status code
Integer response status 409
${problemDetails}= Output response body
Validate Json ProblemDetails.schema.json ${problemDetails}
Log Validation OK
GET Cancel operation task - Method not implemented GET Cancel operation task - Method not implemented
log Trying to perform a GET. This method should not be implemented [Documentation] Test ID: 6.3.5.16.3
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: GET Cancel operation task - Method not implemented
Get ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfInstanceId}/cancel ... Test objective: The objective is to test that GET method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.17.3.2 - SOL002 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
GET Cancel operation task
Check HTTP Response Status Code Is 405
PUT Cancel operation task - Method not implemented PUT Cancel operation task - Method not implemented
log Trying to perform a PUT. This method should not be implemented [Documentation] Test ID: 6.3.5.16.3
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: PUT Cancel operation task - Method not implemented
Put ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfInstanceId}/cancel ... Test objective: The objective is to test that PUT method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.17.3.2 - SOL002 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
PUT Cancel operation task
Check HTTP Response Status Code Is 405
PATCH Cancel operation task - Method not implemented PATCH Cancel operation task - Method not implemented
log Trying to perform a PATCH. This method should not be implemented [Documentation] Test ID: 6.3.5.16.4
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: PATCH Cancel operation task - Method not implemented
Patch ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfInstanceId}/cancel ... Test objective: The objective is to test that PATCH method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.17.3.3 - SOL002 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
PATCH Cancel operation task
Check HTTP Response Status Code Is 405
DELETE Cancel operation task - Method not implemented DELETE Cancel operation task - Method not implemented
log Trying to perform a DELETE. This method should not be implemented [Documentation] Test ID: 6.3.5.16.5
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: DELETE Cancel operation task - Method not implemented
Delete ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfInstanceId}/cancel ... Test objective: The objective is to test that DELETE method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.17.3.4 - SOL002 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
DELETE Cancel operation task
Check HTTP Response Status Code Is 405
*** Keywords *** *** Keywords ***
Check resource existance Check resource existance
......
*** Settings *** *** Settings ***
Resource environment/variables.txt Resource environment/variables.txt
Resource VnfLcmOperationKeywords.robot
Library REST ${VNFM_SCHEMA}://${VNFM_HOST}:${VNFM_PORT} Library REST ${VNFM_SCHEMA}://${VNFM_HOST}:${VNFM_PORT}
Library OperatingSystem Library OperatingSystem
Library JSONLibrary Library JSONLibrary
...@@ -7,48 +8,66 @@ Library JSONSchemaLibrary schemas/ ...@@ -7,48 +8,66 @@ Library JSONSchemaLibrary schemas/
Suite Setup Check resource existance Suite Setup Check resource existance
*** Test Cases *** *** Test Cases ***
Change external VNF connectivity POST Change external VNF connectivity
[Documentation] The POST method changes the external connectivity of a VNF instance [Documentation] Test ID: 6.3.5.10.1
Log Trying to change the external connectivity of a VNF instance. ... Test title: POST Change external VNF connectivity
Set Headers {"Accept":"${ACCEPT}"} ... Test objective: The objective is to test that POST method trigger a change in VNF external connectivity
Set Headers {"Content-Type": "${CONTENT_TYPE}"} ... Pre-conditions: none
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Reference: section 5.4.11.3.1 - SOL002 v2.4.1
${body}= Get File jsons/changeExtVnfConnectivityRequest .json ... Config ID: Config_prod_VE
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_ext_conn ${body} ... Applicability: none
Integer response status 202 ... Post-Conditions: in response header Location should not be null
Log Status code validated POST Change External VNF Connectivity
${headers}= Output response headers Check HTTP Response Status Code Is 202
Should Contain ${headers} Location Check Operation Occurrence Id
Log Validation OK
GET Change external VNF connectivity - Method not implemented GET Change external VNF connectivity - Method not implemented
log Trying to perform a GET. This method should not be implemented [Documentation] Test ID: 6.3.5.10.2
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: GET Change external VNF connectivity - Method not implemented
Get ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_ext_conn ... Test objective: The objective is to test that GET method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.11.3.2 - SOL002 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
GET Change External VNF Connectivity
Check HTTP Response Status Code Is 405
PUT Change external VNF connectivity - Method not implemented PUT Change external VNF connectivity - Method not implemented
log Trying to perform a PUT. This method should not be implemented [Documentation] Test ID: 6.3.5.10.3
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: PUT Change external VNF connectivity - Method not implemented
Put ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_ext_conn ... Test objective: The objective is to test that PUT method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.11.3.3 - SOL002 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
PUT Change External VNF Connectivity
Check HTTP Response Status Code Is 405
PATCH Change external VNF connectivity - Method not implemented PATCH Change external VNF connectivity - Method not implemented
log Trying to perform a PATCH. This method should not be implemented [Documentation] Test ID: 6.3.5.10.4
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: PATCH Change external VNF connectivity - Method not implemented
Patch ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_ext_conn ... Test objective: The objective is to test that PATCH method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.11.3.4 - SOL002 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
PATCH Change External VNF Connectivity
Check HTTP Response Status Code Is 405
DELETE Change external VNF connectivity - Method not implemented DELETE Change external VNF connectivity - Method not implemented
log Trying to perform a DELETE. This method should not be implemented [Documentation] Test ID: 6.3.5.10.5
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: DELETE Change external VNF connectivity - Method not implemented
Delete ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_ext_conn ... Test objective: The objective is to test that DELETE method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.11.3.5 - SOL002 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
DELETE Change External VNF Connectivity
Check HTTP Response Status Code Is 405
*** Keywords *** *** Keywords ***
Check resource existance Check resource existance
......
*** Settings *** *** Settings ***
Resource environment/variables.txt Resource environment/variables.txt
Resource VnfLcmOperationKeywords.robot
Library REST ${VNFM_SCHEMA}://${VNFM_HOST}:${VNFM_PORT} Library REST ${VNFM_SCHEMA}://${VNFM_HOST}:${VNFM_PORT}
Library OperatingSystem Library OperatingSystem
Library JSONLibrary Library JSONLibrary
...@@ -8,87 +9,93 @@ Suite Setup Check resource existance ...@@ -8,87 +9,93 @@ Suite Setup Check resource existance
*** Test Cases *** *** Test Cases ***
Change deployment flavour of a vnfInstance Change deployment flavour of a vnfInstance
[Documentation] Changes the deployment flavour of a VNF instance.. [Documentation] Test ID: 6.3.5.6.1
Log Trying to change the deployment flavour of a VNF instance. ... Test title: POST Change deployment flavour of a vnfInstance
Set Headers {"Accept":"${ACCEPT}"} ... Test objective: The objective is to test that POST method trigger a change in VNF deployment flavour
Set Headers {"Content-Type": "${CONTENT_TYPE}"} ... Pre-conditions: none
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Reference: section 5.4.7.3.1 - SOL003 v2.4.1
${body}= Get File jsons/changeVnfFlavourRequest.json ... Config ID: Config_prod_VE
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_flavour ${body} ... Applicability: none
Integer response status 202 ... Post-Conditions: in response header Location should not be null
Log Status code validated POST Change VNF deployment flavour
${headers}= Output response headers Check HTTP Response Status Code Is 202
Should Contain ${headers} Location Check Operation Occurrence Id
Log Validation OK
Change deployment flavour of a vnfInstance Conflict (Not-Instantiated) Change deployment flavour of a vnfInstance Conflict (Not-Instantiated)
# TODO: Need to set the pre-condition of the test. VNF instance shall be in INSTANTIATED state [Documentation] Test ID: 6.3.5.6.2
[Documentation] Conflict. ... Test title: POST Change deployment flavour of a vnfInstance
... The operation cannot be executed currently, due to a conflict with the state of the VNF instance resource. ... Test objective: The objective is to test that POST method can't trigger a change in VNF deployment flavour because of a conflict with the state of the VNF instance resource.
... Typically, this is due to the fact that the VNF instance resource is in NOT-INSTANTIATED state, ... Pre-conditions: VNF instance resource is not in NOT-INSTANTIATED state
... or that another lifecycle management operation is ongoing. ... Reference: section 5.4.7.3.1 - SOL003 v2.4.1
... The response body shall contain a ProblemDetails structure, in which the �detail� attribute should convey more information about the error. ... Config ID: Config_prod_VE
[Setup] Check resource not instantiated ${vnfInstanceId} ... Applicability: none
Log Trying to change the deployment flavour of a VNF instance. ... Post-Conditions: none
Set Headers {"Accept":"${ACCEPT}"} POST Change VNF deployment flavour
Set Headers {"Content-Type": "${CONTENT_TYPE}"} Check HTTP Response Status Code Is 409
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} Check HTTP Response Body Json Schema Is ProblemDetails
${body}= Get File jsons/changeVnfFlavourRequest.json
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_flavour ${body}
Integer response status 409
Log Status code validated
${problemDetails}= Output response body
Validate Json ProblemDetails.schema.json ${problemDetails}
Log Validation OK
Change deployment flavour of a vnfInstance Not Found Change deployment flavour of a vnfInstance Not Found
# TODO: Need to create a vnfInstance which's instantiatedVnfInfo.scaleStatus is absent [Documentation] Test ID: 6.3.5.6.3
[Documentation] Not Found ... Test title: POST Change deployment flavour of a vnfInstance
... Error: The API producer did not find a current representation for the target resource or is not willing to disclose that one exists. ... Test objective: The objective is to test that POST method can't trigger a change in VNF deployment flavour because the VNF instance resource is not found.
... Specifically in case of this task resource, the response code 404 shall also returned if the task is not supported for the VNF instance represented by the parent resource, which means that the task resource consequently does not exist. ... Pre-conditions: VNF instance resource is not in NOT-INSTANTIATED state
... In this case, the response body shall be present, and shall contain a ProblemDetails structure, in which the �detail� attribute shall convey more information about the error. ... Reference: section 5.4.7.3.1 - SOL003 v2.4.1
[Setup] Check change flavour not supported ... Config ID: Config_prod_VE
Log Trying to change the deployment flavour of a VNF instance, not exist ... Applicability: none
Set Headers {"Accept":"${ACCEPT}"} ... Post-Conditions: none
Set Headers {"Content-Type": "${CONTENT_TYPE}"} POST Change VNF deployment flavour
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} Check HTTP Response Status Code Is 404
${body}= Get File jsons/changeVnfFlavourRequest.json Check HTTP Response Body Json Schema Is ProblemDetails
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_flavour ${body}
Integer response status 404
Log Status code validated
${problemDetails}= Output response body
Validate Json ProblemDetails.schema.json ${problemDetails}
Log Validation OK
GET Change deployment flavour VNFInstance - Method not implemented GET Change deployment flavour VNFInstance - Method not implemented
log Trying to perform a GET. This method should not be implemented [Documentation] Test ID: 6.3.5.16.4
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: GET Cancel operation task - Method not implemented
Get ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_flavour ... Test objective: The objective is to test that GET method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.7.3.2 - SOL003 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
GET Change VNF deployment flavour
Check HTTP Response Status Code Is 405
PUT Change deployment flavour VNFInstance - Method not implemented PUT Change deployment flavour VNFInstance - Method not implemented
log Trying to perform a PUT. This method should not be implemented [Documentation] Test ID: 6.3.5.16.5
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: PUT Cancel operation task - Method not implemented
Put ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_flavour ... Test objective: The objective is to test that PUT method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.7.3.3 - SOL003 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
PUT Change VNF deployment flavour
Check HTTP Response Status Code Is 405
PATCH Change deployment flavour VNFInstance - Method not implemented PATCH Change deployment flavour VNFInstance - Method not implemented
log Trying to perform a PATCH. This method should not be implemented [Documentation] Test ID: 6.3.5.16.6
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: PATCH Cancel operation task - Method not implemented
Patch ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_flavour ... Test objective: The objective is to test that PATCH method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.7.3.4 - SOL003 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
PATCH Change VNF deployment flavour
Check HTTP Response Status Code Is 405
DELETE Change deployment flavour VNFInstance - Method not implemented DELETE Change deployment flavour VNFInstance - Method not implemented
log Trying to perform a DELETE. This method should not be implemented [Documentation] Test ID: 6.3.5.16.7
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test title: DELETE Cancel operation task - Method not implemented
Delete ${apiRoot}/${apiName}/${apiVersion}/vnf_instances/${vnfInstanceId}/change_flavour ... Test objective: The objective is to test that DELETE method is not implemented
Log Validate Status code ... Pre-conditions: none
Integer response status 405 ... Reference: section 5.4.7.3.5 - SOL003 v2.4.1
... Config ID: Config_prod_VE
... Applicability: none
... Post-Conditions: none
DELETE Change VNF deployment flavour
Check HTTP Response Status Code Is 405
*** Keywords *** *** Keywords ***
Check resource existance Check resource existance
......
*** Settings *** *** Settings ***
Resource environment/variables.txt Resource environment/variables.txt
Resource VnfLcmOperationKeywords.robot
Library REST ${VNFM_SCHEMA}://${VNFM_HOST}:${VNFM_PORT} Library REST ${VNFM_SCHEMA}://${VNFM_HOST}:${VNFM_PORT}
Library DependencyLibrary Library DependencyLibrary
Library JSONLibrary Library JSONLibrary
Library JSONSchemaLibrary schemas/ Library JSONSchemaLibrary schemas/
Documentation This task resource represents the "Fail operation" operation.
... The client can use this resource to mark a VNF lifecycle management operation occurrence as "finally failed",
... i.e. change the state of the related VNF LCM operation occurrence resource to "FAILED", if it is not assumed that a subsequent retry or rollback will succeed.
... Once the operation is marked as "finally failed", it cannot be retried or rolled back anymore.
Suite Setup Check resource existance
*** Test Cases *** *** Test Cases ***
Post Fail operation task Post Fail operation task
[Documentation] The POST method marks a VNF lifecycle management operation occurrence as "finally failed" if that operation occurrence is in "FAILED_TEMP" state. [Documentation] Test ID: 6.3.5.15.1
Log Final fail a VNF lifecycle operation if that operation has experienced a temporary failure ... Test title: Post Fail operation task
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Test objective: The objective is to test that POST method mark as "finally failed" a VNF lifecycle operation if that operation has experienced a temporary failure
Log Execute Query and validate response ... Pre-conditions: the related "VNF LCM operation occurrence" resource is in "FAILED_TEMP" state.
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfLcmOpOccId}/fail ... Reference: section 5.4.16.3.1 - SOL002 v2.4.1
Output response ... Config ID: Config_prod_VE
Log Validate Status code ... Applicability: none
Integer response status 202 ... Post-Conditions: none
${headers}= Output response headers Post Fail operation
Should Contain ${headers} Location Check HTTP Response Status Code Is 202
Log Validation OK Check Operation Occurrence Id
Post Fail operation task Conflict (Not-FAILED_TEMP) Post Fail operation task Conflict (Not-FAILED_TEMP)
# TODO: Need to set the pre-condition of the test. VNF instance shall be in INSTANTIATED state # TODO: Need to set the pre-condition of the test. VNF instance shall be in INSTANTIATED state
[Documentation] Conflict. [Documentation] Test ID: 6.3.5.15.2
... The operation cannot be executed currently, due to a conflict with the state of the VNF instance resource. ... Test title: Post Fail operation task
... Typically, this is due to the fact that the VNF instance resource is not in FAILED_TEMP state, ... Test objective: The objective is to test that POST method cannot mark as "finally failed" a VNF lifecycle operation if that operation has experienced a temporary failure
... or another error handling action is starting, such as retry or rollback. ... Pre-conditions: the related "VNF LCM operation occurrence" resource is not in "FAILED_TEMP" state.
... The response body shall contain a ProblemDetails structure, in which the �detail� attribute should convey more information about the error. ... Reference: section 5.4.16.3.1 - SOL002 v2.4.1
Depends on test failure Check resource FAILED_TEMP ... Config ID: Config_prod_VE
Log Final Fail an operation ... Applicability: none
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} ... Post-Conditions: none
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfLcmOpOccId}/fail Post Fail operation
Integer response status 409 Check HTTP Response Status Code Is 409
Log Status code validated Check HTTP Response Body Json Schema Is ProblemDetails
${problemDetails}= Output response body
Validate Json ProblemDetails.schema.json ${problemDetails}
Log Validation OK
Post Fail operation task Not Found Post Fail operation task Not Found
# TODO: Need to create a vnfInstance which's instantiatedVnfInfo.scaleStatus is absent # TODO: Need to create a vnfInstance which's instantiatedVnfInfo.scaleStatus is absent
[Documentation] Not Found [Documentation] Test ID: 6.3.5.15.3
... Error: The API producer did not find a current representation for the target resource or is not willing to disclose that one exists. ... Test title: Post Fail operation task
... Specifically in case of this task resource, the response code 404 shall also be returned ... Test objective: The objective is to test that POST method cannot mark as "finally failed" a VNF lifecycle operation because the operation is not supported
... if the task is not supported for the VNF LCM operation occurrence represented by the parent resource, ... Pre-conditions:
... which means that the task resource consequently does not exist. ... Reference: section 5.4.16.3.1 - SOL002 v2.4.1
... In this case, the response body shall be present, and shall contain a ProblemDetails structure, in which the �detail� attribute shall convey more information about the error. ... Config ID: Config_prod_VE
[Setup] Check Fail not supported ... Applicability: none
log Final fail an operation ... Post-Conditions: none
Run Keyword If ${AUTH_USAGE} == 1 Set Headers {"Authorization":"${AUTHORIZATION}"} Post Fail operation
Post ${apiRoot}/${apiName}/${apiVersion}/vnf_lcm_op_occs/${vnfLcmOpOccId}/fail Check HTTP Response Status Code Is 404
Log Validate Status code
Integer response status 409
${problemDetails}= Output response body
Validate Json ProblemDetails.schema.json ${problemDetails}
Log Validation OK