Merge "Add missing notifications for rescue/unrescue"

This commit is contained in:
Jenkins 2013-09-12 23:25:12 +00:00 committed by Gerrit Code Review
commit 2f6022f6bf
2 changed files with 104 additions and 8 deletions

View File

@ -2519,10 +2519,19 @@ class ComputeManager(manager.SchedulerDependentManager):
admin_password = (rescue_password if rescue_password else admin_password = (rescue_password if rescue_password else
utils.generate_password()) utils.generate_password())
self.conductor_api.notify_usage_exists(context, instance,
current_period=True)
network_info = self._get_instance_nw_info(context, instance) network_info = self._get_instance_nw_info(context, instance)
rescue_image_meta = self._get_rescue_image(context, instance) rescue_image_meta = self._get_rescue_image(context, instance)
extra_usage_info = {'rescue_image_name':
rescue_image_meta.get('name', '')}
self._notify_about_instance_usage(context, instance,
"rescue.start", extra_usage_info=extra_usage_info,
network_info=network_info)
try: try:
self.driver.rescue(context, instance, self.driver.rescue(context, instance,
network_info, network_info,
@ -2535,13 +2544,16 @@ class ComputeManager(manager.SchedulerDependentManager):
reason=_("Driver Error: %s") % unicode(e)) reason=_("Driver Error: %s") % unicode(e))
current_power_state = self._get_power_state(context, instance) current_power_state = self._get_power_state(context, instance)
self._instance_update(context, instance = self._instance_update(context,
instance['uuid'], instance['uuid'],
vm_state=vm_states.RESCUED, vm_state=vm_states.RESCUED,
task_state=None, task_state=None,
power_state=current_power_state, power_state=current_power_state,
launched_at=timeutils.utcnow(), launched_at=timeutils.utcnow(),
expected_task_state=task_states.RESCUING) expected_task_state=task_states.RESCUING)
self._notify_about_instance_usage(context, instance,
"rescue.end", extra_usage_info=extra_usage_info,
network_info=network_info)
@wrap_exception() @wrap_exception()
@reverts_task_state @reverts_task_state
@ -2553,18 +2565,23 @@ class ComputeManager(manager.SchedulerDependentManager):
LOG.audit(_('Unrescuing'), context=context, instance=instance) LOG.audit(_('Unrescuing'), context=context, instance=instance)
network_info = self._get_instance_nw_info(context, instance) network_info = self._get_instance_nw_info(context, instance)
self._notify_about_instance_usage(context, instance,
"unrescue.start", network_info=network_info)
with self._error_out_instance_on_exception(context, instance['uuid']): with self._error_out_instance_on_exception(context, instance['uuid']):
self.driver.unrescue(instance, self.driver.unrescue(instance,
network_info) network_info)
current_power_state = self._get_power_state(context, instance) current_power_state = self._get_power_state(context, instance)
self._instance_update(context, instance = self._instance_update(context,
instance['uuid'], instance['uuid'],
vm_state=vm_states.ACTIVE, vm_state=vm_states.ACTIVE,
task_state=None, task_state=None,
expected_task_state=task_states.UNRESCUING, expected_task_state=task_states.UNRESCUING,
power_state=current_power_state) power_state=current_power_state)
self._notify_about_instance_usage(context,
instance,
"unrescue.end",
network_info=network_info)
@wrap_exception() @wrap_exception()
@reverts_task_state @reverts_task_state

View File

@ -1645,6 +1645,85 @@ class ComputeTestCase(BaseTestCase):
self.compute.terminate_instance(self.context, instance=instance) self.compute.terminate_instance(self.context, instance=instance)
def test_rescue_notifications(self):
# Ensure notifications on instance rescue.
def fake_rescue(self, context, instance_ref, network_info, image_meta,
rescue_password):
pass
self.stubs.Set(nova.virt.fake.FakeDriver, 'rescue', fake_rescue)
instance = jsonutils.to_primitive(self._create_fake_instance())
instance_uuid = instance['uuid']
self.compute.run_instance(self.context, instance=instance)
fake_notifier.NOTIFICATIONS = []
db.instance_update(self.context, instance_uuid,
{"task_state": task_states.RESCUING})
self.compute.rescue_instance(self.context, instance=instance)
expected_notifications = ['compute.instance.exists',
'compute.instance.rescue.start',
'compute.instance.rescue.end']
self.assertEquals([m.event_type for m in fake_notifier.NOTIFICATIONS],
expected_notifications)
for n, msg in enumerate(fake_notifier.NOTIFICATIONS):
self.assertEquals(msg.event_type, expected_notifications[n])
self.assertEquals(msg.priority, 'INFO')
payload = msg.payload
self.assertEquals(payload['tenant_id'], self.project_id)
self.assertEquals(payload['user_id'], self.user_id)
self.assertEquals(payload['instance_id'], instance_uuid)
self.assertEquals(payload['instance_type'], 'm1.tiny')
type_id = flavors.get_flavor_by_name('m1.tiny')['id']
self.assertEquals(str(payload['instance_type_id']), str(type_id))
self.assertTrue('display_name' in payload)
self.assertTrue('created_at' in payload)
self.assertTrue('launched_at' in payload)
image_ref_url = glance.generate_image_url(FAKE_IMAGE_REF)
self.assertEquals(payload['image_ref_url'], image_ref_url)
msg = fake_notifier.NOTIFICATIONS[1]
self.assertTrue('rescue_image_name' in msg.payload)
self.compute.terminate_instance(self.context, instance=instance)
def test_unrescue_notifications(self):
# Ensure notifications on instance rescue.
def fake_unrescue(self, instance_ref, network_info):
pass
self.stubs.Set(nova.virt.fake.FakeDriver, 'unrescue',
fake_unrescue)
instance = jsonutils.to_primitive(self._create_fake_instance())
instance_uuid = instance['uuid']
self.compute.run_instance(self.context, instance=instance)
fake_notifier.NOTIFICATIONS = []
db.instance_update(self.context, instance_uuid,
{"task_state": task_states.UNRESCUING})
self.compute.unrescue_instance(self.context, instance=instance)
expected_notifications = ['compute.instance.unrescue.start',
'compute.instance.unrescue.end']
self.assertEquals([m.event_type for m in fake_notifier.NOTIFICATIONS],
expected_notifications)
for n, msg in enumerate(fake_notifier.NOTIFICATIONS):
self.assertEquals(msg.event_type, expected_notifications[n])
self.assertEquals(msg.priority, 'INFO')
payload = msg.payload
self.assertEquals(payload['tenant_id'], self.project_id)
self.assertEquals(payload['user_id'], self.user_id)
self.assertEquals(payload['instance_id'], instance_uuid)
self.assertEquals(payload['instance_type'], 'm1.tiny')
type_id = flavors.get_flavor_by_name('m1.tiny')['id']
self.assertEquals(str(payload['instance_type_id']), str(type_id))
self.assertTrue('display_name' in payload)
self.assertTrue('created_at' in payload)
self.assertTrue('launched_at' in payload)
image_ref_url = glance.generate_image_url(FAKE_IMAGE_REF)
self.assertEquals(payload['image_ref_url'], image_ref_url)
self.compute.terminate_instance(self.context, instance=instance)
def test_rescue_handle_err(self): def test_rescue_handle_err(self):
# If the driver fails to rescue, instance state should remain the same # If the driver fails to rescue, instance state should remain the same
# and the exception should be converted to InstanceNotRescuable # and the exception should be converted to InstanceNotRescuable