summaryrefslogtreecommitdiffstats
path: root/doctor_tests/identity_auth.py
diff options
context:
space:
mode:
authorwenjuan dong <dong.wenjuan@zte.com.cn>2017-09-15 01:00:30 +0000
committerGerrit Code Review <gerrit@opnfv.org>2017-09-15 01:00:30 +0000
commit25759e0a0204765a7a9454d7586df66592e943c2 (patch)
tree0f94755b48a577d49d8d34708fb4ed43a553fef4 /doctor_tests/identity_auth.py
parent87da3b937f3130c49cc84608b49a1556fa3d2728 (diff)
parent44d1e135eced7afe13b8772a610ae5cdae310b68 (diff)
Merge "fix package path and move files under doctor_tests"
Diffstat (limited to 'doctor_tests/identity_auth.py')
-rw-r--r--doctor_tests/identity_auth.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/doctor_tests/identity_auth.py b/doctor_tests/identity_auth.py
new file mode 100644
index 00000000..2586720c
--- /dev/null
+++ b/doctor_tests/identity_auth.py
@@ -0,0 +1,43 @@
+##############################################################################
+# Copyright (c) 2017 NEC Corporation and others.
+#
+# All rights reserved. This program and the accompanying materials
+# are made available under the terms of the Apache License, Version 2.0
+# which accompanies this distribution, and is available at
+# http://www.apache.org/licenses/LICENSE-2.0
+##############################################################################
+import os
+
+from keystoneauth1 import loading
+from keystoneauth1 import session
+
+
+def get_identity_auth(username=None, password=None, project=None):
+ auth_url = os.environ['OS_AUTH_URL']
+ username = username or os.environ['OS_USERNAME']
+ password = password or os.environ['OS_PASSWORD']
+ user_domain_name = os.environ.get('OS_USER_DOMAIN_NAME') or 'default'
+ user_domain_id = os.environ.get('OS_USER_DOMAIN_ID') or 'default'
+ project_name = project or os.environ.get('OS_PROJECT_NAME') \
+ or os.environ.get('OS_TENANT_NAME')
+ project_domain_name = os.environ.get('OS_PROJECT_DOMAIN_NAME') or 'default'
+ project_domain_id = os.environ.get('OS_PROJECT_DOMAIN_ID') or 'default'
+
+ loader = loading.get_plugin_loader('password')
+ return loader.load_from_options(
+ auth_url=auth_url,
+ username=username,
+ password=password,
+ user_domain_name=user_domain_name,
+ user_domain_id=user_domain_id,
+ project_name=project_name,
+ tenant_name=project_name,
+ project_domain_name=project_domain_name,
+ project_domain_id=project_domain_id)
+
+
+def get_session(auth=None):
+ """Get a user credentials auth session."""
+ if auth is None:
+ auth = get_identity_auth()
+ return session.Session(auth=auth)