diff options
Diffstat (limited to 'robot/resources/aai/create_complex.robot')
-rw-r--r-- | robot/resources/aai/create_complex.robot | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/robot/resources/aai/create_complex.robot b/robot/resources/aai/create_complex.robot new file mode 100644 index 00000000..e1cc2271 --- /dev/null +++ b/robot/resources/aai/create_complex.robot @@ -0,0 +1,71 @@ +*** Settings *** +Documentation Create A&AI Customer API. +... +... Create A&AI Customer API + +Resource ../json_templater.robot +Resource aai_interface.robot +Library OperatingSystem +Library Collections + + + +*** Variables *** +${COMPLEX_INDEX_PATH} /aai/v11 +${ROOT_COMPLEXES_PATH} /cloud-infrastructure/complexes +${ROOT_COMPLEX_PATH} /cloud-infrastructure/complexes/complex + +${SYSTEM USER} robot-ete +${AAI_ADD_COMPLEX_BODY}= robot/assets/templates/aai/add_complex_body.template + +*** Keywords *** +Inventory Complex If Not Exists + [Documentation] Creates a service in A&AI if it doesn't exist + [Arguments] ${complex_name} ${physical_location_id} ${cloud_owner} ${region} ${owner_defined_type} + ${get_resp}= Run A&AI Get Request ${COMPLEX_INDEX_PATH}${ROOT_COMPLEX_PATH}/${physical_location_id} + Return From Keyword If '${get_resp.status_code}' == '200' + Inventory Complex ${complex_name} ${physical_location_id} ${cloud_owner} ${region} ${owner_defined_type} + +Inventory Complex + [Documentation] Inventorys a COmplex in A&AI + [Arguments] ${complex_name} ${physical_location_id} ${cloud_owner} ${region} ${owner_defined_type} + ${arguments}= Create Dictionary complex_name=${complex_name} + Set To Dictionary ${arguments} physical_location_id=${physical_location_id} + Set To Dictionary ${arguments} cloud_owner=${cloud_owner} + Set To Dictionary ${arguments} region=${region} + Set To Dictionary ${arguments} owner_defined_type=${owner_defined_type} + ${data}= Fill JSON Template File ${AAI_ADD_COMPLEX_BODY} ${arguments} + ${put_resp}= Run A&AI Put Request ${COMPLEX_INDEX_PATH}${ROOT_COMPLEX_PATH}/${physical_location_id} ${data} + ${status_string}= Convert To String ${put_resp.status_code} + Should Match Regexp ${status_string} ^(201|200)$ + +Delete Complex If Exists + [Documentation] Removes a complex + [Arguments] ${physical_location_id} + ${get_resp}= Run A&AI Get Request ${COMPLEX_INDEX_PATH}${ROOT_COMPLEX_PATH}/${physical_location_id} + Run Keyword If '${get_resp.status_code}' == '200' Delete Zone Exists ${physical_location_id} ${get_resp.json()} + +Delete Complex + [Arguments] ${physical_location_id} ${json} + ${resource_version}= Catenate ${json['resource-version']} + ${put_resp}= Run A&AI Delete Request ${COMPLEX_INDEX_PATH}${ROOT_COMPLEX_PATH}/${physical_location_id} ${resource_version} + Should Be Equal As Strings ${put_resp.status_code} 204 + +Get Complex + [Documentation] Return a complex + [Arguments] ${physical_location_id} + ${resp}= Run A&AI Get Request ${COMPLEX_INDEX_PATH}${ROOT_COMPLEX_PATH}/${physical_location_id} + Should Be Equal As Strings ${resp.status_code} 200 + [Return] ${resp.json()} + +Get Complexes + [Documentation] Return all complexes + [Arguments] + ${resp}= Run A&AI Get Request ${COMPLEX_INDEX_PATH}${ROOT_COMPLEXES_PATH} + Should Be Equal As Strings ${resp.status_code} 200 + Log ${resp.json()} + [Return] ${resp.json()} + + + + |