From dbd5dbc2fbdc0b50e3f4d288b9755f35275f93f1 Mon Sep 17 00:00:00 2001 From: The Magician Date: Mon, 15 Mar 2021 16:00:59 -0700 Subject: [PATCH] Promote field compute_instance.scheduling.min_node_cpus and related fields to ga (#4593) (#388) Signed-off-by: Modular Magician --- plugins/modules/gcp_compute_disk.py | 4 +- plugins/modules/gcp_compute_disk_info.py | 3 +- plugins/modules/gcp_compute_health_check.py | 24 +++--- .../modules/gcp_compute_health_check_info.py | 12 +-- plugins/modules/gcp_compute_node_template.py | 76 +++++++++++++++++++ .../modules/gcp_compute_node_template_info.py | 26 +++++++ .../gcp_compute_region_backend_service.py | 11 +-- ...gcp_compute_region_backend_service_info.py | 6 +- .../gcp_compute_region_health_check.py | 24 +++--- .../gcp_compute_region_health_check_info.py | 12 +-- 10 files changed, 151 insertions(+), 47 deletions(-) diff --git a/plugins/modules/gcp_compute_disk.py b/plugins/modules/gcp_compute_disk.py index 51dbaf9..0e91148 100644 --- a/plugins/modules/gcp_compute_disk.py +++ b/plugins/modules/gcp_compute_disk.py @@ -217,7 +217,7 @@ options: kms_key_service_account: description: - The service account used for the encryption request for the given KMS key. - If absent, the Compute Engine Service Agent service account is used. + - If absent, the Compute Engine Service Agent service account is used. required: false type: str project: @@ -501,7 +501,7 @@ sourceSnapshotEncryptionKey: kmsKeyServiceAccount: description: - The service account used for the encryption request for the given KMS key. - If absent, the Compute Engine Service Agent service account is used. + - If absent, the Compute Engine Service Agent service account is used. returned: success type: str sourceSnapshotId: diff --git a/plugins/modules/gcp_compute_disk_info.py b/plugins/modules/gcp_compute_disk_info.py index 619c986..a9c744a 100644 --- a/plugins/modules/gcp_compute_disk_info.py +++ b/plugins/modules/gcp_compute_disk_info.py @@ -336,7 +336,8 @@ resources: kmsKeyServiceAccount: description: - The service account used for the encryption request for the given KMS - key. If absent, the Compute Engine Service Agent service account is used. + key. + - If absent, the Compute Engine Service Agent service account is used. returned: success type: str sourceSnapshotId: diff --git a/plugins/modules/gcp_compute_health_check.py b/plugins/modules/gcp_compute_health_check.py index 231c385..21566f6 100644 --- a/plugins/modules/gcp_compute_health_check.py +++ b/plugins/modules/gcp_compute_health_check.py @@ -411,9 +411,9 @@ options: suboptions: port: description: - - The port number for the health check request. Must be specified if portName - and portSpecification are not set or if port_specification is USE_FIXED_PORT. - Valid values are 1 through 65535. + - The port number for the health check request. + - Must be specified if portName and portSpecification are not set or if port_specification + is USE_FIXED_PORT. Valid values are 1 through 65535. required: false type: int port_name: @@ -438,9 +438,9 @@ options: type: str grpc_service_name: description: - - 'The gRPC service name for the health check. The value of grpcServiceName - has the following meanings by convention: - Empty serviceName means the - overall status of all services at the backend.' + - The gRPC service name for the health check. + - 'The value of grpcServiceName has the following meanings by convention: + - Empty serviceName means the overall status of all services at the backend.' - "- Non-empty serviceName means the health of that gRPC service, as defined by the owner of the service." - The grpcServiceName can only be ASCII. @@ -846,9 +846,9 @@ grpcHealthCheck: contains: port: description: - - The port number for the health check request. Must be specified if portName - and portSpecification are not set or if port_specification is USE_FIXED_PORT. - Valid values are 1 through 65535. + - The port number for the health check request. + - Must be specified if portName and portSpecification are not set or if port_specification + is USE_FIXED_PORT. Valid values are 1 through 65535. returned: success type: int portName: @@ -871,9 +871,9 @@ grpcHealthCheck: type: str grpcServiceName: description: - - 'The gRPC service name for the health check. The value of grpcServiceName - has the following meanings by convention: - Empty serviceName means the overall - status of all services at the backend.' + - The gRPC service name for the health check. + - 'The value of grpcServiceName has the following meanings by convention: - + Empty serviceName means the overall status of all services at the backend.' - "- Non-empty serviceName means the health of that gRPC service, as defined by the owner of the service." - The grpcServiceName can only be ASCII. diff --git a/plugins/modules/gcp_compute_health_check_info.py b/plugins/modules/gcp_compute_health_check_info.py index bd7697b..ad74e1a 100644 --- a/plugins/modules/gcp_compute_health_check_info.py +++ b/plugins/modules/gcp_compute_health_check_info.py @@ -459,9 +459,9 @@ resources: contains: port: description: - - The port number for the health check request. Must be specified if portName - and portSpecification are not set or if port_specification is USE_FIXED_PORT. - Valid values are 1 through 65535. + - The port number for the health check request. + - Must be specified if portName and portSpecification are not set or if + port_specification is USE_FIXED_PORT. Valid values are 1 through 65535. returned: success type: int portName: @@ -486,9 +486,9 @@ resources: type: str grpcServiceName: description: - - 'The gRPC service name for the health check. The value of grpcServiceName - has the following meanings by convention: - Empty serviceName means the - overall status of all services at the backend.' + - The gRPC service name for the health check. + - 'The value of grpcServiceName has the following meanings by convention: + - Empty serviceName means the overall status of all services at the backend.' - "- Non-empty serviceName means the health of that gRPC service, as defined by the owner of the service." - The grpcServiceName can only be ASCII. diff --git a/plugins/modules/gcp_compute_node_template.py b/plugins/modules/gcp_compute_node_template.py index b81a181..00a3e84 100644 --- a/plugins/modules/gcp_compute_node_template.py +++ b/plugins/modules/gcp_compute_node_template.py @@ -88,6 +88,35 @@ options: - Physical memory available to the node, defined in MB. required: false type: str + server_binding: + description: + - The server binding policy for nodes using this template. Determines where the + nodes should restart following a maintenance event. + required: false + type: dict + suboptions: + type: + description: + - Type of server binding policy. If `RESTART_NODE_ON_ANY_SERVER`, nodes using + this template will restart on any physical server following a maintenance + event. + - If `RESTART_NODE_ON_MINIMAL_SERVER`, nodes using this template will restart + on the same physical server following a maintenance event, instead of being + live migrated to or restarted on a new physical server. This option may + be useful if you are using software licenses tied to the underlying server + characteristics such as physical sockets or cores, to avoid the need for + additional licenses when maintenance occurs. However, VMs on such nodes + will experience outages while maintenance is applied. + - 'Some valid choices include: "RESTART_NODE_ON_ANY_SERVER", "RESTART_NODE_ON_MINIMAL_SERVERS"' + required: true + type: str + cpu_overcommit_type: + description: + - CPU overcommit. + - 'Some valid choices include: "ENABLED", "NONE"' + required: false + default: NONE + type: str region: description: - Region where nodes using the node template will be created . @@ -208,6 +237,32 @@ nodeTypeFlexibility: - Use local SSD . returned: success type: str +serverBinding: + description: + - The server binding policy for nodes using this template. Determines where the + nodes should restart following a maintenance event. + returned: success + type: complex + contains: + type: + description: + - Type of server binding policy. If `RESTART_NODE_ON_ANY_SERVER`, nodes using + this template will restart on any physical server following a maintenance + event. + - If `RESTART_NODE_ON_MINIMAL_SERVER`, nodes using this template will restart + on the same physical server following a maintenance event, instead of being + live migrated to or restarted on a new physical server. This option may be + useful if you are using software licenses tied to the underlying server characteristics + such as physical sockets or cores, to avoid the need for additional licenses + when maintenance occurs. However, VMs on such nodes will experience outages + while maintenance is applied. + returned: success + type: str +cpuOvercommitType: + description: + - CPU overcommit. + returned: success + type: str region: description: - Region where nodes using the node template will be created . @@ -247,6 +302,8 @@ def main(): node_affinity_labels=dict(type='dict'), node_type=dict(type='str'), node_type_flexibility=dict(type='dict', options=dict(cpus=dict(type='str'), memory=dict(type='str'))), + server_binding=dict(type='dict', options=dict(type=dict(required=True, type='str'))), + cpu_overcommit_type=dict(default='NONE', type='str'), region=dict(required=True, type='str'), ), mutually_exclusive=[['node_type', 'node_type_flexibility']], @@ -306,6 +363,8 @@ def resource_to_request(module): u'nodeAffinityLabels': module.params.get('node_affinity_labels'), u'nodeType': module.params.get('node_type'), u'nodeTypeFlexibility': NodeTemplateNodetypeflexibility(module.params.get('node_type_flexibility', {}), module).to_request(), + u'serverBinding': NodeTemplateServerbinding(module.params.get('server_binding', {}), module).to_request(), + u'cpuOvercommitType': module.params.get('cpu_overcommit_type'), } return_vals = {} for k, v in request.items(): @@ -377,6 +436,8 @@ def response_to_hash(module, response): u'nodeAffinityLabels': response.get(u'nodeAffinityLabels'), u'nodeType': response.get(u'nodeType'), u'nodeTypeFlexibility': NodeTemplateNodetypeflexibility(response.get(u'nodeTypeFlexibility', {}), module).from_response(), + u'serverBinding': NodeTemplateServerbinding(response.get(u'serverBinding', {}), module).from_response(), + u'cpuOvercommitType': response.get(u'cpuOvercommitType'), } @@ -439,5 +500,20 @@ class NodeTemplateNodetypeflexibility(object): return remove_nones_from_dict({u'cpus': self.request.get(u'cpus'), u'memory': self.request.get(u'memory')}) +class NodeTemplateServerbinding(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'type': self.request.get('type')}) + + def from_response(self): + return remove_nones_from_dict({u'type': self.request.get(u'type')}) + + if __name__ == '__main__': main() diff --git a/plugins/modules/gcp_compute_node_template_info.py b/plugins/modules/gcp_compute_node_template_info.py index 43553d9..42847db 100644 --- a/plugins/modules/gcp_compute_node_template_info.py +++ b/plugins/modules/gcp_compute_node_template_info.py @@ -168,6 +168,32 @@ resources: - Use local SSD . returned: success type: str + serverBinding: + description: + - The server binding policy for nodes using this template. Determines where + the nodes should restart following a maintenance event. + returned: success + type: complex + contains: + type: + description: + - Type of server binding policy. If `RESTART_NODE_ON_ANY_SERVER`, nodes + using this template will restart on any physical server following a maintenance + event. + - If `RESTART_NODE_ON_MINIMAL_SERVER`, nodes using this template will restart + on the same physical server following a maintenance event, instead of + being live migrated to or restarted on a new physical server. This option + may be useful if you are using software licenses tied to the underlying + server characteristics such as physical sockets or cores, to avoid the + need for additional licenses when maintenance occurs. However, VMs on + such nodes will experience outages while maintenance is applied. + returned: success + type: str + cpuOvercommitType: + description: + - CPU overcommit. + returned: success + type: str region: description: - Region where nodes using the node template will be created . diff --git a/plugins/modules/gcp_compute_region_backend_service.py b/plugins/modules/gcp_compute_region_backend_service.py index ec5c2f9..ae49f47 100644 --- a/plugins/modules/gcp_compute_region_backend_service.py +++ b/plugins/modules/gcp_compute_region_backend_service.py @@ -403,9 +403,9 @@ options: health_checks: description: - The set of URLs to HealthCheck resources for health checking this RegionBackendService. - Currently at most one health check can be specified. A health check must be - specified unless the backend service uses an internet or serverless NEG as a - backend. + Currently at most one health check can be specified. + - A health check must be specified unless the backend service uses an internet + or serverless NEG as a backend. elements: str required: false type: list @@ -1089,8 +1089,9 @@ fingerprint: healthChecks: description: - The set of URLs to HealthCheck resources for health checking this RegionBackendService. - Currently at most one health check can be specified. A health check must be specified - unless the backend service uses an internet or serverless NEG as a backend. + Currently at most one health check can be specified. + - A health check must be specified unless the backend service uses an internet or + serverless NEG as a backend. returned: success type: list id: diff --git a/plugins/modules/gcp_compute_region_backend_service_info.py b/plugins/modules/gcp_compute_region_backend_service_info.py index 29a02b5..5065b73 100644 --- a/plugins/modules/gcp_compute_region_backend_service_info.py +++ b/plugins/modules/gcp_compute_region_backend_service_info.py @@ -478,9 +478,9 @@ resources: healthChecks: description: - The set of URLs to HealthCheck resources for health checking this RegionBackendService. - Currently at most one health check can be specified. A health check must be - specified unless the backend service uses an internet or serverless NEG as - a backend. + Currently at most one health check can be specified. + - A health check must be specified unless the backend service uses an internet + or serverless NEG as a backend. returned: success type: list id: diff --git a/plugins/modules/gcp_compute_region_health_check.py b/plugins/modules/gcp_compute_region_health_check.py index 23d9359..63acea3 100644 --- a/plugins/modules/gcp_compute_region_health_check.py +++ b/plugins/modules/gcp_compute_region_health_check.py @@ -406,9 +406,9 @@ options: suboptions: port: description: - - The port number for the health check request. Must be specified if portName - and portSpecification are not set or if port_specification is USE_FIXED_PORT. - Valid values are 1 through 65535. + - The port number for the health check request. + - Must be specified if portName and portSpecification are not set or if port_specification + is USE_FIXED_PORT. Valid values are 1 through 65535. required: false type: int port_name: @@ -433,9 +433,9 @@ options: type: str grpc_service_name: description: - - 'The gRPC service name for the health check. The value of grpcServiceName - has the following meanings by convention: * Empty serviceName means the - overall status of all services at the backend.' + - The gRPC service name for the health check. + - 'The value of grpcServiceName has the following meanings by convention: + * Empty serviceName means the overall status of all services at the backend.' - "* Non-empty serviceName means the health of that gRPC service, as defined by the owner of the service." - The grpcServiceName can only be ASCII. @@ -847,9 +847,9 @@ grpcHealthCheck: contains: port: description: - - The port number for the health check request. Must be specified if portName - and portSpecification are not set or if port_specification is USE_FIXED_PORT. - Valid values are 1 through 65535. + - The port number for the health check request. + - Must be specified if portName and portSpecification are not set or if port_specification + is USE_FIXED_PORT. Valid values are 1 through 65535. returned: success type: int portName: @@ -872,9 +872,9 @@ grpcHealthCheck: type: str grpcServiceName: description: - - 'The gRPC service name for the health check. The value of grpcServiceName - has the following meanings by convention: * Empty serviceName means the overall - status of all services at the backend.' + - The gRPC service name for the health check. + - 'The value of grpcServiceName has the following meanings by convention: * + Empty serviceName means the overall status of all services at the backend.' - "* Non-empty serviceName means the health of that gRPC service, as defined by the owner of the service." - The grpcServiceName can only be ASCII. diff --git a/plugins/modules/gcp_compute_region_health_check_info.py b/plugins/modules/gcp_compute_region_health_check_info.py index e11fb89..740172f 100644 --- a/plugins/modules/gcp_compute_region_health_check_info.py +++ b/plugins/modules/gcp_compute_region_health_check_info.py @@ -465,9 +465,9 @@ resources: contains: port: description: - - The port number for the health check request. Must be specified if portName - and portSpecification are not set or if port_specification is USE_FIXED_PORT. - Valid values are 1 through 65535. + - The port number for the health check request. + - Must be specified if portName and portSpecification are not set or if + port_specification is USE_FIXED_PORT. Valid values are 1 through 65535. returned: success type: int portName: @@ -492,9 +492,9 @@ resources: type: str grpcServiceName: description: - - 'The gRPC service name for the health check. The value of grpcServiceName - has the following meanings by convention: * Empty serviceName means the - overall status of all services at the backend.' + - The gRPC service name for the health check. + - 'The value of grpcServiceName has the following meanings by convention: + * Empty serviceName means the overall status of all services at the backend.' - "* Non-empty serviceName means the health of that gRPC service, as defined by the owner of the service." - The grpcServiceName can only be ASCII.