Add check mode support in vmware_guest (#32858)
This fix adds check mode support in vmware_guest Fixes: #32439 Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
parent
e8dd01fa5b
commit
c65842b9d8
3 changed files with 120 additions and 0 deletions
|
@ -1798,13 +1798,36 @@ def main():
|
||||||
if vm:
|
if vm:
|
||||||
if module.params['state'] == 'absent':
|
if module.params['state'] == 'absent':
|
||||||
# destroy it
|
# destroy it
|
||||||
|
if module.check_mode:
|
||||||
|
result.update(
|
||||||
|
vm_name=vm.name,
|
||||||
|
changed=True,
|
||||||
|
current_powerstate=vm.summary.runtime.powerState.lower(),
|
||||||
|
desired_operation='remove_vm',
|
||||||
|
)
|
||||||
|
module.exit_json(**result)
|
||||||
if module.params['force']:
|
if module.params['force']:
|
||||||
# has to be poweredoff first
|
# has to be poweredoff first
|
||||||
set_vm_power_state(pyv.content, vm, 'poweredoff', module.params['force'])
|
set_vm_power_state(pyv.content, vm, 'poweredoff', module.params['force'])
|
||||||
result = pyv.remove_vm(vm)
|
result = pyv.remove_vm(vm)
|
||||||
elif module.params['state'] == 'present':
|
elif module.params['state'] == 'present':
|
||||||
|
if module.check_mode:
|
||||||
|
result.update(
|
||||||
|
vm_name=vm.name,
|
||||||
|
changed=True,
|
||||||
|
desired_operation='reconfigure_vm',
|
||||||
|
)
|
||||||
|
module.exit_json(**result)
|
||||||
result = pyv.reconfigure_vm()
|
result = pyv.reconfigure_vm()
|
||||||
elif module.params['state'] in ['poweredon', 'poweredoff', 'restarted', 'suspended', 'shutdownguest', 'rebootguest']:
|
elif module.params['state'] in ['poweredon', 'poweredoff', 'restarted', 'suspended', 'shutdownguest', 'rebootguest']:
|
||||||
|
if module.check_mode:
|
||||||
|
result.update(
|
||||||
|
vm_name=vm.name,
|
||||||
|
changed=True,
|
||||||
|
current_powerstate=vm.summary.runtime.powerState.lower(),
|
||||||
|
desired_operation='set_vm_power_state',
|
||||||
|
)
|
||||||
|
module.exit_json(**result)
|
||||||
# set powerstate
|
# set powerstate
|
||||||
tmp_result = set_vm_power_state(pyv.content, vm, module.params['state'], module.params['force'])
|
tmp_result = set_vm_power_state(pyv.content, vm, module.params['state'], module.params['force'])
|
||||||
if tmp_result['changed']:
|
if tmp_result['changed']:
|
||||||
|
@ -1817,6 +1840,12 @@ def main():
|
||||||
# VM doesn't exist
|
# VM doesn't exist
|
||||||
else:
|
else:
|
||||||
if module.params['state'] in ['poweredon', 'poweredoff', 'present', 'restarted', 'suspended']:
|
if module.params['state'] in ['poweredon', 'poweredoff', 'present', 'restarted', 'suspended']:
|
||||||
|
if module.check_mode:
|
||||||
|
result.update(
|
||||||
|
changed=True,
|
||||||
|
desired_operation='deploy_vm',
|
||||||
|
)
|
||||||
|
module.exit_json(**result)
|
||||||
result = pyv.deploy_vm()
|
result = pyv.deploy_vm()
|
||||||
if result['failed']:
|
if result['failed']:
|
||||||
module.fail_json(msg='Failed to create a virtual machine : %s' % result['msg'])
|
module.fail_json(msg='Failed to create a virtual machine : %s' % result['msg'])
|
||||||
|
|
90
test/integration/targets/vmware_guest/tasks/check_mode.yml
Normal file
90
test/integration/targets/vmware_guest/tasks/check_mode.yml
Normal file
|
@ -0,0 +1,90 @@
|
||||||
|
# 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: get a guest
|
||||||
|
set_fact:
|
||||||
|
guest1: "{{ vmlist.json[0] }}"
|
||||||
|
|
||||||
|
- name: Perform all operation in check mode
|
||||||
|
vmware_guest:
|
||||||
|
validate_certs: False
|
||||||
|
hostname: "{{ vcsim }}"
|
||||||
|
username: "{{ vcsim_instance['json']['username'] }}"
|
||||||
|
password: "{{ vcsim_instance['json']['password'] }}"
|
||||||
|
name: "{{ guest1|basename }}"
|
||||||
|
datacenter: "{{ (guest1|basename).split('_')[0] }}"
|
||||||
|
state: "{{ item }}"
|
||||||
|
with_items:
|
||||||
|
- absent
|
||||||
|
- present
|
||||||
|
- poweredoff
|
||||||
|
- poweredon
|
||||||
|
- restarted
|
||||||
|
- suspended
|
||||||
|
- shutdownguest
|
||||||
|
- rebootguest
|
||||||
|
register: check_mode_state
|
||||||
|
check_mode: yes
|
||||||
|
|
||||||
|
- debug: var=check_mode_state
|
||||||
|
|
||||||
|
- name: assert that changes were made
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- "check_mode_state.results|map(attribute='changed')|unique|list == [true]"
|
||||||
|
- "check_mode_state.results|map(attribute='vm_name')|unique|list == [ guest1 | basename ]"
|
||||||
|
|
||||||
|
- name: Perform all operation on non-existent VM in check mode
|
||||||
|
vmware_guest:
|
||||||
|
validate_certs: False
|
||||||
|
hostname: "{{ vcsim }}"
|
||||||
|
username: "{{ vcsim_instance['json']['username'] }}"
|
||||||
|
password: "{{ vcsim_instance['json']['password'] }}"
|
||||||
|
name: non_existent_vm
|
||||||
|
datacenter: "{{ (guest1|basename).split('_')[0] }}"
|
||||||
|
state: "{{ item }}"
|
||||||
|
with_items:
|
||||||
|
- present
|
||||||
|
- poweredoff
|
||||||
|
- poweredon
|
||||||
|
- restarted
|
||||||
|
- suspended
|
||||||
|
register: check_mode_state
|
||||||
|
check_mode: yes
|
||||||
|
|
||||||
|
- debug: var=check_mode_state
|
||||||
|
|
||||||
|
- name: assert that changes were made
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- "check_mode_state.results|map(attribute='changed')|unique|list == [true]"
|
||||||
|
- "check_mode_state.results|map(attribute='desired_operation')|unique|list == ['deploy_vm']"
|
|
@ -16,6 +16,7 @@
|
||||||
# Commenting following two is failing right now - 15 Dec 2017
|
# Commenting following two is failing right now - 15 Dec 2017
|
||||||
#- include: poweroff_d1_c1_f0.yml
|
#- include: poweroff_d1_c1_f0.yml
|
||||||
#- include: poweroff_d1_c1_f1.yml
|
#- include: poweroff_d1_c1_f1.yml
|
||||||
|
- include: check_mode.yml
|
||||||
- include: clone_d1_c1_f0.yml
|
- include: clone_d1_c1_f0.yml
|
||||||
- include: create_d1_c1_f0.yml
|
- include: create_d1_c1_f0.yml
|
||||||
- include: cdrom_d1_c1_f0.yml
|
- include: cdrom_d1_c1_f0.yml
|
||||||
|
|
Loading…
Reference in a new issue