本文整理匯總了Python中charmhelpers.contrib.openstack.context.IdentityServiceContext方法的典型用法代碼示例。如果您正苦於以下問題:Python context.IdentityServiceContext方法的具體用法?Python context.IdentityServiceContext怎麽用?Python context.IdentityServiceContext使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類charmhelpers.contrib.openstack.context
的用法示例。
在下文中一共展示了context.IdentityServiceContext方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: get_keystone_manager_from_identity_service_context
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def get_keystone_manager_from_identity_service_context():
"""Return a keystonmanager generated from a
instance of charmhelpers.contrib.openstack.context.IdentityServiceContext
@returns keystonamenager instance
"""
context = IdentityServiceContext()()
if not context:
msg = "Identity service context cannot be generated"
log(msg, level=ERROR)
raise ValueError(msg)
endpoint = format_endpoint(context['service_protocol'],
context['service_host'],
context['service_port'],
context['api_version'])
if context['api_version'] in (2, "2.0"):
api_version = 2
else:
api_version = 3
return get_keystone_manager(endpoint, api_version,
username=context['admin_user'],
password=context['admin_password'],
tenant_name=context['admin_tenant_name'])
示例2: __call__
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def __call__(self):
ctxt = super(IdentityServiceContext, self).__call__()
if not ctxt:
return
ctxt['admin_token'] = None
for relid in relation_ids('identity-service'):
for unit in related_units(relid):
if not ctxt.get('admin_token'):
ctxt['admin_token'] = \
relation_get('admin_token', unit, relid)
if cmp_pkgrevno('radosgw', "10.2.0") >= 0:
ctxt['auth_keystone_v3_supported'] = True
ctxt['auth_type'] = 'keystone'
ctxt['user_roles'] = config('operator-roles')
ctxt['cache_size'] = config('cache-size')
ctxt['revocation_check_interval'] = config('revocation-check-interval')
if self.context_complete(ctxt):
return ctxt
return {}
示例3: test_identity_service_context_with_data
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def test_identity_service_context_with_data(self):
'''Test shared-db context with all required data'''
relation = FakeRelation(relation_data=IDENTITY_SERVICE_RELATION_UNSET)
self.relation_get.side_effect = relation.get
identity_service = context.IdentityServiceContext()
result = identity_service()
expected = {
'admin_password': 'foo',
'admin_tenant_name': 'admin',
'admin_tenant_id': None,
'admin_user': 'adam',
'auth_host': 'keystone-host.local',
'auth_port': '35357',
'auth_protocol': 'http',
'service_host': 'keystonehost.local',
'service_port': '5000',
'service_protocol': 'http',
'api_version': '2.0',
}
self.assertEquals(result, expected)
示例4: test_identity_service_context_with_cache
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def test_identity_service_context_with_cache(self):
'''Test shared-db context with signing cache info'''
relation = FakeRelation(relation_data=IDENTITY_SERVICE_RELATION_UNSET)
self.relation_get.side_effect = relation.get
svc = 'cinder'
identity_service = context.IdentityServiceContext(service=svc,
service_user=svc)
result = identity_service()
expected = {
'admin_password': 'foo',
'admin_tenant_name': 'admin',
'admin_tenant_id': None,
'admin_user': 'adam',
'auth_host': 'keystone-host.local',
'auth_port': '35357',
'auth_protocol': 'http',
'service_host': 'keystonehost.local',
'service_port': '5000',
'service_protocol': 'http',
'signing_dir': '/var/cache/cinder',
'api_version': '2.0',
}
self.assertTrue(self.mkdir.called)
self.assertEquals(result, expected)
示例5: test_identity_service_context_with_data_http
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def test_identity_service_context_with_data_http(self):
'''Test shared-db context with all required data'''
relation = FakeRelation(relation_data=IDENTITY_SERVICE_RELATION_HTTP)
self.relation_get.side_effect = relation.get
identity_service = context.IdentityServiceContext()
result = identity_service()
expected = {
'admin_password': 'foo',
'admin_tenant_name': 'admin',
'admin_tenant_id': '123456',
'admin_user': 'adam',
'auth_host': 'keystone-host.local',
'auth_port': '35357',
'auth_protocol': 'http',
'service_host': 'keystonehost.local',
'service_port': '5000',
'service_protocol': 'http',
'api_version': '2.0',
}
self.assertEquals(result, expected)
示例6: test_identity_service_context_with_data_https
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def test_identity_service_context_with_data_https(self):
'''Test shared-db context with all required data'''
relation = FakeRelation(relation_data=IDENTITY_SERVICE_RELATION_HTTPS)
self.relation_get.side_effect = relation.get
identity_service = context.IdentityServiceContext()
result = identity_service()
expected = {
'admin_password': 'foo',
'admin_tenant_name': 'admin',
'admin_tenant_id': None,
'admin_user': 'adam',
'auth_host': 'keystone-host.local',
'auth_port': '35357',
'auth_protocol': 'https',
'service_host': 'keystonehost.local',
'service_port': '5000',
'service_protocol': 'https',
'api_version': '2.0',
}
self.assertEquals(result, expected)
示例7: test_identity_service_context_with_ipv6
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def test_identity_service_context_with_ipv6(self, format_ipv6_addr):
'''Test identity-service context with ipv6'''
relation = FakeRelation(relation_data=IDENTITY_SERVICE_RELATION_HTTP)
self.relation_get.side_effect = relation.get
format_ipv6_addr.return_value = '[2001:db8:1::1]'
identity_service = context.IdentityServiceContext()
result = identity_service()
expected = {
'admin_password': 'foo',
'admin_tenant_name': 'admin',
'admin_tenant_id': '123456',
'admin_user': 'adam',
'auth_host': '[2001:db8:1::1]',
'auth_port': '35357',
'auth_protocol': 'http',
'service_host': '[2001:db8:1::1]',
'service_port': '5000',
'service_protocol': 'http',
'api_version': '2.0',
}
self.assertEquals(result, expected)
示例8: __call__
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def __call__(self):
ctxt = super(IdentityServiceContext, self).__call__()
if not ctxt:
return
ctxt['region'] = config('region')
return ctxt
示例9: test_identity_service_context_with_altname
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def test_identity_service_context_with_altname(self):
'''Test identity context when using an explicit relation name'''
relation = FakeRelation(
relation_data=APIIDENTITY_SERVICE_RELATION_UNSET
)
self.relation_get.side_effect = relation.get
self.relation_ids.return_value = ['neutron-plugin-api:0']
self.related_units.return_value = ['neutron-api/0']
identity_service = context.IdentityServiceContext(
rel_name='neutron-plugin-api'
)
result = identity_service()
expected = {
'admin_password': 'foo',
'admin_tenant_name': 'admin',
'admin_tenant_id': None,
'admin_user': 'adam',
'auth_host': 'keystone-host.local',
'auth_port': '35357',
'auth_protocol': 'http',
'service_host': 'keystonehost.local',
'service_port': '5000',
'service_protocol': 'http',
'api_version': '2.0',
}
self.assertEquals(result, expected)
示例10: test_identity_service_context_with_missing_relation
# 需要導入模塊: from charmhelpers.contrib.openstack import context [as 別名]
# 或者: from charmhelpers.contrib.openstack.context import IdentityServiceContext [as 別名]
def test_identity_service_context_with_missing_relation(self):
'''Test shared-db context missing relation data'''
incomplete_relation = copy(IDENTITY_SERVICE_RELATION_UNSET)
incomplete_relation['service_password'] = None
relation = FakeRelation(relation_data=incomplete_relation)
self.relation_get.side_effect = relation.get
identity_service = context.IdentityServiceContext()
result = identity_service()
self.assertEquals(result, {})