Docker volume fix labels (#48536)
* Add integration test for labels (which fails).
* Changing labels from list to dict.
* Add changelog.
(cherry picked from commit feb60b947c
)
This commit is contained in:
parent
709845436e
commit
b126a21963
3 changed files with 56 additions and 4 deletions
2
changelogs/fragments/48536-docker_volume-labels.yml
Normal file
2
changelogs/fragments/48536-docker_volume-labels.yml
Normal file
|
@ -0,0 +1,2 @@
|
|||
bugfixes:
|
||||
- "docker_volume - ``labels`` now work (and are a ``dict`` and no longer a ``list``)."
|
|
@ -25,6 +25,7 @@ options:
|
|||
description:
|
||||
- Name of the volume to operate on.
|
||||
required: true
|
||||
type: dict
|
||||
aliases:
|
||||
- volume_name
|
||||
|
||||
|
@ -32,15 +33,18 @@ options:
|
|||
description:
|
||||
- Specify the type of volume. Docker provides the C(local) driver, but 3rd party drivers can also be used.
|
||||
default: local
|
||||
type: str
|
||||
|
||||
driver_options:
|
||||
description:
|
||||
- "Dictionary of volume settings. Consult docker docs for valid options and values:
|
||||
U(https://docs.docker.com/engine/reference/commandline/volume_create/#driver-specific-options)"
|
||||
type: dict
|
||||
|
||||
labels:
|
||||
description:
|
||||
- List of labels to set for the volume
|
||||
- Dictionary of label key/values to set for the volume
|
||||
type: dict
|
||||
|
||||
force:
|
||||
description:
|
||||
|
@ -185,8 +189,7 @@ class DockerVolumeManager(object):
|
|||
differences.append('driver_options.%s' % key)
|
||||
if self.parameters.labels:
|
||||
existing_labels = self.existing_volume.get('Labels', {})
|
||||
all_labels = set(self.parameters.labels) | set(existing_labels)
|
||||
for label in all_labels:
|
||||
for label in self.parameters.labels:
|
||||
if existing_labels.get(label) != self.parameters.labels.get(label):
|
||||
differences.append('labels.%s' % label)
|
||||
|
||||
|
@ -247,7 +250,7 @@ def main():
|
|||
state=dict(type='str', default='present', choices=['present', 'absent']),
|
||||
driver=dict(type='str', default='local'),
|
||||
driver_options=dict(type='dict', default={}),
|
||||
labels=dict(type='list'),
|
||||
labels=dict(type='dict'),
|
||||
force=dict(type='bool', default=False),
|
||||
debug=dict(type='bool', default=False)
|
||||
)
|
||||
|
|
|
@ -90,3 +90,50 @@
|
|||
- driver_options_1 is changed
|
||||
- driver_options_2 is not changed
|
||||
- driver_options_3 is changed
|
||||
|
||||
####################################################################
|
||||
## labels ##########################################################
|
||||
####################################################################
|
||||
|
||||
- name: Create a volume with labels
|
||||
docker_volume:
|
||||
name: "{{ vname }}"
|
||||
labels:
|
||||
ansible.test.1: hello
|
||||
ansible.test.2: world
|
||||
register: driver_labels_1
|
||||
|
||||
- name: Create a volume with labels (idempotency)
|
||||
docker_volume:
|
||||
name: "{{ vname }}"
|
||||
labels:
|
||||
ansible.test.2: world
|
||||
ansible.test.1: hello
|
||||
register: driver_labels_2
|
||||
|
||||
- name: Create a volume with labels (less)
|
||||
docker_volume:
|
||||
name: "{{ vname }}"
|
||||
labels:
|
||||
ansible.test.1: hello
|
||||
register: driver_labels_3
|
||||
|
||||
- name: Create a volume with labels (more)
|
||||
docker_volume:
|
||||
name: "{{ vname }}"
|
||||
labels:
|
||||
ansible.test.1: hello
|
||||
ansible.test.3: ansible
|
||||
register: driver_labels_4
|
||||
|
||||
- name: Cleanup
|
||||
docker_volume:
|
||||
name: "{{ vname }}"
|
||||
state: absent
|
||||
|
||||
- assert:
|
||||
that:
|
||||
- driver_labels_1 is changed
|
||||
- driver_labels_2 is not changed
|
||||
- driver_labels_3 is not changed
|
||||
- driver_labels_4 is changed
|
||||
|
|
Loading…
Add table
Reference in a new issue