mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
cs_vpc: add new argument clean_up (#33278)
* cs_vpc: add new argument clean_up * docs cleanup * extend tests and increase coverage * change default for clean_up to None * extend tests
This commit is contained in:
parent
c800048e93
commit
1a546711e1
2 changed files with 175 additions and 76 deletions
|
@ -1,22 +1,8 @@
|
||||||
#!/usr/bin/python
|
#!/usr/bin/python
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
# (c) 2016, René Moser <mail@renemoser.net>
|
# Copyright (c) 2016, René Moser <mail@renemoser.net>
|
||||||
#
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||||
# This file is part of Ansible
|
|
||||||
#
|
|
||||||
# Ansible is free software: you can redistribute it an/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published by
|
|
||||||
# the Free Software Foundation, either version 3 of the License, or
|
|
||||||
# (at your option) any later version.
|
|
||||||
#
|
|
||||||
# Ansible is distributed in the hope that it will be useful,
|
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
# GNU General Public License for more details.
|
|
||||||
#
|
|
||||||
# You should have received a copy of the GNU General Public License
|
|
||||||
# along with Ansible. If not, see <http//www.gnu.or/license/>.
|
|
||||||
|
|
||||||
ANSIBLE_METADATA = {'metadata_version': '1.1',
|
ANSIBLE_METADATA = {'metadata_version': '1.1',
|
||||||
'status': ['stableinterface'],
|
'status': ['stableinterface'],
|
||||||
|
@ -40,31 +26,26 @@ options:
|
||||||
description:
|
description:
|
||||||
- "Display text of the VPC."
|
- "Display text of the VPC."
|
||||||
- "If not set, C(name) will be used for creating."
|
- "If not set, C(name) will be used for creating."
|
||||||
required: false
|
|
||||||
default: null
|
|
||||||
cidr:
|
cidr:
|
||||||
description:
|
description:
|
||||||
- "CIDR of the VPC, e.g. 10.1.0.0/16"
|
- "CIDR of the VPC, e.g. 10.1.0.0/16"
|
||||||
- "All VPC guest networks' CIDRs must be within this CIDR."
|
- "All VPC guest networks' CIDRs must be within this CIDR."
|
||||||
- "Required on C(state=present)."
|
- "Required on C(state=present)."
|
||||||
required: false
|
|
||||||
default: null
|
|
||||||
network_domain:
|
network_domain:
|
||||||
description:
|
description:
|
||||||
- "Network domain for the VPC."
|
- "Network domain for the VPC."
|
||||||
- "All networks inside the VPC will belong to this domain."
|
- "All networks inside the VPC will belong to this domain."
|
||||||
required: false
|
|
||||||
default: null
|
|
||||||
vpc_offering:
|
vpc_offering:
|
||||||
description:
|
description:
|
||||||
- "Name of the VPC offering."
|
- "Name of the VPC offering."
|
||||||
- "If not set, default VPC offering is used."
|
- "If not set, default VPC offering is used."
|
||||||
required: false
|
clean_up:
|
||||||
default: null
|
description:
|
||||||
|
- "Whether to redeploy a VPC router or not when C(state=restarted)"
|
||||||
|
version_added: "2.5"
|
||||||
state:
|
state:
|
||||||
description:
|
description:
|
||||||
- "State of the VPC."
|
- "State of the VPC."
|
||||||
required: false
|
|
||||||
default: present
|
default: present
|
||||||
choices:
|
choices:
|
||||||
- present
|
- present
|
||||||
|
@ -73,58 +54,48 @@ options:
|
||||||
domain:
|
domain:
|
||||||
description:
|
description:
|
||||||
- "Domain the VPC is related to."
|
- "Domain the VPC is related to."
|
||||||
required: false
|
|
||||||
default: null
|
|
||||||
account:
|
account:
|
||||||
description:
|
description:
|
||||||
- "Account the VPC is related to."
|
- "Account the VPC is related to."
|
||||||
required: false
|
|
||||||
default: null
|
|
||||||
project:
|
project:
|
||||||
description:
|
description:
|
||||||
- "Name of the project the VPC is related to."
|
- "Name of the project the VPC is related to."
|
||||||
required: false
|
|
||||||
default: null
|
|
||||||
zone:
|
zone:
|
||||||
description:
|
description:
|
||||||
- "Name of the zone."
|
- "Name of the zone."
|
||||||
- "If not set, default zone is used."
|
- "If not set, default zone is used."
|
||||||
required: false
|
|
||||||
default: null
|
|
||||||
tags:
|
tags:
|
||||||
description:
|
description:
|
||||||
- "List of tags. Tags are a list of dictionaries having keys C(key) and C(value)."
|
- "List of tags. Tags are a list of dictionaries having keys C(key) and C(value)."
|
||||||
- "For deleting all tags, set an empty list e.g. C(tags: [])."
|
- "For deleting all tags, set an empty list e.g. C(tags: [])."
|
||||||
required: false
|
|
||||||
default: null
|
|
||||||
aliases:
|
aliases:
|
||||||
- tag
|
- tag
|
||||||
poll_async:
|
poll_async:
|
||||||
description:
|
description:
|
||||||
- "Poll async jobs until job has finished."
|
- "Poll async jobs until job has finished."
|
||||||
required: false
|
|
||||||
default: true
|
default: true
|
||||||
extends_documentation_fragment: cloudstack
|
extends_documentation_fragment: cloudstack
|
||||||
'''
|
'''
|
||||||
|
|
||||||
EXAMPLES = '''
|
EXAMPLES = '''
|
||||||
# Ensure a VPC is present
|
- name: Ensure a VPC is present
|
||||||
- local_action:
|
local_action:
|
||||||
module: cs_vpc
|
module: cs_vpc
|
||||||
name: my_vpc
|
name: my_vpc
|
||||||
display_text: My example VPC
|
display_text: My example VPC
|
||||||
cidr: 10.10.0.0/16
|
cidr: 10.10.0.0/16
|
||||||
|
|
||||||
# Ensure a VPC is absent
|
- name: Ensure a VPC is absent
|
||||||
- local_action:
|
local_action:
|
||||||
module: cs_vpc
|
module: cs_vpc
|
||||||
name: my_vpc
|
name: my_vpc
|
||||||
state: absent
|
state: absent
|
||||||
|
|
||||||
# Ensure a VPC is restarted
|
- name: Ensure a VPC is restarted with clean up
|
||||||
- local_action:
|
local_action:
|
||||||
module: cs_vpc
|
module: cs_vpc
|
||||||
name: my_vpc
|
name: my_vpc
|
||||||
|
clean_up: true
|
||||||
state: restarted
|
state: restarted
|
||||||
'''
|
'''
|
||||||
|
|
||||||
|
@ -228,12 +199,8 @@ class AnsibleCloudStackVpc(AnsibleCloudStack):
|
||||||
'restartrequired': 'restart_required',
|
'restartrequired': 'restart_required',
|
||||||
}
|
}
|
||||||
self.vpc = None
|
self.vpc = None
|
||||||
self.vpc_offering = None
|
|
||||||
|
|
||||||
def get_vpc_offering(self, key=None):
|
def get_vpc_offering(self, key=None):
|
||||||
if self.vpc_offering:
|
|
||||||
return self._get_by_key(key, self.vpc_offering)
|
|
||||||
|
|
||||||
vpc_offering = self.module.params.get('vpc_offering')
|
vpc_offering = self.module.params.get('vpc_offering')
|
||||||
args = {}
|
args = {}
|
||||||
if vpc_offering:
|
if vpc_offering:
|
||||||
|
@ -243,9 +210,8 @@ class AnsibleCloudStackVpc(AnsibleCloudStack):
|
||||||
|
|
||||||
vpc_offerings = self.query_api('listVPCOfferings', **args)
|
vpc_offerings = self.query_api('listVPCOfferings', **args)
|
||||||
if vpc_offerings:
|
if vpc_offerings:
|
||||||
self.vpc_offering = vpc_offerings['vpcoffering'][0]
|
return self._get_by_key(key, vpc_offerings['vpcoffering'][0])
|
||||||
return self._get_by_key(key, self.vpc_offering)
|
self.module.fail_json(msg="VPC offering not found: %s" % vpc_offering)
|
||||||
self.module.fail_json(msg="VPC offering '%s' not found" % vpc_offering)
|
|
||||||
|
|
||||||
def get_vpc(self):
|
def get_vpc(self):
|
||||||
if self.vpc:
|
if self.vpc:
|
||||||
|
@ -263,7 +229,7 @@ class AnsibleCloudStackVpc(AnsibleCloudStack):
|
||||||
if vpc_name in [v['name'], v['displaytext'], v['id']]:
|
if vpc_name in [v['name'], v['displaytext'], v['id']]:
|
||||||
# Fail if the identifyer matches more than one VPC
|
# Fail if the identifyer matches more than one VPC
|
||||||
if self.vpc:
|
if self.vpc:
|
||||||
self.module.fail_json(msg="More than one VPC found with the provided identifyer '%s'" % vpc_name)
|
self.module.fail_json(msg="More than one VPC found with the provided identifyer: %s" % vpc_name)
|
||||||
else:
|
else:
|
||||||
self.vpc = v
|
self.vpc = v
|
||||||
return self.vpc
|
return self.vpc
|
||||||
|
@ -274,6 +240,7 @@ class AnsibleCloudStackVpc(AnsibleCloudStack):
|
||||||
if vpc and not self.module.check_mode:
|
if vpc and not self.module.check_mode:
|
||||||
args = {
|
args = {
|
||||||
'id': vpc['id'],
|
'id': vpc['id'],
|
||||||
|
'cleanup': self.module.params.get('clean_up'),
|
||||||
}
|
}
|
||||||
res = self.query_api('restartVPC', **args)
|
res = self.query_api('restartVPC', **args)
|
||||||
|
|
||||||
|
@ -347,16 +314,17 @@ def main():
|
||||||
argument_spec = cs_argument_spec()
|
argument_spec = cs_argument_spec()
|
||||||
argument_spec.update(dict(
|
argument_spec.update(dict(
|
||||||
name=dict(required=True),
|
name=dict(required=True),
|
||||||
cidr=dict(default=None),
|
cidr=dict(),
|
||||||
display_text=dict(default=None),
|
display_text=dict(),
|
||||||
vpc_offering=dict(default=None),
|
vpc_offering=dict(),
|
||||||
network_domain=dict(default=None),
|
network_domain=dict(),
|
||||||
|
clean_up=dict(type='bool'),
|
||||||
state=dict(choices=['present', 'absent', 'restarted'], default='present'),
|
state=dict(choices=['present', 'absent', 'restarted'], default='present'),
|
||||||
domain=dict(default=None),
|
domain=dict(),
|
||||||
account=dict(default=None),
|
account=dict(),
|
||||||
project=dict(default=None),
|
project=dict(),
|
||||||
zone=dict(default=None),
|
zone=dict(),
|
||||||
tags=dict(type='list', aliases=['tag'], default=None),
|
tags=dict(type='list', aliases=['tag']),
|
||||||
poll_async=dict(type='bool', default=True),
|
poll_async=dict(type='bool', default=True),
|
||||||
))
|
))
|
||||||
|
|
||||||
|
|
|
@ -33,7 +33,70 @@
|
||||||
- vpc|failed
|
- vpc|failed
|
||||||
- 'vpc.msg == "state is present but all of the following are missing: cidr"'
|
- 'vpc.msg == "state is present but all of the following are missing: cidr"'
|
||||||
|
|
||||||
- name: test create vpc in check mode
|
- name: test fail missing vpc offering not found
|
||||||
|
cs_vpc:
|
||||||
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
|
vpc_offering: does_not_exist
|
||||||
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
|
cidr: 10.10.1.0/16
|
||||||
|
ignore_errors: true
|
||||||
|
register: vpc
|
||||||
|
- name: verify test fail missing cidr for vpc
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- vpc|failed
|
||||||
|
- 'vpc.msg == "VPC offering not found: does_not_exist"'
|
||||||
|
|
||||||
|
- name: test create vpc with custom offering in check mode
|
||||||
|
cs_vpc:
|
||||||
|
name: "{{ cs_resource_prefix }}_vpc_custom"
|
||||||
|
display_text: "{{ cs_resource_prefix }}_display_text_custom"
|
||||||
|
cidr: 10.10.1.0/16
|
||||||
|
vpc_offering: Redundant VPC offering
|
||||||
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
|
register: vpc
|
||||||
|
check_mode: true
|
||||||
|
- name: verify test create vpc with custom offering in check mode
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- vpc|success
|
||||||
|
- vpc|changed
|
||||||
|
|
||||||
|
- name: test create vpc with custom offering
|
||||||
|
cs_vpc:
|
||||||
|
name: "{{ cs_resource_prefix }}_vpc_custom"
|
||||||
|
display_text: "{{ cs_resource_prefix }}_display_text_custom"
|
||||||
|
cidr: 10.10.1.0/16
|
||||||
|
vpc_offering: Redundant VPC offering
|
||||||
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
|
register: vpc
|
||||||
|
- name: verify test create vpc with custom offering
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- vpc|success
|
||||||
|
- vpc|changed
|
||||||
|
- vpc.name == "{{ cs_resource_prefix }}_vpc_custom"
|
||||||
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text_custom"
|
||||||
|
- vpc.cidr == "10.10.1.0/16"
|
||||||
|
|
||||||
|
- name: test create vpc with custom offering idempotence
|
||||||
|
cs_vpc:
|
||||||
|
name: "{{ cs_resource_prefix }}_vpc_custom"
|
||||||
|
display_text: "{{ cs_resource_prefix }}_display_text_custom"
|
||||||
|
cidr: 10.10.1.0/16
|
||||||
|
vpc_offering: Redundant VPC offering
|
||||||
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
|
register: vpc
|
||||||
|
- name: verify test create vpc with custom offering idempotence
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- vpc|success
|
||||||
|
- not vpc|changed
|
||||||
|
- vpc.name == "{{ cs_resource_prefix }}_vpc_custom"
|
||||||
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text_custom"
|
||||||
|
- vpc.cidr == "10.10.1.0/16"
|
||||||
|
|
||||||
|
- name: test create vpc with default offering in check mode
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
display_text: "{{ cs_resource_prefix }}_display_text"
|
display_text: "{{ cs_resource_prefix }}_display_text"
|
||||||
|
@ -41,20 +104,20 @@
|
||||||
zone: "{{ cs_common_zone_adv }}"
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
register: vpc
|
register: vpc
|
||||||
check_mode: true
|
check_mode: true
|
||||||
- name: verify test create vpc in check mode
|
- name: verify test create vpc with default offering in check mode
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- vpc|success
|
- vpc|success
|
||||||
- vpc|changed
|
- vpc|changed
|
||||||
|
|
||||||
- name: test create vpc
|
- name: test create vpc with default offering
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
display_text: "{{ cs_resource_prefix }}_display_text"
|
display_text: "{{ cs_resource_prefix }}_display_text"
|
||||||
cidr: 10.10.0.0/16
|
cidr: 10.10.0.0/16
|
||||||
zone: "{{ cs_common_zone_adv }}"
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
register: vpc
|
register: vpc
|
||||||
- name: verify test create vpc
|
- name: verify test create vpc with default offering
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- vpc|success
|
- vpc|success
|
||||||
|
@ -63,14 +126,14 @@
|
||||||
- vpc.display_text == "{{ cs_resource_prefix }}_display_text"
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text"
|
||||||
- vpc.cidr == "10.10.0.0/16"
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
- name: test create vpc idempotence
|
- name: test create vpc with default offering idempotence
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
display_text: "{{ cs_resource_prefix }}_display_text"
|
display_text: "{{ cs_resource_prefix }}_display_text"
|
||||||
cidr: 10.10.0.0/16
|
cidr: 10.10.0.0/16
|
||||||
zone: "{{ cs_common_zone_adv }}"
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
register: vpc
|
register: vpc
|
||||||
- name: verify test create vpc idempotence
|
- name: verify test create vpc with default offering idempotence
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- vpc|success
|
- vpc|success
|
||||||
|
@ -79,7 +142,7 @@
|
||||||
- vpc.display_text == "{{ cs_resource_prefix }}_display_text"
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text"
|
||||||
- vpc.cidr == "10.10.0.0/16"
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
- name: test create vpc idempotence2
|
- name: test create vpc with default offering idempotence2
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
cidr: 10.10.0.0/16
|
cidr: 10.10.0.0/16
|
||||||
|
@ -94,7 +157,7 @@
|
||||||
- vpc.display_text == "{{ cs_resource_prefix }}_display_text"
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text"
|
||||||
- vpc.cidr == "10.10.0.0/16"
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
- name: test update vpc in check mode
|
- name: test update vpc with default offering in check mode
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
display_text: "{{ cs_resource_prefix }}_display_text2"
|
display_text: "{{ cs_resource_prefix }}_display_text2"
|
||||||
|
@ -102,7 +165,7 @@
|
||||||
zone: "{{ cs_common_zone_adv }}"
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
register: vpc
|
register: vpc
|
||||||
check_mode: true
|
check_mode: true
|
||||||
- name: verify test update vpc in check mode
|
- name: verify test update vpc with default offering in check mode
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- vpc|success
|
- vpc|success
|
||||||
|
@ -111,14 +174,14 @@
|
||||||
- vpc.display_text == "{{ cs_resource_prefix }}_display_text"
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text"
|
||||||
- vpc.cidr == "10.10.0.0/16"
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
- name: test update vpc
|
- name: test update vpc with default offering
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
display_text: "{{ cs_resource_prefix }}_display_text2"
|
display_text: "{{ cs_resource_prefix }}_display_text2"
|
||||||
cidr: 10.10.0.0/16
|
cidr: 10.10.0.0/16
|
||||||
zone: "{{ cs_common_zone_adv }}"
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
register: vpc
|
register: vpc
|
||||||
- name: verify test update vpc
|
- name: verify test update vpc with default offering
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- vpc|success
|
- vpc|success
|
||||||
|
@ -127,7 +190,7 @@
|
||||||
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
||||||
- vpc.cidr == "10.10.0.0/16"
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
- name: test update vpc idempotence
|
- name: test update vpc with default offering idempotence
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
display_text: "{{ cs_resource_prefix }}_display_text2"
|
display_text: "{{ cs_resource_prefix }}_display_text2"
|
||||||
|
@ -143,6 +206,60 @@
|
||||||
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
||||||
- vpc.cidr == "10.10.0.0/16"
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
|
- name: test restart vpc with default offering with clean up in check mode
|
||||||
|
cs_vpc:
|
||||||
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
|
display_text: "{{ cs_resource_prefix }}_display_text2"
|
||||||
|
cidr: 10.10.0.0/16
|
||||||
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
|
clean_up: true
|
||||||
|
state: restarted
|
||||||
|
register: vpc
|
||||||
|
check_mode: true
|
||||||
|
- name: verify test restart vpc with default offering with clean up in check mode
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- vpc|success
|
||||||
|
- vpc|changed
|
||||||
|
- vpc.name == "{{ cs_resource_prefix }}_vpc"
|
||||||
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
||||||
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
|
- name: test restart vpc with default offering with clean up
|
||||||
|
cs_vpc:
|
||||||
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
|
display_text: "{{ cs_resource_prefix }}_display_text2"
|
||||||
|
cidr: 10.10.0.0/16
|
||||||
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
|
clean_up: true
|
||||||
|
state: restarted
|
||||||
|
register: vpc
|
||||||
|
- name: verify test restart vpc with default offering with clean up
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- vpc|success
|
||||||
|
- vpc|changed
|
||||||
|
- vpc.name == "{{ cs_resource_prefix }}_vpc"
|
||||||
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
||||||
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
|
- name: test restart vpc with default offering without clean up
|
||||||
|
cs_vpc:
|
||||||
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
|
display_text: "{{ cs_resource_prefix }}_display_text2"
|
||||||
|
cidr: 10.10.0.0/16
|
||||||
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
|
state: restarted
|
||||||
|
register: vpc
|
||||||
|
- name: verify test restart vpc with default offering without clean up
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- vpc|success
|
||||||
|
- vpc|changed
|
||||||
|
- vpc.name == "{{ cs_resource_prefix }}_vpc"
|
||||||
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
||||||
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
- name: test create network in vpc in check mode
|
- name: test create network in vpc in check mode
|
||||||
cs_network:
|
cs_network:
|
||||||
name: "{{ cs_resource_prefix }}_net_vpc"
|
name: "{{ cs_resource_prefix }}_net_vpc"
|
||||||
|
@ -533,14 +650,14 @@
|
||||||
- vpc_net|success
|
- vpc_net|success
|
||||||
- not vpc_net|changed
|
- not vpc_net|changed
|
||||||
|
|
||||||
- name: test remove vpc in check mode
|
- name: test remove vpc with default offering in check mode
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
state: absent
|
state: absent
|
||||||
zone: "{{ cs_common_zone_adv }}"
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
register: vpc
|
register: vpc
|
||||||
check_mode: true
|
check_mode: true
|
||||||
- name: verify test remove vpc in check mode
|
- name: verify test remove vpc with default offering in check mode
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- vpc|success
|
- vpc|success
|
||||||
|
@ -549,13 +666,13 @@
|
||||||
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
||||||
- vpc.cidr == "10.10.0.0/16"
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
- name: test remove vpc
|
- name: test remove vpc with default offering
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
state: absent
|
state: absent
|
||||||
zone: "{{ cs_common_zone_adv }}"
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
register: vpc
|
register: vpc
|
||||||
- name: verify test remove vpc
|
- name: verify test remove vpc with default offering
|
||||||
assert:
|
assert:
|
||||||
that:
|
that:
|
||||||
- vpc|success
|
- vpc|success
|
||||||
|
@ -564,7 +681,7 @@
|
||||||
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
- vpc.display_text == "{{ cs_resource_prefix }}_display_text2"
|
||||||
- vpc.cidr == "10.10.0.0/16"
|
- vpc.cidr == "10.10.0.0/16"
|
||||||
|
|
||||||
- name: test remove vpc idempotence
|
- name: test remove vpc with default offering idempotence
|
||||||
cs_vpc:
|
cs_vpc:
|
||||||
name: "{{ cs_resource_prefix }}_vpc"
|
name: "{{ cs_resource_prefix }}_vpc"
|
||||||
state: absent
|
state: absent
|
||||||
|
@ -574,3 +691,17 @@
|
||||||
that:
|
that:
|
||||||
- vpc|success
|
- vpc|success
|
||||||
- not vpc|changed
|
- not vpc|changed
|
||||||
|
|
||||||
|
- name: test remove vpc with custom offering
|
||||||
|
cs_vpc:
|
||||||
|
name: "{{ cs_resource_prefix }}_vpc_custom"
|
||||||
|
state: absent
|
||||||
|
zone: "{{ cs_common_zone_adv }}"
|
||||||
|
register: vpc
|
||||||
|
- name: verify test remove vpc with custom offering
|
||||||
|
assert:
|
||||||
|
that:
|
||||||
|
- vpc|success
|
||||||
|
- vpc|changed
|
||||||
|
- vpc.name == "{{ cs_resource_prefix }}_vpc_custom"
|
||||||
|
- vpc.cidr == "10.10.1.0/16"
|
||||||
|
|
Loading…
Reference in a new issue