
Some plugins were moved to plugins.common, in order to better reflect the fact that they are not platform specific. Unfortunately, there are a lot of users out there with old config files which are using the old plugin names. So in order not to crash cloudbaseinit for their cases, we provide an explicit mapping between old plugin names, found in plugin.windows to new plugin names, found in plugins.common. This will be removed when we'll reach 1.0 though. Change-Id: I1102260849bbc940f2a26325c652e2cf02892eab
70 lines
2.7 KiB
Python
70 lines
2.7 KiB
Python
# Copyright 2013 Cloudbase Solutions Srl
|
|
#
|
|
# 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.
|
|
|
|
import unittest
|
|
|
|
try:
|
|
import unittest.mock as mock
|
|
except ImportError:
|
|
import mock
|
|
from oslo.config import cfg
|
|
|
|
from cloudbaseinit.plugins.common import factory
|
|
from cloudbaseinit.tests import testutils
|
|
|
|
CONF = cfg.CONF
|
|
|
|
|
|
class PluginFactoryTests(unittest.TestCase):
|
|
|
|
@mock.patch('cloudbaseinit.utils.classloader.ClassLoader.load_class')
|
|
def test_load_plugins(self, mock_load_class):
|
|
expected = []
|
|
for path in CONF.plugins:
|
|
expected.append(mock.call(path))
|
|
response = factory.load_plugins()
|
|
self.assertEqual(expected, mock_load_class.call_args_list)
|
|
self.assertTrue(response is not None)
|
|
|
|
@testutils.ConfPatcher('plugins', ['missing.plugin'])
|
|
def test_load_plugins_plugin_failed(self):
|
|
with testutils.LogSnatcher('cloudbaseinit.plugins.'
|
|
'common.factory') as snatcher:
|
|
plugins = factory.load_plugins()
|
|
|
|
self.assertEqual([], plugins)
|
|
self.assertEqual(["Could not import plugin module 'missing.plugin'"],
|
|
snatcher.output)
|
|
|
|
@testutils.ConfPatcher('plugins', ["cloudbaseinit.plugins.windows."
|
|
"localscripts.LocalScriptsPlugin"])
|
|
@mock.patch('cloudbaseinit.utils.classloader.ClassLoader.load_class')
|
|
def test_old_plugin_mapping(self, mock_load_class):
|
|
with testutils.LogSnatcher('cloudbaseinit.plugins.common.'
|
|
'factory') as snatcher:
|
|
factory.load_plugins()
|
|
|
|
expected = [
|
|
"Old plugin module 'cloudbaseinit.plugins.windows."
|
|
"localscripts.LocalScriptsPlugin' was found. "
|
|
"The new name is 'cloudbaseinit.plugins.common."
|
|
"localscripts.LocalScriptsPlugin'. The old name will not "
|
|
"be supported starting with cloudbaseinit 1.0",
|
|
]
|
|
expected_call = mock.call('cloudbaseinit.plugins.common.'
|
|
'localscripts.LocalScriptsPlugin')
|
|
self.assertEqual(expected, snatcher.output)
|
|
called = mock_load_class.mock_calls[0]
|
|
self.assertEqual(expected_call, called)
|