From 05328ebf2121de18f8bede086fbec81be7ee94e7 Mon Sep 17 00:00:00 2001 From: David Passante Date: Mon, 17 Sep 2018 16:08:16 +0200 Subject: [PATCH] Cloudstack: fix support for some VPC service capabilities (#45727) * Fix support for VPC capabilities such as redundant routers or region level VPC * Add integration test cases for "region level VPC" and "distributed router" capabilities --- .../cloud/cloudstack/cs_vpc_offering.py | 33 +++++++++++++++-- .../targets/cs_vpc_offering/tasks/main.yml | 35 +++++++++++++++++++ 2 files changed, 66 insertions(+), 2 deletions(-) diff --git a/lib/ansible/modules/cloud/cloudstack/cs_vpc_offering.py b/lib/ansible/modules/cloud/cloudstack/cs_vpc_offering.py index 67ce8bdc2b..60214884a6 100644 --- a/lib/ansible/modules/cloud/cloudstack/cs_vpc_offering.py +++ b/lib/ansible/modules/cloud/cloudstack/cs_vpc_offering.py @@ -65,8 +65,36 @@ EXAMPLES = ''' state: enabled supported_services: [ Dns, Dhcp ] service_providers: - - {service: 'dns', provider: 'virtualrouter'} - - {service: 'dhcp', provider: 'virtualrouter'} + - {service: 'dns', provider: 'VpcVirtualRouter'} + - {service: 'dhcp', provider: 'VpcVirtualRouter'} + +# Create a vpc offering with redundant router +- local_action: + module: cs_vpc_offering + name: "my_vpc_offering" + display_text: "vpc offering description" + supported_services: [ Dns, Dhcp, SourceNat ] + service_providers: + - {service: 'dns', provider: 'VpcVirtualRouter'} + - {service: 'dhcp', provider: 'VpcVirtualRouter'} + - {service: 'SourceNat', provider: 'VpcVirtualRouter'} + service_capabilities: + - {service: 'SourceNat', capabilitytype: 'RedundantRouter', capabilityvalue: true} + +# Create a region level vpc offering with distributed router +- local_action: + module: cs_vpc_offering + name: "my_vpc_offering" + display_text: "vpc offering description" + state: present + supported_services: [ Dns, Dhcp, SourceNat ] + service_providers: + - {service: 'dns', provider: 'VpcVirtualRouter'} + - {service: 'dhcp', provider: 'VpcVirtualRouter'} + - {service: 'SourceNat', provider: 'VpcVirtualRouter'} + service_capabilities: + - {service: 'Connectivity', capabilitytype: 'DistributedRouter', capabilityvalue: true} + - {service: 'Connectivity', capabilitytype: 'RegionLevelVPC', capabilityvalue: true} # Remove a vpc offering - local_action: @@ -189,6 +217,7 @@ class AnsibleCloudStackVPCOffering(AnsibleCloudStack): 'supportedservices': self.module.params.get('supported_services'), 'serviceproviderlist': self.module.params.get('service_providers'), 'serviceofferingid': self.get_service_offering_id(), + 'servicecapabilitylist': self.module.params.get('service_capabilities'), } required_params = [ diff --git a/test/integration/targets/cs_vpc_offering/tasks/main.yml b/test/integration/targets/cs_vpc_offering/tasks/main.yml index 0336495ff1..ebbeaf910a 100644 --- a/test/integration/targets/cs_vpc_offering/tasks/main.yml +++ b/test/integration/targets/cs_vpc_offering/tasks/main.yml @@ -380,6 +380,30 @@ - vpcoffer.state == "Enabled" - vpcoffer.display_text == "vpc offering description" +- name: test create enabled region level vpc offer with distrubuted router + cs_vpc_offering: + name: "{{ cs_resource_prefix }}_vpc_drl" + display_text: "vpc offering description" + supported_services: [ Dns, PortForwarding, Dhcp, SourceNat, UserData, StaticNat, Vpn, Lb ] + service_providers: + - { service: 'dns', provider: 'virtualrouter' } + - { service: 'dhcp', provider: 'virtualrouter' } + state: enabled + service_capabilities: + - {service: 'Connectivity', capabilitytype: 'DistributedRouter', capabilityvalue: true} + - {service: 'Connectivity', capabilitytype: 'RegionLevelVPC', capabilityvalue: true} + register: vpcoffer +- name: verify results of create enabled region level vpc offer with distrubuted router + assert: + that: + - vpcoffer is successful + - vpcoffer is changed + - vpcoffer.name == "{{ cs_resource_prefix }}_vpc_drl" + - vpcoffer.state == "Enabled" + - vpcoffer.display_text == "vpc offering description" + - vpcoffer.distributed == true + - vpcoffer.region_level == true + - name: remove vpc offer cs_vpc_offering: name: "{{ cs_resource_prefix }}_vpc" @@ -390,3 +414,14 @@ that: - vpcoffer is successful - vpcoffer is changed + +- name: remove region level vpc offer with distrubuted router + cs_vpc_offering: + name: "{{ cs_resource_prefix }}_vpc_drl" + state: absent + register: vpcoffer +- name: verify results of remove region level vpc offer with distrubuted router + assert: + that: + - vpcoffer is successful + - vpcoffer is changed