~ubuntu-branches/ubuntu/raring/nova/raring-proposed

« back to all changes in this revision

Viewing changes to nova/tests/test_notifications.py

  • Committer: Package Import Robot
  • Author(s): Chuck Short, Adam Gandelman, Chuck Short
  • Date: 2012-11-23 09:04:58 UTC
  • mfrom: (1.1.66)
  • Revision ID: package-import@ubuntu.com-20121123090458-91565o7aev1i1h71
Tags: 2013.1~g1-0ubuntu1
[ Adam Gandelman ]
* debian/control: Ensure novaclient is upgraded with nova,
  require python-keystoneclient >= 1:2.9.0. (LP: #1073289)
* debian/patches/{ubuntu/*, rbd-security.patch}: Dropped, applied
  upstream.
* debian/control: Add python-testtools to Build-Depends.

[ Chuck Short ]
* New upstream version.
* Refreshed debian/patches/avoid_setuptools_git_dependency.patch.
* debian/rules: FTBFS if missing binaries.
* debian/nova-scheudler.install: Add missing rabbit-queues and
  nova-rpc-zmq-receiver.
* Remove nova-volume since it doesnt exist anymore, transition to cinder-*.
* debian/rules: install apport hook in the right place.
* debian/patches/ubuntu-show-tests.patch: Display test failures.
* debian/control: Add depends on genisoimage
* debian/control: Suggest guestmount.
* debian/control: Suggest websockify. (LP: #1076442)
* debian/nova.conf: Disable nova-volume service.
* debian/control: Depend on xen-system-* rather than the hypervisor.
* debian/control, debian/mans/nova-conductor.8, debian/nova-conductor.init,
  debian/nova-conductor.install, debian/nova-conductor.logrotate
  debian/nova-conductor.manpages, debian/nova-conductor.postrm
  debian/nova-conductor.upstart.in: Add nova-conductor service.
* debian/control: Add python-fixtures as a build deps.

Show diffs side-by-side

added added

removed removed

Lines of Context:
24
24
from nova.compute import vm_states
25
25
from nova import context
26
26
from nova import db
27
 
from nova import flags
28
 
import nova.network
 
27
from nova.network import api as network_api
29
28
from nova import notifications
30
29
from nova.openstack.common import log as logging
31
30
from nova.openstack.common.notifier import api as notifier_api
34
33
from nova.tests import fake_network
35
34
 
36
35
LOG = logging.getLogger(__name__)
37
 
FLAGS = flags.FLAGS
38
36
 
39
37
 
40
38
class NotificationsTestCase(test.TestCase):
49
47
            self.assertTrue(ctxt.is_admin)
50
48
            return self.net_info
51
49
 
52
 
        self.stubs.Set(nova.network.API, 'get_instance_nw_info',
 
50
        self.stubs.Set(network_api.API, 'get_instance_nw_info',
53
51
                fake_get_nw_info)
54
52
        fake_network.set_stub_network_methods(self.stubs)
55
53
 
82
80
        inst['access_ip_v4'] = '1.2.3.4'
83
81
        inst['access_ip_v6'] = 'feed:5eed'
84
82
        inst['display_name'] = 'test_instance'
 
83
        inst['hostname'] = 'test_instance_hostname'
85
84
        if params:
86
85
            inst.update(params)
87
86
        return db.instance_create(self.context, inst)
88
87
 
 
88
    def test_send_api_fault_disabled(self):
 
89
        self.flags(notify_api_faults=False)
 
90
        notifications.send_api_fault("http://example.com/foo", 500, None)
 
91
        self.assertEquals(0, len(test_notifier.NOTIFICATIONS))
 
92
 
 
93
    def test_send_api_fault(self):
 
94
        self.flags(notify_api_faults=True)
 
95
        exception = None
 
96
        try:
 
97
            # Get a real exception with a call stack.
 
98
            raise test.TestingException("junk")
 
99
        except test.TestingException, e:
 
100
            exception = e
 
101
 
 
102
        notifications.send_api_fault("http://example.com/foo", 500, exception)
 
103
 
 
104
        self.assertEquals(1, len(test_notifier.NOTIFICATIONS))
 
105
        n = test_notifier.NOTIFICATIONS[0]
 
106
        self.assertEquals(n['priority'], 'ERROR')
 
107
        self.assertEquals(n['event_type'], 'api.fault')
 
108
        self.assertEquals(n['payload']['url'], 'http://example.com/foo')
 
109
        self.assertEquals(n['payload']['status'], 500)
 
110
        self.assertTrue(n['payload']['exception'] is not None)
 
111
 
89
112
    def test_notif_disabled(self):
90
113
 
91
114
        # test config disable of the notifcations
187
210
        access_ip_v4 = self.instance["access_ip_v4"]
188
211
        access_ip_v6 = self.instance["access_ip_v6"]
189
212
        display_name = self.instance["display_name"]
 
213
        hostname = self.instance["hostname"]
190
214
 
191
215
        self.assertEquals(vm_states.BUILDING, payload["old_state"])
192
216
        self.assertEquals(vm_states.ACTIVE, payload["state"])
195
219
        self.assertEquals(payload["access_ip_v4"], access_ip_v4)
196
220
        self.assertEquals(payload["access_ip_v6"], access_ip_v6)
197
221
        self.assertEquals(payload["display_name"], display_name)
 
222
        self.assertEquals(payload["hostname"], hostname)
198
223
 
199
224
    def test_task_update_with_states(self):
200
225
        self.flags(notify_on_state_change="vm_and_task_state")
208
233
        access_ip_v4 = self.instance["access_ip_v4"]
209
234
        access_ip_v6 = self.instance["access_ip_v6"]
210
235
        display_name = self.instance["display_name"]
 
236
        hostname = self.instance["hostname"]
211
237
 
212
238
        self.assertEquals(vm_states.BUILDING, payload["old_state"])
213
239
        self.assertEquals(vm_states.BUILDING, payload["state"])
216
242
        self.assertEquals(payload["access_ip_v4"], access_ip_v4)
217
243
        self.assertEquals(payload["access_ip_v6"], access_ip_v6)
218
244
        self.assertEquals(payload["display_name"], display_name)
 
245
        self.assertEquals(payload["hostname"], hostname)
219
246
 
220
247
    def test_update_no_service_name(self):
221
248
        notifications.send_update_with_states(self.context, self.instance,