diff options
Diffstat (limited to 'robot')
-rw-r--r-- | robot/assets/templates/aai/add-connectivity.template | 21 | ||||
-rw-r--r-- | robot/resources/aai/aai_interface.robot | 4 | ||||
-rw-r--r-- | robot/resources/aai/api_version_properties.robot | 12 | ||||
-rw-r--r-- | robot/resources/aai/ccvpn-connectivities.robot | 80 | ||||
-rw-r--r-- | robot/resources/so_interface.robot | 20 | ||||
-rw-r--r-- | robot/testsuites/aai/aai-regression-test-v14.robot | 18 |
6 files changed, 144 insertions, 11 deletions
diff --git a/robot/assets/templates/aai/add-connectivity.template b/robot/assets/templates/aai/add-connectivity.template new file mode 100644 index 00000000..a693b208 --- /dev/null +++ b/robot/assets/templates/aai/add-connectivity.template @@ -0,0 +1,21 @@ +{ + "connectivity-id": "${connectivity_id}", + "bandwidth-profile-name": "", + "vpn-type": "", + "cir": "", + "eir": "", + "cbs": "", + "ebs": "", + "color-aware": "", + "coupling-flag": "", + "etht-svc-name": "", + "access-provider-id": "", + "access-client-id": "", + "access-topology-id": "", + "access-node-id": "", + "access-ltp-id": "", + "connectivity-selflink": "", + "cvlan": "", + "operational-status": "", + "resource-version": "" +} diff --git a/robot/resources/aai/aai_interface.robot b/robot/resources/aai/aai_interface.robot index b72103d0..c0600064 100644 --- a/robot/resources/aai/aai_interface.robot +++ b/robot/resources/aai/aai_interface.robot @@ -68,12 +68,12 @@ Run A&AI Delete Request Delete A&AI Entity [Documentation] Deletes an entity in A&AI [Arguments] ${uri} - ${get_resp}= Run A&AI Get Request ${VERSIONED_INDEX PATH}${uri} + ${get_resp}= Run A&AI Get Request ${VERSIONED_INDEX_PATH}${uri} Run Keyword If '${get_resp.status_code}' == '200' Delete A&AI Entity Exists ${uri} ${get_resp.json()['resource-version']} Delete A&AI Entity Exists [Documentation] Deletes an A&AI entity [Arguments] ${uri} ${resource_version_id} - ${put_resp}= Run A&AI Delete Request ${VERSIONED_INDEX PATH}${uri} ${resource_version_id} + ${put_resp}= Run A&AI Delete Request ${VERSIONED_INDEX_PATH}${uri} ${resource_version_id} Should Be Equal As Strings ${put_resp.status_code} 204 diff --git a/robot/resources/aai/api_version_properties.robot b/robot/resources/aai/api_version_properties.robot new file mode 100644 index 00000000..17ba9de5 --- /dev/null +++ b/robot/resources/aai/api_version_properties.robot @@ -0,0 +1,12 @@ +*** Settings *** +Documentation store all properties that can change or are used in multiple places here +... format is all caps with underscores between words and prepended with AAI +... make sure you prepend them with AAI so that other files can easily see it is from this file. + + +*** Variables *** +${AAI_AMSTERDAM_INDEX_PATH} /aai/v11 +${AAI_BEIJING_INDEX_PATH} /aai/v13 +${AAI_CASABLANCA_INDEX_PATH} /aai/v14 +${AAI_DUBLIN_INDEX_PATH} /aai/v16 + diff --git a/robot/resources/aai/ccvpn-connectivities.robot b/robot/resources/aai/ccvpn-connectivities.robot new file mode 100644 index 00000000..e4d7bd51 --- /dev/null +++ b/robot/resources/aai/ccvpn-connectivities.robot @@ -0,0 +1,80 @@ +*** Settings *** +Documentation Operations on connectivities in AAI for CCVPN use case, using earliest API version where it is implemented and latest API version where it is not implemented + +Resource ../json_templater.robot +Resource aai_interface.robot +Resource api_version_properties.robot +Library OperatingSystem +Library Collections + + +*** Variables *** +${AAI_CONN_ROOT_PATH} /network/connectivities/connectivity +${AAI_CONN_EXAMPLES_PATH} /examples/connectivities +${AAI_CONN_NODES_PATH} /nodes/connectivities +${AAI_ADD_CONNECTIVITY_BODY}= robot/assets/templates/aai/add-connectivity.template +${AAI_CONN_API_NA_INDEX_PATH}= ${AAI_BEIJING_INDEX_PATH} +${AAI_CONN_API_IMPL_INDEX_PATH}= ${AAI_CASABLANCA_INDEX_PATH} + +*** Keywords *** +Create Connectivity If Not Exists + [Documentation] Creates Connectivity in AAI if it doesn't exist + [Arguments] ${connectivity_id} + ${get_resp}= Run A&AI Get Request ${AAI_CONN_API_IMPL_INDEX_PATH}${AAI_CONN_ROOT_PATH}/${connectivity_id} + Return From Keyword If '${get_resp.status_code}' == '200' + Create Connectivity ${connectivity_id} + +Create Connectivity + [Documentation] Creates Connectivity in AAI + [Arguments] ${connectivity_id} + ${arguments}= Create Dictionary connectivity_id=${connectivity_id} + ${data}= Fill JSON Template File ${AAI_ADD_CONNECTIVITY_BODY} ${arguments} + ${put_resp}= Run A&AI Put Request ${AAI_CONN_API_IMPL_INDEX_PATH}${AAI_CONN_ROOT_PATH}/${connectivity_id} ${data} + ${status_string}= Convert To String ${put_resp.status_code} + Should Match Regexp ${status_string} ^(201|200)$ + +Delete Connectivity If Exists + [Documentation] Removes Connectivity from AAI if it exists + [Arguments] ${connectivity_id} + ${get_resp}= Run A&AI Get Request ${AAI_CONN_API_IMPL_INDEX_PATH}${AAI_CONN_ROOT_PATH}/${connectivity_id} + Run Keyword If '${get_resp.status_code}' == '200' Delete Connectivity ${connectivity_id} ${get_resp.json()} + +Delete Connectivity + [Documentation] Removes Connectivity from AAI + [Arguments] ${connectivity_id} ${json} + ${resource_version}= Catenate ${json['resource-version']} + ${put_resp}= Run A&AI Delete Request ${AAI_CONN_API_IMPL_INDEX_PATH}${AAI_CONN_ROOT_PATH}/${connectivity_id} ${resource_version} + Should Be Equal As Strings ${put_resp.status_code} 204 + +Get Connectivity + [Documentation] Return Connectivity + [Arguments] ${connectivity_id} + ${resp}= Run A&AI Get Request ${AAI_CONN_API_IMPL_INDEX_PATH}${AAI_CONN_ROOT_PATH}/${connectivity_id} + Should Be Equal As Strings ${resp.status_code} 200 + [Return] ${resp.json()} + +Get Nodes Query Connectivity + [Documentation] Return Nodes query Connectivity + [Arguments] ${connectivity_id} + ${resp}= Run A&AI Get Request ${AAI_CONN_API_IMPL_INDEX_PATH}${AAI_CONN_NODES_PATH}?connectivity-id=${connectivity_id} + Should Be Equal As Strings ${resp.status_code} 200 + [Return] ${resp.json()} + +Get Example Connectivity + [Documentation] Return Example Connectivity + ${resp}= Run A&AI Get Request ${AAI_CONN_API_IMPL_INDEX_PATH}${AAI_CONN_EXAMPLES_PATH} + Should Be Equal As Strings ${resp.status_code} 200 + [Return] ${resp.json()} + +Confirm No Connectivity + [Documentation] Confirm No Connectivity + [Arguments] ${connectivity_id} + ${resp}= Run A&AI Get Request ${AAI_CONN_API_IMPL_INDEX_PATH}${AAI_CONN_ROOT_PATH}/${connectivity_id} + Should Be Equal As Strings ${resp.status_code} 404 + +Confirm API Not Implemented Connectivity + [Documentation] Confirm latest API version where Connectivity is not implemented + [Arguments] ${connectivity_id} + ${resp}= Run A&AI Get Request ${AAI_CONN_API_NA_INDEX_PATH}${AAI_CONN_ROOT_PATH}/${connectivity_id} + Should Be Equal As Strings ${resp.status_code} 400 + diff --git a/robot/resources/so_interface.robot b/robot/resources/so_interface.robot index bc0aa3c0..0bb4f49a 100644 --- a/robot/resources/so_interface.robot +++ b/robot/resources/so_interface.robot @@ -17,22 +17,24 @@ ${SO_OPENSTACK_ENDPOINT} ${GLOBAL_MSO_SERVER_PROTOCOL}://${GLOBAL_INJECTED_S ${SO_REQDB_ENDPOINT} ${GLOBAL_MSO_SERVER_PROTOCOL}://${GLOBAL_INJECTED_SO_REQDB_IP_ADDR}:${GLOBAL_MSO_REQDB_SERVER_PORT} ${SO_SDNC_ENDPOINT} ${GLOBAL_MSO_SERVER_PROTOCOL}://${GLOBAL_INJECTED_SO_SDNC_IP_ADDR}:${GLOBAL_MSO_SDNC_SERVER_PORT} ${SO_VFC_ENDPOINT} ${GLOBAL_MSO_SERVER_PROTOCOL}://${GLOBAL_INJECTED_SO_VFC_IP_ADDR}:${GLOBAL_MSO_VFC_SERVER_PORT} +${SO_VNFM_ENDPOINT} ${GLOBAL_MSO_SERVER_PROTOCOL}://${GLOBAL_INJECTED_SO_VNFM_IP_ADDR}:${GLOBAL_MSO_VNFM_SERVER_PORT} *** Keywords *** Run SO Global Health Check - Run SO Container Health Check API_HANDLER ${SO_APIHAND_ENDPOINT} - Run SO Container Health Check ASDC_HANDLER ${SO_ASDCHAND_ENDPOINT} - Run SO Container Health Check BPMN_INFRA ${SO_BPMN_ENDPOINT} - Run SO Container Health Check CATALOG_DB ${SO_CATDB_ENDPOINT} - Run SO Container Health Check OPENSTACK_INFRA ${SO_OPENSTACK_ENDPOINT} - Run SO Container Health Check REQUEST_DB ${SO_REQDB_ENDPOINT} - Run SO Container Health Check SDNC_INFRA ${SO_SDNC_ENDPOINT} - Run SO Container Health Check VFC_INFRA ${SO_VFC_ENDPOINT} + Run SO Container Health Check API_HANDLER ${SO_APIHAND_ENDPOINT} + Run SO Container Health Check ASDC_HANDLER ${SO_ASDCHAND_ENDPOINT} + Run SO Container Health Check BPMN_INFRA ${SO_BPMN_ENDPOINT} + Run SO Container Health Check CATALOG_DB ${SO_CATDB_ENDPOINT} + Run SO Container Health Check OPENSTACK_INFRA ${SO_OPENSTACK_ENDPOINT} + Run SO Container Health Check REQUEST_DB ${SO_REQDB_ENDPOINT} + Run SO Container Health Check SDNC_INFRA ${SO_SDNC_ENDPOINT} + Run SO Container Health Check VFC_INFRA ${SO_VFC_ENDPOINT} + Run SO Container Health Check VNFM_INFRA ${SO_VNFM_ENDPOINT} Run SO Container Health Check [Documentation] Runs an MSO global health check - [Arguments] ${so_endpoint_label} ${so_endpoint} + [Arguments] ${so_endpoint_label} ${so_endpoint} ${auth}= Create List ${GLOBAL_MSO_USERNAME} ${GLOBAL_MSO_PASSWORD} ${session}= Create Session mso ${so_endpoint} ${uuid}= Generate UUID diff --git a/robot/testsuites/aai/aai-regression-test-v14.robot b/robot/testsuites/aai/aai-regression-test-v14.robot new file mode 100644 index 00000000..ab43776d --- /dev/null +++ b/robot/testsuites/aai/aai-regression-test-v14.robot @@ -0,0 +1,18 @@ +*** Settings *** +Documentation AAI CSIT-style regression tests for CCVPN - new schema elements introduced in Casablanca release for CCVPN use case +Default Tags aai csit ccvpn +Test Timeout 10s +Resource ${EXECDIR}/robot/resources/aai/ccvpn-connectivities.robot + +*** Variables *** +${connectivity_id}= robot-connectivity-test-1 + +*** Test Cases *** +Connectivity test case + Confirm API Not Implemented Connectivity ${connectivity_id} + Confirm No Connectivity ${connectivity_id} + Create Connectivity If Not Exists ${connectivity_id} + Get Connectivity ${connectivity_id} + Delete Connectivity If Exists ${connectivity_id} + Confirm No Connectivity ${connectivity_id} + [Teardown] Delete Connectivity If Exists ${connectivity_id} |