1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00

[GCE] Invalid zone reported through fail_json

* added new helper function for zones and regions.
* modified GCE module to use it

Fixes: ansible/ansible#20616
This commit is contained in:
Tom Melendez 2017-03-18 03:18:04 +00:00 committed by Brian Coca
parent cdb4d350b4
commit 1c38cba7ca
2 changed files with 27 additions and 12 deletions

View file

@ -400,3 +400,16 @@ def check_min_pkg_version(pkg_name, minimum_version):
def unexpected_error_msg(error): def unexpected_error_msg(error):
"""Create an error string based on passed in error.""" """Create an error string based on passed in error."""
return 'Unexpected response: (%s). Detail: %s' % (str(error), traceback.format_exc()) return 'Unexpected response: (%s). Detail: %s' % (str(error), traceback.format_exc())
def get_valid_location(module, driver, location, location_type='zone'):
if location_type == 'zone':
l = driver.ex_get_zone(location)
else:
l = driver.ex_get_region(location)
if l is None:
link = 'https://cloud.google.com/compute/docs/regions-zones/regions-zones#available'
module.fail_json(msg=('%s %s is invalid. Please see the list of '
'available %s at %s' % (
location_type, location, location_type, link)),
changed=False)
return l

View file

@ -144,7 +144,7 @@ options:
default: null default: null
zone: zone:
description: description:
- the GCE zone to use - the GCE zone to use. The list of available zones is at U(https://cloud.google.com/compute/docs/regions-zones/regions-zones#available).
required: true required: true
default: "us-central1-a" default: "us-central1-a"
ip_forward: ip_forward:
@ -367,13 +367,15 @@ def get_instance_info(inst):
}) })
def create_instances(module, gce, instance_names, number): def create_instances(module, gce, instance_names, number, lc_zone):
"""Creates new instances. Attributes other than instance_names are picked """Creates new instances. Attributes other than instance_names are picked
up from 'module' up from 'module'
module : AnsibleModule object module : AnsibleModule object
gce: authenticated GCE libcloud driver gce: authenticated GCE libcloud driver
instance_names: python list of instance names to create instance_names: python list of instance names to create
number: number of instances to create
lc_zone: GCEZone object
Returns: Returns:
A list of dictionaries with instance information A list of dictionaries with instance information
@ -389,7 +391,6 @@ def create_instances(module, gce, instance_names, number):
disks = module.params.get('disks') disks = module.params.get('disks')
state = module.params.get('state') state = module.params.get('state')
tags = module.params.get('tags') tags = module.params.get('tags')
zone = module.params.get('zone')
ip_forward = module.params.get('ip_forward') ip_forward = module.params.get('ip_forward')
external_ip = module.params.get('external_ip') external_ip = module.params.get('external_ip')
disk_auto_delete = module.params.get('disk_auto_delete') disk_auto_delete = module.params.get('disk_auto_delete')
@ -421,15 +422,14 @@ def create_instances(module, gce, instance_names, number):
disk_modes = [] disk_modes = []
for i, disk in enumerate(disks or []): for i, disk in enumerate(disks or []):
if isinstance(disk, dict): if isinstance(disk, dict):
lc_disks.append(gce.ex_get_volume(disk['name'])) lc_disks.append(gce.ex_get_volume(disk['name'], lc_zone))
disk_modes.append(disk['mode']) disk_modes.append(disk['mode'])
else: else:
lc_disks.append(gce.ex_get_volume(disk)) lc_disks.append(gce.ex_get_volume(disk, lc_zone))
# boot disk is implicitly READ_WRITE # boot disk is implicitly READ_WRITE
disk_modes.append('READ_ONLY' if i > 0 else 'READ_WRITE') disk_modes.append('READ_ONLY' if i > 0 else 'READ_WRITE')
lc_network = gce.ex_get_network(network) lc_network = gce.ex_get_network(network)
lc_machine_type = gce.ex_get_size(machine_type) lc_machine_type = gce.ex_get_size(machine_type, lc_zone)
lc_zone = gce.ex_get_zone(zone)
# Try to convert the user's metadata value into the format expected # Try to convert the user's metadata value into the format expected
# by GCE. First try to ensure user has proper quoting of a # by GCE. First try to ensure user has proper quoting of a
@ -562,14 +562,14 @@ def create_instances(module, gce, instance_names, number):
return (changed, instance_json_data, instance_names) return (changed, instance_json_data, instance_names)
def change_instance_state(module, gce, instance_names, number, zone_name, state): def change_instance_state(module, gce, instance_names, number, zone, state):
"""Changes the state of a list of instances. For example, """Changes the state of a list of instances. For example,
change from started to stopped, or started to absent. change from started to stopped, or started to absent.
module: Ansible module object module: Ansible module object
gce: authenticated GCE connection object gce: authenticated GCE connection object
instance_names: a list of instance names to terminate instance_names: a list of instance names to terminate
zone_name: the zone where the instances reside prior to termination zone: GCEZone object where the instances reside prior to termination
state: 'state' parameter passed into module as argument state: 'state' parameter passed into module as argument
Returns a dictionary of instance names that were changed. Returns a dictionary of instance names that were changed.
@ -589,7 +589,7 @@ def change_instance_state(module, gce, instance_names, number, zone_name, state)
for name in node_names: for name in node_names:
inst = None inst = None
try: try:
inst = gce.ex_get_node(name, zone_name) inst = gce.ex_get_node(name, zone)
except ResourceNotFoundError: except ResourceNotFoundError:
state_instance_names.append(name) state_instance_names.append(name)
except Exception as e: except Exception as e:
@ -685,6 +685,7 @@ def main():
if not zone: if not zone:
module.fail_json(msg='Must specify a "zone"', changed=False) module.fail_json(msg='Must specify a "zone"', changed=False)
lc_zone = get_valid_location(module, gce, zone)
if preemptible is not None and hasattr(libcloud, '__version__') and libcloud.__version__ < '0.20': if preemptible is not None and hasattr(libcloud, '__version__') and libcloud.__version__ < '0.20':
module.fail_json(msg="Apache Libcloud 0.20.0+ is required to use 'preemptible' option", module.fail_json(msg="Apache Libcloud 0.20.0+ is required to use 'preemptible' option",
changed=False) changed=False)
@ -697,7 +698,7 @@ def main():
if state in ['absent', 'deleted', 'started', 'stopped', 'terminated']: if state in ['absent', 'deleted', 'started', 'stopped', 'terminated']:
json_output['state'] = state json_output['state'] = state
(changed, state_instance_names) = change_instance_state( (changed, state_instance_names) = change_instance_state(
module, gce, inames, number, zone, state) module, gce, inames, number, lc_zone, state)
# based on what user specified, return the same variable, although # based on what user specified, return the same variable, although
# value could be different if an instance could not be destroyed # value could be different if an instance could not be destroyed
@ -709,7 +710,7 @@ def main():
elif state in ['active', 'present']: elif state in ['active', 'present']:
json_output['state'] = 'present' json_output['state'] = 'present'
(changed, instance_data, instance_name_list) = create_instances( (changed, instance_data, instance_name_list) = create_instances(
module, gce, inames, number) module, gce, inames, number, lc_zone)
json_output['instance_data'] = instance_data json_output['instance_data'] = instance_data
if instance_names: if instance_names:
json_output['instance_names'] = instance_name_list json_output['instance_names'] = instance_name_list
@ -746,5 +747,6 @@ class LazyDiskImage:
# import module snippets # import module snippets
from ansible.module_utils.basic import * from ansible.module_utils.basic import *
from ansible.module_utils.gce import * from ansible.module_utils.gce import *
from ansible.module_utils.gcp import get_valid_location
if __name__ == '__main__': if __name__ == '__main__':
main() main()