mirror of
				https://github.com/ansible-collections/google.cloud.git
				synced 2025-10-26 05:50:44 -07:00 
			
		
		
		
	Ansible Autoscaler (#321)
Signed-off-by: Modular Magician <magic-modules@google.com>
This commit is contained in:
		
					parent
					
						
							
								bafbed933b
							
						
					
				
			
			
				commit
				
					
						24e74655f3
					
				
			
		
					 6 changed files with 1262 additions and 0 deletions
				
			
		
							
								
								
									
										722
									
								
								plugins/modules/gcp_compute_autoscaler.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										722
									
								
								plugins/modules/gcp_compute_autoscaler.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,722 @@ | |||
| #!/usr/bin/python | ||||
| # -*- coding: utf-8 -*- | ||||
| # | ||||
| # Copyright (C) 2017 Google | ||||
| # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) | ||||
| # ---------------------------------------------------------------------------- | ||||
| # | ||||
| #     ***     AUTO GENERATED CODE    ***    AUTO GENERATED CODE     *** | ||||
| # | ||||
| # ---------------------------------------------------------------------------- | ||||
| # | ||||
| #     This file is automatically generated by Magic Modules and manual | ||||
| #     changes will be clobbered when the file is regenerated. | ||||
| # | ||||
| #     Please read more about how to change this file at | ||||
| #     https://www.github.com/GoogleCloudPlatform/magic-modules | ||||
| # | ||||
| # ---------------------------------------------------------------------------- | ||||
| 
 | ||||
| from __future__ import absolute_import, division, print_function | ||||
| 
 | ||||
| __metaclass__ = type | ||||
| 
 | ||||
| ################################################################################ | ||||
| # Documentation | ||||
| ################################################################################ | ||||
| 
 | ||||
| ANSIBLE_METADATA = {'metadata_version': '1.1', 'status': ["preview"], 'supported_by': 'community'} | ||||
| 
 | ||||
| DOCUMENTATION = ''' | ||||
| --- | ||||
| module: gcp_compute_autoscaler | ||||
| description: | ||||
| - Represents an Autoscaler resource. | ||||
| - Autoscalers allow you to automatically scale virtual machine instances in managed | ||||
|   instance groups according to an autoscaling policy that you define. | ||||
| short_description: Creates a GCP Autoscaler | ||||
| version_added: 2.9 | ||||
| author: Google Inc. (@googlecloudplatform) | ||||
| requirements: | ||||
| - python >= 2.6 | ||||
| - requests >= 2.18.4 | ||||
| - google-auth >= 1.3.0 | ||||
| options: | ||||
|   state: | ||||
|     description: | ||||
|     - Whether the given object should exist in GCP | ||||
|     choices: | ||||
|     - present | ||||
|     - absent | ||||
|     default: present | ||||
|     type: str | ||||
|   name: | ||||
|     description: | ||||
|     - Name of the resource. The name must be 1-63 characters long and match the regular | ||||
|       expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must | ||||
|       be a lowercase letter, and all following characters must be a dash, lowercase | ||||
|       letter, or digit, except the last character, which cannot be a dash. | ||||
|     required: true | ||||
|     type: str | ||||
|   description: | ||||
|     description: | ||||
|     - An optional description of this resource. | ||||
|     required: false | ||||
|     type: str | ||||
|   autoscaling_policy: | ||||
|     description: | ||||
|     - 'The configuration parameters for the autoscaling algorithm. You can define | ||||
|       one or more of the policies for an autoscaler: cpuUtilization, customMetricUtilizations, | ||||
|       and loadBalancingUtilization.' | ||||
|     - If none of these are specified, the default will be to autoscale based on cpuUtilization | ||||
|       to 0.6 or 60%. | ||||
|     required: true | ||||
|     type: dict | ||||
|     suboptions: | ||||
|       min_num_replicas: | ||||
|         description: | ||||
|         - The minimum number of replicas that the autoscaler can scale down to. This | ||||
|           cannot be less than 0. If not provided, autoscaler will choose a default | ||||
|           value depending on maximum number of instances allowed. | ||||
|         required: false | ||||
|         type: int | ||||
|         aliases: | ||||
|         - minReplicas | ||||
|       max_num_replicas: | ||||
|         description: | ||||
|         - The maximum number of instances that the autoscaler can scale up to. This | ||||
|           is required when creating or updating an autoscaler. The maximum number | ||||
|           of replicas should not be lower than minimal number of replicas. | ||||
|         required: true | ||||
|         type: int | ||||
|         aliases: | ||||
|         - maxReplicas | ||||
|       cool_down_period_sec: | ||||
|         description: | ||||
|         - The number of seconds that the autoscaler should wait before it starts collecting | ||||
|           information from a new instance. This prevents the autoscaler from collecting | ||||
|           information when the instance is initializing, during which the collected | ||||
|           usage would not be reliable. The default time autoscaler waits is 60 seconds. | ||||
|         - Virtual machine initialization times might vary because of numerous factors. | ||||
|           We recommend that you test how long an instance may take to initialize. | ||||
|           To do this, create an instance and time the startup process. | ||||
|         required: false | ||||
|         default: '60' | ||||
|         type: int | ||||
|         aliases: | ||||
|         - cooldownPeriod | ||||
|       cpu_utilization: | ||||
|         description: | ||||
|         - Defines the CPU utilization policy that allows the autoscaler to scale based | ||||
|           on the average CPU utilization of a managed instance group. | ||||
|         required: false | ||||
|         type: dict | ||||
|         suboptions: | ||||
|           utilization_target: | ||||
|             description: | ||||
|             - The target CPU utilization that the autoscaler should maintain. | ||||
|             - Must be a float value in the range (0, 1]. If not specified, the default | ||||
|               is 0.6. | ||||
|             - If the CPU level is below the target utilization, the autoscaler scales | ||||
|               down the number of instances until it reaches the minimum number of | ||||
|               instances you specified or until the average CPU of your instances reaches | ||||
|               the target utilization. | ||||
|             - If the average CPU is above the target utilization, the autoscaler scales | ||||
|               up until it reaches the maximum number of instances you specified or | ||||
|               until the average utilization reaches the target utilization. | ||||
|             required: false | ||||
|             type: str | ||||
|             aliases: | ||||
|             - target | ||||
|       custom_metric_utilizations: | ||||
|         description: | ||||
|         - Defines the CPU utilization policy that allows the autoscaler to scale based | ||||
|           on the average CPU utilization of a managed instance group. | ||||
|         required: false | ||||
|         type: list | ||||
|         aliases: | ||||
|         - metric | ||||
|         suboptions: | ||||
|           metric: | ||||
|             description: | ||||
|             - The identifier (type) of the Stackdriver Monitoring metric. | ||||
|             - The metric cannot have negative values. | ||||
|             - The metric must have a value type of INT64 or DOUBLE. | ||||
|             required: true | ||||
|             type: str | ||||
|             aliases: | ||||
|             - name | ||||
|           utilization_target: | ||||
|             description: | ||||
|             - The target value of the metric that autoscaler should maintain. This | ||||
|               must be a positive value. A utilization metric scales number of virtual | ||||
|               machines handling requests to increase or decrease proportionally to | ||||
|               the metric. | ||||
|             - For example, a good metric to use as a utilizationTarget is U(www.googleapis.com/compute/instance/network/received_bytes_count). | ||||
|             - The autoscaler will work to keep this value constant for each of the | ||||
|               instances. | ||||
|             required: false | ||||
|             type: str | ||||
|             aliases: | ||||
|             - target | ||||
|           utilization_target_type: | ||||
|             description: | ||||
|             - Defines how target utilization value is expressed for a Stackdriver | ||||
|               Monitoring metric. Either GAUGE, DELTA_PER_SECOND, or DELTA_PER_MINUTE. | ||||
|             - 'Some valid choices include: "GAUGE", "DELTA_PER_SECOND", "DELTA_PER_MINUTE"' | ||||
|             required: false | ||||
|             type: str | ||||
|             aliases: | ||||
|             - type | ||||
|       load_balancing_utilization: | ||||
|         description: | ||||
|         - Configuration parameters of autoscaling based on a load balancer. | ||||
|         required: false | ||||
|         type: dict | ||||
|         suboptions: | ||||
|           utilization_target: | ||||
|             description: | ||||
|             - Fraction of backend capacity utilization (set in HTTP(s) load balancing | ||||
|               configuration) that autoscaler should maintain. Must be a positive float | ||||
|               value. If not defined, the default is 0.8. | ||||
|             required: false | ||||
|             type: str | ||||
|             aliases: | ||||
|             - target | ||||
|   target: | ||||
|     description: | ||||
|     - URL of the managed instance group that this autoscaler will scale. | ||||
|     - 'This field represents a link to a InstanceGroupManager resource in GCP. It | ||||
|       can be specified in two ways. First, you can place a dictionary with key ''selfLink'' | ||||
|       and value of your resource''s selfLink Alternatively, you can add `register: | ||||
|       name-of-resource` to a gcp_compute_instance_group_manager task and then set | ||||
|       this target field to "{{ name-of-resource }}"' | ||||
|     required: true | ||||
|     type: dict | ||||
|   zone: | ||||
|     description: | ||||
|     - URL of the zone where the instance group resides. | ||||
|     required: true | ||||
|     type: str | ||||
| extends_documentation_fragment: gcp | ||||
| notes: | ||||
| - 'API Reference: U(https://cloud.google.com/compute/docs/reference/rest/v1/autoscalers)' | ||||
| - 'Autoscaling Groups of Instances: U(https://cloud.google.com/compute/docs/autoscaler/)' | ||||
| ''' | ||||
| 
 | ||||
| EXAMPLES = ''' | ||||
| - name: create a network | ||||
|   gcp_compute_network: | ||||
|     name: network-instancetemplate | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: network | ||||
| 
 | ||||
| - name: create a address | ||||
|   gcp_compute_address: | ||||
|     name: address-instancetemplate | ||||
|     region: us-central1 | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: address | ||||
| 
 | ||||
| - name: create a instance template | ||||
|   gcp_compute_instance_template: | ||||
|     name: "{{ resource_name }}" | ||||
|     properties: | ||||
|       disks: | ||||
|       - auto_delete: 'true' | ||||
|         boot: 'true' | ||||
|         initialize_params: | ||||
|           source_image: projects/ubuntu-os-cloud/global/images/family/ubuntu-1604-lts | ||||
|       machine_type: n1-standard-1 | ||||
|       network_interfaces: | ||||
|       - network: "{{ network }}" | ||||
|         access_configs: | ||||
|         - name: test-config | ||||
|           type: ONE_TO_ONE_NAT | ||||
|           nat_ip: "{{ address }}" | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: instancetemplate | ||||
| 
 | ||||
| - name: create a instance group manager | ||||
|   gcp_compute_instance_group_manager: | ||||
|     name: "{{ resource_name }}" | ||||
|     base_instance_name: test1-child | ||||
|     instance_template: "{{ instancetemplate }}" | ||||
|     target_size: 3 | ||||
|     zone: us-central1-a | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: igm | ||||
| 
 | ||||
| - name: create a autoscaler | ||||
|   gcp_compute_autoscaler: | ||||
|     name: test_object | ||||
|     zone: us-central1-a | ||||
|     target: "{{ igm }}" | ||||
|     autoscaling_policy: | ||||
|       max_num_replicas: 5 | ||||
|       min_num_replicas: 1 | ||||
|       cool_down_period_sec: 60 | ||||
|       cpu_utilization: | ||||
|         utilization_target: 0.5 | ||||
|     project: test_project | ||||
|     auth_kind: serviceaccount | ||||
|     service_account_file: "/tmp/auth.pem" | ||||
|     state: present | ||||
| ''' | ||||
| 
 | ||||
| RETURN = ''' | ||||
| id: | ||||
|   description: | ||||
|   - Unique identifier for the resource. | ||||
|   returned: success | ||||
|   type: int | ||||
| creationTimestamp: | ||||
|   description: | ||||
|   - Creation timestamp in RFC3339 text format. | ||||
|   returned: success | ||||
|   type: str | ||||
| name: | ||||
|   description: | ||||
|   - Name of the resource. The name must be 1-63 characters long and match the regular | ||||
|     expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character must be | ||||
|     a lowercase letter, and all following characters must be a dash, lowercase letter, | ||||
|     or digit, except the last character, which cannot be a dash. | ||||
|   returned: success | ||||
|   type: str | ||||
| description: | ||||
|   description: | ||||
|   - An optional description of this resource. | ||||
|   returned: success | ||||
|   type: str | ||||
| autoscalingPolicy: | ||||
|   description: | ||||
|   - 'The configuration parameters for the autoscaling algorithm. You can define one | ||||
|     or more of the policies for an autoscaler: cpuUtilization, customMetricUtilizations, | ||||
|     and loadBalancingUtilization.' | ||||
|   - If none of these are specified, the default will be to autoscale based on cpuUtilization | ||||
|     to 0.6 or 60%. | ||||
|   returned: success | ||||
|   type: complex | ||||
|   contains: | ||||
|     minNumReplicas: | ||||
|       description: | ||||
|       - The minimum number of replicas that the autoscaler can scale down to. This | ||||
|         cannot be less than 0. If not provided, autoscaler will choose a default value | ||||
|         depending on maximum number of instances allowed. | ||||
|       returned: success | ||||
|       type: int | ||||
|     maxNumReplicas: | ||||
|       description: | ||||
|       - The maximum number of instances that the autoscaler can scale up to. This | ||||
|         is required when creating or updating an autoscaler. The maximum number of | ||||
|         replicas should not be lower than minimal number of replicas. | ||||
|       returned: success | ||||
|       type: int | ||||
|     coolDownPeriodSec: | ||||
|       description: | ||||
|       - The number of seconds that the autoscaler should wait before it starts collecting | ||||
|         information from a new instance. This prevents the autoscaler from collecting | ||||
|         information when the instance is initializing, during which the collected | ||||
|         usage would not be reliable. The default time autoscaler waits is 60 seconds. | ||||
|       - Virtual machine initialization times might vary because of numerous factors. | ||||
|         We recommend that you test how long an instance may take to initialize. To | ||||
|         do this, create an instance and time the startup process. | ||||
|       returned: success | ||||
|       type: int | ||||
|     cpuUtilization: | ||||
|       description: | ||||
|       - Defines the CPU utilization policy that allows the autoscaler to scale based | ||||
|         on the average CPU utilization of a managed instance group. | ||||
|       returned: success | ||||
|       type: complex | ||||
|       contains: | ||||
|         utilizationTarget: | ||||
|           description: | ||||
|           - The target CPU utilization that the autoscaler should maintain. | ||||
|           - Must be a float value in the range (0, 1]. If not specified, the default | ||||
|             is 0.6. | ||||
|           - If the CPU level is below the target utilization, the autoscaler scales | ||||
|             down the number of instances until it reaches the minimum number of instances | ||||
|             you specified or until the average CPU of your instances reaches the target | ||||
|             utilization. | ||||
|           - If the average CPU is above the target utilization, the autoscaler scales | ||||
|             up until it reaches the maximum number of instances you specified or until | ||||
|             the average utilization reaches the target utilization. | ||||
|           returned: success | ||||
|           type: str | ||||
|     customMetricUtilizations: | ||||
|       description: | ||||
|       - Defines the CPU utilization policy that allows the autoscaler to scale based | ||||
|         on the average CPU utilization of a managed instance group. | ||||
|       returned: success | ||||
|       type: complex | ||||
|       contains: | ||||
|         metric: | ||||
|           description: | ||||
|           - The identifier (type) of the Stackdriver Monitoring metric. | ||||
|           - The metric cannot have negative values. | ||||
|           - The metric must have a value type of INT64 or DOUBLE. | ||||
|           returned: success | ||||
|           type: str | ||||
|         utilizationTarget: | ||||
|           description: | ||||
|           - The target value of the metric that autoscaler should maintain. This must | ||||
|             be a positive value. A utilization metric scales number of virtual machines | ||||
|             handling requests to increase or decrease proportionally to the metric. | ||||
|           - For example, a good metric to use as a utilizationTarget is U(www.googleapis.com/compute/instance/network/received_bytes_count). | ||||
|           - The autoscaler will work to keep this value constant for each of the instances. | ||||
|           returned: success | ||||
|           type: str | ||||
|         utilizationTargetType: | ||||
|           description: | ||||
|           - Defines how target utilization value is expressed for a Stackdriver Monitoring | ||||
|             metric. Either GAUGE, DELTA_PER_SECOND, or DELTA_PER_MINUTE. | ||||
|           returned: success | ||||
|           type: str | ||||
|     loadBalancingUtilization: | ||||
|       description: | ||||
|       - Configuration parameters of autoscaling based on a load balancer. | ||||
|       returned: success | ||||
|       type: complex | ||||
|       contains: | ||||
|         utilizationTarget: | ||||
|           description: | ||||
|           - Fraction of backend capacity utilization (set in HTTP(s) load balancing | ||||
|             configuration) that autoscaler should maintain. Must be a positive float | ||||
|             value. If not defined, the default is 0.8. | ||||
|           returned: success | ||||
|           type: str | ||||
| target: | ||||
|   description: | ||||
|   - URL of the managed instance group that this autoscaler will scale. | ||||
|   returned: success | ||||
|   type: dict | ||||
| zone: | ||||
|   description: | ||||
|   - URL of the zone where the instance group resides. | ||||
|   returned: success | ||||
|   type: str | ||||
| ''' | ||||
| 
 | ||||
| ################################################################################ | ||||
| # Imports | ||||
| ################################################################################ | ||||
| 
 | ||||
| from ansible.module_utils.gcp_utils import navigate_hash, GcpSession, GcpModule, GcpRequest, remove_nones_from_dict, replace_resource_dict | ||||
| import json | ||||
| import time | ||||
| 
 | ||||
| ################################################################################ | ||||
| # Main | ||||
| ################################################################################ | ||||
| 
 | ||||
| 
 | ||||
| def main(): | ||||
|     """Main function""" | ||||
| 
 | ||||
|     module = GcpModule( | ||||
|         argument_spec=dict( | ||||
|             state=dict(default='present', choices=['present', 'absent'], type='str'), | ||||
|             name=dict(required=True, type='str'), | ||||
|             description=dict(type='str'), | ||||
|             autoscaling_policy=dict( | ||||
|                 required=True, | ||||
|                 type='dict', | ||||
|                 options=dict( | ||||
|                     min_num_replicas=dict(type='int', aliases=['minReplicas']), | ||||
|                     max_num_replicas=dict(required=True, type='int', aliases=['maxReplicas']), | ||||
|                     cool_down_period_sec=dict(default=60, type='int', aliases=['cooldownPeriod']), | ||||
|                     cpu_utilization=dict(type='dict', options=dict(utilization_target=dict(type='str', aliases=['target']))), | ||||
|                     custom_metric_utilizations=dict( | ||||
|                         type='list', | ||||
|                         elements='dict', | ||||
|                         aliases=['metric'], | ||||
|                         options=dict( | ||||
|                             metric=dict(required=True, type='str', aliases=['name']), | ||||
|                             utilization_target=dict(type='str', aliases=['target']), | ||||
|                             utilization_target_type=dict(type='str', aliases=['type']), | ||||
|                         ), | ||||
|                     ), | ||||
|                     load_balancing_utilization=dict(type='dict', options=dict(utilization_target=dict(type='str', aliases=['target']))), | ||||
|                 ), | ||||
|             ), | ||||
|             target=dict(required=True, type='dict'), | ||||
|             zone=dict(required=True, type='str'), | ||||
|         ) | ||||
|     ) | ||||
| 
 | ||||
|     if not module.params['scopes']: | ||||
|         module.params['scopes'] = ['https://www.googleapis.com/auth/compute'] | ||||
| 
 | ||||
|     state = module.params['state'] | ||||
|     kind = 'compute#autoscaler' | ||||
| 
 | ||||
|     fetch = fetch_resource(module, self_link(module), kind) | ||||
|     changed = False | ||||
| 
 | ||||
|     if fetch: | ||||
|         if state == 'present': | ||||
|             if is_different(module, fetch): | ||||
|                 update(module, self_link(module), kind) | ||||
|                 fetch = fetch_resource(module, self_link(module), kind) | ||||
|                 changed = True | ||||
|         else: | ||||
|             delete(module, self_link(module), kind) | ||||
|             fetch = {} | ||||
|             changed = True | ||||
|     else: | ||||
|         if state == 'present': | ||||
|             fetch = create(module, collection(module), kind) | ||||
|             changed = True | ||||
|         else: | ||||
|             fetch = {} | ||||
| 
 | ||||
|     fetch.update({'changed': changed}) | ||||
| 
 | ||||
|     module.exit_json(**fetch) | ||||
| 
 | ||||
| 
 | ||||
| def create(module, link, kind): | ||||
|     auth = GcpSession(module, 'compute') | ||||
|     return wait_for_operation(module, auth.post(link, resource_to_request(module))) | ||||
| 
 | ||||
| 
 | ||||
| def update(module, link, kind): | ||||
|     auth = GcpSession(module, 'compute') | ||||
|     return wait_for_operation(module, auth.put(link, resource_to_request(module))) | ||||
| 
 | ||||
| 
 | ||||
| def delete(module, link, kind): | ||||
|     auth = GcpSession(module, 'compute') | ||||
|     return wait_for_operation(module, auth.delete(link)) | ||||
| 
 | ||||
| 
 | ||||
| def resource_to_request(module): | ||||
|     request = { | ||||
|         u'kind': 'compute#autoscaler', | ||||
|         u'zone': module.params.get('zone'), | ||||
|         u'name': module.params.get('name'), | ||||
|         u'description': module.params.get('description'), | ||||
|         u'autoscalingPolicy': AutoscalerAutoscalingpolicy(module.params.get('autoscaling_policy', {}), module).to_request(), | ||||
|         u'target': replace_resource_dict(module.params.get(u'target', {}), 'selfLink'), | ||||
|     } | ||||
|     return_vals = {} | ||||
|     for k, v in request.items(): | ||||
|         if v or v is False: | ||||
|             return_vals[k] = v | ||||
| 
 | ||||
|     return return_vals | ||||
| 
 | ||||
| 
 | ||||
| def fetch_resource(module, link, kind, allow_not_found=True): | ||||
|     auth = GcpSession(module, 'compute') | ||||
|     return return_if_object(module, auth.get(link), kind, allow_not_found) | ||||
| 
 | ||||
| 
 | ||||
| def self_link(module): | ||||
|     return "https://www.googleapis.com/compute/v1/projects/{project}/zones/{zone}/autoscalers/{name}".format(**module.params) | ||||
| 
 | ||||
| 
 | ||||
| def collection(module): | ||||
|     return "https://www.googleapis.com/compute/v1/projects/{project}/zones/{zone}/autoscalers".format(**module.params) | ||||
| 
 | ||||
| 
 | ||||
| def return_if_object(module, response, kind, allow_not_found=False): | ||||
|     # If not found, return nothing. | ||||
|     if allow_not_found and response.status_code == 404: | ||||
|         return None | ||||
| 
 | ||||
|     # If no content, return nothing. | ||||
|     if response.status_code == 204: | ||||
|         return None | ||||
| 
 | ||||
|     try: | ||||
|         module.raise_for_status(response) | ||||
|         result = response.json() | ||||
|     except getattr(json.decoder, 'JSONDecodeError', ValueError): | ||||
|         module.fail_json(msg="Invalid JSON response with error: %s" % response.text) | ||||
| 
 | ||||
|     if navigate_hash(result, ['error', 'errors']): | ||||
|         module.fail_json(msg=navigate_hash(result, ['error', 'errors'])) | ||||
| 
 | ||||
|     return result | ||||
| 
 | ||||
| 
 | ||||
| def is_different(module, response): | ||||
|     request = resource_to_request(module) | ||||
|     response = response_to_hash(module, response) | ||||
| 
 | ||||
|     # Remove all output-only from response. | ||||
|     response_vals = {} | ||||
|     for k, v in response.items(): | ||||
|         if k in request: | ||||
|             response_vals[k] = v | ||||
| 
 | ||||
|     request_vals = {} | ||||
|     for k, v in request.items(): | ||||
|         if k in response: | ||||
|             request_vals[k] = v | ||||
| 
 | ||||
|     return GcpRequest(request_vals) != GcpRequest(response_vals) | ||||
| 
 | ||||
| 
 | ||||
| # Remove unnecessary properties from the response. | ||||
| # This is for doing comparisons with Ansible's current parameters. | ||||
| def response_to_hash(module, response): | ||||
|     return { | ||||
|         u'id': response.get(u'id'), | ||||
|         u'creationTimestamp': response.get(u'creationTimestamp'), | ||||
|         u'name': module.params.get('name'), | ||||
|         u'description': response.get(u'description'), | ||||
|         u'autoscalingPolicy': AutoscalerAutoscalingpolicy(response.get(u'autoscalingPolicy', {}), module).from_response(), | ||||
|         u'target': response.get(u'target'), | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
| def async_op_url(module, extra_data=None): | ||||
|     if extra_data is None: | ||||
|         extra_data = {} | ||||
|     url = "https://www.googleapis.com/compute/v1/projects/{project}/zones/{zone}/operations/{op_id}" | ||||
|     combined = extra_data.copy() | ||||
|     combined.update(module.params) | ||||
|     return url.format(**combined) | ||||
| 
 | ||||
| 
 | ||||
| def wait_for_operation(module, response): | ||||
|     op_result = return_if_object(module, response, 'compute#operation') | ||||
|     if op_result is None: | ||||
|         return {} | ||||
|     status = navigate_hash(op_result, ['status']) | ||||
|     wait_done = wait_for_completion(status, op_result, module) | ||||
|     return fetch_resource(module, navigate_hash(wait_done, ['targetLink']), 'compute#autoscaler') | ||||
| 
 | ||||
| 
 | ||||
| def wait_for_completion(status, op_result, module): | ||||
|     op_id = navigate_hash(op_result, ['name']) | ||||
|     op_uri = async_op_url(module, {'op_id': op_id}) | ||||
|     while status != 'DONE': | ||||
|         raise_if_errors(op_result, ['error', 'errors'], module) | ||||
|         time.sleep(1.0) | ||||
|         op_result = fetch_resource(module, op_uri, 'compute#operation', False) | ||||
|         status = navigate_hash(op_result, ['status']) | ||||
|     return op_result | ||||
| 
 | ||||
| 
 | ||||
| def raise_if_errors(response, err_path, module): | ||||
|     errors = navigate_hash(response, err_path) | ||||
|     if errors is not None: | ||||
|         module.fail_json(msg=errors) | ||||
| 
 | ||||
| 
 | ||||
| class AutoscalerAutoscalingpolicy(object): | ||||
|     def __init__(self, request, module): | ||||
|         self.module = module | ||||
|         if request: | ||||
|             self.request = request | ||||
|         else: | ||||
|             self.request = {} | ||||
| 
 | ||||
|     def to_request(self): | ||||
|         return remove_nones_from_dict( | ||||
|             { | ||||
|                 u'minNumReplicas': self.request.get('min_num_replicas'), | ||||
|                 u'maxNumReplicas': self.request.get('max_num_replicas'), | ||||
|                 u'coolDownPeriodSec': self.request.get('cool_down_period_sec'), | ||||
|                 u'cpuUtilization': AutoscalerCpuutilization(self.request.get('cpu_utilization', {}), self.module).to_request(), | ||||
|                 u'customMetricUtilizations': AutoscalerCustommetricutilizationsArray( | ||||
|                     self.request.get('custom_metric_utilizations', []), self.module | ||||
|                 ).to_request(), | ||||
|                 u'loadBalancingUtilization': AutoscalerLoadbalancingutilization(self.request.get('load_balancing_utilization', {}), self.module).to_request(), | ||||
|             } | ||||
|         ) | ||||
| 
 | ||||
|     def from_response(self): | ||||
|         return remove_nones_from_dict( | ||||
|             { | ||||
|                 u'minNumReplicas': self.request.get(u'minNumReplicas'), | ||||
|                 u'maxNumReplicas': self.request.get(u'maxNumReplicas'), | ||||
|                 u'coolDownPeriodSec': self.request.get(u'coolDownPeriodSec'), | ||||
|                 u'cpuUtilization': AutoscalerCpuutilization(self.request.get(u'cpuUtilization', {}), self.module).from_response(), | ||||
|                 u'customMetricUtilizations': AutoscalerCustommetricutilizationsArray( | ||||
|                     self.request.get(u'customMetricUtilizations', []), self.module | ||||
|                 ).from_response(), | ||||
|                 u'loadBalancingUtilization': AutoscalerLoadbalancingutilization(self.request.get(u'loadBalancingUtilization', {}), self.module).from_response(), | ||||
|             } | ||||
|         ) | ||||
| 
 | ||||
| 
 | ||||
| class AutoscalerCpuutilization(object): | ||||
|     def __init__(self, request, module): | ||||
|         self.module = module | ||||
|         if request: | ||||
|             self.request = request | ||||
|         else: | ||||
|             self.request = {} | ||||
| 
 | ||||
|     def to_request(self): | ||||
|         return remove_nones_from_dict({u'utilizationTarget': self.request.get('utilization_target')}) | ||||
| 
 | ||||
|     def from_response(self): | ||||
|         return remove_nones_from_dict({u'utilizationTarget': self.request.get(u'utilizationTarget')}) | ||||
| 
 | ||||
| 
 | ||||
| class AutoscalerCustommetricutilizationsArray(object): | ||||
|     def __init__(self, request, module): | ||||
|         self.module = module | ||||
|         if request: | ||||
|             self.request = request | ||||
|         else: | ||||
|             self.request = [] | ||||
| 
 | ||||
|     def to_request(self): | ||||
|         items = [] | ||||
|         for item in self.request: | ||||
|             items.append(self._request_for_item(item)) | ||||
|         return items | ||||
| 
 | ||||
|     def from_response(self): | ||||
|         items = [] | ||||
|         for item in self.request: | ||||
|             items.append(self._response_from_item(item)) | ||||
|         return items | ||||
| 
 | ||||
|     def _request_for_item(self, item): | ||||
|         return remove_nones_from_dict( | ||||
|             {u'metric': item.get('metric'), u'utilizationTarget': item.get('utilization_target'), u'utilizationTargetType': item.get('utilization_target_type')} | ||||
|         ) | ||||
| 
 | ||||
|     def _response_from_item(self, item): | ||||
|         return remove_nones_from_dict( | ||||
|             {u'metric': item.get(u'metric'), u'utilizationTarget': item.get(u'utilizationTarget'), u'utilizationTargetType': item.get(u'utilizationTargetType')} | ||||
|         ) | ||||
| 
 | ||||
| 
 | ||||
| class AutoscalerLoadbalancingutilization(object): | ||||
|     def __init__(self, request, module): | ||||
|         self.module = module | ||||
|         if request: | ||||
|             self.request = request | ||||
|         else: | ||||
|             self.request = {} | ||||
| 
 | ||||
|     def to_request(self): | ||||
|         return remove_nones_from_dict({u'utilizationTarget': self.request.get('utilization_target')}) | ||||
| 
 | ||||
|     def from_response(self): | ||||
|         return remove_nones_from_dict({u'utilizationTarget': self.request.get(u'utilizationTarget')}) | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == '__main__': | ||||
|     main() | ||||
							
								
								
									
										285
									
								
								plugins/modules/gcp_compute_autoscaler_facts.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										285
									
								
								plugins/modules/gcp_compute_autoscaler_facts.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,285 @@ | |||
| #!/usr/bin/python | ||||
| # -*- coding: utf-8 -*- | ||||
| # | ||||
| # Copyright (C) 2017 Google | ||||
| # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) | ||||
| # ---------------------------------------------------------------------------- | ||||
| # | ||||
| #     ***     AUTO GENERATED CODE    ***    AUTO GENERATED CODE     *** | ||||
| # | ||||
| # ---------------------------------------------------------------------------- | ||||
| # | ||||
| #     This file is automatically generated by Magic Modules and manual | ||||
| #     changes will be clobbered when the file is regenerated. | ||||
| # | ||||
| #     Please read more about how to change this file at | ||||
| #     https://www.github.com/GoogleCloudPlatform/magic-modules | ||||
| # | ||||
| # ---------------------------------------------------------------------------- | ||||
| 
 | ||||
| from __future__ import absolute_import, division, print_function | ||||
| 
 | ||||
| __metaclass__ = type | ||||
| 
 | ||||
| ################################################################################ | ||||
| # Documentation | ||||
| ################################################################################ | ||||
| 
 | ||||
| ANSIBLE_METADATA = {'metadata_version': '1.1', 'status': ["preview"], 'supported_by': 'community'} | ||||
| 
 | ||||
| DOCUMENTATION = ''' | ||||
| --- | ||||
| module: gcp_compute_autoscaler_facts | ||||
| description: | ||||
| - Gather facts for GCP Autoscaler | ||||
| short_description: Gather facts for GCP Autoscaler | ||||
| version_added: 2.9 | ||||
| author: Google Inc. (@googlecloudplatform) | ||||
| requirements: | ||||
| - python >= 2.6 | ||||
| - requests >= 2.18.4 | ||||
| - google-auth >= 1.3.0 | ||||
| options: | ||||
|   filters: | ||||
|     description: | ||||
|     - A list of filter value pairs. Available filters are listed here U(https://cloud.google.com/sdk/gcloud/reference/topic/filters). | ||||
|     - Each additional filter in the list will act be added as an AND condition (filter1 | ||||
|       and filter2) . | ||||
|   zone: | ||||
|     description: | ||||
|     - URL of the zone where the instance group resides. | ||||
|     required: true | ||||
|     type: str | ||||
| extends_documentation_fragment: gcp | ||||
| ''' | ||||
| 
 | ||||
| EXAMPLES = ''' | ||||
| - name: " a autoscaler facts" | ||||
|   gcp_compute_autoscaler_facts: | ||||
|     zone: us-central1-a | ||||
|     filters: | ||||
|     - name = test_object | ||||
|     project: test_project | ||||
|     auth_kind: serviceaccount | ||||
|     service_account_file: "/tmp/auth.pem" | ||||
| ''' | ||||
| 
 | ||||
| RETURN = ''' | ||||
| resources: | ||||
|   description: List of resources | ||||
|   returned: always | ||||
|   type: complex | ||||
|   contains: | ||||
|     id: | ||||
|       description: | ||||
|       - Unique identifier for the resource. | ||||
|       returned: success | ||||
|       type: int | ||||
|     creationTimestamp: | ||||
|       description: | ||||
|       - Creation timestamp in RFC3339 text format. | ||||
|       returned: success | ||||
|       type: str | ||||
|     name: | ||||
|       description: | ||||
|       - Name of the resource. The name must be 1-63 characters long and match the | ||||
|         regular expression `[a-z]([-a-z0-9]*[a-z0-9])?` which means the first character | ||||
|         must be a lowercase letter, and all following characters must be a dash, lowercase | ||||
|         letter, or digit, except the last character, which cannot be a dash. | ||||
|       returned: success | ||||
|       type: str | ||||
|     description: | ||||
|       description: | ||||
|       - An optional description of this resource. | ||||
|       returned: success | ||||
|       type: str | ||||
|     autoscalingPolicy: | ||||
|       description: | ||||
|       - 'The configuration parameters for the autoscaling algorithm. You can define | ||||
|         one or more of the policies for an autoscaler: cpuUtilization, customMetricUtilizations, | ||||
|         and loadBalancingUtilization.' | ||||
|       - If none of these are specified, the default will be to autoscale based on | ||||
|         cpuUtilization to 0.6 or 60%. | ||||
|       returned: success | ||||
|       type: complex | ||||
|       contains: | ||||
|         minNumReplicas: | ||||
|           description: | ||||
|           - The minimum number of replicas that the autoscaler can scale down to. | ||||
|             This cannot be less than 0. If not provided, autoscaler will choose a | ||||
|             default value depending on maximum number of instances allowed. | ||||
|           returned: success | ||||
|           type: int | ||||
|         maxNumReplicas: | ||||
|           description: | ||||
|           - The maximum number of instances that the autoscaler can scale up to. This | ||||
|             is required when creating or updating an autoscaler. The maximum number | ||||
|             of replicas should not be lower than minimal number of replicas. | ||||
|           returned: success | ||||
|           type: int | ||||
|         coolDownPeriodSec: | ||||
|           description: | ||||
|           - The number of seconds that the autoscaler should wait before it starts | ||||
|             collecting information from a new instance. This prevents the autoscaler | ||||
|             from collecting information when the instance is initializing, during | ||||
|             which the collected usage would not be reliable. The default time autoscaler | ||||
|             waits is 60 seconds. | ||||
|           - Virtual machine initialization times might vary because of numerous factors. | ||||
|             We recommend that you test how long an instance may take to initialize. | ||||
|             To do this, create an instance and time the startup process. | ||||
|           returned: success | ||||
|           type: int | ||||
|         cpuUtilization: | ||||
|           description: | ||||
|           - Defines the CPU utilization policy that allows the autoscaler to scale | ||||
|             based on the average CPU utilization of a managed instance group. | ||||
|           returned: success | ||||
|           type: complex | ||||
|           contains: | ||||
|             utilizationTarget: | ||||
|               description: | ||||
|               - The target CPU utilization that the autoscaler should maintain. | ||||
|               - Must be a float value in the range (0, 1]. If not specified, the default | ||||
|                 is 0.6. | ||||
|               - If the CPU level is below the target utilization, the autoscaler scales | ||||
|                 down the number of instances until it reaches the minimum number of | ||||
|                 instances you specified or until the average CPU of your instances | ||||
|                 reaches the target utilization. | ||||
|               - If the average CPU is above the target utilization, the autoscaler | ||||
|                 scales up until it reaches the maximum number of instances you specified | ||||
|                 or until the average utilization reaches the target utilization. | ||||
|               returned: success | ||||
|               type: str | ||||
|         customMetricUtilizations: | ||||
|           description: | ||||
|           - Defines the CPU utilization policy that allows the autoscaler to scale | ||||
|             based on the average CPU utilization of a managed instance group. | ||||
|           returned: success | ||||
|           type: complex | ||||
|           contains: | ||||
|             metric: | ||||
|               description: | ||||
|               - The identifier (type) of the Stackdriver Monitoring metric. | ||||
|               - The metric cannot have negative values. | ||||
|               - The metric must have a value type of INT64 or DOUBLE. | ||||
|               returned: success | ||||
|               type: str | ||||
|             utilizationTarget: | ||||
|               description: | ||||
|               - The target value of the metric that autoscaler should maintain. This | ||||
|                 must be a positive value. A utilization metric scales number of virtual | ||||
|                 machines handling requests to increase or decrease proportionally | ||||
|                 to the metric. | ||||
|               - For example, a good metric to use as a utilizationTarget is U(www.googleapis.com/compute/instance/network/received_bytes_count). | ||||
|               - The autoscaler will work to keep this value constant for each of the | ||||
|                 instances. | ||||
|               returned: success | ||||
|               type: str | ||||
|             utilizationTargetType: | ||||
|               description: | ||||
|               - Defines how target utilization value is expressed for a Stackdriver | ||||
|                 Monitoring metric. Either GAUGE, DELTA_PER_SECOND, or DELTA_PER_MINUTE. | ||||
|               returned: success | ||||
|               type: str | ||||
|         loadBalancingUtilization: | ||||
|           description: | ||||
|           - Configuration parameters of autoscaling based on a load balancer. | ||||
|           returned: success | ||||
|           type: complex | ||||
|           contains: | ||||
|             utilizationTarget: | ||||
|               description: | ||||
|               - Fraction of backend capacity utilization (set in HTTP(s) load balancing | ||||
|                 configuration) that autoscaler should maintain. Must be a positive | ||||
|                 float value. If not defined, the default is 0.8. | ||||
|               returned: success | ||||
|               type: str | ||||
|     target: | ||||
|       description: | ||||
|       - URL of the managed instance group that this autoscaler will scale. | ||||
|       returned: success | ||||
|       type: dict | ||||
|     zone: | ||||
|       description: | ||||
|       - URL of the zone where the instance group resides. | ||||
|       returned: success | ||||
|       type: str | ||||
| ''' | ||||
| 
 | ||||
| ################################################################################ | ||||
| # Imports | ||||
| ################################################################################ | ||||
| from ansible.module_utils.gcp_utils import navigate_hash, GcpSession, GcpModule, GcpRequest | ||||
| import json | ||||
| 
 | ||||
| ################################################################################ | ||||
| # Main | ||||
| ################################################################################ | ||||
| 
 | ||||
| 
 | ||||
| def main(): | ||||
|     module = GcpModule(argument_spec=dict(filters=dict(type='list', elements='str'), zone=dict(required=True, type='str'))) | ||||
| 
 | ||||
|     if not module.params['scopes']: | ||||
|         module.params['scopes'] = ['https://www.googleapis.com/auth/compute'] | ||||
| 
 | ||||
|     items = fetch_list(module, collection(module), query_options(module.params['filters'])) | ||||
|     if items.get('items'): | ||||
|         items = items.get('items') | ||||
|     else: | ||||
|         items = [] | ||||
|     return_value = {'resources': items} | ||||
|     module.exit_json(**return_value) | ||||
| 
 | ||||
| 
 | ||||
| def collection(module): | ||||
|     return "https://www.googleapis.com/compute/v1/projects/{project}/zones/{zone}/autoscalers".format(**module.params) | ||||
| 
 | ||||
| 
 | ||||
| def fetch_list(module, link, query): | ||||
|     auth = GcpSession(module, 'compute') | ||||
|     response = auth.get(link, params={'filter': query}) | ||||
|     return return_if_object(module, response) | ||||
| 
 | ||||
| 
 | ||||
| def query_options(filters): | ||||
|     if not filters: | ||||
|         return '' | ||||
| 
 | ||||
|     if len(filters) == 1: | ||||
|         return filters[0] | ||||
|     else: | ||||
|         queries = [] | ||||
|         for f in filters: | ||||
|             # For multiple queries, all queries should have () | ||||
|             if f[0] != '(' and f[-1] != ')': | ||||
|                 queries.append("(%s)" % ''.join(f)) | ||||
|             else: | ||||
|                 queries.append(f) | ||||
| 
 | ||||
|         return ' '.join(queries) | ||||
| 
 | ||||
| 
 | ||||
| def return_if_object(module, response): | ||||
|     # If not found, return nothing. | ||||
|     if response.status_code == 404: | ||||
|         return None | ||||
| 
 | ||||
|     # If no content, return nothing. | ||||
|     if response.status_code == 204: | ||||
|         return None | ||||
| 
 | ||||
|     try: | ||||
|         module.raise_for_status(response) | ||||
|         result = response.json() | ||||
|     except getattr(json.decoder, 'JSONDecodeError', ValueError) as inst: | ||||
|         module.fail_json(msg="Invalid JSON response with error: %s" % inst) | ||||
| 
 | ||||
|     if navigate_hash(result, ['error', 'errors']): | ||||
|         module.fail_json(msg=navigate_hash(result, ['error', 'errors'])) | ||||
| 
 | ||||
|     return result | ||||
| 
 | ||||
| 
 | ||||
| if __name__ == "__main__": | ||||
|     main() | ||||
							
								
								
									
										2
									
								
								tests/integration/gcp_compute_autoscaler/aliases
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								tests/integration/gcp_compute_autoscaler/aliases
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,2 @@ | |||
| cloud/gcp | ||||
| unsupported | ||||
|  | @ -0,0 +1,2 @@ | |||
| --- | ||||
| resource_name: "{{ resource_prefix }}" | ||||
							
								
								
									
										0
									
								
								tests/integration/gcp_compute_autoscaler/meta/main.yml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										0
									
								
								tests/integration/gcp_compute_autoscaler/meta/main.yml
									
										
									
									
									
										Normal file
									
								
							
							
								
								
									
										251
									
								
								tests/integration/gcp_compute_autoscaler/tasks/main.yml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										251
									
								
								tests/integration/gcp_compute_autoscaler/tasks/main.yml
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,251 @@ | |||
| --- | ||||
| # ---------------------------------------------------------------------------- | ||||
| # | ||||
| #     ***     AUTO GENERATED CODE    ***    AUTO GENERATED CODE     *** | ||||
| # | ||||
| # ---------------------------------------------------------------------------- | ||||
| # | ||||
| #     This file is automatically generated by Magic Modules and manual | ||||
| #     changes will be clobbered when the file is regenerated. | ||||
| # | ||||
| #     Please read more about how to change this file at | ||||
| #     https://www.github.com/GoogleCloudPlatform/magic-modules | ||||
| # | ||||
| # ---------------------------------------------------------------------------- | ||||
| # Pre-test setup | ||||
| - name: create a network | ||||
|   gcp_compute_network: | ||||
|     name: network-instancetemplate | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: network | ||||
| - name: create a address | ||||
|   gcp_compute_address: | ||||
|     name: address-instancetemplate | ||||
|     region: us-central1 | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: address | ||||
| - name: create a instance template | ||||
|   gcp_compute_instance_template: | ||||
|     name: "{{ resource_name }}" | ||||
|     properties: | ||||
|       disks: | ||||
|       - auto_delete: 'true' | ||||
|         boot: 'true' | ||||
|         initialize_params: | ||||
|           source_image: projects/ubuntu-os-cloud/global/images/family/ubuntu-1604-lts | ||||
|       machine_type: n1-standard-1 | ||||
|       network_interfaces: | ||||
|       - network: "{{ network }}" | ||||
|         access_configs: | ||||
|         - name: test-config | ||||
|           type: ONE_TO_ONE_NAT | ||||
|           nat_ip: "{{ address }}" | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: instancetemplate | ||||
| - name: create a instance group manager | ||||
|   gcp_compute_instance_group_manager: | ||||
|     name: "{{ resource_name }}" | ||||
|     base_instance_name: test1-child | ||||
|     instance_template: "{{ instancetemplate }}" | ||||
|     target_size: 3 | ||||
|     zone: us-central1-a | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: igm | ||||
| - name: delete a autoscaler | ||||
|   gcp_compute_autoscaler: | ||||
|     name: "{{ resource_name }}" | ||||
|     zone: us-central1-a | ||||
|     target: "{{ igm }}" | ||||
|     autoscaling_policy: | ||||
|       max_num_replicas: 5 | ||||
|       min_num_replicas: 1 | ||||
|       cool_down_period_sec: 60 | ||||
|       cpu_utilization: | ||||
|         utilization_target: 0.5 | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: absent | ||||
| #---------------------------------------------------------- | ||||
| - name: create a autoscaler | ||||
|   gcp_compute_autoscaler: | ||||
|     name: "{{ resource_name }}" | ||||
|     zone: us-central1-a | ||||
|     target: "{{ igm }}" | ||||
|     autoscaling_policy: | ||||
|       max_num_replicas: 5 | ||||
|       min_num_replicas: 1 | ||||
|       cool_down_period_sec: 60 | ||||
|       cpu_utilization: | ||||
|         utilization_target: 0.5 | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: result | ||||
| - name: assert changed is true | ||||
|   assert: | ||||
|     that: | ||||
|       - result.changed == true | ||||
| - name: verify that autoscaler was created | ||||
|   gcp_compute_autoscaler_facts: | ||||
|       filters: | ||||
|          - name = {{ resource_name }} | ||||
|       zone: us-central1-a | ||||
|       project: "{{ gcp_project }}" | ||||
|       auth_kind: "{{ gcp_cred_kind }}" | ||||
|       service_account_file: "{{ gcp_cred_file }}" | ||||
|       scopes: | ||||
|         - https://www.googleapis.com/auth/compute | ||||
|   register: results | ||||
| - name: verify that command succeeded | ||||
|   assert: | ||||
|     that: | ||||
|       - results['resources'] | length == 1 | ||||
| # ---------------------------------------------------------------------------- | ||||
| - name: create a autoscaler that already exists | ||||
|   gcp_compute_autoscaler: | ||||
|     name: "{{ resource_name }}" | ||||
|     zone: us-central1-a | ||||
|     target: "{{ igm }}" | ||||
|     autoscaling_policy: | ||||
|       max_num_replicas: 5 | ||||
|       min_num_replicas: 1 | ||||
|       cool_down_period_sec: 60 | ||||
|       cpu_utilization: | ||||
|         utilization_target: 0.5 | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: present | ||||
|   register: result | ||||
| - name: assert changed is false | ||||
|   assert: | ||||
|     that: | ||||
|       - result.changed == false | ||||
| #---------------------------------------------------------- | ||||
| - name: delete a autoscaler | ||||
|   gcp_compute_autoscaler: | ||||
|     name: "{{ resource_name }}" | ||||
|     zone: us-central1-a | ||||
|     target: "{{ igm }}" | ||||
|     autoscaling_policy: | ||||
|       max_num_replicas: 5 | ||||
|       min_num_replicas: 1 | ||||
|       cool_down_period_sec: 60 | ||||
|       cpu_utilization: | ||||
|         utilization_target: 0.5 | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: absent | ||||
|   register: result | ||||
| - name: assert changed is true | ||||
|   assert: | ||||
|     that: | ||||
|       - result.changed == true | ||||
| - name: verify that autoscaler was deleted | ||||
|   gcp_compute_autoscaler_facts: | ||||
|       filters: | ||||
|          - name = {{ resource_name }} | ||||
|       zone: us-central1-a | ||||
|       project: "{{ gcp_project }}" | ||||
|       auth_kind: "{{ gcp_cred_kind }}" | ||||
|       service_account_file: "{{ gcp_cred_file }}" | ||||
|       scopes: | ||||
|         - https://www.googleapis.com/auth/compute | ||||
|   register: results | ||||
| - name: verify that command succeeded | ||||
|   assert: | ||||
|     that: | ||||
|       - results['resources'] | length == 0 | ||||
| # ---------------------------------------------------------------------------- | ||||
| - name: delete a autoscaler that does not exist | ||||
|   gcp_compute_autoscaler: | ||||
|     name: "{{ resource_name }}" | ||||
|     zone: us-central1-a | ||||
|     target: "{{ igm }}" | ||||
|     autoscaling_policy: | ||||
|       max_num_replicas: 5 | ||||
|       min_num_replicas: 1 | ||||
|       cool_down_period_sec: 60 | ||||
|       cpu_utilization: | ||||
|         utilization_target: 0.5 | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: absent | ||||
|   register: result | ||||
| - name: assert changed is false | ||||
|   assert: | ||||
|     that: | ||||
|       - result.changed == false | ||||
| #--------------------------------------------------------- | ||||
| # Post-test teardown | ||||
| # If errors happen, don't crash the playbook! | ||||
| - name: delete a instance group manager | ||||
|   gcp_compute_instance_group_manager: | ||||
|     name: "{{ resource_name }}" | ||||
|     base_instance_name: test1-child | ||||
|     instance_template: "{{ instancetemplate }}" | ||||
|     target_size: 3 | ||||
|     zone: us-central1-a | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: absent | ||||
|   register: igm | ||||
|   ignore_errors: true | ||||
| - name: delete a instance template | ||||
|   gcp_compute_instance_template: | ||||
|     name: "{{ resource_name }}" | ||||
|     properties: | ||||
|       disks: | ||||
|       - auto_delete: 'true' | ||||
|         boot: 'true' | ||||
|         initialize_params: | ||||
|           source_image: projects/ubuntu-os-cloud/global/images/family/ubuntu-1604-lts | ||||
|       machine_type: n1-standard-1 | ||||
|       network_interfaces: | ||||
|       - network: "{{ network }}" | ||||
|         access_configs: | ||||
|         - name: test-config | ||||
|           type: ONE_TO_ONE_NAT | ||||
|           nat_ip: "{{ address }}" | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: absent | ||||
|   register: instancetemplate | ||||
|   ignore_errors: true | ||||
| - name: delete a address | ||||
|   gcp_compute_address: | ||||
|     name: address-instancetemplate | ||||
|     region: us-central1 | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: absent | ||||
|   register: address | ||||
|   ignore_errors: true | ||||
| - name: delete a network | ||||
|   gcp_compute_network: | ||||
|     name: network-instancetemplate | ||||
|     project: "{{ gcp_project }}" | ||||
|     auth_kind: "{{ gcp_cred_kind }}" | ||||
|     service_account_file: "{{ gcp_cred_file }}" | ||||
|     state: absent | ||||
|   register: network | ||||
|   ignore_errors: true | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue