VMware: Add new module vmware_folder_info (#54344)
* Adds a new vmware module to support getting the folders and their paths within a datacenter * Add integration tests * Bump version added * Refactor integration test * Improve grammar in docs
This commit is contained in:
parent
0e0735f10e
commit
50e9955a23
3 changed files with 218 additions and 0 deletions
164
lib/ansible/modules/cloud/vmware/vmware_folder_info.py
Normal file
164
lib/ansible/modules/cloud/vmware/vmware_folder_info.py
Normal file
|
@ -0,0 +1,164 @@
|
|||
#!/usr/bin/python
|
||||
# -*- coding: utf-8 -*-
|
||||
#
|
||||
# Copyright: (c) 2019, David Hewitt <davidmhewitt@gmail.com>
|
||||
#
|
||||
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||
|
||||
from __future__ import absolute_import, division, print_function
|
||||
__metaclass__ = type
|
||||
|
||||
ANSIBLE_METADATA = {
|
||||
'metadata_version': '1.1',
|
||||
'status': ['preview'],
|
||||
'supported_by': 'community'
|
||||
}
|
||||
|
||||
DOCUMENTATION = r'''
|
||||
---
|
||||
module: vmware_folder_info
|
||||
short_description: Provides information about folders in a datacenter
|
||||
description:
|
||||
- The module can be used to gather a hierarchical view of the folders that exist within a datacenter
|
||||
version_added: 2.9
|
||||
author:
|
||||
- David Hewitt (@davidmhewitt)
|
||||
notes:
|
||||
- Tested on vSphere 6.5
|
||||
requirements:
|
||||
- python >= 2.6
|
||||
- PyVmomi
|
||||
options:
|
||||
datacenter:
|
||||
description:
|
||||
- Name of the datacenter.
|
||||
required: true
|
||||
type: str
|
||||
aliases: ['datacenter_name']
|
||||
extends_documentation_fragment: vmware.documentation
|
||||
'''
|
||||
|
||||
EXAMPLES = r'''
|
||||
- name: Provide information about vCenter folders
|
||||
vmware_folder_info:
|
||||
hostname: '{{ vcenter_hostname }}'
|
||||
username: '{{ vcenter_username }}'
|
||||
password: '{{ vcenter_password }}'
|
||||
datacenter: datacenter_name
|
||||
delegate_to: localhost
|
||||
register: vcenter_folder_info
|
||||
'''
|
||||
|
||||
RETURN = r'''
|
||||
folder_info:
|
||||
description:
|
||||
- dict about folders
|
||||
returned: success
|
||||
type: str
|
||||
sample:
|
||||
{
|
||||
"datastoreFolders": {
|
||||
"path": "/DC01/datastore",
|
||||
"subfolders": {
|
||||
"Local Datastores": {
|
||||
"path": "/DC01/datastore/Local Datastores",
|
||||
"subfolders": {}
|
||||
}
|
||||
}
|
||||
},
|
||||
"hostFolders": {
|
||||
"path": "/DC01/host",
|
||||
"subfolders": {}
|
||||
},
|
||||
"networkFolders": {
|
||||
"path": "/DC01/network",
|
||||
"subfolders": {}
|
||||
},
|
||||
"vmFolders": {
|
||||
"path": "/DC01/vm",
|
||||
"subfolders": {
|
||||
"Core Infrastructure Servers": {
|
||||
"path": "/DC01/vm/Core Infrastructure Servers",
|
||||
"subfolders": {
|
||||
"Staging Network Services": {
|
||||
"path": "/DC01/vm/Core Infrastructure Servers/Staging Network Services",
|
||||
"subfolders": {}
|
||||
},
|
||||
"VMware": {
|
||||
"path": "/DC01/vm/Core Infrastructure Servers/VMware",
|
||||
"subfolders": {}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
'''
|
||||
|
||||
try:
|
||||
from pyVmomi import vim
|
||||
except ImportError as import_err:
|
||||
pass
|
||||
|
||||
from ansible.module_utils.basic import AnsibleModule
|
||||
from ansible.module_utils.vmware import vmware_argument_spec, PyVmomi
|
||||
|
||||
|
||||
class VmwareFolderInfoManager(PyVmomi):
|
||||
def __init__(self, module):
|
||||
super(VmwareFolderInfoManager, self).__init__(module)
|
||||
self.dc_name = self.params['datacenter']
|
||||
|
||||
def gather_folder_info(self):
|
||||
datacenter = self.find_datacenter_by_name(self.dc_name)
|
||||
if datacenter is None:
|
||||
self.module.fail_json(msg="Failed to find the datacenter %s" % self.dc_name)
|
||||
|
||||
folder_trees = {}
|
||||
folder_trees['vmFolders'] = self.build_folder_tree(datacenter.vmFolder, "/%s/vm" % self.dc_name)
|
||||
folder_trees['hostFolders'] = self.build_folder_tree(datacenter.hostFolder, "/%s/host" % self.dc_name)
|
||||
folder_trees['networkFolders'] = self.build_folder_tree(datacenter.networkFolder, "/%s/network" % self.dc_name)
|
||||
folder_trees['datastoreFolders'] = self.build_folder_tree(datacenter.datastoreFolder, "/%s/datastore" % self.dc_name)
|
||||
|
||||
self.module.exit_json(
|
||||
changed=False,
|
||||
folder_info=folder_trees
|
||||
)
|
||||
|
||||
def build_folder_tree(self, folder, path):
|
||||
tree = {
|
||||
'path': path,
|
||||
'subfolders': {}
|
||||
}
|
||||
|
||||
children = None
|
||||
if hasattr(folder, 'childEntity'):
|
||||
children = folder.childEntity
|
||||
|
||||
if children:
|
||||
for child in children:
|
||||
if child == folder:
|
||||
continue
|
||||
if isinstance(child, vim.Folder):
|
||||
ctree = self.build_folder_tree(child, "%s/%s" % (path, child.name))
|
||||
tree['subfolders'][child.name] = dict.copy(ctree)
|
||||
return tree
|
||||
|
||||
|
||||
def main():
|
||||
argument_spec = vmware_argument_spec()
|
||||
argument_spec.update(
|
||||
datacenter=dict(type='str', required=True, aliases=['datacenter_name'])
|
||||
)
|
||||
|
||||
module = AnsibleModule(
|
||||
argument_spec=argument_spec,
|
||||
supports_check_mode=True,
|
||||
)
|
||||
|
||||
vmware_folder_info_mgr = VmwareFolderInfoManager(module)
|
||||
vmware_folder_info_mgr.gather_folder_info()
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
3
test/integration/targets/vmware_folder_info/aliases
Normal file
3
test/integration/targets/vmware_folder_info/aliases
Normal file
|
@ -0,0 +1,3 @@
|
|||
shippable/vcenter/group1
|
||||
cloud/vcenter
|
||||
needs/target/prepare_vmware_tests
|
51
test/integration/targets/vmware_folder_info/tasks/main.yml
Normal file
51
test/integration/targets/vmware_folder_info/tasks/main.yml
Normal file
|
@ -0,0 +1,51 @@
|
|||
# Test code for the vmware_folder_info module.
|
||||
# Copyright: (c) 2019, David Hewitt (@davidmhewitt) <davidmhewitt@gmail.com>
|
||||
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||
|
||||
- import_role:
|
||||
name: prepare_vmware_tests
|
||||
|
||||
- name: create example toplevel folder
|
||||
vcenter_folder:
|
||||
<<: &vcenter_folder_data
|
||||
hostname: "{{ vcenter_hostname }}"
|
||||
username: "{{ vcenter_username }}"
|
||||
password: "{{ vcenter_password }}"
|
||||
datacenter: "{{ dc1 | basename }}"
|
||||
validate_certs: no
|
||||
folder_name: "toplevel"
|
||||
|
||||
- name: create an example child folder
|
||||
vcenter_folder:
|
||||
<<: *vcenter_folder_data
|
||||
folder_name: "child_folder"
|
||||
parent_folder: "toplevel"
|
||||
|
||||
# Testcase 0001: Get details about folders
|
||||
- name: get info about folders
|
||||
vmware_folder_info:
|
||||
<<: *vcenter_folder_data
|
||||
register: folder_info_0001
|
||||
|
||||
- debug: var=folder_info_0001
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "{{ item }} is defined"
|
||||
with_items:
|
||||
- folder_info_0001['folder_info']
|
||||
- folder_info_0001['folder_info']['datastoreFolders']
|
||||
- folder_info_0001['folder_info']['hostFolders']
|
||||
- folder_info_0001['folder_info']['vmFolders']
|
||||
- folder_info_0001['folder_info']['networkFolders']
|
||||
- folder_info_0001['folder_info']['vmFolders']['subfolders']['toplevel']
|
||||
- folder_info_0001['folder_info']['vmFolders']['subfolders']['toplevel']['subfolders']['child_folder']
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- "folder_info_0001['folder_info']['datastoreFolders']['path'] == \"/{{ dc1 | basename }}/datastore\""
|
||||
- "folder_info_0001['folder_info']['hostFolders']['path'] == \"/{{ dc1 | basename }}/host\""
|
||||
- "folder_info_0001['folder_info']['vmFolders']['path'] == \"/{{ dc1 | basename }}/vm\""
|
||||
- "folder_info_0001['folder_info']['networkFolders']['path'] == \"/{{ dc1 | basename }}/network\""
|
||||
- "folder_info_0001['folder_info']['vmFolders']['subfolders']['toplevel']['path'] == \"/{{ dc1 | basename }}/vm/toplevel\""
|
||||
- "folder_info_0001['folder_info']['vmFolders']['subfolders']['toplevel']['subfolders']['child_folder']['path'] == \"/{{ dc1 | basename }}/vm/toplevel/child_folder\""
|
Loading…
Reference in a new issue