mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
vmware_host: Small fixes and docs updates (#25144)
* vmware_host: Small fixes and docs updates This PR includes: - A fix to no longer require a datacenter folder for adding a host - Documentation improvements - Ensure imports are specific * Update vmware_host Fix adds following: * Update logic in vmware_host * Update example documentation * Added test case for vmware_host Signed-off-by: Abhijeet Kasurde <akasurde@redhat.com>
This commit is contained in:
parent
9649195c26
commit
a5eea9042e
3 changed files with 201 additions and 61 deletions
|
@ -22,67 +22,66 @@ ANSIBLE_METADATA = {'metadata_version': '1.0',
|
||||||
'status': ['preview'],
|
'status': ['preview'],
|
||||||
'supported_by': 'community'}
|
'supported_by': 'community'}
|
||||||
|
|
||||||
|
DOCUMENTATION = r'''
|
||||||
DOCUMENTATION = '''
|
|
||||||
---
|
---
|
||||||
module: vmware_host
|
module: vmware_host
|
||||||
short_description: Add/remove ESXi host to/from vCenter
|
short_description: Add/remove ESXi host to/from vCenter
|
||||||
description:
|
description:
|
||||||
- This module can be used to add/remove an ESXi host to/from vCenter
|
- This module can be used to add/remove an ESXi host to/from vCenter.
|
||||||
version_added: 2.0
|
version_added: '2.0'
|
||||||
author: "Joseph Callen (@jcpowermac), Russell Teague (@mtnbikenc)"
|
author:
|
||||||
|
- Joseph Callen (@jcpowermac)
|
||||||
|
- Russell Teague (@mtnbikenc)
|
||||||
notes:
|
notes:
|
||||||
- Tested on vSphere 5.5
|
- Tested on vSphere 5.5
|
||||||
requirements:
|
requirements:
|
||||||
- "python >= 2.6"
|
- python >= 2.6
|
||||||
- PyVmomi
|
- PyVmomi
|
||||||
options:
|
options:
|
||||||
datacenter_name:
|
datacenter_name:
|
||||||
description:
|
description:
|
||||||
- Name of the datacenter to add the host
|
- Name of the datacenter to add the host.
|
||||||
required: True
|
required: yes
|
||||||
cluster_name:
|
cluster_name:
|
||||||
description:
|
description:
|
||||||
- Name of the cluster to add the host
|
- Name of the cluster to add the host.
|
||||||
required: True
|
required: yes
|
||||||
esxi_hostname:
|
esxi_hostname:
|
||||||
description:
|
description:
|
||||||
- ESXi hostname to manage
|
- ESXi hostname to manage.
|
||||||
required: True
|
required: yes
|
||||||
esxi_username:
|
esxi_username:
|
||||||
description:
|
description:
|
||||||
- ESXi username
|
- ESXi username.
|
||||||
required: True
|
required: yes
|
||||||
esxi_password:
|
esxi_password:
|
||||||
description:
|
description:
|
||||||
- ESXi password
|
- ESXi password.
|
||||||
required: True
|
required: yes
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- Add or remove the host
|
- Add or remove the host.
|
||||||
default: 'present'
|
choices: [absent, present]
|
||||||
choices:
|
default: present
|
||||||
- 'present'
|
|
||||||
- 'absent'
|
|
||||||
required: False
|
|
||||||
extends_documentation_fragment: vmware.documentation
|
extends_documentation_fragment: vmware.documentation
|
||||||
'''
|
'''
|
||||||
|
|
||||||
EXAMPLES = '''
|
EXAMPLES = r'''
|
||||||
# Example from Ansible playbook
|
- name: Add ESXi Host to vCenter
|
||||||
|
vmware_host:
|
||||||
- name: Add ESXi Host to VCSA
|
hostname: '{{ vcenter_hostname }}'
|
||||||
local_action:
|
username: '{{ vcenter_username }}'
|
||||||
module: vmware_host
|
password: '{{ vcenter_password }}'
|
||||||
hostname: vcsa_host
|
|
||||||
username: vcsa_user
|
|
||||||
password: vcsa_pass
|
|
||||||
datacenter_name: datacenter_name
|
datacenter_name: datacenter_name
|
||||||
cluster_name: cluster_name
|
cluster_name: cluster_name
|
||||||
esxi_hostname: esxi_hostname
|
esxi_hostname: '{{ esxi_hostname }}'
|
||||||
esxi_username: esxi_username
|
esxi_username: '{{ esxi_username }}'
|
||||||
esxi_password: esxi_password
|
esxi_password: '{{ esxi_password }}'
|
||||||
state: present
|
state: present
|
||||||
|
delegate_to: localhost
|
||||||
|
'''
|
||||||
|
|
||||||
|
RETURN = r'''
|
||||||
'''
|
'''
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
@ -91,6 +90,16 @@ try:
|
||||||
except ImportError:
|
except ImportError:
|
||||||
HAS_PYVMOMI = False
|
HAS_PYVMOMI = False
|
||||||
|
|
||||||
|
from ansible.module_utils.basic import AnsibleModule
|
||||||
|
from ansible.module_utils.vmware import (
|
||||||
|
TaskError,
|
||||||
|
connect_to_api,
|
||||||
|
find_cluster_by_name,
|
||||||
|
find_datacenter_by_name,
|
||||||
|
vmware_argument_spec,
|
||||||
|
wait_for_task,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
class VMwareHost(object):
|
class VMwareHost(object):
|
||||||
def __init__(self, module):
|
def __init__(self, module):
|
||||||
|
@ -131,7 +140,10 @@ class VMwareHost(object):
|
||||||
|
|
||||||
def find_host_by_cluster_datacenter(self):
|
def find_host_by_cluster_datacenter(self):
|
||||||
self.dc = find_datacenter_by_name(self.content, self.datacenter_name)
|
self.dc = find_datacenter_by_name(self.content, self.datacenter_name)
|
||||||
self.cluster = find_cluster_by_name_datacenter(self.dc, self.cluster_name)
|
self.cluster = find_cluster_by_name(self.content, self.cluster_name, self.dc)
|
||||||
|
|
||||||
|
if self.cluster is None:
|
||||||
|
self.module.fail_json(msg="Unable to find cluster %(cluster_name)s" % self.module.params)
|
||||||
|
|
||||||
for host in self.cluster.host:
|
for host in self.cluster.host:
|
||||||
if host.name == self.esxi_hostname:
|
if host.name == self.esxi_hostname:
|
||||||
|
@ -208,14 +220,19 @@ class VMwareHost(object):
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
argument_spec = vmware_argument_spec()
|
argument_spec = vmware_argument_spec()
|
||||||
argument_spec.update(dict(datacenter_name=dict(required=True, type='str'),
|
argument_spec.update(
|
||||||
cluster_name=dict(required=True, type='str'),
|
datacenter_name=dict(type='str', required=True),
|
||||||
esxi_hostname=dict(required=True, type='str'),
|
cluster_name=dict(type='str'),
|
||||||
esxi_username=dict(required=True, type='str'),
|
esxi_hostname=dict(type='str', required=True),
|
||||||
esxi_password=dict(required=True, type='str', no_log=True),
|
esxi_username=dict(type='str', required=True),
|
||||||
state=dict(default='present', choices=['present', 'absent'], type='str')))
|
esxi_password=dict(type='str', required=True, no_log=True),
|
||||||
|
state=dict(type='str', default='present', choices=['absent', 'present'])
|
||||||
|
)
|
||||||
|
|
||||||
module = AnsibleModule(argument_spec=argument_spec, supports_check_mode=True)
|
module = AnsibleModule(
|
||||||
|
argument_spec=argument_spec,
|
||||||
|
supports_check_mode=True,
|
||||||
|
)
|
||||||
|
|
||||||
if not HAS_PYVMOMI:
|
if not HAS_PYVMOMI:
|
||||||
module.fail_json(msg='pyvmomi is required for this module')
|
module.fail_json(msg='pyvmomi is required for this module')
|
||||||
|
@ -223,8 +240,5 @@ def main():
|
||||||
vmware_host = VMwareHost(module)
|
vmware_host = VMwareHost(module)
|
||||||
vmware_host.process_state()
|
vmware_host.process_state()
|
||||||
|
|
||||||
from ansible.module_utils.vmware import *
|
|
||||||
from ansible.module_utils.basic import *
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
main()
|
main()
|
||||||
|
|
2
test/integration/targets/vmware_host/aliases
Normal file
2
test/integration/targets/vmware_host/aliases
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
posix/ci/cloud/vcenter
|
||||||
|
cloud/vcenter
|
124
test/integration/targets/vmware_host/tasks/main.yml
Normal file
124
test/integration/targets/vmware_host/tasks/main.yml
Normal file
|
@ -0,0 +1,124 @@
|
||||||
|
# Test code for the vmware_host module.
|
||||||
|
# (c) 2017, Abhijeet Kasurde <akasurde@redhat.com>
|
||||||
|
|
||||||
|
# This file is part of Ansible
|
||||||
|
#
|
||||||
|
# Ansible is free software: you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# Ansible is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
- 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: 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
|
||||||
|
uri:
|
||||||
|
url: http://{{ vcsim }}:5000/spawn?cluster=2
|
||||||
|
register: vcsim_instance
|
||||||
|
|
||||||
|
- debug:
|
||||||
|
var: vcsim_instance
|
||||||
|
|
||||||
|
- name: Wait for vcsim server to come up online
|
||||||
|
wait_for:
|
||||||
|
host: "{{ vcsim }}"
|
||||||
|
port: 443
|
||||||
|
state: started
|
||||||
|
|
||||||
|
- name: get a list of Datacenter from vcsim
|
||||||
|
uri:
|
||||||
|
url: http://{{ vcsim }}:5000/govc_find?filter=DC
|
||||||
|
register: datacenters
|
||||||
|
|
||||||
|
- name: get a datacenter
|
||||||
|
set_fact:
|
||||||
|
dc1: "{{ datacenters.json[0] | basename }}"
|
||||||
|
|
||||||
|
- debug: var=dc1
|
||||||
|
|
||||||
|
|
||||||
|
- name: get a list of Cluster from vcsim
|
||||||
|
uri:
|
||||||
|
url: http://{{ vcsim }}:5000/govc_find?filter=CCR
|
||||||
|
register: clusters
|
||||||
|
|
||||||
|
- name: get a cluster
|
||||||
|
set_fact:
|
||||||
|
ccr1: "{{ clusters.json[0] | basename }}"
|
||||||
|
|
||||||
|
- debug: var=ccr1
|
||||||
|
|
||||||
|
# Testcase 0001: Add Host
|
||||||
|
- name: add host
|
||||||
|
vmware_host:
|
||||||
|
hostname: "{{ vcsim }}"
|
||||||
|
username: "{{ vcsim_instance.json.username }}"
|
||||||
|
password: "{{ vcsim_instance.json.password }}"
|
||||||
|
validate_certs: no
|
||||||
|
esxi_hostname: test_host_system_0001
|
||||||
|
esxi_username: "{{ vcsim_instance.json.username }}"
|
||||||
|
esxi_password: "{{ vcsim_instance.json.password }}"
|
||||||
|
datacenter_name: "{{ dc1 }}"
|
||||||
|
cluster_name: "{{ ccr1 }}"
|
||||||
|
state: present
|
||||||
|
register: host_system_result_0001
|
||||||
|
|
||||||
|
- name: get a list of host system from vcsim after adding host system
|
||||||
|
uri:
|
||||||
|
url: http://{{ vcsim }}:5000/govc_find?filter=H
|
||||||
|
register: new_host_list
|
||||||
|
|
||||||
|
- set_fact:
|
||||||
|
new_host: "{% for host in new_host_list.json %} {{ True if (host | basename) == 'test_host_system_0001' else False }} {% endfor %}"
|
||||||
|
|
||||||
|
- name: ensure host system is present
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- host_system_result_0001.changed == true
|
||||||
|
- "'True' in new_host"
|
||||||
|
|
||||||
|
# Testcase 0002: Add Host again
|
||||||
|
- name: add host again
|
||||||
|
vmware_host:
|
||||||
|
hostname: "{{ vcsim }}"
|
||||||
|
username: "{{ vcsim_instance.json.username }}"
|
||||||
|
password: "{{ vcsim_instance.json.password }}"
|
||||||
|
validate_certs: no
|
||||||
|
esxi_hostname: test_host_system_0001
|
||||||
|
esxi_username: "{{ vcsim_instance.json.username }}"
|
||||||
|
esxi_password: "{{ vcsim_instance.json.password }}"
|
||||||
|
datacenter_name: "{{ dc1 }}"
|
||||||
|
cluster_name: "{{ ccr1 }}"
|
||||||
|
state: present
|
||||||
|
register: host_system_result_0002
|
||||||
|
|
||||||
|
- name: ensure host system is present
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- host_system_result_0002.changed == false
|
Loading…
Add table
Reference in a new issue