Ensure coe_cluster_template compare labels properly

SDK does return all keys and values of the template labels as
strings. At the same time user can define some labels as integers or
booleans, which will break comparison of labels and lead to module
failure on consecutive runs.

Change-Id: I7ab624428c8bb06030a2b28888f5cb89bb249f08
This commit is contained in:
Dmitriy Rabotyagov 2023-05-02 19:21:15 +02:00 committed by Dmitriy Rabotyagov
parent e6379e3038
commit 40a384214c
3 changed files with 16 additions and 0 deletions

View File

@ -0,0 +1,7 @@
---
bugfixes:
- |
coe_cluster_template - now labels are converted to strings by module that
fixes module idempotence in case label values defined by users are
integers or booleans.

View File

@ -26,6 +26,9 @@
keypair_id: '{{ keypair.keypair.id }}' keypair_id: '{{ keypair.keypair.id }}'
name: k8s name: k8s
state: present state: present
labels:
docker_volume_size: 10
cloud_provider_tag: v1.23.1
register: coe_cluster_template register: coe_cluster_template
- name: Assert return values of coe_cluster_template module - name: Assert return values of coe_cluster_template module
@ -43,6 +46,9 @@
keypair_id: '{{ keypair.keypair.id }}' keypair_id: '{{ keypair.keypair.id }}'
name: k8s name: k8s
state: present state: present
labels:
docker_volume_size: 10
cloud_provider_tag: v1.23.1
register: coe_cluster_template register: coe_cluster_template
- name: Assert return values of coe_cluster_template module - name: Assert return values of coe_cluster_template module

View File

@ -433,6 +433,9 @@ class COEClusterTemplateModule(OpenStackModule):
if isinstance(labels, str): if isinstance(labels, str):
labels = dict([tuple(kv.split(":")) labels = dict([tuple(kv.split(":"))
for kv in labels.split(",")]) for kv in labels.split(",")])
elif isinstance(labels, dict):
labels = dict({str(k): str(v)
for k, v in labels.items()})
if labels != cluster_template['labels']: if labels != cluster_template['labels']:
non_updateable_keys.append('labels') non_updateable_keys.append('labels')