New Module vmware_host_facts (#26492)
Add new module vmware_host_facts ,it can get remote vmware host system info like setup module * modify ansible version * optimized output for human readable * add serial number get_system_facts() add ansible_product_serial * fix pep8 issue and ansible module required format * Use find_obj method instead get_obj * add ansible_hostname ansible_distribution_build * add integration test * vmware_host_facts integration test add verify * fix yamllint issue * fix boilerplate test * Update vmware_host_facts.py * fix RETURN key's name
This commit is contained in:
parent
9cedb89644
commit
fa764f6918
3 changed files with 196 additions and 0 deletions
155
lib/ansible/modules/cloud/vmware/vmware_host_facts.py
Normal file
155
lib/ansible/modules/cloud/vmware/vmware_host_facts.py
Normal file
|
@ -0,0 +1,155 @@
|
|||
#!/usr/bin/python
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
# Copyright: (c) 2017, Wei Gao <gaowei3@qq.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 = '''
|
||||
---
|
||||
module: vmware_host_facts
|
||||
short_description: Gathers facts about remote vmware host
|
||||
description:
|
||||
- Gathers facts about remote vmware host.
|
||||
version_added: 2.5
|
||||
author:
|
||||
- Wei Gao (@woshihaoren)
|
||||
requirements:
|
||||
- python >= 2.6
|
||||
- PyVmomi
|
||||
extends_documentation_fragment: vmware.documentation
|
||||
'''
|
||||
|
||||
EXAMPLES = '''
|
||||
- name: Gather vmware host facts
|
||||
vmware_host_facts:
|
||||
hostname: esxi_ip_or_hostname
|
||||
username: username
|
||||
password: password
|
||||
register: host_facts
|
||||
delegate_to: localhost
|
||||
'''
|
||||
|
||||
RETURN = '''
|
||||
ansible_facts:
|
||||
description: system info about the host machine
|
||||
returned: always
|
||||
type: dict
|
||||
'''
|
||||
|
||||
from ansible.module_utils.basic import AnsibleModule, bytes_to_human
|
||||
from ansible.module_utils.vmware import connect_to_api, vmware_argument_spec, find_obj
|
||||
|
||||
try:
|
||||
from pyVmomi import vim, vmodl
|
||||
HAS_PYVMOMI = True
|
||||
except ImportError:
|
||||
HAS_PYVMOMI = False
|
||||
|
||||
|
||||
def get_cpu_facts(host):
|
||||
facts = {
|
||||
'ansible_processor': host.summary.hardware.cpuModel,
|
||||
'ansible_processor_cores': host.summary.hardware.numCpuCores,
|
||||
'ansible_processor_count': host.summary.hardware.numCpuPkgs,
|
||||
'ansible_processor_vcpus': host.summary.hardware.numCpuThreads,
|
||||
}
|
||||
return facts
|
||||
|
||||
|
||||
def get_memory_facts(host):
|
||||
facts = {
|
||||
'ansible_memfree_mb': host.hardware.memorySize // 1024 // 1024 - host.summary.quickStats.overallMemoryUsage,
|
||||
'ansible_memtotal_mb': host.hardware.memorySize // 1024 // 1024,
|
||||
}
|
||||
return facts
|
||||
|
||||
|
||||
def get_datastore_facts(host):
|
||||
facts = {}
|
||||
facts['ansible_datastore'] = []
|
||||
for store in host.datastore:
|
||||
_tmp = {
|
||||
'name': store.summary.name,
|
||||
'total': bytes_to_human(store.summary.capacity),
|
||||
'free': bytes_to_human(store.summary.freeSpace),
|
||||
}
|
||||
facts['ansible_datastore'].append(_tmp)
|
||||
return facts
|
||||
|
||||
|
||||
def get_network_facts(host):
|
||||
facts = {}
|
||||
facts['ansible_interfaces'] = []
|
||||
facts['ansible_all_ipv4_addresses'] = []
|
||||
for nic in host.config.network.vnic:
|
||||
device = nic.device
|
||||
facts['ansible_interfaces'].append(device)
|
||||
facts['ansible_all_ipv4_addresses'].append(nic.spec.ip.ipAddress)
|
||||
_tmp = {
|
||||
'device': device,
|
||||
'ipv4': {
|
||||
'address': nic.spec.ip.ipAddress,
|
||||
'netmask': nic.spec.ip.subnetMask,
|
||||
},
|
||||
'macaddress': nic.spec.mac,
|
||||
'mtu': nic.spec.mtu,
|
||||
}
|
||||
facts['ansible_' + device] = _tmp
|
||||
return facts
|
||||
|
||||
|
||||
def get_system_facts(host):
|
||||
sn = 'NA'
|
||||
for info in host.hardware.systemInfo.otherIdentifyingInfo:
|
||||
if info.identifierType.key == 'ServiceTag':
|
||||
sn = info.identifierValue
|
||||
facts = {
|
||||
'ansible_distribution': host.config.product.name,
|
||||
'ansible_distribution_version': host.config.product.version,
|
||||
'ansible_distribution_build': host.config.product.build,
|
||||
'ansible_os_type': host.config.product.osType,
|
||||
'ansible_system_vendor': host.hardware.systemInfo.vendor,
|
||||
'ansible_hostname': host.summary.config.name,
|
||||
'ansible_product_name': host.hardware.systemInfo.model,
|
||||
'ansible_product_serial': sn,
|
||||
'ansible_bios_date': host.hardware.biosInfo.releaseDate,
|
||||
'ansible_bios_version': host.hardware.biosInfo.biosVersion,
|
||||
}
|
||||
return facts
|
||||
|
||||
|
||||
def all_facts(content):
|
||||
host = find_obj(content, [vim.HostSystem], None)
|
||||
ansible_facts = {}
|
||||
ansible_facts.update(get_cpu_facts(host))
|
||||
ansible_facts.update(get_memory_facts(host))
|
||||
ansible_facts.update(get_datastore_facts(host))
|
||||
ansible_facts.update(get_network_facts(host))
|
||||
ansible_facts.update(get_system_facts(host))
|
||||
return ansible_facts
|
||||
|
||||
|
||||
def main():
|
||||
|
||||
argument_spec = vmware_argument_spec()
|
||||
module = AnsibleModule(argument_spec=argument_spec, supports_check_mode=False)
|
||||
|
||||
if not HAS_PYVMOMI:
|
||||
module.fail_json(msg='pyvmomi is required for this module')
|
||||
|
||||
content = connect_to_api(module)
|
||||
data = all_facts(content)
|
||||
module.exit_json(changed=False, ansible_facts=data)
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
main()
|
3
test/integration/targets/vmware_host_facts/aliases
Normal file
3
test/integration/targets/vmware_host_facts/aliases
Normal file
|
@ -0,0 +1,3 @@
|
|||
posix/ci/cloud/vcenter
|
||||
cloud/vcenter
|
||||
|
38
test/integration/targets/vmware_host_facts/tasks/main.yml
Normal file
38
test/integration/targets/vmware_host_facts/tasks/main.yml
Normal file
|
@ -0,0 +1,38 @@
|
|||
- name: make sure pyvmomi is installed
|
||||
pip:
|
||||
name: pyvmomi
|
||||
state: latest
|
||||
|
||||
- name: store the vcenter container ip
|
||||
set_fact:
|
||||
vcsim: "{{ lookup('env', 'vcenter_host') }}"
|
||||
- debug: var=vcsim
|
||||
|
||||
- name: kill vcsim
|
||||
uri:
|
||||
url: "{{ 'http://' + vcsim + ':5000/killall' }}"
|
||||
- name: start vcsim
|
||||
uri:
|
||||
url: "{{ 'http://' + vcsim + ':5000/spawn?cluster=2' }}"
|
||||
register: vcsim_instance
|
||||
|
||||
- name: get host facts
|
||||
vmware_host_facts:
|
||||
validate_certs: False
|
||||
hostname: "{{ vcsim }}"
|
||||
username: "{{ vcsim_instance['json']['username'] }}"
|
||||
password: "{{ vcsim_instance['json']['password'] }}"
|
||||
register: facts
|
||||
|
||||
- debug: var=facts
|
||||
|
||||
- name: get host info
|
||||
uri:
|
||||
url: "{{ 'http://' + vcsim + ':5000/govc_host_info' }}"
|
||||
register: host_info_result
|
||||
|
||||
- name: verify some data,like ansible_processor
|
||||
assert:
|
||||
that:
|
||||
- facts['ansible_facts']['ansible_hostname'] in host_info_result['json']
|
||||
- facts['ansible_facts']['ansible_processor'] == host_info_result['json'][facts['ansible_facts']['ansible_hostname']]['Processor type']
|
Loading…
Reference in a new issue