
This patch tries to fix a common problem with a lot of configuration files out there, which contains invalid plugin paths. Instead of failing with a traceback, which might be confusing to users, we emit an error which should be clearer and easily debuggable by a non-Python user. Change-Id: I1390136b37055207787151ebd80ac83dfaefea4c
49 lines
1.7 KiB
Python
49 lines
1.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)
|