VMware: support folder param in vmware_vm_facts (#56298)

folder can be used as a filter while gathering facts about VMs.

Fixes: #56125

Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
Abhijeet Kasurde 2019-05-11 11:56:57 +05:30 committed by GitHub
parent f5326aa6cd
commit 9f86257a65
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 56 additions and 11 deletions

View file

@ -0,0 +1,2 @@
minor_changes:
- vmware_vm_facts supports folder as a filter to gather fact for VM (https://github.com/ansible/ansible/issues/56125).

View file

@ -50,6 +50,21 @@ options:
default: no
type: bool
version_added: 2.8
folder:
description:
- Specify a folder location of VMs to gather facts from.
- 'Examples:'
- ' folder: /ha-datacenter/vm'
- ' folder: ha-datacenter/vm'
- ' folder: /datacenter1/vm'
- ' folder: datacenter1/vm'
- ' folder: /datacenter1/vm/folder1'
- ' folder: datacenter1/vm/folder1'
- ' folder: /folder1/datacenter1/vm'
- ' folder: folder1/datacenter1/vm'
- ' folder: /folder1/datacenter1/vm/folder2'
type: str
version_added: 2.9
extends_documentation_fragment: vmware.documentation
'''
@ -161,7 +176,14 @@ class VmwareVmFacts(PyVmomi):
"""
Get all virtual machines and related configurations information
"""
virtual_machines = get_all_objs(self.content, [vim.VirtualMachine])
folder = self.params.get('folder')
folder_obj = None
if folder:
folder_obj = self.content.searchIndex.FindByInventoryPath(folder)
if not folder_obj:
self.module.fail_json(msg="Failed to find folder specified by %(folder)s" % self.params)
virtual_machines = get_all_objs(self.content, [vim.VirtualMachine], folder=folder_obj)
_virtual_machines = []
for vm in virtual_machines:
@ -234,6 +256,7 @@ def main():
argument_spec.update(
vm_type=dict(type='str', choices=['vm', 'all', 'template'], default='all'),
show_attribute=dict(type='bool', default='no'),
folder=dict(type='str'),
)
module = AnsibleModule(

View file

@ -10,8 +10,8 @@
setup_datastore: true
setup_virtualmachines: true
- name: Get facts about available vms
- &vm_data
name: Get facts about available vms
vmware_vm_facts:
validate_certs: false
hostname: "{{ vcenter_hostname }}"
@ -21,7 +21,8 @@
- debug: var=vm_facts_0001
- name: Verify if VM facts exist
- &vm_fact_check
name: Verify if VM facts exist
assert:
that:
- "item.esxi_hostname is defined"
@ -36,17 +37,37 @@
vars:
query: "[?guest_name=='DC0_H0_VM0']"
- <<: *vm_data
name: Get facts about available vms in check mode
check_mode: yes
- name: Get facts about available vms in check mode
vmware_vm_facts:
- <<: *vm_fact_check
name: Verify if VM facts exist in check mode
- name: Get folder name from VM
vmware_guest_find:
validate_certs: false
hostname: "{{ vcenter_hostname }}"
username: "{{ vcenter_username }}"
password: "{{ vcenter_password }}"
register: vm_facts_0001
check_mode: yes
name: "DC0_H0_VM0"
register: folder_path_info
- name: Verify if VM facts exist in check mode
- set_fact:
folder_path: "{{ folder_path_info.folders[0] }}"
when: folder_path_info.folders is defined
- name: Gather facts about VM using folder
vmware_vm_facts:
hostname: "{{ vcenter_hostname }}"
username: "{{ vcenter_username }}"
password: "{{ vcenter_password }}"
validate_certs: no
folder: "{{ folder_path }}"
register: vm_facts
when: folder_path_info.folders is defined
- name: Check if facts are returned for VM with folder specified
assert:
that:
- "item.esxi_hostname is defined"
@ -56,8 +77,7 @@
- "item.power_state is defined"
- "item.uuid is defined"
- "item.vm_network is defined"
- "item.attributes is defined"
with_items:
- "{{ vm_facts_0001.virtual_machines | json_query(query) }}"
- "{{ vm_facts.virtual_machines | json_query(query) }}"
vars:
query: "[?guest_name=='DC0_H0_VM0']"