From 0ce1e792e90b15576a7c5aa54a711ff829c01cd9 Mon Sep 17 00:00:00 2001 From: Ye Chen <127243817+yec-akamai@users.noreply.github.com> Date: Tue, 3 Sep 2024 14:28:38 -0400 Subject: [PATCH 1/8] ref: Migrate lke_version_list to use common list info (#573) --- README.md | 2 +- docs/modules/lke_version_list.md | 17 +++-- plugins/modules/lke_version_list.py | 97 +++++------------------------ 3 files changed, 29 insertions(+), 87 deletions(-) diff --git a/README.md b/README.md index 00392c9e..b397fc6f 100644 --- a/README.md +++ b/README.md @@ -100,7 +100,7 @@ Name | Description | [linode.cloud.image_list](./docs/modules/image_list.md)|List and filter on Images.| [linode.cloud.instance_list](./docs/modules/instance_list.md)|List and filter on Instances.| [linode.cloud.instance_type_list](./docs/modules/instance_type_list.md)|**NOTE: This module has been deprecated in favor of `type_list`.| -[linode.cloud.lke_version_list](./docs/modules/lke_version_list.md)|List Kubernetes versions available for deployment to a Kubernetes cluster.| +[linode.cloud.lke_version_list](./docs/modules/lke_version_list.md)|List and filter on LKE Versions.| [linode.cloud.nodebalancer_list](./docs/modules/nodebalancer_list.md)|List and filter on Node Balancers.| [linode.cloud.object_cluster_list](./docs/modules/object_cluster_list.md)|**NOTE: This module has been deprecated because it relies on deprecated API endpoints. Going forward, `region` will be the preferred way to designate where Object Storage resources should be created.**| [linode.cloud.placement_group_list](./docs/modules/placement_group_list.md)|List and filter on Placement Groups.| diff --git a/docs/modules/lke_version_list.md b/docs/modules/lke_version_list.md index da6f0d54..f7474cc6 100644 --- a/docs/modules/lke_version_list.md +++ b/docs/modules/lke_version_list.md @@ -1,6 +1,6 @@ # lke_version_list -List Kubernetes versions available for deployment to a Kubernetes cluster. +List and filter on LKE Versions. - [Minimum Required Fields](#minimum-required-fields) - [Examples](#examples) @@ -24,12 +24,21 @@ List Kubernetes versions available for deployment to a Kubernetes cluster. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `order` |
`str`
|
Optional
| The order to list lke versions in. **(Choices: `desc`, `asc`; Default: `asc`)** | -| `count` |
`int`
|
Optional
| The number of results to return. If undefined, all results will be returned. | +| `order` |
`str`
|
Optional
| The order to list LKE Versions in. **(Choices: `desc`, `asc`; Default: `asc`)** | +| `order_by` |
`str`
|
Optional
| The attribute to order LKE Versions by. | +| [`filters` (sub-options)](#filters) |
`list`
|
Optional
| A list of filters to apply to the resulting LKE Versions. | +| `count` |
`int`
|
Optional
| The number of LKE Versions to return. If undefined, all results will be returned. | + +### filters + +| Field | Type | Required | Description | +|-----------|------|----------|------------------------------------------------------------------------------| +| `name` |
`str`
|
**Required**
| The name of the field to filter on. Valid filterable fields can be found [here](https://techdocs.akamai.com/linode-api/reference/get-lke-versions). | +| `values` |
`list`
|
**Required**
| A list of values to allow for this field. Fields will pass this filter if at least one of these values matches. | ## Return Values -- `lke_versions` - The returned LKE versions. +- `lke_versions` - The returned LKE Versions. - Sample Response: ```json diff --git a/plugins/modules/lke_version_list.py b/plugins/modules/lke_version_list.py index c0224400..97dbe869 100644 --- a/plugins/modules/lke_version_list.py +++ b/plugins/modules/lke_version_list.py @@ -1,67 +1,28 @@ #!/usr/bin/python # -*- coding: utf-8 -*- -"""This module allows users to list Linode instances.""" -from __future__ import absolute_import, division, print_function +"""This module allows users to list Linode LKE Versions.""" -from typing import Any, Dict, Optional +from __future__ import absolute_import, division, print_function -import ansible_collections.linode.cloud.plugins.module_utils.doc_fragments.lke_version_list as docs -from ansible_collections.linode.cloud.plugins.module_utils.linode_common import ( - LinodeModuleBase, -) -from ansible_collections.linode.cloud.plugins.module_utils.linode_docs import ( - global_authors, - global_requirements, -) -from ansible_collections.linode.cloud.plugins.module_utils.linode_helper import ( - get_all_paginated, +from ansible_collections.linode.cloud.plugins.module_utils.doc_fragments import ( + lke_version_list as docs, ) -from ansible_specdoc.objects import ( - FieldType, - SpecDocMeta, - SpecField, - SpecReturnValue, +from ansible_collections.linode.cloud.plugins.module_utils.linode_common_list import ( + ListModule, ) -spec = { - # Disable the default values - "state": SpecField(type=FieldType.string, required=False, doc_hide=True), - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), - "order": SpecField( - type=FieldType.string, - description=["The order to list lke versions in."], - default="asc", - choices=["desc", "asc"], - ), - "count": SpecField( - type=FieldType.integer, - description=[ - "The number of results to return.", - "If undefined, all results will be returned.", - ], - ), -} - -SPECDOC_META = SpecDocMeta( - description=[ - "List Kubernetes versions available for deployment to a Kubernetes cluster." - ], - requirements=global_requirements, - author=global_authors, - options=spec, +module = ListModule( + result_display_name="LKE Versions", + result_field_name="lke_versions", + endpoint_template="/lke/versions", + result_docs_url="https://techdocs.akamai.com/linode-api/reference/get-lke-versions", + result_samples=docs.result_lke_versions_samples, examples=docs.specdoc_examples, - return_values={ - "lke_versions": SpecReturnValue( - description="The returned LKE versions.", - docs_url="https://techdocs.akamai.com/linode-api/reference/get-lke-versions", - type=FieldType.list, - elements=FieldType.dict, - sample=docs.result_lke_versions_samples, - ) - }, ) +SPECDOC_META = module.spec + DOCUMENTATION = r""" """ EXAMPLES = r""" @@ -69,33 +30,5 @@ RETURN = r""" """ - -class Module(LinodeModuleBase): - """Module for getting a list of Kubernetes versions""" - - def __init__(self) -> None: - self.module_arg_spec = SPECDOC_META.ansible_spec - self.results: Dict[str, Any] = {"lke_versions": []} - - super().__init__(module_arg_spec=self.module_arg_spec) - - def exec_module(self, **kwargs: Any) -> Optional[dict]: - """Entrypoint for lke version list module""" - - self.results["lke_versions"] = get_all_paginated( - self.client, - "/lke/versions", - None, - num_results=self.module.params["count"], - ) - - return self.results - - -def main() -> None: - """Constructs and calls the module""" - Module() - - if __name__ == "__main__": - main() + module.run() From e5c9ea46dc84040bf9cd2bcc2379295f2dd81311 Mon Sep 17 00:00:00 2001 From: Lena Garber <114949949+lgarber-akamai@users.noreply.github.com> Date: Tue, 3 Sep 2024 15:00:08 -0400 Subject: [PATCH 2/8] ref: Migrate object_cluster_list module to ListModule base class; add deprecation support to ListModule and InfoModule (#575) * Migrate object_cluster_list module to ListModule base class * Apply deprecation to instance_type_list * Upgrade deps and make gendocs --- README.md | 2 +- docs/modules/instance_type_list.md | 4 +- docs/modules/object_cluster_list.md | 12 +- plugins/module_utils/linode_common_info.py | 15 ++ plugins/module_utils/linode_common_list.py | 14 ++ plugins/modules/instance_type_list.py | 6 +- plugins/modules/object_cluster_list.py | 146 +++--------------- .../object_cluster_list/tasks/main.yaml | 12 -- 8 files changed, 58 insertions(+), 153 deletions(-) diff --git a/README.md b/README.md index b397fc6f..c7debbca 100644 --- a/README.md +++ b/README.md @@ -99,7 +99,7 @@ Name | Description | [linode.cloud.firewall_list](./docs/modules/firewall_list.md)|List and filter on Firewalls.| [linode.cloud.image_list](./docs/modules/image_list.md)|List and filter on Images.| [linode.cloud.instance_list](./docs/modules/instance_list.md)|List and filter on Instances.| -[linode.cloud.instance_type_list](./docs/modules/instance_type_list.md)|**NOTE: This module has been deprecated in favor of `type_list`.| +[linode.cloud.instance_type_list](./docs/modules/instance_type_list.md)|**NOTE: This module has been deprecated in favor of `type_list`.**| [linode.cloud.lke_version_list](./docs/modules/lke_version_list.md)|List and filter on LKE Versions.| [linode.cloud.nodebalancer_list](./docs/modules/nodebalancer_list.md)|List and filter on Node Balancers.| [linode.cloud.object_cluster_list](./docs/modules/object_cluster_list.md)|**NOTE: This module has been deprecated because it relies on deprecated API endpoints. Going forward, `region` will be the preferred way to designate where Object Storage resources should be created.**| diff --git a/docs/modules/instance_type_list.md b/docs/modules/instance_type_list.md index f3d18950..c68d9e5f 100644 --- a/docs/modules/instance_type_list.md +++ b/docs/modules/instance_type_list.md @@ -1,8 +1,8 @@ # instance_type_list -**NOTE: This module has been deprecated in favor of `type_list`. +**NOTE: This module has been deprecated in favor of `type_list`.** -List and filter on Linode Instance Types. +List and filter on Instance Types. - [Minimum Required Fields](#minimum-required-fields) - [Examples](#examples) diff --git a/docs/modules/object_cluster_list.md b/docs/modules/object_cluster_list.md index 35b31ca7..26688d5a 100644 --- a/docs/modules/object_cluster_list.md +++ b/docs/modules/object_cluster_list.md @@ -34,21 +34,21 @@ List and filter on Object Storage Clusters. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `order` |
`str`
|
Optional
| The order to list object storage clusters in. **(Choices: `desc`, `asc`; Default: `asc`)** | -| `order_by` |
`str`
|
Optional
| The attribute to order object storage clusters by. | -| [`filters` (sub-options)](#filters) |
`list`
|
Optional
| A list of filters to apply to the resulting object storage clusters. | -| `count` |
`int`
|
Optional
| The number of results to return. If undefined, all results will be returned. | +| `order` |
`str`
|
Optional
| The order to list Object Storage Clusters in. **(Choices: `desc`, `asc`; Default: `asc`)** | +| `order_by` |
`str`
|
Optional
| The attribute to order Object Storage Clusters by. | +| [`filters` (sub-options)](#filters) |
`list`
|
Optional
| A list of filters to apply to the resulting Object Storage Clusters. | +| `count` |
`int`
|
Optional
| The number of Object Storage Clusters to return. If undefined, all results will be returned. | ### filters | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `name` |
`str`
|
**Required**
| The name of the field to filter on. Valid filterable attributes can be found here: https://techdocs.akamai.com/linode-api/reference/get-object-storage-buckets | +| `name` |
`str`
|
**Required**
| The name of the field to filter on. Valid filterable fields can be found [here](https://techdocs.akamai.com/linode-api/reference/get-object-storage-clusters). | | `values` |
`list`
|
**Required**
| A list of values to allow for this field. Fields will pass this filter if at least one of these values matches. | ## Return Values -- `clusters` - The returned object storage clusters. +- `clusters` - The returned Object Storage Clusters. - Sample Response: ```json diff --git a/plugins/module_utils/linode_common_info.py b/plugins/module_utils/linode_common_info.py index 709b5144..7db3b163 100644 --- a/plugins/module_utils/linode_common_info.py +++ b/plugins/module_utils/linode_common_info.py @@ -124,6 +124,8 @@ def __init__( examples: List[str] = None, description: List[str] = None, requires_beta: bool = False, + deprecated: bool = False, + deprecation_message: Optional[str] = None, ) -> None: self.primary_result = primary_result self.secondary_results = secondary_results or [] @@ -133,6 +135,15 @@ def __init__( f"Get info about a Linode {self.primary_result.display_name}." ] self.requires_beta = requires_beta + self.deprecated = deprecated + self.deprecation_message = ( + deprecation_message or "This module has been deprecated." + ) + + # If this module is deprecated, we should add the deprecation message + # to the module's description. + if self.deprecated: + self.description.insert(0, f"**NOTE: {self.deprecation_message}**") # Singular params should be translated into groups self.param_groups = [ @@ -274,6 +285,10 @@ def run(self) -> None: """ Initializes and runs the info module. """ + + if self.deprecated: + self.warn(self.deprecation_message) + base_module_args = { "module_arg_spec": self.module_arg_spec, "required_one_of": [], diff --git a/plugins/module_utils/linode_common_list.py b/plugins/module_utils/linode_common_list.py index cc7ba234..4a352586 100644 --- a/plugins/module_utils/linode_common_list.py +++ b/plugins/module_utils/linode_common_list.py @@ -56,6 +56,8 @@ def __init__( description: List[str] = None, result_samples: List[str] = None, requires_beta: bool = False, + deprecated: bool = False, + deprecation_message: Optional[str] = None, ) -> None: self.result_display_name = result_display_name self.result_field_name = result_field_name @@ -69,13 +71,25 @@ def __init__( ] self.result_samples = result_samples or [] self.requires_beta = requires_beta + self.deprecated = deprecated + self.deprecation_message = ( + deprecation_message or "This module has been deprecated." + ) self.module_arg_spec = self.spec.ansible_spec self.results: Dict[str, Any] = {self.result_field_name: []} + # If this module is deprecated, we should add the deprecation message + # to the module's description. + if self.deprecated: + self.description.insert(0, f"**NOTE: {self.deprecation_message}**") + def exec_module(self, **kwargs: Any) -> Optional[dict]: """Entrypoint for list module""" + if self.deprecated: + self.warn(self.deprecation_message) + filter_dict = construct_api_filter(self.module.params) self.results[self.result_field_name] = get_all_paginated( diff --git a/plugins/modules/instance_type_list.py b/plugins/modules/instance_type_list.py index 6b60d597..16de88bb 100644 --- a/plugins/modules/instance_type_list.py +++ b/plugins/modules/instance_type_list.py @@ -18,10 +18,8 @@ result_docs_url="https://techdocs.akamai.com/linode-api/reference/get-linode-types", examples=docs.specdoc_examples, result_samples=docs.result_instance_type_samples, - description=[ - "**NOTE: This module has been deprecated in favor of `type_list`.", - "List and filter on Linode Instance Types.", - ], + deprecated=True, + deprecation_message="This module has been deprecated in favor of `type_list`.", ) SPECDOC_META = module.spec diff --git a/plugins/modules/object_cluster_list.py b/plugins/modules/object_cluster_list.py index 277f875a..d857f1b5 100644 --- a/plugins/modules/object_cluster_list.py +++ b/plugins/modules/object_cluster_list.py @@ -1,107 +1,33 @@ #!/usr/bin/python # -*- coding: utf-8 -*- -"""This module allows users to list Object Storage clusters.""" -from __future__ import absolute_import, division, print_function +"""This module allows users to list Linode Object Storage clusters. .""" -from typing import Any, Dict, Optional +from __future__ import absolute_import, division, print_function from ansible_collections.linode.cloud.plugins.module_utils.doc_fragments import ( object_cluster_list as docs, ) -from ansible_collections.linode.cloud.plugins.module_utils.linode_common import ( - LinodeModuleBase, -) -from ansible_collections.linode.cloud.plugins.module_utils.linode_docs import ( - global_authors, - global_requirements, -) -from ansible_collections.linode.cloud.plugins.module_utils.linode_helper import ( - construct_api_filter, - get_all_paginated, -) -from ansible_specdoc.objects import ( - FieldType, - SpecDocMeta, - SpecField, - SpecReturnValue, +from ansible_collections.linode.cloud.plugins.module_utils.linode_common_list import ( + ListModule, ) -spec_filter = { - "name": SpecField( - type=FieldType.string, - required=True, - description=[ - "The name of the field to filter on.", - "Valid filterable attributes can be found here: " - "https://techdocs.akamai.com/linode-api/reference/get-object-storage-buckets", - ], - ), - "values": SpecField( - type=FieldType.list, - element_type=FieldType.string, - required=True, - description=[ - "A list of values to allow for this field.", - "Fields will pass this filter if at least one of these values matches.", - ], - ), -} - -spec = { - # Disable the default values - "state": SpecField(type=FieldType.string, required=False, doc_hide=True), - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), - "order": SpecField( - type=FieldType.string, - description=["The order to list object storage clusters in."], - default="asc", - choices=["desc", "asc"], - ), - "order_by": SpecField( - type=FieldType.string, - description=["The attribute to order object storage clusters by."], - ), - "filters": SpecField( - type=FieldType.list, - element_type=FieldType.dict, - suboptions=spec_filter, - description=[ - "A list of filters to apply to the resulting object storage clusters." - ], - ), - "count": SpecField( - type=FieldType.integer, - description=[ - "The number of results to return.", - "If undefined, all results will be returned.", - ], - ), -} - -SPECDOC_META = SpecDocMeta( - description=[ - "**NOTE: This module has been deprecated because it " - + "relies on deprecated API endpoints. Going forward, `region` will " - + "be the preferred way to designate where Object Storage resources " - + "should be created.**", - "List and filter on Object Storage Clusters.", - ], - requirements=global_requirements, - author=global_authors, - options=spec, +module = ListModule( + result_display_name="Object Storage Clusters", + result_field_name="clusters", + endpoint_template="/object-storage/clusters", + result_docs_url="https://techdocs.akamai.com/linode-api/reference/get-object-storage-clusters", + result_samples=docs.result_object_clusters_samples, examples=docs.specdoc_examples, - return_values={ - "clusters": SpecReturnValue( - description="The returned object storage clusters.", - docs_url="https://techdocs.akamai.com/linode-api/reference/get-object-storage-clusters", - type=FieldType.list, - elements=FieldType.dict, - sample=docs.result_object_clusters_samples, - ) - }, + deprecated=True, + deprecation_message="This module has been deprecated because it " + + "relies on deprecated API endpoints. Going forward, `region` will " + + "be the preferred way to designate where Object Storage resources " + + "should be created.", ) +SPECDOC_META = module.spec + DOCUMENTATION = r""" """ EXAMPLES = r""" @@ -109,41 +35,5 @@ RETURN = r""" """ - -class Module(LinodeModuleBase): - """Module for getting a list of Object Storage Clusters""" - - def __init__(self) -> None: - self.module_arg_spec = SPECDOC_META.ansible_spec - self.results: Dict[str, Any] = {"clusters": []} - - super().__init__(module_arg_spec=self.module_arg_spec) - - def exec_module(self, **kwargs: Any) -> Optional[dict]: - """Entrypoint for object storage cluster list module""" - - self.warn( - "The linode.cloud.object_cluster_list has been deprecated because it relies " - "on deprecated API endpoints.\n" - "Going forward, region will be the preferred way to designate where Object " - "Storage resources should be created." - ) - - filter_dict = construct_api_filter(self.module.params) - - self.results["clusters"] = get_all_paginated( - self.client, - "/object-storage/clusters", - filter_dict, - num_results=self.module.params["count"], - ) - return self.results - - -def main() -> None: - """Constructs and calls the module""" - Module() - - if __name__ == "__main__": - main() + module.run() diff --git a/tests/integration/targets/object_cluster_list/tasks/main.yaml b/tests/integration/targets/object_cluster_list/tasks/main.yaml index 49acd90d..2bced3f2 100644 --- a/tests/integration/targets/object_cluster_list/tasks/main.yaml +++ b/tests/integration/targets/object_cluster_list/tasks/main.yaml @@ -10,18 +10,6 @@ # - assert: # that: # - no_filter.clusters | length >= 1 -# -# - name: List regions with filter on region -# linode.cloud.object_cluster_list: -# filters: -# - name: region -# values: us-ord -# register: filter -# -# - assert: -# that: -# - filter.clusters | length >= 1 -# - filter.clusters[0].region == 'us-ord' environment: LINODE_UA_PREFIX: '{{ ua_prefix }}' From a37266300021d2b7ec26b17f4d1b09186b3a97a9 Mon Sep 17 00:00:00 2001 From: Ye Chen <127243817+yec-akamai@users.noreply.github.com> Date: Thu, 5 Sep 2024 13:30:27 -0400 Subject: [PATCH 3/8] add labels and taints (#580) --- docs/modules/lke_cluster.md | 10 ++ docs/modules/lke_node_pool.md | 10 ++ plugins/module_utils/linode_helper.py | 12 +++ plugins/modules/lke_cluster.py | 92 +++++++++++++++++++ plugins/modules/lke_node_pool.py | 51 ++++++++++ requirements.txt | 2 +- .../targets/lke_cluster_basic/tasks/main.yaml | 29 +++++- .../lke_node_pool_basic/tasks/main.yaml | 24 +++++ 8 files changed, 227 insertions(+), 3 deletions(-) diff --git a/docs/modules/lke_cluster.md b/docs/modules/lke_cluster.md index d18469bd..b4141cfa 100644 --- a/docs/modules/lke_cluster.md +++ b/docs/modules/lke_cluster.md @@ -87,6 +87,8 @@ Manage Linode LKE clusters. | `count` |
`int`
|
**Required**
| The number of nodes in the Node Pool. **(Updatable)** | | `type` |
`str`
|
**Required**
| The Linode Type for all of the nodes in the Node Pool. | | [`autoscaler` (sub-options)](#autoscaler) |
`dict`
|
Optional
| When enabled, the number of nodes autoscales within the defined minimum and maximum values. **(Updatable)** | +| `labels` |
`dict`
|
Optional
| Key-value pairs added as labels to nodes in the node pool. Labels help classify your nodes and to easily select subsets of objects. **(Updatable)** | +| [`taints` (sub-options)](#taints) |
`list`
|
Optional
| Kubernetes taints to add to node pool nodes. Taints help control how pods are scheduled onto nodes, specifically allowing them to repel certain pods. **(Updatable)** | ### autoscaler @@ -96,6 +98,14 @@ Manage Linode LKE clusters. | `max` |
`int`
|
Optional
| The maximum number of nodes to autoscale to. Defaults to the value provided by the count field. **(Updatable)** | | `min` |
`int`
|
Optional
| The minimum number of nodes to autoscale to. Defaults to the Node Pool’s count. **(Updatable)** | +### taints + +| Field | Type | Required | Description | +|-----------|------|----------|------------------------------------------------------------------------------| +| `key` |
`str`
|
**Required**
| The Kubernetes taint key. **(Updatable)** | +| `value` |
`str`
|
**Required**
| The Kubernetes taint value. **(Updatable)** | +| `effect` |
`str`
|
**Required**
| The Kubernetes taint effect. **(Choices: `NoSchedule`, `PreferNoSchedule`, `NoExecute`; Updatable)** | + ## Return Values - `cluster` - The LKE cluster in JSON serialized form. diff --git a/docs/modules/lke_node_pool.md b/docs/modules/lke_node_pool.md index 9d9767e7..4d0c0b86 100644 --- a/docs/modules/lke_node_pool.md +++ b/docs/modules/lke_node_pool.md @@ -61,6 +61,8 @@ Manage Linode LKE cluster node pools. | `type` |
`str`
|
Optional
| The Linode Type for all of the nodes in the Node Pool. Required if `state` == `present`. | | `skip_polling` |
`bool`
|
Optional
| If true, the module will not wait for all nodes in the node pool to be ready. **(Default: `False`)** | | `wait_timeout` |
`int`
|
Optional
| The period to wait for the node pool to be ready in seconds. **(Default: `600`)** | +| `labels` |
`dict`
|
Optional
| Key-value pairs added as labels to nodes in the node pool. Labels help classify your nodes and to easily select subsets of objects. **(Updatable)** | +| [`taints` (sub-options)](#taints) |
`list`
|
Optional
| Kubernetes taints to add to node pool nodes. Taints help control how pods are scheduled onto nodes, specifically allowing them to repel certain pods. **(Updatable)** | ### autoscaler @@ -77,6 +79,14 @@ Manage Linode LKE cluster node pools. | `type` |
`str`
|
**Required**
| This custom disk partition’s filesystem type. **(Choices: `raw`, `ext4`)** | | `size` |
`int`
|
**Required**
| The size of this custom disk partition in MB. | +### taints + +| Field | Type | Required | Description | +|-----------|------|----------|------------------------------------------------------------------------------| +| `key` |
`str`
|
**Required**
| The Kubernetes taint key. **(Updatable)** | +| `value` |
`str`
|
**Required**
| The Kubernetes taint value. **(Updatable)** | +| `effect` |
`str`
|
**Required**
| The Kubernetes taint effect. **(Choices: `NoSchedule`, `PreferNoSchedule`, `NoExecute`; Updatable)** | + ## Return Values - `node_pool` - The Node Pool in JSON serialized form. diff --git a/plugins/module_utils/linode_helper.py b/plugins/module_utils/linode_helper.py index 43124162..f2d69ed4 100644 --- a/plugins/module_utils/linode_helper.py +++ b/plugins/module_utils/linode_helper.py @@ -9,6 +9,7 @@ LinodeClient, LKENodePool, LKENodePoolNode, + LKENodePoolTaint, MappedObject, and_, ) @@ -203,6 +204,7 @@ def jsonify_node_pool(pool: LKENodePool) -> Dict[str, Any]: result = pool._raw_json result["nodes"] = [jsonify_node_pool_node(node) for node in pool.nodes] + result["taints"] = [jsonify_node_pool_taint(taint) for taint in pool.taints] return result @@ -217,6 +219,16 @@ def jsonify_node_pool_node(node: LKENodePoolNode) -> Dict[str, Any]: } +def jsonify_node_pool_taint(taint: LKENodePoolTaint) -> Dict[str, Any]: + """Converts an LKENodePoolTaint into a JSON-compatible dict""" + + return { + "key": taint.key, + "value": taint.value, + "effect": taint.effect, + } + + def validate_required(required_fields: Set[str], params: Dict[str, Any]): """Returns whether the given parameters contain all of the required fields specified.""" diff --git a/plugins/modules/lke_cluster.py b/plugins/modules/lke_cluster.py index 1fe8ee49..a10f7de5 100644 --- a/plugins/modules/lke_cluster.py +++ b/plugins/modules/lke_cluster.py @@ -112,6 +112,28 @@ ), } +linode_lke_cluster_taint = { + "key": SpecField( + type=FieldType.string, + description=["The Kubernetes taint key."], + required=True, + editable=True, + ), + "value": SpecField( + type=FieldType.string, + description=["The Kubernetes taint value."], + required=True, + editable=True, + ), + "effect": SpecField( + type=FieldType.string, + description=["The Kubernetes taint effect."], + required=True, + editable=True, + choices=["NoSchedule", "PreferNoSchedule", "NoExecute"], + ), +} + linode_lke_cluster_node_pool_spec = { "count": SpecField( type=FieldType.integer, @@ -133,6 +155,23 @@ ], suboptions=linode_lke_cluster_autoscaler, ), + "labels": SpecField( + type=FieldType.dict, + editable=True, + description=[ + "Key-value pairs added as labels to nodes in the node pool. " + "Labels help classify your nodes and to easily select subsets of objects." + ], + ), + "taints": SpecField( + type=FieldType.list, + editable=True, + description=[ + "Kubernetes taints to add to node pool nodes. Taints help control " + "how pods are scheduled onto nodes, specifically allowing them to repel certain pods." + ], + suboptions=linode_lke_cluster_taint, + ), } linode_lke_cluster_spec = { @@ -421,6 +460,7 @@ def _cluster_put_updates(self, cluster: LKECluster) -> None: self._attempt_update_acl(cluster) + # pylint: disable=too-many-statements def _update_cluster(self, cluster: LKECluster) -> None: """Handles all update functionality for the current LKE cluster""" @@ -468,6 +508,32 @@ def _update_cluster(self, cluster: LKECluster) -> None: current_pool.autoscaler = pool.get("autoscaler") current_pool.save() + if ( + "taints" in pool + and current_pool.taints != pool["taints"] + ): + self.register_action( + "Updated taints for Node Pool {}".format( + current_pool.id + ) + ) + + current_pool.taints = pool.get("taints") + current_pool.save() + + if ( + "labels" in pool + and current_pool.labels != pool["labels"] + ): + self.register_action( + "Updated labels for Node Pool {}".format( + current_pool.id + ) + ) + + current_pool.labels = pool.get("labels") + current_pool.save() + pools_handled[k] = True should_keep[i] = True break @@ -510,6 +576,32 @@ def _update_cluster(self, cluster: LKECluster) -> None: existing_pool.autoscaler = pool["autoscaler"] should_update = True + if ( + "taints" in pool + and existing_pool.taints != pool["taints"] + ): + self.register_action( + "Updated taints for Node Pool {}".format( + existing_pool.id + ) + ) + + existing_pool.taints = pool["taints"] + should_update = True + + if ( + "labels" in pool + and existing_pool.labels != pool["labels"] + ): + self.register_action( + "Updated labels for Node Pool {}".format( + existing_pool.id + ) + ) + + existing_pool.labels = pool["labels"] + should_update = True + if should_update: existing_pool.save() diff --git a/plugins/modules/lke_node_pool.py b/plugins/modules/lke_node_pool.py index f5ec96e5..f7006921 100644 --- a/plugins/modules/lke_node_pool.py +++ b/plugins/modules/lke_node_pool.py @@ -69,6 +69,28 @@ ), } +linode_lke_pool_taint = { + "key": SpecField( + type=FieldType.string, + description=["The Kubernetes taint key."], + required=True, + editable=True, + ), + "value": SpecField( + type=FieldType.string, + description=["The Kubernetes taint value."], + required=True, + editable=True, + ), + "effect": SpecField( + type=FieldType.string, + description=["The Kubernetes taint effect."], + required=True, + editable=True, + choices=["NoSchedule", "PreferNoSchedule", "NoExecute"], + ), +} + MODULE_SPEC = { "label": SpecField(type=FieldType.string, required=False, doc_hide=True), "cluster_id": SpecField( @@ -140,6 +162,23 @@ ], default=600, ), + "labels": SpecField( + type=FieldType.dict, + editable=True, + description=[ + "Key-value pairs added as labels to nodes in the node pool. " + "Labels help classify your nodes and to easily select subsets of objects." + ], + ), + "taints": SpecField( + type=FieldType.list, + editable=True, + description=[ + "Kubernetes taints to add to node pool nodes. Taints help control " + "how pods are scheduled onto nodes, specifically allowing them to repel certain pods." + ], + suboptions=linode_lke_pool_taint, + ), } SPECDOC_META = SpecDocMeta( @@ -251,6 +290,8 @@ def _update_pool(self, pool: LKENodePool) -> LKENodePool: params.pop("autoscaler") if "autoscaler" in params else None ) new_count = params.pop("count") + new_taints = params.pop("taints") if "taints" in params else None + new_labels = params.pop("labels") if "labels" in params else None try: handle_updates(pool, params, set(), self.register_action) @@ -276,6 +317,16 @@ def _update_pool(self, pool: LKENodePool) -> LKENodePool: pool.autoscaler = new_autoscaler should_update = True + if new_taints is not None and pool.taints != new_taints: + self.register_action("Updated taints for Node Pool") + pool.taints = new_taints + should_update = True + + if new_labels is not None and pool.labels != new_labels: + self.register_action("Updated labels for Node Pool") + pool.labels = new_labels + should_update = True + if should_update: try: pool.save() diff --git a/requirements.txt b/requirements.txt index 856067fa..6bcfac1f 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,4 +1,4 @@ -linode-api4>=5.20.0 +linode-api4>=5.21.0 polling>=0.3.2 types-requests==2.32.0.20240712 ansible-specdoc>=0.0.15 diff --git a/tests/integration/targets/lke_cluster_basic/tasks/main.yaml b/tests/integration/targets/lke_cluster_basic/tasks/main.yaml index 3da2258e..9f1e0597 100644 --- a/tests/integration/targets/lke_cluster_basic/tasks/main.yaml +++ b/tests/integration/targets/lke_cluster_basic/tasks/main.yaml @@ -24,6 +24,13 @@ node_pools: - type: g6-standard-1 count: 3 + labels: + foo.example.com/test: bar + foo.example.com/test2: foo + taints: + - key: foo.example.com/test2 + value: test + effect: NoExecute - type: g6-standard-4 count: 1 autoscaler: @@ -41,6 +48,11 @@ - create_cluster.cluster.region == 'us-southeast' - create_cluster.node_pools[0].type == 'g6-standard-1' - create_cluster.node_pools[0].count == 3 + - create_cluster.node_pools[0].labels['foo.example.com/test'] == 'bar' + - create_cluster.node_pools[0].labels['foo.example.com/test2'] == 'foo' + - create_cluster.node_pools[0].taints[0].key == 'foo.example.com/test2' + - create_cluster.node_pools[0].taints[0].value == 'test' + - create_cluster.node_pools[0].taints[0].effect == 'NoExecute' - create_cluster.node_pools[1].autoscaler.enabled - create_cluster.node_pools[1].autoscaler.min == 1 - create_cluster.node_pools[1].autoscaler.max == 2 @@ -54,6 +66,13 @@ node_pools: - type: g6-standard-1 count: 2 + labels: + foo.example.com/update: updated + foo.example.com/test2: foo + taints: + - key: foo.example.com/update + value: updated + effect: PreferNoSchedule - type: g6-standard-2 count: 1 - type: g6-standard-1 @@ -73,6 +92,12 @@ - update_pools.node_pools[0].count == 2 - update_pools.node_pools[0].id == create_cluster.node_pools[0].id + - update_pools.node_pools[0].labels['foo.example.com/update'] == 'updated' + - update_pools.node_pools[0].labels['foo.example.com/test2'] == 'foo' + - update_pools.node_pools[0].taints[0].key == 'foo.example.com/update' + - update_pools.node_pools[0].taints[0].value == 'updated' + - update_pools.node_pools[0].taints[0].effect == 'PreferNoSchedule' + - update_pools.node_pools[1].type == 'g6-standard-2' - update_pools.node_pools[1].count == 1 - update_pools.node_pools[2].type == 'g6-standard-1' @@ -114,8 +139,8 @@ - name: Get lke_cluster_info about the cluster by id linode.cloud.lke_cluster_info: id: '{{ upgrade.cluster.id }}' - - + + register: info_by_id - name: Assert lke_cluster_info about cluster by id diff --git a/tests/integration/targets/lke_node_pool_basic/tasks/main.yaml b/tests/integration/targets/lke_node_pool_basic/tasks/main.yaml index 92c3cede..ff0596eb 100644 --- a/tests/integration/targets/lke_node_pool_basic/tasks/main.yaml +++ b/tests/integration/targets/lke_node_pool_basic/tasks/main.yaml @@ -37,6 +37,13 @@ tags: ['my-pool'] type: g6-standard-1 count: 2 + labels: + foo.example.com/test: bar + foo.example.com/test2: foo + taints: + - key: foo.example.com/test2 + value: test + effect: NoExecute state: present register: new_pool @@ -47,6 +54,11 @@ - new_pool.node_pool.type == 'g6-standard-1' - new_pool.node_pool.nodes[0].status == 'ready' - new_pool.node_pool.nodes[1].status == 'ready' + - new_pool.node_pool.labels['foo.example.com/test'] == 'bar' + - new_pool.node_pool.labels['foo.example.com/test2'] == 'foo' + - new_pool.node_pool.taints[0].key == 'foo.example.com/test2' + - new_pool.node_pool.taints[0].value == 'test' + - new_pool.node_pool.taints[0].effect == 'NoExecute' - name: Attempt to update an invalid field on the node pool linode.cloud.lke_node_pool: @@ -71,6 +83,13 @@ enabled: true min: 1 max: 3 + labels: + foo.example.com/update: updated + foo.example.com/test2: foo + taints: + - key: foo.example.com/update + value: updated + effect: PreferNoSchedule state: present register: update_pool @@ -82,6 +101,11 @@ - update_pool.node_pool.autoscaler.enabled - update_pool.node_pool.autoscaler.min == 1 - update_pool.node_pool.autoscaler.max == 3 + - update_pool.node_pool.labels['foo.example.com/update'] == 'updated' + - update_pool.node_pool.labels['foo.example.com/test2'] == 'foo' + - update_pool.node_pool.taints[0].key == 'foo.example.com/update' + - update_pool.node_pool.taints[0].value == 'updated' + - update_pool.node_pool.taints[0].effect == 'PreferNoSchedule' always: - ignore_errors: yes From bfa97d9b40833cbbeee51596f4bb040ef80268f9 Mon Sep 17 00:00:00 2001 From: Ye Chen <127243817+yec-akamai@users.noreply.github.com> Date: Thu, 5 Sep 2024 16:18:29 -0400 Subject: [PATCH 4/8] ref: Remove state,tags,label from linode_common (#584) * remove state,tags,label from common base * fix doc * fix instance.rst * fix ip_share * fix user module * lint --- docs/modules/firewall_info.md | 2 +- docs/modules/image_info.md | 2 +- docs/modules/instance_info.md | 2 +- docs/modules/ip_share.md | 1 + docs/modules/lke_cluster.md | 1 + docs/modules/nodebalancer_info.md | 2 +- docs/modules/nodebalancer_stats.md | 2 +- docs/modules/placement_group.md | 1 + docs/modules/placement_group_assign.md | 1 + docs/modules/ssh_key_info.md | 2 +- docs/modules/stackscript_info.md | 2 +- docs/modules/token_info.md | 2 +- docs/modules/vlan_info.md | 2 +- docs/modules/vpc_info.md | 2 +- docs/modules/vpc_subnet_info.md | 2 +- plugins/module_utils/linode_common.py | 28 --------------------- plugins/module_utils/linode_common_info.py | 9 +------ plugins/module_utils/linode_common_list.py | 7 ------ plugins/modules/database_engine_list.py | 3 --- plugins/modules/database_list.py | 3 --- plugins/modules/database_mysql_info.py | 2 -- plugins/modules/database_postgresql_info.py | 2 -- plugins/modules/domain.py | 2 -- plugins/modules/domain_record.py | 2 -- plugins/modules/ip_assign.py | 3 --- plugins/modules/ip_rdns.py | 2 -- plugins/modules/ip_share.py | 9 ++++--- plugins/modules/lke_cluster.py | 8 +++++- plugins/modules/lke_cluster_info.py | 2 -- plugins/modules/lke_node_pool.py | 1 - plugins/modules/placement_group.py | 6 +++++ plugins/modules/placement_group_assign.py | 8 ++++-- plugins/modules/user.py | 8 ++---- 33 files changed, 43 insertions(+), 88 deletions(-) diff --git a/docs/modules/firewall_info.md b/docs/modules/firewall_info.md index 162d3334..eb0d6e44 100644 --- a/docs/modules/firewall_info.md +++ b/docs/modules/firewall_info.md @@ -31,8 +31,8 @@ Get info about a Linode Firewall. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the Firewall to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the Firewall to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the Firewall to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/image_info.md b/docs/modules/image_info.md index 6ede4285..abf339b4 100644 --- a/docs/modules/image_info.md +++ b/docs/modules/image_info.md @@ -31,8 +31,8 @@ Get info about a Linode Image. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the Image to resolve. **(Conflicts With: `id`)** | | `id` |
`str`
|
Optional
| The ID of the Image to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the Image to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/instance_info.md b/docs/modules/instance_info.md index 21c59298..93578f0b 100644 --- a/docs/modules/instance_info.md +++ b/docs/modules/instance_info.md @@ -31,8 +31,8 @@ Get info about a Linode Instance. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the Instance to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the Instance to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the Instance to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/ip_share.md b/docs/modules/ip_share.md index 3a8f6b90..4843f8a0 100644 --- a/docs/modules/ip_share.md +++ b/docs/modules/ip_share.md @@ -31,6 +31,7 @@ WARNING! This module makes use of beta endpoints and requires the C(api_version) |-----------|------|----------|------------------------------------------------------------------------------| | `ips` |
`list`
|
**Required**
| A list of secondary Linode IPs to share with the primary Linode. | | `linode_id` |
`int`
|
**Required**
| The ID of the primary Linode that the addresses will be shared with. | +| `state` |
`str`
|
**Required**
| The desired state of the target. **(Choices: `present`, `absent`)** | ## Return Values diff --git a/docs/modules/lke_cluster.md b/docs/modules/lke_cluster.md index b4141cfa..6bebdbab 100644 --- a/docs/modules/lke_cluster.md +++ b/docs/modules/lke_cluster.md @@ -57,6 +57,7 @@ Manage Linode LKE clusters. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| | `label` |
`str`
|
**Required**
| This Kubernetes cluster’s unique label. | +| `state` |
`str`
|
**Required**
| The desired state of the target. **(Choices: `present`, `absent`)** | | `k8s_version` |
`str`
|
Optional
| The desired Kubernetes version for this Kubernetes cluster in the format of ., and the latest supported patch version will be deployed. A version upgrade requires that you manually recycle the nodes in your cluster. **(Updatable)** | | `region` |
`str`
|
Optional
| This Kubernetes cluster’s location. | | `tags` |
`list`
|
Optional
| An array of tags applied to the Kubernetes cluster. | diff --git a/docs/modules/nodebalancer_info.md b/docs/modules/nodebalancer_info.md index ba0e4e2a..587b016c 100644 --- a/docs/modules/nodebalancer_info.md +++ b/docs/modules/nodebalancer_info.md @@ -31,8 +31,8 @@ Get info about a Linode Node Balancer. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the Node Balancer to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the Node Balancer to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the Node Balancer to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/nodebalancer_stats.md b/docs/modules/nodebalancer_stats.md index 85db71a7..58b4a262 100644 --- a/docs/modules/nodebalancer_stats.md +++ b/docs/modules/nodebalancer_stats.md @@ -28,8 +28,8 @@ Get info about a Linode Node Balancer Stats. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the Node Balancer Stats to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the Node Balancer Stats to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the Node Balancer Stats to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/placement_group.md b/docs/modules/placement_group.md index b13b551c..e376a0f0 100644 --- a/docs/modules/placement_group.md +++ b/docs/modules/placement_group.md @@ -55,6 +55,7 @@ NOTE: Placement Groups may not currently be available to all users. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| +| `state` |
`str`
|
**Required**
| The desired state of the target. **(Choices: `present`, `absent`)** | | `id` |
`int`
|
Optional
| The unique ID of the placement group. | | `label` |
`str`
|
Optional
| The label of the Placement Group. This field can only contain ASCII letters, digits and dashes. | | `region` |
`str`
|
Optional
| The region that the placement group is in. | diff --git a/docs/modules/placement_group_assign.md b/docs/modules/placement_group_assign.md index fcdac1ed..701d3f66 100644 --- a/docs/modules/placement_group_assign.md +++ b/docs/modules/placement_group_assign.md @@ -40,6 +40,7 @@ NOTE: Placement Groups may not currently be available to all users. |-----------|------|----------|------------------------------------------------------------------------------| | `placement_group_id` |
`int`
|
**Required**
| The ID of the Placement Group for this assignment. | | `linode_id` |
`int`
|
**Required**
| The Linode ID to assign or unassign to the Placement Group. | +| `state` |
`str`
|
**Required**
| The desired state of the target. **(Choices: `present`, `absent`)** | ## Return Values diff --git a/docs/modules/ssh_key_info.md b/docs/modules/ssh_key_info.md index 6d193e78..9f1380c7 100644 --- a/docs/modules/ssh_key_info.md +++ b/docs/modules/ssh_key_info.md @@ -31,8 +31,8 @@ Get info about a Linode SSH Key. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the SSH Key to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the SSH Key to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the SSH Key to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/stackscript_info.md b/docs/modules/stackscript_info.md index cfcf79e9..94d21905 100644 --- a/docs/modules/stackscript_info.md +++ b/docs/modules/stackscript_info.md @@ -31,8 +31,8 @@ Get info about a Linode StackScript. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the StackScript to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the StackScript to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the StackScript to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/token_info.md b/docs/modules/token_info.md index ede98195..94815ecc 100644 --- a/docs/modules/token_info.md +++ b/docs/modules/token_info.md @@ -31,8 +31,8 @@ Get info about a Linode Personal Access Token. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the Personal Access Token to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the Personal Access Token to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the Personal Access Token to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/vlan_info.md b/docs/modules/vlan_info.md index c5ef1d98..5104a7e8 100644 --- a/docs/modules/vlan_info.md +++ b/docs/modules/vlan_info.md @@ -26,8 +26,8 @@ Get info about a Linode VLAN. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the VLAN to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the VLAN to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the VLAN to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/vpc_info.md b/docs/modules/vpc_info.md index 985047fa..507bf2af 100644 --- a/docs/modules/vpc_info.md +++ b/docs/modules/vpc_info.md @@ -31,8 +31,8 @@ Get info about a Linode VPC. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| -| `label` |
`str`
|
Optional
| The label of the VPC to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the VPC to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the VPC to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/docs/modules/vpc_subnet_info.md b/docs/modules/vpc_subnet_info.md index 16a76f05..9a3afbf2 100644 --- a/docs/modules/vpc_subnet_info.md +++ b/docs/modules/vpc_subnet_info.md @@ -34,8 +34,8 @@ Get info about a Linode VPC Subnet. | Field | Type | Required | Description | |-----------|------|----------|------------------------------------------------------------------------------| | `vpc_id` |
`int`
|
**Required**
| The ID of the VPC for this resource. | -| `label` |
`str`
|
Optional
| The label of the VPC Subnet to resolve. **(Conflicts With: `id`)** | | `id` |
`int`
|
Optional
| The ID of the VPC Subnet to resolve. **(Conflicts With: `label`)** | +| `label` |
`str`
|
Optional
| The label of the VPC Subnet to resolve. **(Conflicts With: `id`)** | ## Return Values diff --git a/plugins/module_utils/linode_common.py b/plugins/module_utils/linode_common.py index 58218df3..b05dfc95 100644 --- a/plugins/module_utils/linode_common.py +++ b/plugins/module_utils/linode_common.py @@ -70,11 +70,6 @@ "fallback": (env_fallback, ["LINODE_API_URL"]), "default": "https://api.linode.com/", }, - "state": { - "type": "str", - "required": True, - "choices": ["present", "absent"], - }, "ua_prefix": { "type": "str", "description": "An HTTP User-Agent Prefix to prepend in API requests.", @@ -88,21 +83,6 @@ }, } -LINODE_TAG_ARGS = { - "tags": { - "type": "list", - "description": "The tags to assign to this resource.", - }, -} - -LINODE_LABEL_ARGS = { - "label": { - "type": "str", - "required": True, - "description": "The label to assign to this resource.", - }, -} - RESOURCE_NAMES = ( { Image: "image", @@ -130,8 +110,6 @@ class LinodeModuleBase: def __init__( self, module_arg_spec: dict, - supports_tags: bool = True, - has_label: bool = True, bypass_checks: bool = False, no_log: bool = False, mutually_exclusive: Any = None, @@ -145,12 +123,6 @@ def __init__( arg_spec = {} arg_spec.update(LINODE_COMMON_ARGS) - if has_label: - arg_spec.update(LINODE_LABEL_ARGS) - - if supports_tags: - arg_spec.update(LINODE_TAG_ARGS) - arg_spec.update(module_arg_spec) self._client = None diff --git a/plugins/module_utils/linode_common_info.py b/plugins/module_utils/linode_common_info.py index 7db3b163..ce5a2a0c 100644 --- a/plugins/module_utils/linode_common_info.py +++ b/plugins/module_utils/linode_common_info.py @@ -218,14 +218,7 @@ def spec(self): Returns the ansible-specdoc spec for this module. """ - options = { - "state": SpecField( - type=FieldType.string, required=False, doc_hide=True - ), - "label": SpecField( - type=FieldType.string, required=False, doc_hide=True - ), - } + options = {} # Add params to spec for group in self.param_groups: diff --git a/plugins/module_utils/linode_common_list.py b/plugins/module_utils/linode_common_list.py index 4a352586..7db6a4fb 100644 --- a/plugins/module_utils/linode_common_list.py +++ b/plugins/module_utils/linode_common_list.py @@ -126,13 +126,6 @@ def spec(self): } options = { - # Disable the default values - "state": SpecField( - type=FieldType.string, required=False, doc_hide=True - ), - "label": SpecField( - type=FieldType.string, required=False, doc_hide=True - ), "order": SpecField( type=FieldType.string, description=[ diff --git a/plugins/modules/database_engine_list.py b/plugins/modules/database_engine_list.py index 618f5933..65c56676 100644 --- a/plugins/modules/database_engine_list.py +++ b/plugins/modules/database_engine_list.py @@ -49,9 +49,6 @@ } spec = { - # Disable the default values - "state": SpecField(type=FieldType.string, required=False, doc_hide=True), - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), "order": SpecField( type=FieldType.string, description=["The order to list database engine types in."], diff --git a/plugins/modules/database_list.py b/plugins/modules/database_list.py index 321e6fcf..1cceb056 100644 --- a/plugins/modules/database_list.py +++ b/plugins/modules/database_list.py @@ -50,9 +50,6 @@ } spec = { - # Disable the default values - "state": SpecField(type=FieldType.string, required=False, doc_hide=True), - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), "order": SpecField( type=FieldType.string, description=["The order to list databases in."], diff --git a/plugins/modules/database_mysql_info.py b/plugins/modules/database_mysql_info.py index 910a7e4f..156e872d 100644 --- a/plugins/modules/database_mysql_info.py +++ b/plugins/modules/database_mysql_info.py @@ -37,8 +37,6 @@ from linode_api4 import MySQLDatabase spec = { - # Disable the default values - "state": SpecField(type=FieldType.string, required=False, doc_hide=True), "id": SpecField( type=FieldType.string, conflicts_with=["label"], diff --git a/plugins/modules/database_postgresql_info.py b/plugins/modules/database_postgresql_info.py index daa24097..5425180d 100644 --- a/plugins/modules/database_postgresql_info.py +++ b/plugins/modules/database_postgresql_info.py @@ -37,8 +37,6 @@ from linode_api4 import PostgreSQLDatabase spec = { - # Disable the default values - "state": SpecField(type=FieldType.string, required=False, doc_hide=True), "id": SpecField( type=FieldType.string, conflicts_with=["label"], diff --git a/plugins/modules/domain.py b/plugins/modules/domain.py index ca46b6ac..e1ed8ae1 100644 --- a/plugins/modules/domain.py +++ b/plugins/modules/domain.py @@ -29,8 +29,6 @@ from linode_api4 import Domain linode_domain_spec = { - # Unused for domain objects - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), "axfr_ips": SpecField( type=FieldType.list, element_type=FieldType.string, diff --git a/plugins/modules/domain_record.py b/plugins/modules/domain_record.py index afa6a794..a591b1ac 100644 --- a/plugins/modules/domain_record.py +++ b/plugins/modules/domain_record.py @@ -28,8 +28,6 @@ from linode_api4 import Domain, DomainRecord linode_domain_record_spec = { - # Unused for domain record objects - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), "domain_id": SpecField( type=FieldType.integer, description=["The ID of the parent Domain."] ), diff --git a/plugins/modules/ip_assign.py b/plugins/modules/ip_assign.py index 4d9e5594..0d95eec2 100644 --- a/plugins/modules/ip_assign.py +++ b/plugins/modules/ip_assign.py @@ -35,9 +35,6 @@ } spec = { - # Disable the default values - "state": SpecField(type=FieldType.string, required=False, doc_hide=True), - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), "assignments": SpecField( type=FieldType.list, element_type=FieldType.dict, diff --git a/plugins/modules/ip_rdns.py b/plugins/modules/ip_rdns.py index 4cb85bdf..bbe305f5 100644 --- a/plugins/modules/ip_rdns.py +++ b/plugins/modules/ip_rdns.py @@ -26,8 +26,6 @@ from linode_api4 import ExplicitNullValue, IPAddress ip_rdns_spec = { - # Disable the default values - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), "state": SpecField( type=FieldType.string, choices=["present", "absent"], diff --git a/plugins/modules/ip_share.py b/plugins/modules/ip_share.py index c2740078..a34dcabe 100644 --- a/plugins/modules/ip_share.py +++ b/plugins/modules/ip_share.py @@ -25,9 +25,6 @@ from linode_api4.objects import Instance ip_share_spec = { - # Disable the default values - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), - "state": SpecField(type=FieldType.string, required=False, doc_hide=True), "ips": SpecField( type=FieldType.list, required=True, @@ -42,6 +39,12 @@ "The ID of the primary Linode that the addresses will be shared with." ], ), + "state": SpecField( + type=FieldType.string, + description=["The desired state of the target."], + choices=["present", "absent"], + required=True, + ), } SPECDOC_META = SpecDocMeta( diff --git a/plugins/modules/lke_cluster.py b/plugins/modules/lke_cluster.py index a10f7de5..b355e859 100644 --- a/plugins/modules/lke_cluster.py +++ b/plugins/modules/lke_cluster.py @@ -238,6 +238,12 @@ ], default=600, ), + "state": SpecField( + type=FieldType.string, + description=["The desired state of the target."], + choices=["present", "absent"], + required=True, + ), } SPECDOC_META = SpecDocMeta( @@ -745,7 +751,7 @@ def _handle_absent(self) -> None: self.register_action("Deleted cluster {0}".format(cluster)) def exec_module(self, **kwargs: Any) -> Optional[dict]: - """Entrypoint for Domain module""" + """Entrypoint for LKE Cluster module""" state = kwargs.get("state") if state == "absent": diff --git a/plugins/modules/lke_cluster_info.py b/plugins/modules/lke_cluster_info.py index c5061745..754deff9 100644 --- a/plugins/modules/lke_cluster_info.py +++ b/plugins/modules/lke_cluster_info.py @@ -36,8 +36,6 @@ from linode_api4 import ApiError, LKECluster linode_lke_cluster_info_spec = { - # We need to overwrite attributes to exclude them as requirements - "state": SpecField(type=FieldType.string, required=False, doc_hide=True), "id": SpecField( type=FieldType.integer, required=False, diff --git a/plugins/modules/lke_node_pool.py b/plugins/modules/lke_node_pool.py index f7006921..45531e2d 100644 --- a/plugins/modules/lke_node_pool.py +++ b/plugins/modules/lke_node_pool.py @@ -92,7 +92,6 @@ } MODULE_SPEC = { - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), "cluster_id": SpecField( type=FieldType.integer, required=True, diff --git a/plugins/modules/placement_group.py b/plugins/modules/placement_group.py index 1c42a1e8..0e26c094 100644 --- a/plugins/modules/placement_group.py +++ b/plugins/modules/placement_group.py @@ -55,6 +55,12 @@ ], choices=["flexible", "strict"], ), + "state": SpecField( + type=FieldType.string, + description=["The desired state of the target."], + choices=["present", "absent"], + required=True, + ), } SPECDOC_META = SpecDocMeta( diff --git a/plugins/modules/placement_group_assign.py b/plugins/modules/placement_group_assign.py index 7c66298f..88cee007 100644 --- a/plugins/modules/placement_group_assign.py +++ b/plugins/modules/placement_group_assign.py @@ -22,8 +22,6 @@ from linode_api4 import PlacementGroup placement_group_assignment_spec = { - # Disable the default values - "label": SpecField(type=FieldType.string, required=False, doc_hide=True), "placement_group_id": SpecField( type=FieldType.integer, required=True, @@ -41,6 +39,12 @@ description=[], doc_hide=True, ), + "state": SpecField( + type=FieldType.string, + description=["The desired state of the target."], + choices=["present", "absent"], + required=True, + ), } SPECDOC_META = SpecDocMeta( diff --git a/plugins/modules/user.py b/plugins/modules/user.py index 1d582ff7..daeb5198 100644 --- a/plugins/modules/user.py +++ b/plugins/modules/user.py @@ -165,11 +165,6 @@ } SPEC = { - # We don't use label for this module - "label": SpecField( - type=FieldType.string, - doc_hide=True, - ), "username": SpecField( type=FieldType.string, required=True, @@ -377,7 +372,8 @@ def _create_user(self) -> Optional[User]: k: v for k, v in params.items() if k - not in list(LINODE_COMMON_ARGS.keys()) + ["grants", "ua_prefix"] + not in list(LINODE_COMMON_ARGS.keys()) + + ["grants", "ua_prefix", "state"] } try: From a85863d0029e328cee025e00f576c8f9611b099f Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Fri, 6 Sep 2024 12:00:31 -0400 Subject: [PATCH 5/8] build(deps): bump types-requests from 2.32.0.20240712 to 2.32.0.20240905 (#585) Bumps [types-requests](https://github.com/python/typeshed) from 2.32.0.20240712 to 2.32.0.20240905. - [Commits](https://github.com/python/typeshed/commits) --- updated-dependencies: - dependency-name: types-requests dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- requirements.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements.txt b/requirements.txt index 6bcfac1f..3013900a 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,4 +1,4 @@ linode-api4>=5.21.0 polling>=0.3.2 -types-requests==2.32.0.20240712 +types-requests==2.32.0.20240905 ansible-specdoc>=0.0.15 From 5b8caff687fbe688011dbc77155be9a25b058f7b Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 11 Sep 2024 10:03:10 -0400 Subject: [PATCH 6/8] build(deps): bump types-requests from 2.32.0.20240905 to 2.32.0.20240907 (#586) Bumps [types-requests](https://github.com/python/typeshed) from 2.32.0.20240905 to 2.32.0.20240907. - [Commits](https://github.com/python/typeshed/commits) --- updated-dependencies: - dependency-name: types-requests dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- requirements.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements.txt b/requirements.txt index 3013900a..e11a49b8 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,4 +1,4 @@ linode-api4>=5.21.0 polling>=0.3.2 -types-requests==2.32.0.20240905 +types-requests==2.32.0.20240907 ansible-specdoc>=0.0.15 From 1da8e4969e9e7ec3999a44d1cef71d1b3d71f09b Mon Sep 17 00:00:00 2001 From: Erik Zilber Date: Wed, 11 Sep 2024 15:48:00 -0400 Subject: [PATCH 7/8] Implemented changes for Linode Disk Encryption (re-merge) (#582) * Implemented changes for LDE * Added tests * Fix lint * Addressed PR comments * fixed * Fixed docs * Removed default --- docs/modules/instance.md | 7 +- docs/modules/instance_info.md | 5 +- docs/modules/instance_list.md | 4 +- docs/modules/lke_cluster.md | 1 + docs/modules/lke_cluster_info.md | 1 + docs/modules/lke_node_pool.md | 1 + .../module_utils/doc_fragments/instance.py | 5 +- .../doc_fragments/instance_list.py | 4 +- .../module_utils/doc_fragments/lke_cluster.py | 1 + .../doc_fragments/lke_node_pool.py | 1 + plugins/modules/instance.py | 12 ++ .../instance_disk_encryption/tasks/main.yaml | 143 ++++++++++++++++++ .../targets/lke_cluster_basic/tasks/main.yaml | 30 ++++ .../lke_node_pool_basic/tasks/main.yaml | 54 +++++++ 14 files changed, 264 insertions(+), 5 deletions(-) create mode 100644 tests/integration/targets/instance_disk_encryption/tasks/main.yaml diff --git a/docs/modules/instance.md b/docs/modules/instance.md index 581e93f2..919e66ee 100644 --- a/docs/modules/instance.md +++ b/docs/modules/instance.md @@ -149,6 +149,7 @@ Manage Linode Instances, Configs, and Disks. | `auto_disk_resize` |
`bool`
|
Optional
| Whether implicitly created disks should be resized during a type change operation. **(Default: `False`)** | | `tags` |
`list`
|
Optional
| An array of tags applied to this object. Tags are for organizational purposes only. **(Updatable)** | | [`placement_group` (sub-options)](#placement_group) |
`dict`
|
Optional
| A Placement Group to create this Linode under. | +| `disk_encryption` |
`str`
|
Optional
| The disk encryption status of this Linode. NOTE: Disk encryption may not currently be available to all users. **(Choices: `enabled`, `disabled`)** | | `swap_size` |
`int`
|
Optional
| When deploying from an Image, this field is optional, otherwise it is ignored. This is used to set the swap disk size for the newly-created Linode. | ### configs @@ -274,6 +275,7 @@ Manage Linode Instances, Configs, and Disks. | `authorized_keys` |
`list`
|
Optional
| A list of SSH public key parts to deploy for the root user. | | `authorized_users` |
`list`
|
Optional
| A list of usernames. | | `filesystem` |
`str`
|
Optional
| The filesystem to create this disk with. | +| `disk_encryption` |
`str`
|
Optional
| The disk encryption status of this disk.NOTE: Disk encryption may not currently be available to all users. **(Choices: `enabled`, `disabled`)** | | `image` |
`str`
|
Optional
| An Image ID to deploy the Disk from. | | `root_pass` |
`str`
|
Optional
| The root user’s password on the newly-created Linode. | | `stackscript_id` |
`int`
|
Optional
| The ID of the StackScript to use when creating the instance. See the [Linode API documentation](https://techdocs.akamai.com/linode-api/reference/get-stack-scripts). | @@ -354,6 +356,8 @@ Manage Linode Instances, Configs, and Disks. "placement_group_type": "anti_affinity:local", "placement_group_policy": "strict" } + "disk_encryption": "enabled", + "lke_cluster_id": null } ``` - See the [Linode API response documentation](https://techdocs.akamai.com/linode-api/reference/get-linode-instance) for a list of returned fields @@ -439,7 +443,8 @@ Manage Linode Instances, Configs, and Disks. "label": "Debian 9 Disk", "size": 48640, "status": "ready", - "updated": "2018-01-01T00:01:01" + "updated": "2018-01-01T00:01:01", + "disk_encryption": "enabled" } ] ``` diff --git a/docs/modules/instance_info.md b/docs/modules/instance_info.md index 93578f0b..2bb5b53e 100644 --- a/docs/modules/instance_info.md +++ b/docs/modules/instance_info.md @@ -89,6 +89,8 @@ Get info about a Linode Instance. "placement_group_type": "anti_affinity:local", "placement_group_policy": "strict" } + "disk_encryption": "enabled", + "lke_cluster_id": null } ``` - See the [Linode API response documentation](https://techdocs.akamai.com/linode-api/reference/get-linode-instance) for a list of returned fields @@ -174,7 +176,8 @@ Get info about a Linode Instance. "label": "Debian 9 Disk", "size": 48640, "status": "ready", - "updated": "2018-01-01T00:01:01" + "updated": "2018-01-01T00:01:01", + "disk_encryption": "enabled" } ] ``` diff --git a/docs/modules/instance_list.md b/docs/modules/instance_list.md index e0b63c07..156a41a3 100644 --- a/docs/modules/instance_list.md +++ b/docs/modules/instance_list.md @@ -94,7 +94,9 @@ List and filter on Instances. ], "type": "g6-standard-1", "updated": "2018-01-01T00:01:01", - "watchdog_enabled": true + "watchdog_enabled": true, + "disk_encryption": "enabled", + "lke_cluster_id": null } ] ``` diff --git a/docs/modules/lke_cluster.md b/docs/modules/lke_cluster.md index 6bebdbab..bf02a695 100644 --- a/docs/modules/lke_cluster.md +++ b/docs/modules/lke_cluster.md @@ -150,6 +150,7 @@ Manage Linode LKE clusters. "max": 12, "min": 3 }, + "disk_encryption": "enabled", "count": 6, "disks": [ { diff --git a/docs/modules/lke_cluster_info.md b/docs/modules/lke_cluster_info.md index 3c395fce..23dbfe75 100644 --- a/docs/modules/lke_cluster_info.md +++ b/docs/modules/lke_cluster_info.md @@ -77,6 +77,7 @@ Get info about a Linode LKE cluster. "max": 12, "min": 3 }, + "disk_encryption": "enabled", "count": 6, "disks": [ { diff --git a/docs/modules/lke_node_pool.md b/docs/modules/lke_node_pool.md index 4d0c0b86..c86314e2 100644 --- a/docs/modules/lke_node_pool.md +++ b/docs/modules/lke_node_pool.md @@ -99,6 +99,7 @@ Manage Linode LKE cluster node pools. "max": 12, "min": 3 }, + "disk_encryption": "enabled", "count": 6, "disks": [ { diff --git a/plugins/module_utils/doc_fragments/instance.py b/plugins/module_utils/doc_fragments/instance.py index f13bf3d3..a71d3fa9 100644 --- a/plugins/module_utils/doc_fragments/instance.py +++ b/plugins/module_utils/doc_fragments/instance.py @@ -135,6 +135,8 @@ "placement_group_type": "anti_affinity:local", "placement_group_policy": "strict" } + "disk_encryption": "enabled", + "lke_cluster_id": null }'''] result_configs_samples = ['''[ @@ -206,7 +208,8 @@ "label": "Debian 9 Disk", "size": 48640, "status": "ready", - "updated": "2018-01-01T00:01:01" + "updated": "2018-01-01T00:01:01", + "disk_encryption": "enabled" } ]'''] diff --git a/plugins/module_utils/doc_fragments/instance_list.py b/plugins/module_utils/doc_fragments/instance_list.py index d69ef97c..41191845 100644 --- a/plugins/module_utils/doc_fragments/instance_list.py +++ b/plugins/module_utils/doc_fragments/instance_list.py @@ -53,6 +53,8 @@ ], "type": "g6-standard-1", "updated": "2018-01-01T00:01:01", - "watchdog_enabled": true + "watchdog_enabled": true, + "disk_encryption": "enabled", + "lke_cluster_id": null } ]'''] diff --git a/plugins/module_utils/doc_fragments/lke_cluster.py b/plugins/module_utils/doc_fragments/lke_cluster.py index f9b9ba8f..2a89d0b7 100644 --- a/plugins/module_utils/doc_fragments/lke_cluster.py +++ b/plugins/module_utils/doc_fragments/lke_cluster.py @@ -60,6 +60,7 @@ "max": 12, "min": 3 }, + "disk_encryption": "enabled", "count": 6, "disks": [ { diff --git a/plugins/module_utils/doc_fragments/lke_node_pool.py b/plugins/module_utils/doc_fragments/lke_node_pool.py index d58bb9fd..e7d86544 100644 --- a/plugins/module_utils/doc_fragments/lke_node_pool.py +++ b/plugins/module_utils/doc_fragments/lke_node_pool.py @@ -35,6 +35,7 @@ "max": 12, "min": 3 }, + "disk_encryption": "enabled", "count": 6, "disks": [ { diff --git a/plugins/modules/instance.py b/plugins/modules/instance.py index eeb38bc6..d7740953 100644 --- a/plugins/modules/instance.py +++ b/plugins/modules/instance.py @@ -83,6 +83,12 @@ type=FieldType.string, description=["The filesystem to create this disk with."], ), + "disk_encryption": SpecField( + type=FieldType.string, + description="The disk encryption status of this disk." + + "NOTE: Disk encryption may not currently be available to all users.", + choices=["enabled", "disabled"], + ), "image": SpecField( type=FieldType.string, description=["An Image ID to deploy the Disk from."], @@ -523,6 +529,12 @@ suboptions=linode_instance_placement_group_spec, description=["A Placement Group to create this Linode under."], ), + "disk_encryption": SpecField( + type=FieldType.string, + description="The disk encryption status of this Linode. " + + "NOTE: Disk encryption may not currently be available to all users.", + choices=["enabled", "disabled"], + ), "swap_size": SpecField( type=FieldType.integer, description=[ diff --git a/tests/integration/targets/instance_disk_encryption/tasks/main.yaml b/tests/integration/targets/instance_disk_encryption/tasks/main.yaml new file mode 100644 index 00000000..cbb92667 --- /dev/null +++ b/tests/integration/targets/instance_disk_encryption/tasks/main.yaml @@ -0,0 +1,143 @@ +- name: instance_disk_encryption + block: + - set_fact: + r: "{{ 1000000000 | random }}" + + - name: List regions that support Disk Encryption + linode.cloud.region_list: {} + register: all_regions + + - set_fact: + lde_region: '{{ (all_regions.regions | selectattr("capabilities", "search", "Disk Encryption") | list)[0].id }}' + + - name: Create a Linode instance with disk encryption set + linode.cloud.instance: + label: 'ansible-test-disk-encryption-{{ r }}' + region: '{{ lde_region }}' + type: g6-standard-1 + image: linode/ubuntu22.04 + private_ip: true + wait: false + state: present + firewall_id: '{{ firewall_id }}' + disk_encryption: 'enabled' + register: create_instance_with_disk_encryption + + - name: Assert instance created + assert: + that: + - create_instance_with_disk_encryption.changed + - create_instance_with_disk_encryption.instance.disk_encryption == 'enabled' + + - name: Create a Linode instance with explicit disks with disk encryption set + linode.cloud.instance: + label: 'ansible-test-disks-disk-encryption-{{ r }}' + region: '{{ lde_region }}' + type: g6-standard-1 + booted: false + disks: + - label: test-disk + filesystem: ext4 + size: 5000 + state: present + firewall_id: '{{ firewall_id }}' + disk_encryption: 'enabled' + register: create_instance_disks_disk_encryption + + - name: Assert instance created + assert: + that: + - create_instance_disks_disk_encryption.changed + - create_instance_disks_disk_encryption.instance.disk_encryption == 'enabled' + - create_instance_disks_disk_encryption.disks[0].disk_encryption == 'enabled' + + - name: Create a small Linode instance with two disks that sum up to its max size + linode.cloud.instance: + label: 'ansible-test-disks-max-size-{{ r }}' + region: '{{ lde_region }}' + type: g6-nanode-1 + booted: false + disks: + - label: test-disk-1 + filesystem: ext4 + size: 15000 + - label: test-disk-2 + filesystem: ext4 + size: 10000 + state: present + firewall_id: '{{ firewall_id }}' + disk_encryption: 'enabled' + register: create_instance_disks_max_size + + - name: Assert instance created + assert: + that: + - create_instance_disks_max_size.changed + - create_instance_disks_max_size.disks[0].size == 15000 + - create_instance_disks_max_size.disks[1].size == 10000 + + - name: Update the instance to resize test-disk-1 and test-disk-2 + linode.cloud.instance: + label: "{{ create_instance_disks_max_size.instance.label }}" + disks: + - label: test-disk-1 + filesystem: ext4 + size: 14500 + - label: test-disk-2 + filesystem: ext4 + size: 10500 + state: present + register: resize_disks + + - name: Assert instance created + assert: + that: + - resize_disks.changed + - resize_disks.disks[0].size == 14500 + - resize_disks.disks[1].size == 10500 + + always: + - ignore_errors: yes + block: + - name: Delete a Linode instance + linode.cloud.instance: + label: 'ansible-test-disk-encryption-{{ r }}' + state: absent + register: delete_disk_encryption + + - name: Assert instance delete succeeded + assert: + that: + - delete_disk_encryption.changed + - delete_disk_encryption.instance.id == create_instance_with_disk_encryption.instance.id + + - name: Delete a Linode instance + linode.cloud.instance: + label: 'ansible-test-disks-disk-encryption-{{ r }}' + state: absent + register: delete_disks_disk_encryption + + - name: Assert instance delete succeeded + assert: + that: + - delete_disks_disk_encryption.changed + - delete_disks_disk_encryption.instance.id == create_instance_disks_disk_encryption.instance.id + + - name: Delete a Linode instance + linode.cloud.instance: + label: 'ansible-test-disks-max-size-{{ r }}' + state: absent + register: delete_disks_max_size + + - name: Assert instance delete succeeded + assert: + that: + - delete_disks_max_size.changed + - delete_disks_max_size.instance.id == create_instance_disks_max_size.instance.id + + environment: + LINODE_UA_PREFIX: '{{ ua_prefix }}' + LINODE_API_TOKEN: '{{ api_token }}' + LINODE_API_URL: '{{ api_url }}' + LINODE_API_VERSION: '{{ api_version }}' + LINODE_CA: '{{ ca_file or "" }}' \ No newline at end of file diff --git a/tests/integration/targets/lke_cluster_basic/tasks/main.yaml b/tests/integration/targets/lke_cluster_basic/tasks/main.yaml index 9f1e0597..203f3eba 100644 --- a/tests/integration/targets/lke_cluster_basic/tasks/main.yaml +++ b/tests/integration/targets/lke_cluster_basic/tasks/main.yaml @@ -16,6 +16,13 @@ # Sometimes only one LKE version is available for provisioning kube_version: '{{ lke_versions[1].id if lke_versions|length > 1 else lke_versions[0].id }}' + - name: List regions that support Disk Encryption + linode.cloud.region_list: {} + register: all_regions + + - set_fact: + lde_region: '{{ (all_regions.regions | selectattr("capabilities", "search", "Disk Encryption") | list)[0].id }}' + - name: Create a Linode LKE cluster linode.cloud.lke_cluster: label: 'ansible-test-{{ r }}' @@ -172,6 +179,23 @@ - info_by_label.node_pools[0].count == 1 - info_by_label.node_pools[0].id == create_cluster.node_pools[0].id + - name: Create a Linode LKE cluster with a pool with disk encryption enabled + linode.cloud.lke_cluster: + label: 'ansible-test-de-{{ r }}' + region: '{{ lde_region }}' + k8s_version: '{{ old_kube_version }}' + node_pools: + - type: g6-standard-1 + count: 3 + skip_polling: true + state: present + register: create_cluster_disk_encryption + + - name: Assert LKE cluster is created + assert: + that: + - create_cluster_disk_encryption.node_pools[0].disk_encryption == 'enabled' + always: - ignore_errors: yes block: @@ -180,6 +204,12 @@ label: '{{ create_cluster.cluster.label }}' state: absent + - name: Delete the LKE cluster + linode.cloud.lke_cluster: + label: '{{ create_cluster_disk_encryption.cluster.label }}' + state: absent + + environment: LINODE_UA_PREFIX: '{{ ua_prefix }}' LINODE_API_TOKEN: '{{ api_token }}' diff --git a/tests/integration/targets/lke_node_pool_basic/tasks/main.yaml b/tests/integration/targets/lke_node_pool_basic/tasks/main.yaml index ff0596eb..52b35ccc 100644 --- a/tests/integration/targets/lke_node_pool_basic/tasks/main.yaml +++ b/tests/integration/targets/lke_node_pool_basic/tasks/main.yaml @@ -10,6 +10,13 @@ - set_fact: kube_version: '{{ lke_versions.lke_versions[0].id }}' + - name: List regions that support Disk Encryption + linode.cloud.region_list: {} + register: all_regions + + - set_fact: + lde_region: '{{ (all_regions.regions | selectattr("capabilities", "search", "Disk Encryption") | list)[0].id }}' + - name: Create a minimal LKE cluster linode.cloud.lke_cluster: label: 'ansible-test-{{ r }}' @@ -107,6 +114,44 @@ - update_pool.node_pool.taints[0].value == 'updated' - update_pool.node_pool.taints[0].effect == 'PreferNoSchedule' + - name: Create a minimal LKE cluster + linode.cloud.lke_cluster: + label: 'ansible-test-de-{{ r }}' + region: '{{ lde_region }}' + k8s_version: '{{ kube_version }}' + node_pools: + - type: g6-standard-1 + count: 1 + skip_polling: true + state: present + register: create_cluster_de + + - name: Assert minimal LKE cluster is created + assert: + that: + - create_cluster_de.cluster.k8s_version == kube_version + - create_cluster_de.node_pools[0].type == 'g6-standard-1' + - create_cluster_de.node_pools[0].count == 1 + + - name: Add a node pool to the cluster + linode.cloud.lke_node_pool: + cluster_id: '{{ create_cluster_de.cluster.id }}' + + tags: ['my-pool'] + type: g6-standard-1 + count: 2 + state: present + register: new_pool_de + + - name: Assert node pool is added to cluster + assert: + that: + - new_pool_de.node_pool.count == 2 + - new_pool_de.node_pool.type == 'g6-standard-1' + - new_pool_de.node_pool.disk_encryption == 'enabled' + - new_pool_de.node_pool.nodes[0].status == 'ready' + - new_pool_de.node_pool.nodes[1].status == 'ready' + always: - ignore_errors: yes block: @@ -119,6 +164,15 @@ linode.cloud.lke_cluster: label: '{{ create_cluster.cluster.label }}' state: absent + - name: Delete the LKE cluster node pool + linode.cloud.lke_node_pool: + cluster_id: '{{ create_cluster_de.cluster.id }}' + tags: ['my-pool'] + state: absent + - name: Delete the LKE cluster + linode.cloud.lke_cluster: + label: '{{ create_cluster_de.cluster.label }}' + state: absent environment: LINODE_UA_PREFIX: '{{ ua_prefix }}' From 7769e338edc210cf58ccfe62f658c752334da683 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 16 Sep 2024 14:05:22 -0400 Subject: [PATCH 8/8] build(deps): bump types-requests from 2.32.0.20240907 to 2.32.0.20240914 (#587) Bumps [types-requests](https://github.com/python/typeshed) from 2.32.0.20240907 to 2.32.0.20240914. - [Commits](https://github.com/python/typeshed/commits) --- updated-dependencies: - dependency-name: types-requests dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> --- requirements.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/requirements.txt b/requirements.txt index e11a49b8..ec5774d6 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,4 +1,4 @@ linode-api4>=5.21.0 polling>=0.3.2 -types-requests==2.32.0.20240907 +types-requests==2.32.0.20240914 ansible-specdoc>=0.0.15