Fixup volume creation functionality
Some checks failed
continuous-integration/drone/push Build is failing
continuous-integration/drone/tag Build is failing

This commit is contained in:
Luke Murphy 2021-01-06 15:21:42 +01:00
parent 5fd3f5ca94
commit 1423840fba
No known key found for this signature in database
GPG Key ID: 5E2EF5A63E3718CC
6 changed files with 34 additions and 31 deletions

View File

@ -14,7 +14,8 @@ new major version of Molecule. If you use the `volumes:` key in your
`molecule.yml` then this change will break your configuration. Please see the `molecule.yml` then this change will break your configuration. Please see the
section on "Volume Handling" in the README.md on how to upgrade successfully. section on "Volume Handling" in the README.md on how to upgrade successfully.
You will now need to install Ansible yourself as Molecule does not do it for You will now need to install Ansible yourself as Molecule does not do it for
you. you. If there are any other breaking changes, please report them on the issue
tracker so that we can mention them here.
- Support Python 3.9. - Support Python 3.9.
- Support Molecule 3.2.1 - Support Molecule 3.2.1

View File

@ -82,11 +82,16 @@ after use.
```yaml ```yaml
volumes: volumes:
name: "molecule-hetznercloud-volume-${INSTANCE_UUID}" - name: "molecule-hetznercloud-volume-1-${INSTANCE_UUID}"
size: 11 - name: "molecule-hetznercloud-volume-2-${INSTANCE_UUID}"
create: true
``` ```
Supported keys are:
- **name** (required): name of volume
- **size** (optional, default: `10GB`): size of volume
- **location** (optional, default: `omitted`): path for volume
## Only use `molecule.yml` for configuration ## Only use `molecule.yml` for configuration
It is being worked on that it is possible to remove all the files except the It is being worked on that it is possible to remove all the files except the

View File

@ -8,9 +8,8 @@ platforms:
server_type: cx11 server_type: cx11
image: debian-10 image: debian-10
volumes: volumes:
name: "molecule-hetznercloud-volume-${INSTANCE_UUID}" - name: "molecule-hetznercloud-volume-1-${INSTANCE_UUID}"
size: 11 # - name: "molecule-hetznercloud-volume-2-${INSTANCE_UUID}"
create: true
provisioner: provisioner:
name: ansible name: ansible
verifier: verifier:

View File

@ -53,16 +53,13 @@
- name: Create volume(s) - name: Create volume(s)
hcloud_volume: hcloud_volume:
name: "{{ item.volumes.name | default(item.name) }}" name: "{{ item.1.name | default(item.0.name) }}"
server: "{{ item.name }}" server: "{{ item.0.name }}"
location: "{{ item.volumes.location | default(omit) }}" location: "{{ item.1.location | default(omit) }}"
size: "{{ item.volumes.size | default(10) }}" size: "{{ item.1.size | default(10) }}"
api_token: "{{ lookup('env', 'HCLOUD_TOKEN') }}" api_token: "{{ lookup('env', 'HCLOUD_TOKEN') }}"
state: "present" state: "present"
with_items: "{{ molecule_yml.platforms }}" loop: "{{ molecule_yml.platforms|subelements('volumes', skip_missing=True)}}"
when:
- item.volumes is defined
- item.volumes.create | default(False) | bool
register: volumes register: volumes
async: 7200 async: 7200
poll: 0 poll: 0
@ -73,19 +70,23 @@
register: hetzner_volumes register: hetzner_volumes
until: hetzner_volumes.finished until: hetzner_volumes.finished
retries: 300 retries: 300
when: volumes.changed when:
- volumes is defined
- volumes.changed
with_items: "{{ volumes.results }}" with_items: "{{ volumes.results }}"
- name: Populate instance config dict - name: Populate instance config dict
set_fact: set_fact:
instance_conf_dict: { instance_conf_dict:
'instance': "{{ item.hcloud_server.name }}", {
'ssh_key_name': "{{ ssh_key_name }}", "instance": "{{ item.hcloud_server.name }}",
'address': "{{ item.hcloud_server.ipv4_address }}", "ssh_key_name": "{{ ssh_key_name }}",
'user': "{{ ssh_user }}", "address": "{{ item.hcloud_server.ipv4_address }}",
'port': "{{ ssh_port }}", "user": "{{ ssh_user }}",
'identity_file': "{{ ssh_path }}", "port": "{{ ssh_port }}",
'volumes': "{{ item.item.item.volumes | default({}) }}", } "identity_file": "{{ ssh_path }}",
"volumes": "{{ item.item.item.volumes | default({}) }}",
}
with_items: "{{ hetzner_jobs.results }}" with_items: "{{ hetzner_jobs.results }}"
register: instance_config_dict register: instance_config_dict
when: server.changed | bool when: server.changed | bool

View File

@ -41,12 +41,9 @@
name: "{{ item.volumes.name | default(item.instance) }}" name: "{{ item.volumes.name | default(item.instance) }}"
server: "{{ item.instance }}" server: "{{ item.instance }}"
api_token: "{{ lookup('env', 'HCLOUD_TOKEN') }}" api_token: "{{ lookup('env', 'HCLOUD_TOKEN') }}"
state: "absent" state: absent
register: volumes register: volumes
with_items: "{{ instance_conf }}" with_items: "{{ instance_conf }}"
when:
- item.volumes is defined
- item.volumes.create | default(False) | bool
async: 7200 async: 7200
poll: 0 poll: 0

View File

@ -10,7 +10,7 @@ def _model_platform_hetznercloud_section_data():
{ {
"name": "instance", "name": "instance",
"server_type": "", "server_type": "",
"volumes": {}, "volumes": [],
"image": "", "image": "",
"location": "", "location": "",
"datacenter": "", "datacenter": "",
@ -57,7 +57,7 @@ def test_platforms_hetznercloud_has_errors(_config):
{ {
"name": ["must be of string type"], "name": ["must be of string type"],
"server_type": ["must be of string type"], "server_type": ["must be of string type"],
"volumes": ["must be of dict type"], "volumes": ["must be of list type"],
"image": ["must be of string type"], "image": ["must be of string type"],
"location": ["must be of string type"], "location": ["must be of string type"],
"datacenter": ["must be of string type"], "datacenter": ["must be of string type"],