VMware: Allow user to select disk_mode (#38951)
* VMware: Allow user to select disk_mode This fix allows user to select disk modes for given disk configuration in the given VM. Fixes: #37749 Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com> * Review comments Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
parent
2ecf1d35d3
commit
c021fd8e84
3 changed files with 140 additions and 2 deletions
|
@ -172,6 +172,11 @@ options:
|
||||||
- ' Default: C(None) thick disk, no eagerzero.'
|
- ' Default: C(None) thick disk, no eagerzero.'
|
||||||
- ' - C(datastore) (string): Datastore to use for the disk. If C(autoselect_datastore) is enabled, filter datastore selection.'
|
- ' - C(datastore) (string): Datastore to use for the disk. If C(autoselect_datastore) is enabled, filter datastore selection.'
|
||||||
- ' - C(autoselect_datastore) (bool): select the less used datastore. Specify only if C(datastore) is not specified.'
|
- ' - C(autoselect_datastore) (bool): select the less used datastore. Specify only if C(datastore) is not specified.'
|
||||||
|
- ' - C(disk_mode) (string): Type of disk mode. Added in version 2.6'
|
||||||
|
- ' - Available options are :'
|
||||||
|
- ' - C(persistent): Changes are immediately and permanently written to the virtual disk. This is default.'
|
||||||
|
- ' - C(independent_persistent): Same as persistent, but not affected by snapshots.'
|
||||||
|
- ' - C(independent_nonpersistent): Changes to virtual disk are made to a redo log and discarded at power off, but not affected by snapshots.'
|
||||||
cdrom:
|
cdrom:
|
||||||
description:
|
description:
|
||||||
- A CD-ROM configuration for the virtual machine.
|
- A CD-ROM configuration for the virtual machine.
|
||||||
|
@ -588,7 +593,6 @@ class PyVmomiDeviceHelper(object):
|
||||||
diskspec.fileOperation = vim.vm.device.VirtualDeviceSpec.FileOperation.create
|
diskspec.fileOperation = vim.vm.device.VirtualDeviceSpec.FileOperation.create
|
||||||
diskspec.device = vim.vm.device.VirtualDisk()
|
diskspec.device = vim.vm.device.VirtualDisk()
|
||||||
diskspec.device.backing = vim.vm.device.VirtualDisk.FlatVer2BackingInfo()
|
diskspec.device.backing = vim.vm.device.VirtualDisk.FlatVer2BackingInfo()
|
||||||
diskspec.device.backing.diskMode = 'persistent'
|
|
||||||
diskspec.device.controllerKey = scsi_ctl.device.key
|
diskspec.device.controllerKey = scsi_ctl.device.key
|
||||||
|
|
||||||
if self.next_disk_unit_number == 7:
|
if self.next_disk_unit_number == 7:
|
||||||
|
@ -1571,6 +1575,19 @@ class PyVmomiHelper(PyVmomi):
|
||||||
diskspec = self.device_helper.create_scsi_disk(scsi_ctl, disk_index)
|
diskspec = self.device_helper.create_scsi_disk(scsi_ctl, disk_index)
|
||||||
disk_modified = True
|
disk_modified = True
|
||||||
|
|
||||||
|
if 'disk_mode' in expected_disk_spec:
|
||||||
|
disk_mode = expected_disk_spec.get('disk_mode', 'persistent').lower()
|
||||||
|
valid_disk_mode = ['persistent', 'independent_persistent', 'independent_nonpersistent']
|
||||||
|
if disk_mode not in valid_disk_mode:
|
||||||
|
self.module.fail_json(msg="disk_mode specified is not valid."
|
||||||
|
" Should be one of ['%s']" % "', '".join(valid_disk_mode))
|
||||||
|
|
||||||
|
if (vm_obj and diskspec.device.backing.diskMode != disk_mode) or (vm_obj is None):
|
||||||
|
diskspec.device.backing.diskMode = disk_mode
|
||||||
|
disk_modified = True
|
||||||
|
else:
|
||||||
|
diskspec.device.backing.diskMode = "persistent"
|
||||||
|
|
||||||
# is it thin?
|
# is it thin?
|
||||||
if 'type' in expected_disk_spec:
|
if 'type' in expected_disk_spec:
|
||||||
disk_type = expected_disk_spec.get('type', '').lower()
|
disk_type = expected_disk_spec.get('type', '').lower()
|
||||||
|
|
|
@ -0,0 +1,120 @@
|
||||||
|
# Test code for the vmware_guest module.
|
||||||
|
# Copyright: (c) 2018, Abhijeet Kasurde <akasurde@redhat.com>
|
||||||
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||||
|
|
||||||
|
- name: Wait for Flask controller to come up online
|
||||||
|
wait_for:
|
||||||
|
host: "{{ vcsim }}"
|
||||||
|
port: 5000
|
||||||
|
state: started
|
||||||
|
|
||||||
|
- name: kill vcsim
|
||||||
|
uri:
|
||||||
|
url: http://{{ vcsim }}:5000/killall
|
||||||
|
- name: start vcsim with no folders
|
||||||
|
uri:
|
||||||
|
url: http://{{ vcsim }}:5000/spawn?datacenter=1&cluster=1&folder=0
|
||||||
|
register: vcsim_instance
|
||||||
|
|
||||||
|
- name: Wait for Flask controller to come up online
|
||||||
|
wait_for:
|
||||||
|
host: "{{ vcsim }}"
|
||||||
|
port: 443
|
||||||
|
state: started
|
||||||
|
|
||||||
|
- name: get a list of VMS from vcsim
|
||||||
|
uri:
|
||||||
|
url: http://{{ vcsim }}:5000/govc_find?filter=VM
|
||||||
|
register: vmlist
|
||||||
|
|
||||||
|
- debug: var=vcsim_instance
|
||||||
|
- debug: var=vmlist
|
||||||
|
|
||||||
|
- name: create new VMs with invalid disk mode
|
||||||
|
vmware_guest:
|
||||||
|
validate_certs: False
|
||||||
|
hostname: "{{ vcsim }}"
|
||||||
|
username: "{{ vcsim_instance['json']['username'] }}"
|
||||||
|
password: "{{ vcsim_instance['json']['password'] }}"
|
||||||
|
name: "{{ 'newvm_' + item|basename }}"
|
||||||
|
guest_id: centos64Guest
|
||||||
|
datacenter: "{{ (item|basename).split('_')[0] }}"
|
||||||
|
hardware:
|
||||||
|
num_cpus: 1
|
||||||
|
memory_mb: 512
|
||||||
|
disk:
|
||||||
|
- size: 1gb
|
||||||
|
type: eagerzeroedthick
|
||||||
|
autoselect_datastore: True
|
||||||
|
disk_mode: 'invalid_disk_mode'
|
||||||
|
state: poweredoff
|
||||||
|
folder: "{{ item|dirname }}"
|
||||||
|
with_items: "{{ vmlist['json'] }}"
|
||||||
|
register: disk_mode_d1_c1_f0
|
||||||
|
ignore_errors: True
|
||||||
|
|
||||||
|
- debug: var=disk_mode_d1_c1_f0
|
||||||
|
|
||||||
|
- name: assert that changes were not made
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- "disk_mode_d1_c1_f0.results|map(attribute='changed')|unique|list == [false]"
|
||||||
|
|
||||||
|
- name: create new VMs with valid disk mode
|
||||||
|
vmware_guest:
|
||||||
|
validate_certs: False
|
||||||
|
hostname: "{{ vcsim }}"
|
||||||
|
username: "{{ vcsim_instance['json']['username'] }}"
|
||||||
|
password: "{{ vcsim_instance['json']['password'] }}"
|
||||||
|
name: "{{ 'newvm_' + item|basename }}"
|
||||||
|
guest_id: centos64Guest
|
||||||
|
datacenter: "{{ (item|basename).split('_')[0] }}"
|
||||||
|
hardware:
|
||||||
|
num_cpus: 1
|
||||||
|
memory_mb: 512
|
||||||
|
disk:
|
||||||
|
- size: 1gb
|
||||||
|
type: eagerzeroedthick
|
||||||
|
autoselect_datastore: True
|
||||||
|
disk_mode: 'independent_persistent'
|
||||||
|
state: poweredoff
|
||||||
|
folder: "{{ item|dirname }}"
|
||||||
|
with_items: "{{ vmlist['json'] }}"
|
||||||
|
register: disk_mode_d1_c1_f0_2
|
||||||
|
|
||||||
|
- debug: var=disk_mode_d1_c1_f0_2
|
||||||
|
|
||||||
|
- name: assert that changes were made
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- "disk_mode_d1_c1_f0_2.results|map(attribute='changed')|unique|list == [true]"
|
||||||
|
|
||||||
|
# TODO: vcsim does not support reconfiguration of disk mode, fails with types.InvalidDeviceSpec
|
||||||
|
#- name: create new VMs with valid disk mode again
|
||||||
|
# vmware_guest:
|
||||||
|
# validate_certs: False
|
||||||
|
# hostname: "{{ vcsim }}"
|
||||||
|
# username: "{{ vcsim_instance['json']['username'] }}"
|
||||||
|
# password: "{{ vcsim_instance['json']['password'] }}"
|
||||||
|
# name: "{{ 'newvm_' + item|basename }}"
|
||||||
|
# guest_id: centos64Guest
|
||||||
|
# datacenter: "{{ (item|basename).split('_')[0] }}"
|
||||||
|
# hardware:
|
||||||
|
# num_cpus: 1
|
||||||
|
# memory_mb: 512
|
||||||
|
# disk:
|
||||||
|
# - size: 1gb
|
||||||
|
# type: eagerzeroedthick
|
||||||
|
# autoselect_datastore: True
|
||||||
|
# disk_mode: 'independent_persistent'
|
||||||
|
# state: poweredoff
|
||||||
|
# folder: "{{ item|dirname }}"
|
||||||
|
# with_items: "{{ vmlist['json'] }}"
|
||||||
|
# register: disk_mode_d1_c1_f0_2
|
||||||
|
|
||||||
|
#- debug: var=disk_mode_d1_c1_f0_2
|
||||||
|
|
||||||
|
#- name: assert that changes were not made
|
||||||
|
# assert:
|
||||||
|
# that:
|
||||||
|
# - "disk_mode_d1_c1_f0_2.results|map(attribute='changed')|unique|list == [false]"
|
|
@ -28,4 +28,5 @@
|
||||||
#- include: template_d1_c1_f0.yml
|
#- include: template_d1_c1_f0.yml
|
||||||
- include: vapp_d1_c1_f0.yml
|
- include: vapp_d1_c1_f0.yml
|
||||||
- include: disk_size_d1_c1_f0.yml
|
- include: disk_size_d1_c1_f0.yml
|
||||||
- include: network_with_device.yml
|
- include: network_with_device.yml
|
||||||
|
- include: disk_mode_d1_c1_f0.yml
|
||||||
|
|
Loading…
Reference in a new issue