From e5decc3e51bb7b6dc008ef74d50141cd65d60a95 Mon Sep 17 00:00:00 2001 From: Sebastien Couture Date: Wed, 23 Dec 2015 15:42:00 -0500 Subject: [PATCH] Added support for resizing disks when state is 'reconfigured' --- .../modules/cloud/vmware/vsphere_guest.py | 44 +++++++++++++++++++ 1 file changed, 44 insertions(+) diff --git a/lib/ansible/modules/cloud/vmware/vsphere_guest.py b/lib/ansible/modules/cloud/vmware/vsphere_guest.py index 140dbd2f952..17b7ab76274 100644 --- a/lib/ansible/modules/cloud/vmware/vsphere_guest.py +++ b/lib/ansible/modules/cloud/vmware/vsphere_guest.py @@ -877,6 +877,50 @@ def reconfigure_vm(vsphere_client, vm, module, esxi, resource_pool, cluster_name changes['cpu'] = vm_hardware['num_cpus'] + # Resize hard drives + if vm_disk: + spec = spec_singleton(spec, request, vm) + disk_num = 0 + dev_changes = [] + disks_changed = {} + for disk in sorted(vm_disk.iterkeys()): + try: + disksize = int(vm_disk[disk]['size_gb']) + # Convert the disk size to kilobytes + disksize = disksize * 1024 * 1024 + except (KeyError, ValueError): + vsphere_client.disconnect() + module.fail_json(msg="Error in '%s' definition. Size needs to be specified as an integer." % disk) + + # Get a list of the hard drives + dev_list = [d for d in vm.properties.config.hardware.device if d._type=='VirtualDisk'] + if disk_num >= len(dev_list): + vsphere_client.disconnect() + module.fail_json(msg="Error in '%s' definition. Too many disks defined in comparison to the VM's disk profile." % disk) + + # Make sure the new disk size is higher than the current value + dev = dev_list[disk_num] + if disksize < int(dev.capacityInKB): + vsphere_client.disconnect() + module.fail_json(msg="Error in '%s' definition. New size needs to be higher than the current value (%s GB)." % (disk, int(dev.capacityInKB) / 1024 / 1024)) + + # Set the new disk size + elif disksize > int(dev.capacityInKB): + dev_obj = dev._obj + dev_obj.set_element_capacityInKB(disksize) + dev_change = spec.new_deviceChange() + dev_change.set_element_operation("edit") + dev_change.set_element_device(dev_obj) + dev_changes.append(dev_change) + disks_changed[disk] = {'size_gb': int(vm_disk[disk]['size_gb'])} + + disk_num = disk_num + 1 + + if dev_changes: + spec.set_element_deviceChange(dev_changes) + changes['disks'] = disks_changed + + if len(changes): if shutdown and vm.is_powered_on():