Merge "Add missing notifications for rescue/unrescue"
This commit is contained in:
commit
2f6022f6bf
@ -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
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user