135 lines
5.6 KiB
Python
135 lines
5.6 KiB
Python
# Copyright (c) 2015 Red Hat, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
# implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
from keystoneauth1 import session as keystone
|
|
import mock
|
|
|
|
from sahara import exceptions as ex
|
|
from sahara.service import sessions
|
|
from sahara.tests.unit import base
|
|
|
|
|
|
class TestSessionCache(base.SaharaTestCase):
|
|
|
|
def test_get_session(self):
|
|
sc = sessions.SessionCache()
|
|
session = sc.get_session()
|
|
self.assertIsInstance(session, keystone.Session)
|
|
|
|
self.assertRaises(ex.SaharaException,
|
|
sc.get_session,
|
|
session_type='bad service')
|
|
|
|
@mock.patch('keystoneauth1.session.Session')
|
|
def test_get_keystone_session(self, keystone_session):
|
|
sc = sessions.SessionCache()
|
|
self.override_config('ca_file', '/some/cacert', group='keystone')
|
|
self.override_config('api_insecure', False, group='keystone')
|
|
sc.get_session(sessions.SESSION_TYPE_KEYSTONE)
|
|
keystone_session.assert_called_once_with(verify='/some/cacert')
|
|
|
|
sc = sessions.SessionCache()
|
|
keystone_session.reset_mock()
|
|
self.override_config('ca_file', None, group='keystone')
|
|
self.override_config('api_insecure', True, group='keystone')
|
|
sc.get_session(sessions.SESSION_TYPE_KEYSTONE)
|
|
keystone_session.assert_called_once_with(verify=False)
|
|
|
|
keystone_session.reset_mock()
|
|
sc.get_session(sessions.SESSION_TYPE_KEYSTONE)
|
|
self.assertFalse(keystone_session.called)
|
|
|
|
@mock.patch('keystoneauth1.session.Session')
|
|
def test_get_nova_session(self, keystone_session):
|
|
sc = sessions.SessionCache()
|
|
self.override_config('ca_file', '/some/cacert', group='nova')
|
|
self.override_config('api_insecure', False, group='nova')
|
|
sc.get_session(sessions.SESSION_TYPE_NOVA)
|
|
keystone_session.assert_called_once_with(verify='/some/cacert')
|
|
|
|
sc = sessions.SessionCache()
|
|
keystone_session.reset_mock()
|
|
self.override_config('ca_file', None, group='nova')
|
|
self.override_config('api_insecure', True, group='nova')
|
|
sc.get_session(sessions.SESSION_TYPE_NOVA)
|
|
keystone_session.assert_called_once_with(verify=False)
|
|
|
|
keystone_session.reset_mock()
|
|
sc.get_session(sessions.SESSION_TYPE_NOVA)
|
|
self.assertFalse(keystone_session.called)
|
|
|
|
@mock.patch('keystoneauth1.session.Session')
|
|
def test_get_cinder_session(self, keystone_session):
|
|
sc = sessions.SessionCache()
|
|
self.override_config('ca_file', '/some/cacert', group='cinder')
|
|
self.override_config('api_insecure', False, group='cinder')
|
|
sc.get_session(sessions.SESSION_TYPE_CINDER)
|
|
keystone_session.assert_called_once_with(verify='/some/cacert')
|
|
|
|
sc = sessions.SessionCache()
|
|
keystone_session.reset_mock()
|
|
self.override_config('ca_file', None, group='cinder')
|
|
self.override_config('api_insecure', True, group='cinder')
|
|
sc.get_session(sessions.SESSION_TYPE_CINDER)
|
|
keystone_session.assert_called_once_with(verify=False)
|
|
|
|
keystone_session.reset_mock()
|
|
sc.get_session(sessions.SESSION_TYPE_CINDER)
|
|
self.assertFalse(keystone_session.called)
|
|
|
|
@mock.patch('keystoneauth1.session.Session')
|
|
def test_get_neutron_session(self, keystone_session):
|
|
sc = sessions.SessionCache()
|
|
self.override_config('ca_file', '/some/cacert', group='neutron')
|
|
self.override_config('api_insecure', False, group='neutron')
|
|
sc.get_session(sessions.SESSION_TYPE_NEUTRON)
|
|
keystone_session.assert_called_once_with(verify='/some/cacert')
|
|
|
|
sc = sessions.SessionCache()
|
|
keystone_session.reset_mock()
|
|
self.override_config('ca_file', None, group='neutron')
|
|
self.override_config('api_insecure', True, group='neutron')
|
|
sc.get_session(sessions.SESSION_TYPE_NEUTRON)
|
|
keystone_session.assert_called_once_with(verify=False)
|
|
|
|
keystone_session.reset_mock()
|
|
sc.get_session(sessions.SESSION_TYPE_NEUTRON)
|
|
self.assertFalse(keystone_session.called)
|
|
|
|
@mock.patch('keystoneauth1.session.Session')
|
|
def test_get_glance_session(self, keystone_session):
|
|
sc = sessions.SessionCache()
|
|
self.override_config('ca_file', '/some/cacert', group='glance')
|
|
self.override_config('api_insecure', False, group='glance')
|
|
sc.get_session(sessions.SESSION_TYPE_GLANCE)
|
|
keystone_session.assert_called_once_with(verify='/some/cacert')
|
|
|
|
sc = sessions.SessionCache()
|
|
keystone_session.reset_mock()
|
|
self.override_config('ca_file', None, group='glance')
|
|
self.override_config('api_insecure', True, group='glance')
|
|
sc.get_session(sessions.SESSION_TYPE_GLANCE)
|
|
keystone_session.assert_called_once_with(verify=False)
|
|
|
|
keystone_session.reset_mock()
|
|
sc.get_session(sessions.SESSION_TYPE_GLANCE)
|
|
self.assertFalse(keystone_session.called)
|
|
|
|
@mock.patch('keystoneauth1.session.Session')
|
|
def test_insecure_session(self, session):
|
|
sc = sessions.SessionCache()
|
|
sc.get_session(sessions.SESSION_TYPE_INSECURE)
|
|
session.assert_called_once_with(verify=False)
|