¡@

Home 

OpenStack Study: test_conf_key_mgr.py

OpenStack Index

**** CubicPower OpenStack Study ****

# Copyright (c) 2013 The Johns Hopkins University/Applied Physics Laboratory

# All Rights Reserved.

#

# 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.

"""

Test cases for the conf key manager.

"""

import array

from oslo.config import cfg

from cinder import context

from cinder import exception

from cinder.keymgr import conf_key_mgr

from cinder.keymgr import key

from cinder.tests.keymgr import test_key_mgr

CONF = cfg.CONF

CONF.import_opt('fixed_key', 'cinder.keymgr.conf_key_mgr', group='keymgr')

**** CubicPower OpenStack Study ****

class ConfKeyManagerTestCase(test_key_mgr.KeyManagerTestCase):

**** CubicPower OpenStack Study ****

    def __init__(self, *args, **kwargs):

        super(ConfKeyManagerTestCase, self).__init__(*args, **kwargs)

        self._hex_key = '1' * 64

**** CubicPower OpenStack Study ****

    def _create_key_manager(self):

        CONF.set_default('fixed_key', default=self._hex_key, group='keymgr')

        return conf_key_mgr.ConfKeyManager()

**** CubicPower OpenStack Study ****

    def setUp(self):

        super(ConfKeyManagerTestCase, self).setUp()

        self.ctxt = context.RequestContext('fake', 'fake')

        self.key_id = '00000000-0000-0000-0000-000000000000'

        encoded = array.array('B', self._hex_key.decode('hex')).tolist()

        self.key = key.SymmetricKey('AES', encoded)

**** CubicPower OpenStack Study ****

    def test___init__(self):

        self.assertEqual(self.key_id, self.key_mgr.key_id)

**** CubicPower OpenStack Study ****

    def test_create_key(self):

        key_id_1 = self.key_mgr.create_key(self.ctxt)

        key_id_2 = self.key_mgr.create_key(self.ctxt)

        # ensure that the UUIDs are the same

        self.assertEqual(key_id_1, key_id_2)

**** CubicPower OpenStack Study ****

    def test_create_null_context(self):

        self.assertRaises(exception.NotAuthorized,

                          self.key_mgr.create_key, None)

**** CubicPower OpenStack Study ****

    def test_store_key(self):

        key_id = self.key_mgr.store_key(self.ctxt, self.key)

        actual_key = self.key_mgr.get_key(self.ctxt, key_id)

        self.assertEqual(self.key, actual_key)

**** CubicPower OpenStack Study ****

    def test_store_null_context(self):

        self.assertRaises(exception.NotAuthorized,

                          self.key_mgr.store_key, None, self.key)

**** CubicPower OpenStack Study ****

    def test_store_key_invalid(self):

        encoded = self.key.get_encoded()

        inverse_key = key.SymmetricKey('AES', [~b for b in encoded])

        self.assertRaises(exception.KeyManagerError,

                          self.key_mgr.store_key, self.ctxt, inverse_key)

**** CubicPower OpenStack Study ****

    def test_copy_key(self):

        key_id = self.key_mgr.create_key(self.ctxt)

        key = self.key_mgr.get_key(self.ctxt, key_id)

        copied_key_id = self.key_mgr.copy_key(self.ctxt, key_id)

        copied_key = self.key_mgr.get_key(self.ctxt, copied_key_id)

        self.assertEqual(key_id, copied_key_id)

        self.assertEqual(key, copied_key)

**** CubicPower OpenStack Study ****

    def test_copy_null_context(self):

        self.assertRaises(exception.NotAuthorized,

                          self.key_mgr.copy_key, None, None)

**** CubicPower OpenStack Study ****

    def test_delete_key(self):

        key_id = self.key_mgr.create_key(self.ctxt)

        self.key_mgr.delete_key(self.ctxt, key_id)

        # cannot delete key -- might have lingering references

        self.assertEqual(self.key,

                         self.key_mgr.get_key(self.ctxt, self.key_id))

**** CubicPower OpenStack Study ****

    def test_delete_null_context(self):

        self.assertRaises(exception.NotAuthorized,

                          self.key_mgr.delete_key, None, None)

**** CubicPower OpenStack Study ****

    def test_delete_unknown_key(self):

        self.assertRaises(exception.KeyManagerError,

                          self.key_mgr.delete_key, self.ctxt, None)

**** CubicPower OpenStack Study ****

    def test_get_key(self):

        self.assertEqual(self.key,

                         self.key_mgr.get_key(self.ctxt, self.key_id))

**** CubicPower OpenStack Study ****

    def test_get_null_context(self):

        self.assertRaises(exception.NotAuthorized,

                          self.key_mgr.get_key, None, None)

**** CubicPower OpenStack Study ****

    def test_get_unknown_key(self):

        self.assertRaises(KeyError, self.key_mgr.get_key, self.ctxt, None)