158 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			158 lines
		
	
	
		
			5.0 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# 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.
 | 
						|
 | 
						|
import stubout
 | 
						|
 | 
						|
import nova
 | 
						|
from nova import context
 | 
						|
from nova import flags
 | 
						|
from nova import log
 | 
						|
from nova import rpc
 | 
						|
import nova.notifier.api
 | 
						|
from nova.notifier.api import notify
 | 
						|
from nova.notifier import no_op_notifier
 | 
						|
from nova.notifier import rabbit_notifier
 | 
						|
from nova import test
 | 
						|
 | 
						|
 | 
						|
class NotifierTestCase(test.TestCase):
 | 
						|
    """Test case for notifications"""
 | 
						|
    def setUp(self):
 | 
						|
        super(NotifierTestCase, self).setUp()
 | 
						|
        self.stubs = stubout.StubOutForTesting()
 | 
						|
 | 
						|
    def tearDown(self):
 | 
						|
        self.stubs.UnsetAll()
 | 
						|
        super(NotifierTestCase, self).tearDown()
 | 
						|
 | 
						|
    def test_send_notification(self):
 | 
						|
        self.notify_called = False
 | 
						|
 | 
						|
        def mock_notify(cls, *args):
 | 
						|
            self.notify_called = True
 | 
						|
 | 
						|
        self.stubs.Set(nova.notifier.no_op_notifier, 'notify',
 | 
						|
                mock_notify)
 | 
						|
 | 
						|
        class Mock(object):
 | 
						|
            pass
 | 
						|
        notify('publisher_id', 'event_type',
 | 
						|
                nova.notifier.api.WARN, dict(a=3))
 | 
						|
        self.assertEqual(self.notify_called, True)
 | 
						|
 | 
						|
    def test_verify_message_format(self):
 | 
						|
        """A test to ensure changing the message format is prohibitively
 | 
						|
        annoying"""
 | 
						|
 | 
						|
        def message_assert(message):
 | 
						|
            fields = [('publisher_id', 'publisher_id'),
 | 
						|
                      ('event_type', 'event_type'),
 | 
						|
                      ('priority', 'WARN'),
 | 
						|
                      ('payload', dict(a=3))]
 | 
						|
            for k, v in fields:
 | 
						|
                self.assertEqual(message[k], v)
 | 
						|
            self.assertTrue(len(message['message_id']) > 0)
 | 
						|
            self.assertTrue(len(message['timestamp']) > 0)
 | 
						|
 | 
						|
        self.stubs.Set(nova.notifier.no_op_notifier, 'notify',
 | 
						|
                message_assert)
 | 
						|
        notify('publisher_id', 'event_type',
 | 
						|
                nova.notifier.api.WARN, dict(a=3))
 | 
						|
 | 
						|
    def test_send_rabbit_notification(self):
 | 
						|
        self.stubs.Set(nova.flags.FLAGS, 'notification_driver',
 | 
						|
                'nova.notifier.rabbit_notifier')
 | 
						|
        self.mock_cast = False
 | 
						|
 | 
						|
        def mock_cast(cls, *args):
 | 
						|
            self.mock_cast = True
 | 
						|
 | 
						|
        class Mock(object):
 | 
						|
            pass
 | 
						|
 | 
						|
        self.stubs.Set(nova.rpc, 'cast', mock_cast)
 | 
						|
        notify('publisher_id', 'event_type',
 | 
						|
                nova.notifier.api.WARN, dict(a=3))
 | 
						|
 | 
						|
        self.assertEqual(self.mock_cast, True)
 | 
						|
 | 
						|
    def test_invalid_priority(self):
 | 
						|
        def mock_cast(cls, *args):
 | 
						|
            pass
 | 
						|
 | 
						|
        class Mock(object):
 | 
						|
            pass
 | 
						|
 | 
						|
        self.stubs.Set(nova.rpc, 'cast', mock_cast)
 | 
						|
        self.assertRaises(nova.notifier.api.BadPriorityException,
 | 
						|
                notify, 'publisher_id',
 | 
						|
                'event_type', 'not a priority', dict(a=3))
 | 
						|
 | 
						|
    def test_rabbit_priority_queue(self):
 | 
						|
        self.stubs.Set(nova.flags.FLAGS, 'notification_driver',
 | 
						|
                'nova.notifier.rabbit_notifier')
 | 
						|
        self.stubs.Set(nova.flags.FLAGS, 'notification_topic',
 | 
						|
                'testnotify')
 | 
						|
 | 
						|
        self.test_topic = None
 | 
						|
 | 
						|
        def mock_cast(context, topic, msg):
 | 
						|
            self.test_topic = topic
 | 
						|
 | 
						|
        self.stubs.Set(nova.rpc, 'cast', mock_cast)
 | 
						|
        notify('publisher_id',
 | 
						|
                'event_type', 'DEBUG', dict(a=3))
 | 
						|
        self.assertEqual(self.test_topic, 'testnotify.debug')
 | 
						|
 | 
						|
    def test_error_notification(self):
 | 
						|
        self.stubs.Set(nova.flags.FLAGS, 'notification_driver',
 | 
						|
            'nova.notifier.rabbit_notifier')
 | 
						|
        self.stubs.Set(nova.flags.FLAGS, 'publish_errors', True)
 | 
						|
        LOG = log.getLogger('nova')
 | 
						|
        LOG.setup_from_flags()
 | 
						|
        msgs = []
 | 
						|
 | 
						|
        def mock_cast(context, topic, data):
 | 
						|
            msgs.append(data)
 | 
						|
 | 
						|
        self.stubs.Set(nova.rpc, 'cast', mock_cast)
 | 
						|
        LOG.error('foo')
 | 
						|
        self.assertEqual(1, len(msgs))
 | 
						|
        msg = msgs[0]
 | 
						|
        self.assertEqual(msg['event_type'], 'error_notification')
 | 
						|
        self.assertEqual(msg['priority'], 'ERROR')
 | 
						|
        self.assertEqual(msg['payload']['error'], 'foo')
 | 
						|
 | 
						|
    def test_send_notification_by_decorator(self):
 | 
						|
        self.notify_called = False
 | 
						|
 | 
						|
        def example_api(arg1, arg2):
 | 
						|
            return arg1 + arg2
 | 
						|
 | 
						|
        example_api = nova.notifier.api.notify_decorator(
 | 
						|
                            'example_api',
 | 
						|
                             example_api)
 | 
						|
 | 
						|
        def mock_notify(cls, *args):
 | 
						|
            self.notify_called = True
 | 
						|
 | 
						|
        self.stubs.Set(nova.notifier.no_op_notifier, 'notify',
 | 
						|
                mock_notify)
 | 
						|
 | 
						|
        class Mock(object):
 | 
						|
            pass
 | 
						|
        self.assertEqual(3, example_api(1, 2))
 | 
						|
        self.assertEqual(self.notify_called, True)
 |