ansible/test/integration/targets/vultr_server/tasks/main.yml
René Moser 1705ef5f26
vultr_server: fix idempotency for private network and IPv6 options (#55619)
* vultr_server: fix idempotency for private network and IPv6 options

* add changelog
2019-04-23 21:22:17 +02:00

515 lines
15 KiB
YAML

# Copyright (c) 2018, René Moser <mail@renemoser.net>
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
---
- name: setup
vultr_server:
name: "{{ vultr_server_name }}"
state: absent
register: result
- name: verify setup
assert:
that:
- result is success
# Servers can only be destroyed 5 min after creation
- name: wait for 5 min
local_action: wait_for
when: result is changed
- name: test fail if missing name
vultr_server:
register: result
ignore_errors: yes
- name: verify test fail if missing name
assert:
that:
- result is failed
- 'result.msg == "missing required arguments: name"'
- name: test fail if missing params for state=present
vultr_server:
name: "{{ vultr_server_name }}"
register: result
ignore_errors: yes
- name: verify fail if missing params for state=present
assert:
that:
- result is failed
- 'result.msg == "missing required arguments: os, plan, region"'
- name: setup create ssh keys
vultr_ssh_key:
name: "{{ item.name }}"
ssh_key: "{{ item.key }}"
loop: "{{ vultr_server_ssh_keys }}"
- name: test create server in check mode
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_1 }}"
ssh_keys:
- key1
- key2
region: Amsterdam
state: started
register: result
check_mode: yes
- name: verify test create server in check mode
assert:
that:
- result is changed
- name: test create server
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_1 }}"
ssh_keys:
- key1
- key2
region: Amsterdam
state: started
register: result
- name: verify test create server
assert:
that:
- result is changed
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_1
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.power_status == 'running'
- name: test create server idempotence
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_1 }}"
ssh_keys:
- key1
- key2
region: Amsterdam
state: started
register: result
- name: verify test create server idempotence
assert:
that:
- result is not changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_1
- result.vultr_server.region == 'Amsterdam'
- name: test stop an existing server in check mode
vultr_server:
name: "{{ vultr_server_name }}"
state: stopped
register: result
check_mode: yes
- name: verify test stop server in check mode
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- name: test stop an existing server
vultr_server:
name: "{{ vultr_server_name }}"
state: stopped
register: result
- name: verify test stop an existing server
assert:
that:
- result is changed
- result.vultr_server.power_status == 'stopped'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- name: test stop an existing server idempotence
vultr_server:
name: "{{ vultr_server_name }}"
state: stopped
register: result
- name: verify test stop an existing server idempotence
assert:
that:
- result is not changed
- result.vultr_server.power_status == 'stopped'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- name: test start an existing server in check mode
vultr_server:
name: "{{ vultr_server_name }}"
state: started
register: result
check_mode: yes
- name: verify test start an existing server in check mode
assert:
that:
- result is changed
- result.vultr_server.power_status == 'stopped'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- name: test start an existing server
vultr_server:
name: "{{ vultr_server_name }}"
state: started
register: result
- name: verify test start an existing server
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- name: test start an existing server idempotence
vultr_server:
name: "{{ vultr_server_name }}"
state: started
register: result
- name: verify test start an existing server idempotence
assert:
that:
- result is not changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- name: test update plan for server in check mode without force
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_2 }}"
region: Amsterdam
register: result
check_mode: yes
- name: verify test update plan for server in check mode without force
assert:
that:
- result is not changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_1
- result.vultr_server.region == 'Amsterdam'
- name: test update plan for server without force
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_2 }}"
region: Amsterdam
register: result
- name: verify test update plan for server without force
assert:
that:
- result is not changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_1
- result.vultr_server.region == 'Amsterdam'
- name: setup firewall group
vultr_firewall_group:
name: test_firewall_group
register: result
- name: verify test create firewall group
assert:
that:
- result is success
- name: test fail with unknown firewall group
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
region: Amsterdam
firewall_group: does not exist
tag: test_tag
register: result
ignore_errors: yes
check_mode: yes
- name: verify test fail with unknown firewall group
assert:
that:
- result is failed
- result.msg.startswith('Could not find')
- name: test update tag, firewall group for server in check mode without force
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
region: Amsterdam
firewall_group: test_firewall_group
tag: test_tag
register: result
check_mode: yes
- name: verify test update tag, firewall group for server in check mode without force
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_1
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.tag == ''
- result.vultr_server.firewall_group != 'test_firewall_group'
- name: test update tag, firewall group for server without force
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
region: Amsterdam
firewall_group: test_firewall_group
tag: test_tag
register: result
- name: verify test update tag, firewall group for server without force
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.tag == 'test_tag'
- result.vultr_server.firewall_group == 'test_firewall_group'
- name: test update tag, firewall group for server without force idempotence
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
region: Amsterdam
firewall_group: test_firewall_group
tag: test_tag
register: result
- name: verify test update tag, firewall group for server without force idempotence
assert:
that:
- result is not changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.tag == 'test_tag'
- result.vultr_server.firewall_group == 'test_firewall_group'
- name: test update server in check mode with force
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_2 }}"
auto_backup_enabled: yes
private_network_enabled: yes
region: Amsterdam
force: yes
register: result
check_mode: yes
- name: verify test update server in check mode with force
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_1
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.auto_backup_enabled == false
- result.vultr_server.internal_ip == ''
- name: test update server with force
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_2 }}"
auto_backup_enabled: yes
private_network_enabled: yes
region: Amsterdam
force: yes
register: result
- name: verify test update server with force
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_2
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.auto_backup_enabled == true
- result.vultr_server.internal_ip != ''
- name: test update server idempotence with force
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_2 }}"
auto_backup_enabled: yes
private_network_enabled: yes
region: Amsterdam
force: yes
register: result
- name: verify test update server idempotence with force
assert:
that:
- result is not changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_2
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.auto_backup_enabled == true
- result.vultr_server.internal_ip != ''
- name: test update server to stopped in check mode
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_2 }}"
ipv6_enabled: yes
region: Amsterdam
state: stopped
register: result
check_mode: yes
- name: verify test update server to stopped in check mode
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_2
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.v6_main_ip == ''
- name: test update server to stopped
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_2 }}"
ipv6_enabled: yes
region: Amsterdam
state: stopped
register: result
- name: verify test update server to stopped
assert:
that:
- result is changed
- result.vultr_server.power_status == 'stopped'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_2
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.v6_main_ip != ''
- name: test update server to stopped idempotence
vultr_server:
name: "{{ vultr_server_name }}"
os: CentOS 6 x64
plan: "{{ vultr_server_plan_2 }}"
ipv6_enabled: yes
region: Amsterdam
state: stopped
register: result
- name: verify test update server to stopped idempotence
assert:
that:
- result is not changed
- result.vultr_server.power_status == 'stopped'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.plan == vultr_server_plan_2
- result.vultr_server.region == 'Amsterdam'
- result.vultr_server.v6_main_ip != ''
- name: test restart an existing server in check mode
vultr_server:
name: "{{ vultr_server_name }}"
state: restarted
register: result
check_mode: yes
- name: verify test restart an existing server in check mode
assert:
that:
- result is changed
- result.vultr_server.power_status == 'stopped'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- name: test restart an existing server
vultr_server:
name: "{{ vultr_server_name }}"
state: restarted
register: result
- name: verify test restart an existing server
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- name: test absent server in check mode
vultr_server:
name: "{{ vultr_server_name }}"
state: absent
register: result
check_mode: yes
- name: verify test absent server in check mode
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
# Servers can only be destroyed 5 min after creation
- name: wait for 5 min
local_action: wait_for
- name: test absent server
vultr_server:
name: "{{ vultr_server_name }}"
state: absent
register: result
- name: verify test absent server
assert:
that:
- result is changed
- result.vultr_server.power_status == 'running'
- result.vultr_server.name == vultr_server_name
- result.vultr_server.os == 'CentOS 6 x64'
- result.vultr_server.region == 'Amsterdam'
- name: test absent server idempotence
vultr_server:
name: "{{ vultr_server_name }}"
state: absent
register: result
- name: verify test absent server idempotence
assert:
that:
- result is not changed
- name: cleanup ssh keys
vultr_ssh_key:
name: "{{ item.name }}"
ssh_key: "{{ item.key }}"
state: absent
loop: "{{ vultr_server_ssh_keys }}"