Skip to content

Commit

Permalink
ec2_vpc_igw: increase integration tests coverage and code cleaning (a…
Browse files Browse the repository at this point in the history
…nsible-collections#386)

* Internet gateway: add missing integration tests and code check
 * Add CamelCase tags integration test
 * Removed check_input_tags() because useless as ansible_dict_to_boto3_tag_list() already performs a to_native() conversion to strings
 * Add additional integration tests for ec2_vpc_igw_info module

Signed-off-by: Alina Buzachis <[email protected]>

* Internet Gateway - integration tests
 * Fix Internet Gatways search by tags

* * Apply reviewer suggestions
        * Better error handling for the waiter

This commit was initially merged in https://github.com/ansible-collections/community.aws
See: ansible-collections/community.aws@cff6d00
  • Loading branch information
alinabuzachis committed Jul 20, 2021
1 parent 0350132 commit 8e2a079
Show file tree
Hide file tree
Showing 2 changed files with 145 additions and 14 deletions.
15 changes: 2 additions & 13 deletions plugins/modules/ec2_vpc_igw.py
Original file line number Diff line number Diff line change
Expand Up @@ -92,8 +92,6 @@
except ImportError:
pass # caught by AnsibleAWSModule

from ansible.module_utils.six import string_types

from ansible_collections.amazon.aws.plugins.module_utils.core import AnsibleAWSModule
from ansible_collections.amazon.aws.plugins.module_utils.waiters import get_waiter
from ansible_collections.amazon.aws.plugins.module_utils.ec2 import AWSRetry
Expand Down Expand Up @@ -141,13 +139,6 @@ def get_matching_igw(self, vpc_id):

return igw

def check_input_tags(self, tags):
if tags is None:
return
nonstring_tags = [k for k, v in tags.items() if not isinstance(v, string_types)]
if nonstring_tags:
self._module.fail_json(msg='One or more tags contain non-string values: {0}'.format(nonstring_tags))

def ensure_tags(self, igw_id, tags, purge_tags):
final_tags = []

Expand All @@ -167,7 +158,6 @@ def ensure_tags(self, igw_id, tags, purge_tags):
if to_update:
try:
if self._check_mode:
# update tags
final_tags.update(to_update)
else:
self._connection.create_tags(
Expand All @@ -183,7 +173,6 @@ def ensure_tags(self, igw_id, tags, purge_tags):
if to_delete:
try:
if self._check_mode:
# update tags
for key in to_delete:
del final_tags[key]
else:
Expand Down Expand Up @@ -233,8 +222,6 @@ def ensure_igw_absent(self, vpc_id):
return self._results

def ensure_igw_present(self, vpc_id, tags, purge_tags):
self.check_input_tags(tags)

igw = self.get_matching_igw(vpc_id)

if igw is None:
Expand All @@ -253,6 +240,8 @@ def ensure_igw_present(self, vpc_id, tags, purge_tags):
igw = camel_dict_to_snake_dict(response['InternetGateway'])
self._connection.attach_internet_gateway(aws_retry=True, InternetGatewayId=igw['internet_gateway_id'], VpcId=vpc_id)
self._results['changed'] = True
except botocore.exceptions.WaiterError as e:
self._module.fail_json_aws(e, msg="No Internet Gateway exists.")
except (botocore.exceptions.ClientError, botocore.exceptions.BotoCoreError) as e:
self._module.fail_json_aws(e, msg='Unable to create Internet Gateway')

Expand Down
144 changes: 143 additions & 1 deletion tests/integration/targets/ec2_vpc_igw/tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,13 @@
assert:
that:
- vpc_result is successful
- '"vpc" in vpc_result'
- '"id" in vpc_result.vpc'
- vpc_result.vpc.state == 'available'
- '"tags" in vpc_result.vpc'
- vpc_result.vpc.tags | length == 2
- vpc_result.vpc.tags["Name"] == "{{ resource_prefix }}-vpc"
- vpc_result.vpc.tags["Description"] == "Created by ansible-test"

# ============================================================
- name: Search for internet gateway by VPC - no matches
Expand All @@ -50,6 +57,7 @@
that:
- igw_info is successful
- '"internet_gateways" in igw_info'
- (igw_info.internet_gateways | length) == 0

# ============================================================
- name: create internet gateway (expected changed=true) - CHECK_MODE
Expand Down Expand Up @@ -194,6 +202,12 @@
assert:
that:
- vpc_igw_recreate is not changed
- vpc_igw_recreate.gateway_id == igw_id
- vpc_igw_recreate.vpc_id == vpc_id
- '"tags" in vpc_igw_create'
- vpc_igw_create.tags | length == 2
- vpc_igw_create.tags["tag_one"] == '{{ resource_prefix }} One'
- vpc_igw_create.tags["Tag Two"] == 'two {{ resource_prefix }}'

- name: attempt to recreate internet gateway on VPC (expected changed=false)
ec2_vpc_igw:
Expand Down Expand Up @@ -227,6 +241,12 @@
assert:
that:
- vpc_igw_recreate is not changed
- vpc_igw_recreate.gateway_id == igw_id
- vpc_igw_recreate.vpc_id == vpc_id
- '"tags" in vpc_igw_recreate'
- vpc_igw_recreate.tags | length == 2
- vpc_igw_recreate.tags["tag_one"] == '{{ resource_prefix }} One'
- vpc_igw_recreate.tags["Tag Two"] == 'two {{ resource_prefix }}'

- name: Update the tags (no change)
ec2_vpc_igw:
Expand Down Expand Up @@ -263,6 +283,13 @@
assert:
that:
- vpc_igw_update is changed
- vpc_igw_update.gateway_id == igw_id
- vpc_igw_update.vpc_id == vpc_id
- '"tags" in vpc_igw_update'
- vpc_igw_update.tags | length == 2
- vpc_igw_update.tags["tag_three"] == '{{ resource_prefix }} Three'
- vpc_igw_update.tags["Tag Two"] == 'two {{ resource_prefix }}'


- name: Update the tags - remove and add
ec2_vpc_igw:
Expand Down Expand Up @@ -299,6 +326,13 @@
assert:
that:
- vpc_igw_update is changed
- vpc_igw_update.gateway_id == igw_id
- vpc_igw_update.vpc_id == vpc_id
- '"tags" in vpc_igw_update'
- vpc_igw_update.tags | length == 3
- vpc_igw_update.tags["tag_one"] == '{{ resource_prefix }} One'
- vpc_igw_update.tags["tag_three"] == '{{ resource_prefix }} Three'
- vpc_igw_update.tags["Tag Two"] == 'two {{ resource_prefix }}'

- name: Update the tags add without purge
ec2_vpc_igw:
Expand All @@ -321,6 +355,114 @@
- vpc_igw_update.tags["tag_three"] == '{{ resource_prefix }} Three'
- vpc_igw_update.tags["Tag Two"] == 'two {{ resource_prefix }}'


# ============================================================
- name: Update with CamelCase tags - CHECK_MODE
ec2_vpc_igw:
state: present
vpc_id: "{{ vpc_result.vpc.id }}"
tags:
"lowercase spaced": 'hello cruel world ❤️'
"Title Case": 'Hello Cruel World ❤️'
CamelCase: 'SimpleCamelCase ❤️'
snake_case: 'simple_snake_case ❤️'
register: vpc_igw_update
check_mode: yes

- name: assert tag update would happen (expected changed=true) - CHECK_MODE
assert:
that:
- vpc_igw_update is changed
- vpc_igw_update.gateway_id == igw_id
- vpc_igw_update.vpc_id == vpc_id
- '"tags" in vpc_igw_update'
- vpc_igw_update.tags | length == 4
- vpc_igw_update.tags["lowercase spaced"] == 'hello cruel world ❤️'
- vpc_igw_update.tags["Title Case"] == 'Hello Cruel World ❤️'
- vpc_igw_update.tags["CamelCase"] == 'SimpleCamelCase ❤️'
- vpc_igw_update.tags["snake_case"] == 'simple_snake_case ❤️'


- name: Update the tags - remove and add
ec2_vpc_igw:
state: present
vpc_id: "{{ vpc_result.vpc.id }}"
tags:
"lowercase spaced": 'hello cruel world ❤️'
"Title Case": 'Hello Cruel World ❤️'
CamelCase: 'SimpleCamelCase ❤️'
snake_case: 'simple_snake_case ❤️'
register: vpc_igw_update

- name: assert tags are updated (expected changed=true)
assert:
that:
- vpc_igw_update is changed
- vpc_igw_update.gateway_id == igw_id
- vpc_igw_update.vpc_id == vpc_id
- '"tags" in vpc_igw_update'
- vpc_igw_update.tags | length == 4
- vpc_igw_update.tags["lowercase spaced"] == 'hello cruel world ❤️'
- vpc_igw_update.tags["Title Case"] == 'Hello Cruel World ❤️'
- vpc_igw_update.tags["CamelCase"] == 'SimpleCamelCase ❤️'
- vpc_igw_update.tags["snake_case"] == 'simple_snake_case ❤️'

# ============================================================
- name: Gather information about a filtered list of Internet Gateways using tags
ec2_vpc_igw_info:
filters:
"tag:Title Case": 'Hello Cruel World ❤️'
register: igw_info

- name: Assert success
assert:
that:
- igw_info is successful
- '"internet_gateways" in igw_info'
- igw_info.internet_gateways | selectattr("internet_gateway_id",'equalto',"{{ igw_id }}")

- name: Gather information about a filtered list of Internet Gateways using tags - CHECK_MODE
ec2_vpc_igw_info:
filters:
"tag:Title Case": 'Hello Cruel World ❤️'
register: igw_info
check_mode: yes

- name: Assert success - CHECK_MODE
assert:
that:
- igw_info is successful
- '"internet_gateways" in igw_info'
- igw_info.internet_gateways | selectattr("internet_gateway_id",'equalto',"{{ igw_id }}")

# ============================================================
- name: Gather information about a filtered list of Internet Gateways using tags (no match)
ec2_vpc_igw_info:
filters:
"tag:tag_one": '{{ resource_prefix }} One'
register: igw_info

- name: Assert success
assert:
that:
- igw_info is successful
- '"internet_gateways" in igw_info'
- igw_info.internet_gateways | length == 0

- name: Gather information about a filtered list of Internet Gateways using tags (no match) - CHECK_MODE
ec2_vpc_igw_info:
filters:
"tag:tag_one": '{{ resource_prefix }} One'
register: igw_info
check_mode: yes

- name: Assert success - CHECK_MODE
assert:
that:
- igw_info is successful
- '"internet_gateways" in igw_info'
- igw_info.internet_gateways | length == 0

# ============================================================
- name: Remove all tags - CHECK_MODE
ec2_vpc_igw:
Expand Down Expand Up @@ -350,7 +492,7 @@
- vpc_igw_update.vpc_id == vpc_id
- '"tags" in vpc_igw_update'
- vpc_igw_update.tags | length == 0

# ============================================================
- name: test state=absent (expected changed=true) - CHECK_MODE
ec2_vpc_igw:
Expand Down

0 comments on commit 8e2a079

Please sign in to comment.