aboutsummaryrefslogtreecommitdiffstats
path: root/robot/resources/openstack
diff options
context:
space:
mode:
Diffstat (limited to 'robot/resources/openstack')
-rw-r--r--robot/resources/openstack/keystone_interface.robot78
1 files changed, 68 insertions, 10 deletions
diff --git a/robot/resources/openstack/keystone_interface.robot b/robot/resources/openstack/keystone_interface.robot
index b18674f7..f3e017ce 100644
--- a/robot/resources/openstack/keystone_interface.robot
+++ b/robot/resources/openstack/keystone_interface.robot
@@ -6,14 +6,19 @@ Library HTTPUtils
Library UUID
Library Collections
Library OperatingSystem
+Library String
+Library HttpLibrary.HTTP
Resource ../global_properties.robot
Resource ../json_templater.robot
Resource openstack_common.robot
*** Variables ***
-${OPENSTACK_KEYSTONE_API_VERSION} /v2.0
-${OPENSTACK_KEYSTONE_AUTH_PATH} /tokens
-${OPENSTACK_KEYSTONE_AUTH_BODY_FILE} robot/assets/templates/keystone_get_auth.template
+${OPENSTACK_KEYSTONE_API_v3_VERSION} /v3
+${OPENSTACK_KEYSTONE_API_v2_VERSION} /v2.0
+${OPENSTACK_KEYSTONE_AUTH_v3_PATH} /auth/tokens
+${OPENSTACK_KEYSTONE_AUTH_v2_PATH} /tokens
+${OPENSTACK_KEYSTONE_AUTH_v2_BODY_FILE} robot/assets/templates/keystone_get_v2_auth.template
+${OPENSTACK_KEYSTONE_AUTH_v3_BODY_FILE} robot/assets/templates/keystone_get_v3_auth.template
${OPENSTACK_KEYSTONE_TENANT_PATH} /tenants
*** Keywords ***
@@ -21,19 +26,63 @@ Run Openstack Auth Request
[Documentation] Runs an Openstack Auth Request and returns the token and service catalog. you need to include the token in future request's x-auth-token headers. Service catalog describes what can be called
[Arguments] ${alias} ${username}= ${password}=
${username} ${password}= Set Openstack Credentials ${username} ${password}
- ${url} ${path}= Get Keystone Url And Path
+ ${keystone_api_version}= Run Keyword If '${GLOBAL_INJECTED_OPENSTACK_KEYSTONE_API_VERSION}'=='' Get KeystoneAPIVersion
+ ... ELSE Set Variable ${GLOBAL_INJECTED_OPENSTACK_KEYSTONE_API_VERSION}
+ ${url} ${path}= Get Keystone Url And Path ${keystone_api_version}
${session}= Create Session keystone ${url} verify=True
${uuid}= Generate UUID
- ${data_template}= OperatingSystem.Get File ${OPENSTACK_KEYSTONE_AUTH_BODY_FILE}
- ${arguments}= Create Dictionary username=${username} password=${password} tenantId=${GLOBAL_INJECTED_OPENSTACK_TENANT_ID}
- ${data}= Fill JSON Template ${data_template} ${arguments}
- ${data_path}= Catenate ${path}${OPENSTACK_KEYSTONE_AUTH_PATH}
+ ${data_path} ${data}= Run Keyword If '${keystone_api_version}'=='v2.0' Get KeyStoneAuthv2 Data ${username} ${password} ${path}
+ ... ELSE Get KeyStoneAuthv3 Data ${username} ${password} ${path}
${headers}= Create Dictionary Accept=application/json Content-Type=application/json X-TransactionId=${GLOBAL_APPLICATION_ID}-${uuid} X-FromAppId=${GLOBAL_APPLICATION_ID}
Log Sending authenticate post request ${data_path} with headers ${headers} and data ${data}
${resp}= Post Request keystone ${data_path} data=${data} headers=${headers}
Should Be True 200 <= ${resp.status_code} < 300
- Save Openstack Auth ${alias} ${resp.text}
+ ${auth_token}= Evaluate ''
+ ${auth_token}= Run Keyword If '${keystone_api_version}'=='v3' Get From Dictionary ${resp.headers} X-Subject-Token
+ Log Keystone API Version is ${keystone_api_version}
+ Save Openstack Auth ${alias} ${resp.text} ${auth_token} ${keystone_api_version}
+ Log Received response from keystone ${resp.text}
+
+Get KeystoneAPIVersion
+ [Documentation] Get Keystone API version
+ ${pieces}= Url Parse ${GLOBAL_INJECTED_KEYSTONE}
+ ${url}= Catenate ${pieces.scheme}://${pieces.netloc}
+ Log Keystone URL is ${url}
+ ${session}= Create Session keystone ${url} verify=True
+ ${uuid}= Generate UUID
+ ${headers}= Create Dictionary Accept=application/json Content-Type=application/json
+ ${resp}= Get Request keystone / headers=${headers}
Log Received response from keystone ${resp.text}
+ Should Be Equal As Strings ${resp.status_code} 300
+ ${json}= Parse Json ${resp.content}
+ ${versions}= Get From Dictionary ${json} versions
+ ${values}= Get From Dictionary ${versions} values
+ : FOR ${value} IN @{values}
+ \ ${status}= Get Variable Value ${value["status"]}
+ \ Run Keyword If '${status}'=='stable' Exit For Loop
+ ${href}= Set Variable ${value["links"][0]["href"]}
+ ${keystone}= Set Variable ${GLOBAL_INJECTED_KEYSTONE}
+ ${version}= Remove String ${href} ${keystone} /
+ Return From Keyword If '${version}'=='v2.0' or '${version}'=='v3' ${version}
+ Fail Keystone API version not found or not supported
+
+Get KeyStoneAuthv2 Data
+ [Documentation] Returns all the data for keystone auth v2 api
+ [Arguments] ${username} ${password} ${path}
+ ${data_template}= OperatingSystem.Get File ${OPENSTACK_KEYSTONE_AUTH_v2_BODY_FILE}
+ ${arguments}= Create Dictionary username=${username} password=${password} tenantId=${GLOBAL_INJECTED_OPENSTACK_TENANT_ID}
+ ${data}= Fill JSON Template ${data_template} ${arguments}
+ ${data_path}= Catenate ${path}${OPENSTACK_KEYSTONE_AUTH_v2_PATH}
+ [Return] ${data_path} ${data}
+
+Get KeyStoneAuthv3 Data
+ [Documentation] Returns all the data for keystone auth v3 api
+ [Arguments] ${username} ${password} ${path}
+ ${data_template}= OperatingSystem.Get File ${OPENSTACK_KEYSTONE_AUTH_v3_BODY_FILE}
+ ${arguments}= Create Dictionary username=${username} password=${password} domain_id=${GLOBAL_INJECTED_OPENSTACK_DOMAIN_ID} project_name=${GLOBAL_INJECTED_OPENSTACK_PROJECT_NAME}
+ ${data}= Fill JSON Template ${data_template} ${arguments}
+ ${data_path}= Catenate ${path}${OPENSTACK_KEYSTONE_AUTH_v3_PATH}
+ [Return] ${data_path} ${data}
Get Openstack Tenants
[Documentation] Returns all the openstack tenant info
@@ -60,10 +109,19 @@ Get Openstack Credentials
Get Keystone Url And Path
+ [Arguments] ${keystone_api_version}
[Documentation] Handle arbitrary keystone identiit url. Add v2.0 if not present.
+ ${url} ${path}= Run Keyword If '${keystone_api_version}'=='v2.0' Set API Version ${OPENSTACK_KEYSTONE_API_v2_VERSION}
+ ... ELSE Set API Version ${OPENSTACK_KEYSTONE_API_v3_VERSION}
+ Log Path is ${url} ${path}
+ [Return] ${url} ${path}
+
+Set API Version
+ [Documentation] Decides the API version to be used
+ [Arguments] ${openstack_version}
${pieces}= Url Parse ${GLOBAL_INJECTED_KEYSTONE}
${url}= Catenate ${pieces.scheme}://${pieces.netloc}
${version}= Evaluate ''
- ${version}= Set Variable If '${OPENSTACK_KEYSTONE_API_VERSION}' not in '${pieces.path}' ${OPENSTACK_KEYSTONE_API_VERSION} ${version}
+ ${version}= Set Variable If '${openstack_version}' not in '${pieces.path}' ${openstack_version} ${version}
${path}= Catenate ${pieces.path}${version}
[Return] ${url} ${path}