diff options
author | Andrew Bogott <abogott@wikimedia.org> | 2012-07-19 03:34:31 -0500 |
---|---|---|
committer | Andrew Bogott <abogott@wikimedia.org> | 2012-08-02 18:11:37 -0500 |
commit | c767e9beffe4b826eac869ce7e2eef2cc1499bbe (patch) | |
tree | 71e7bb4e8495db8e924ab355483781df32a6190e /tests | |
parent | bcb424dd730a977aeaae9f6e33e9bb35cbc0c062 (diff) | |
download | oslo-c767e9beffe4b826eac869ce7e2eef2cc1499bbe.tar.gz oslo-c767e9beffe4b826eac869ce7e2eef2cc1499bbe.tar.xz oslo-c767e9beffe4b826eac869ce7e2eef2cc1499bbe.zip |
Add multiple-driver support to the notifier api.
Move all of the functionality previously provided by the list_notifier
into the basic notifier api. Move and restructure tests accordingly.
Remove the list_notifier file and test file.
For bug 1025820
Change-Id: Idf7cb975dd78e9951188781622a4d10ca466b154
Diffstat (limited to 'tests')
-rw-r--r-- | tests/unit/notifier/__init__.py | 14 | ||||
-rw-r--r-- | tests/unit/notifier/test_list_notifier.py | 135 | ||||
-rw-r--r-- | tests/unit/test_log.py | 17 | ||||
-rw-r--r-- | tests/unit/test_notifier.py | 106 | ||||
-rw-r--r-- | tests/unit/test_plugin.py | 21 |
5 files changed, 104 insertions, 189 deletions
diff --git a/tests/unit/notifier/__init__.py b/tests/unit/notifier/__init__.py deleted file mode 100644 index 482d54e..0000000 --- a/tests/unit/notifier/__init__.py +++ /dev/null @@ -1,14 +0,0 @@ -# Copyright 2011 OpenStack LLC. -# 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. diff --git a/tests/unit/notifier/test_list_notifier.py b/tests/unit/notifier/test_list_notifier.py deleted file mode 100644 index c441067..0000000 --- a/tests/unit/notifier/test_list_notifier.py +++ /dev/null @@ -1,135 +0,0 @@ -# Copyright 2011 OpenStack LLC. -# 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. - -from openstack.common import log as logging -from openstack.common.notifier import api -from openstack.common.notifier import list_notifier -from openstack.common.notifier import log_notifier -from openstack.common.notifier import no_op_notifier -from tests import utils as test_utils - - -class SimpleNotifier(object): - def __init__(self): - self.notified = False - - def notify(self, *args): - self.notified = True - - -class NotifierListTestCase(test_utils.BaseTestCase): - """Test case for notifications""" - - def setUp(self): - super(NotifierListTestCase, self).setUp() - list_notifier._reset_drivers() - # Mock log to add one to exception_count when log.exception is called - - def mock_exception(cls, *args): - self.exception_count += 1 - - self.exception_count = 0 - list_notifier_log = logging.getLogger( - 'openstack.common.notifier.list_notifier') - self.stubs.Set(list_notifier_log, "exception", mock_exception) - # Mock no_op notifier to add one to notify_count when called. - - def mock_notify(cls, *args): - self.notify_count += 1 - - self.notify_count = 0 - self.stubs.Set(no_op_notifier, 'notify', mock_notify) - # Mock log_notifier to raise RuntimeError when called. - - def mock_notify2(cls, *args): - raise RuntimeError("Bad notifier.") - - self.stubs.Set(log_notifier, 'notify', mock_notify2) - - def tearDown(self): - list_notifier._reset_drivers() - super(NotifierListTestCase, self).tearDown() - - def test_send_notifications_successfully(self): - self.config(notification_driver='openstack.common.' - 'notifier.list_notifier', - list_notifier_drivers=[ - 'openstack.common.notifier.no_op_notifier', - 'openstack.common.notifier.no_op_notifier']) - api.notify('contextarg', 'publisher_id', 'event_type', - api.WARN, dict(a=3)) - self.assertEqual(self.notify_count, 2) - self.assertEqual(self.exception_count, 0) - - def test_send_notifications_with_errors(self): - - self.config(notification_driver='openstack.common.' - 'notifier.list_notifier', - list_notifier_drivers=[ - 'openstack.common.notifier.no_op_notifier', - 'openstack.common.notifier.log_notifier']) - api.notify('contextarg', 'publisher_id', - 'event_type', api.WARN, dict(a=3)) - self.assertEqual(self.notify_count, 1) - self.assertEqual(self.exception_count, 1) - - def test_when_driver_fails_to_import(self): - self.config(notification_driver='openstack.common.' - 'notifier.list_notifier', - list_notifier_drivers=[ - 'openstack.common.notifier.no_op_notifier', - 'openstack.common.notifier.logo_notifier', - 'fdsjgsdfhjkhgsfkj']) - api.notify('contextarg', 'publisher_id', - 'event_type', api.WARN, dict(a=3)) - self.assertEqual(self.exception_count, 2) - self.assertEqual(self.notify_count, 1) - - def test_adding_and_removing_notifier_object(self): - self.notifier_object = SimpleNotifier() - self.config(notification_driver='openstack.common.' - 'notifier.list_notifier', - list_notifier_drivers=[ - 'openstack.common.notifier.no_op_notifier']) - - list_notifier.add_driver(self.notifier_object) - api.notify(None, 'publisher_id', 'event_type', - api.WARN, dict(a=3)) - self.assertEqual(self.notify_count, 1) - self.assertTrue(self.notifier_object.notified) - - self.notifier_object.notified = False - list_notifier.remove_driver(self.notifier_object) - - api.notify(None, 'publisher_id', 'event_type', - api.WARN, dict(a=3)) - self.assertEqual(self.notify_count, 2) - self.assertFalse(self.notifier_object.notified) - - def test_adding_and_removing_notifier_module(self): - self.config(notification_driver='openstack.common.' - 'notifier.list_notifier', - list_notifier_drivers=[]) - - list_notifier.add_driver('openstack.common.notifier.no_op_notifier') - api.notify(None, 'publisher_id', 'event_type', - api.WARN, dict(a=3)) - self.assertEqual(self.notify_count, 1) - - list_notifier.remove_driver('openstack.common.notifier.no_op_notifier') - - api.notify(None, 'publisher_id', 'event_type', - api.WARN, dict(a=3)) - self.assertEqual(self.notify_count, 1) diff --git a/tests/unit/test_log.py b/tests/unit/test_log.py index 35ff72d..f0aab28 100644 --- a/tests/unit/test_log.py +++ b/tests/unit/test_log.py @@ -10,7 +10,6 @@ from openstack.common import cfg from openstack.common import jsonutils from openstack.common import log from openstack.common.notifier import api as notifier -from openstack.common.notifier import list_notifier from tests import utils as test_utils CONF = cfg.CONF @@ -86,20 +85,8 @@ class PublishErrorsHandlerTestCase(test_utils.BaseTestCase): super(PublishErrorsHandlerTestCase, self).setUp() self.publiserrorshandler = log.PublishErrorsHandler(logging.ERROR) - def test_emit_cfg_list_notifier_drivers_in_flags(self): - self.stub_flg = False - - def fake_notifier(*args, **kwargs): - self.stub_flg = True - - self.stubs.Set(notifier, 'notify', fake_notifier) - logrecord = logging.LogRecord('name', 'WARN', '/tmp', 1, - 'Message', None, None) - self.publiserrorshandler.emit(logrecord) - self.assertTrue(self.stub_flg) - - def test_emit_cfg_log_notifier_in_list_notifier_drivers(self): - self.config(list_notifier_drivers=[ + def test_emit_cfg_log_notifier_in_notifier_drivers(self): + self.config(notification_driver=[ 'openstack.common.notifier.rabbit_notifier', 'openstack.common.notifier.log_notifier']) self.stub_flg = True diff --git a/tests/unit/test_notifier.py b/tests/unit/test_notifier.py index 0ffc35c..e5c69b4 100644 --- a/tests/unit/test_notifier.py +++ b/tests/unit/test_notifier.py @@ -17,6 +17,7 @@ from openstack.common import cfg from openstack.common import context from openstack.common import log from openstack.common.notifier import api as notifier_api +from openstack.common.notifier import log_notifier from openstack.common.notifier import no_op_notifier from openstack.common.notifier import rabbit_notifier from openstack.common import rpc @@ -31,10 +32,14 @@ class NotifierTestCase(test_utils.BaseTestCase): """Test case for notifications""" def setUp(self): super(NotifierTestCase, self).setUp() - self.config(notification_driver='openstack.common.' - 'notifier.no_op_notifier') + self.config(notification_driver=['openstack.common.' + 'notifier.no_op_notifier']) self.config(default_publisher_id='publisher') + def tearDown(self): + notifier_api._reset_drivers() + super(NotifierTestCase, self).tearDown() + def test_send_notification(self): self.notify_called = False @@ -70,7 +75,7 @@ class NotifierTestCase(test_utils.BaseTestCase): def test_send_rabbit_notification(self): self.stubs.Set(cfg.CONF, 'notification_driver', - 'openstack.common.notifier.rabbit_notifier') + ['openstack.common.notifier.rabbit_notifier']) self.mock_notify = False def mock_notify(cls, *args): @@ -89,7 +94,7 @@ class NotifierTestCase(test_utils.BaseTestCase): def test_rabbit_priority_queue(self): self.stubs.Set(cfg.CONF, 'notification_driver', - 'openstack.common.notifier.rabbit_notifier') + ['openstack.common.notifier.rabbit_notifier']) self.stubs.Set(cfg.CONF, 'notification_topics', ['testnotify', ]) @@ -105,7 +110,7 @@ class NotifierTestCase(test_utils.BaseTestCase): def test_error_notification(self): self.stubs.Set(cfg.CONF, 'notification_driver', - 'openstack.common.notifier.rabbit_notifier') + ['openstack.common.notifier.rabbit_notifier']) self.stubs.Set(cfg.CONF, 'publish_errors', True) LOG = log.getLogger('common') log.setup(None) @@ -184,3 +189,94 @@ class NotifierTestCase(test_utils.BaseTestCase): self.assertEqual(3, example_api2(1, 2, bananas="delicious")) self.assertEqual(self.notify_called, True) self.assertEqual(self.context_arg, None) + + +class SimpleNotifier(object): + def __init__(self): + self.notified = False + + def notify(self, *args): + self.notified = True + + +class MultiNotifierTestCase(test_utils.BaseTestCase): + """Test case for notifications""" + + def setUp(self): + super(MultiNotifierTestCase, self).setUp() + # Mock log to add one to exception_count when log.exception is called + + def mock_exception(cls, *args): + self.exception_count += 1 + + self.exception_count = 0 + + notifier_log = log.getLogger( + 'openstack.common.notifier.api') + self.stubs.Set(notifier_log, "exception", mock_exception) + + # Mock no_op notifier to add one to notify_count when called. + def mock_notify(cls, *args): + self.notify_count += 1 + + self.notify_count = 0 + self.stubs.Set(no_op_notifier, 'notify', mock_notify) + # Mock log_notifier to raise RuntimeError when called. + + def mock_notify2(cls, *args): + raise RuntimeError("Bad notifier.") + + self.stubs.Set(log_notifier, 'notify', mock_notify2) + notifier_api._reset_drivers() + + def tearDown(self): + notifier_api._reset_drivers() + super(MultiNotifierTestCase, self).tearDown() + + def test_send_notifications_successfully(self): + self.config(notification_driver=[ + 'openstack.common.notifier.no_op_notifier']) + notifier_api.notify('contextarg', 'publisher_id', 'event_type', + notifier_api.WARN, dict(a=3)) + self.assertEqual(self.notify_count, 1) + self.assertEqual(self.exception_count, 0) + + def test_send_notifications_with_errors(self): + self.config(notification_driver=[ + 'openstack.common.notifier.no_op_notifier', + 'openstack.common.notifier.log_notifier']) + notifier_api.notify('contextarg', 'publisher_id', + 'event_type', notifier_api.WARN, dict(a=3)) + self.assertEqual(self.notify_count, 1) + self.assertEqual(self.exception_count, 1) + + def test_when_driver_fails_to_import(self): + self.config(notification_driver=[ + 'openstack.common.notifier.no_op_notifier', + 'openstack.common.notifier.logo_notifier', + 'fdsjgsdfhjkhgsfkj']) + notifier_api.notify('contextarg', 'publisher_id', + 'event_type', notifier_api.WARN, dict(a=3)) + self.assertEqual(self.exception_count, 2) + self.assertEqual(self.notify_count, 1) + + def test_adding_and_removing_notifier_object(self): + self.notifier_object = SimpleNotifier() + self.config(notification_driver=[ + 'openstack.common.notifier.no_op_notifier']) + + notifier_api.add_driver(self.notifier_object) + notifier_api.notify(None, 'publisher_id', 'event_type', + notifier_api.WARN, dict(a=3)) + self.assertEqual(self.notify_count, 1) + self.assertTrue(self.notifier_object.notified) + + self.notifier_object.notified = False + + def test_adding_and_removing_notifier_module(self): + self.config(notification_driver=[]) + + notifier_api.add_driver('openstack.common.notifier.no_op_notifier') + notifier_api.notify(None, 'publisher_id', 'event_type', + notifier_api.WARN, dict(a=3)) + self.assertEqual(self.notify_count, 1) diff --git a/tests/unit/test_plugin.py b/tests/unit/test_plugin.py index 31f2e7a..b68d6f5 100644 --- a/tests/unit/test_plugin.py +++ b/tests/unit/test_plugin.py @@ -17,9 +17,7 @@ import pkg_resources import unittest from openstack.common import cfg -from openstack.common import notifier from openstack.common.notifier import api as notifier_api -from openstack.common.notifier import no_op_notifier from openstack.common.plugin import plugin from openstack.common.plugin import pluginmanager from tests import utils as test_utils @@ -34,12 +32,6 @@ class SimpleNotifier(object): self.message_list.append(message) -class SimplerNotifier(object): - def notify(self, context, message): - global simpler_notify_called - simpler_notify_called = True - - class ManagerTestCase(test_utils.BaseTestCase): def tearDown(self): super(ManagerTestCase, self).tearDown() @@ -54,15 +46,9 @@ class NotifyTestCase(test_utils.BaseTestCase): def setUp(self): super(NotifyTestCase, self).setUp() - # Set up a 'normal' notifier to make sure the plugin logic - # doesn't mess anything up. - self.stubs.Set(cfg.CONF, 'notification_driver', - SimplerNotifier()) - global simpler_notify_called - simpler_notify_called = False - def tearDown(self): super(NotifyTestCase, self).tearDown() + notifier_api._reset_drivers() def test_add_notifier(self): notifier1 = SimpleNotifier() @@ -95,11 +81,6 @@ class NotifyTestCase(test_utils.BaseTestCase): self.assertEqual(len(notifier.message_list), 1) - # Verify that the original baseline notifier is still - # installed and working. - global simpler_notify_called - self.assertTrue(simpler_notify_called) - class StubControllerExtension(object): name = 'stubextension' |