From eb545054ac14d3f731223382b0813d077a34f273 Mon Sep 17 00:00:00 2001 From: micafer Date: Tue, 18 Dec 2018 13:16:07 +0100 Subject: [PATCH] Fix #739 --- IM/connectors/EC2.py | 40 +++++++++++++++++++++++----------------- 1 file changed, 23 insertions(+), 17 deletions(-) diff --git a/IM/connectors/EC2.py b/IM/connectors/EC2.py index 3cc9b673b..b0a6be6e5 100644 --- a/IM/connectors/EC2.py +++ b/IM/connectors/EC2.py @@ -810,27 +810,33 @@ def attach_volumes(self, instance, vm): - instance(:py:class:`boto.ec2.instance`): object to connect to EC2 instance. - vm(:py:class:`IM.VirtualMachine`): VM information. """ - try: - if instance.state == 'running' and "volumes" not in vm.__dict__.keys(): - # Flag to set that this VM has created (or is creating) the - # volumes - vm.volumes = True - conn = instance.connection - cont = 1 - while (vm.info.systems[0].getValue("disk." + str(cont) + ".size") and - vm.info.systems[0].getValue("disk." + str(cont) + ".device")): - disk_size = vm.info.systems[0].getFeature("disk." + str(cont) + ".size").getValue('G') - disk_device = vm.info.systems[0].getValue("disk." + str(cont) + ".device") - disk_type = vm.info.systems[0].getValue("disk." + str(cont) + ".type") - self.log_info("Creating a %d GB volume for the disk %d" % (int(disk_size), cont)) + if instance.state == 'running' and "volumes" not in vm.__dict__.keys(): + # Flag to set that this VM has created (or is creating) the + # volumes + vm.volumes = True + conn = instance.connection + cont = 1 + while (vm.info.systems[0].getValue("disk." + str(cont) + ".size") and + vm.info.systems[0].getValue("disk." + str(cont) + ".device")): + disk_size = vm.info.systems[0].getFeature("disk." + str(cont) + ".size").getValue('G') + disk_device = vm.info.systems[0].getValue("disk." + str(cont) + ".device") + disk_type = vm.info.systems[0].getValue("disk." + str(cont) + ".type") + self.log_info("Creating a %d GB volume for the disk %d" % (int(disk_size), cont)) + volume = None + try: volume = self.create_volume(conn, int(disk_size), instance.placement, disk_type) if volume: self.log_info("Attach the volume ID " + str(volume.id)) conn.attach_volume(volume.id, instance.id, "/dev/" + disk_device) - cont += 1 - except Exception: - self.log_exception( - "Error creating or attaching the volume to the instance") + except: + self.log_exception("Error creating or attaching the volume to the instance") + if volume: + self.log_info("Removing the volume " + volume.id) + try: + conn.delete_volume(volume.id) + except: + self.log_exception("Error deleting the volume") + cont += 1 def delete_volumes(self, conn, volumes, instance_id, timeout=240): """