Skip to content

Commit

Permalink
lambda - fix check mode on creation (#1108) (#1128)
Browse files Browse the repository at this point in the history
[PR #1108/0bde6bbd backport][stable-3] lambda - fix check mode on creation

This is a backport of PR #1108 as merged into main (0bde6bb).
Depends-On: #1116
SUMMARY


When adding integration tests for check mode runs, creating a lambda function failed on check mode with the message "Unable to get function information after creating".


Added parameter kms_key_arn - testing in integration tests appears difficult as I think we'd need to create an IAM policy to allow for adding kms_key, which would render these tests as unsupported.


Added extra waiter for function_update in execute_lambda to resolve occasional integration test failure.


Fixes #1111
ISSUE TYPE

Feature Pull Request
Bugfix Pull Request

COMPONENT NAME
lambda

Reviewed-by: Alina Buzachis <None>
  • Loading branch information
patchback[bot] authored May 6, 2022
1 parent 0f85221 commit 455e73d
Show file tree
Hide file tree
Showing 4 changed files with 125 additions and 6 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
minor_changes:
- lambda - add kms_key_arn parameter (https://github.com/ansible-collections/community.aws/pull/1108).
bugfixes:
- lambda - fix check mode on creation (https://github.com/ansible-collections/community.aws/pull/1108).
- execute_lamba - add waiter for function_updated (https://github.com/ansible-collections/community.aws/pull/1108).
6 changes: 4 additions & 2 deletions plugins/modules/execute_lambda.py
Original file line number Diff line number Diff line change
Expand Up @@ -260,8 +260,10 @@ def main():

def wait_for_lambda(client, module, name):
try:
waiter = client.get_waiter('function_active')
waiter.wait(FunctionName=name)
client_active_waiter = client.get_waiter('function_active')
client_updated_waiter = client.get_waiter('function_updated')
client_active_waiter.wait(FunctionName=name)
client_updated_waiter.wait(FunctionName=name)
except botocore.exceptions.WaiterError as e:
module.fail_json_aws(e, msg='Timeout while waiting on lambda to be Active')
except (botocore.exceptions.ClientError, botocore.exceptions.BotoCoreError) as e:
Expand Down
21 changes: 18 additions & 3 deletions plugins/modules/lambda.py
Original file line number Diff line number Diff line change
Expand Up @@ -107,6 +107,11 @@
description:
- Tag dict to apply to the function.
type: dict
kms_key_arn:
description:
- The KMS key ARN used to encrypt the function's environment variables.
type: str
version_added: 3.3.0
author:
- 'Steyn Huizinga (@steynovich)'
extends_documentation_fragment:
Expand Down Expand Up @@ -350,6 +355,7 @@ def main():
vpc_security_group_ids=dict(type='list', elements='str'),
environment_variables=dict(type='dict'),
dead_letter_arn=dict(),
kms_key_arn=dict(type='str', no_log=False),
tracing_mode=dict(choices=['Active', 'PassThrough']),
tags=dict(type='dict'),
)
Expand Down Expand Up @@ -387,6 +393,7 @@ def main():
dead_letter_arn = module.params.get('dead_letter_arn')
tracing_mode = module.params.get('tracing_mode')
tags = module.params.get('tags')
kms_key_arn = module.params.get('kms_key_arn')

check_mode = module.check_mode
changed = False
Expand Down Expand Up @@ -442,6 +449,8 @@ def main():
func_kwargs.update({'DeadLetterConfig': {'TargetArn': dead_letter_arn}})
if tracing_mode and (current_config.get('TracingConfig', {}).get('Mode', 'PassThrough') != tracing_mode):
func_kwargs.update({'TracingConfig': {'Mode': tracing_mode}})
if kms_key_arn:
func_kwargs.update({'KMSKeyArn': kms_key_arn})

# If VPC configuration is desired
if vpc_subnet_ids:
Expand Down Expand Up @@ -573,17 +582,23 @@ def main():
if tracing_mode:
func_kwargs.update({'TracingConfig': {'Mode': tracing_mode}})

if kms_key_arn:
func_kwargs.update({'KMSKeyArn': kms_key_arn})

# If VPC configuration is given
if vpc_subnet_ids:
func_kwargs.update({'VpcConfig': {'SubnetIds': vpc_subnet_ids,
'SecurityGroupIds': vpc_security_group_ids}})

# Function would have been created if not check mode
if check_mode:
module.exit_json(changed=True)

# Finally try to create function
current_version = None
try:
if not check_mode:
response = client.create_function(aws_retry=True, **func_kwargs)
current_version = response['Version']
response = client.create_function(aws_retry=True, **func_kwargs)
current_version = response['Version']
changed = True
except (BotoCoreError, ClientError) as e:
module.fail_json_aws(e, msg="Trying to create function")
Expand Down
99 changes: 98 additions & 1 deletion tests/integration/targets/lambda/tasks/main.yml
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,19 @@
- '"parameters are required together" in result.msg'

# Prepare minimal Lambda
- name: test state=present - upload the lambda (check mode)
lambda:
name: '{{ lambda_function_name }}'
runtime: python3.6
handler: mini_lambda.handler
role: '{{ lambda_role_name }}'
zip_file: '{{ zip_res.dest }}'
register: result
check_mode: yes
- name: assert lambda upload succeeded
assert:
that:
- result.changed

- name: test state=present - upload the lambda
lambda:
Expand All @@ -105,7 +118,7 @@
- name: assert lambda upload succeeded
assert:
that:
- result is not failed
- result.changed
- result.configuration.tracing_config.mode == "PassThrough"

# Test basic operation of Uploaded lambda
Expand All @@ -122,6 +135,25 @@
- result.result.output.message == "hello Mr Ansible Tests"

# Test updating Lambda
- name: test lambda config updates (check mode)
lambda:
name: '{{lambda_function_name}}'
runtime: nodejs14.x
tracing_mode: Active
handler: mini_lambda.handler
role: '{{ lambda_role_name }}'
tags:
CamelCase: 'ACamelCaseValue'
snake_case: 'a_snake_case_value'
'Spaced key': 'A value with spaces'
register: update_result
check_mode: yes
- name: assert that update succeeded
assert:
that:
- update_result is not failed
- update_result.changed == True

- name: test lambda config updates
lambda:
name: '{{lambda_function_name}}'
Expand All @@ -142,6 +174,25 @@
- update_result.configuration.runtime == 'nodejs14.x'
- update_result.configuration.tracing_config.mode == 'Active'

- name: test no changes are made with the same parameters repeated (check mode)
lambda:
name: '{{lambda_function_name}}'
runtime: nodejs14.x
tracing_mode: Active
handler: mini_lambda.handler
role: '{{ lambda_role_name }}'
tags:
CamelCase: 'ACamelCaseValue'
snake_case: 'a_snake_case_value'
'Spaced key': 'A value with spaces'
register: update_result
check_mode: yes
- name: assert that update succeeded
assert:
that:
- update_result is not failed
- update_result.changed == False

- name: test no changes are made with the same parameters repeated
lambda:
name: '{{lambda_function_name}}'
Expand Down Expand Up @@ -184,6 +235,7 @@
name: '{{ lambda_function_name }}'
query: all
register: lambda_infos_all
check_mode: yes
- name: lambda_info | Assert successfull retrieval of all information
assert:
that:
Expand Down Expand Up @@ -278,6 +330,23 @@
- result is not failed
- result.changed == False

- name: test putting an environment variable changes lambda (check mode)
lambda:
name: '{{lambda_function_name}}'
runtime: python3.6
handler: mini_lambda.handler
role: '{{ lambda_role_name }}'
zip_file: '{{zip_res.dest}}'
environment_variables:
EXTRA_MESSAGE: I think you are great!!
register: result
check_mode: yes
- name: assert lambda upload succeeded
assert:
that:
- result is not failed
- result.changed == True

- name: test putting an environment variable changes lambda
lambda:
name: '{{lambda_function_name}}'
Expand All @@ -293,6 +362,8 @@
that:
- result is not failed
- result.changed == True
- result.configuration.environment.variables.extra_message == "I think you are great!!"

- name: test lambda works
execute_lambda:
name: '{{lambda_function_name}}'
Expand All @@ -306,6 +377,19 @@
- result.result.output.message == "hello Mr Ansible Tests. I think you are great!!"

# Deletion behavious
- name: test state=absent (expect changed=True) (check mode)
lambda:
name: '{{lambda_function_name}}'
state: absent
register: result
check_mode: yes

- name: assert state=absent
assert:
that:
- result is not failed
- result is changed

- name: test state=absent (expect changed=True)
lambda:
name: '{{lambda_function_name}}'
Expand All @@ -318,6 +402,19 @@
- result is not failed
- result is changed

- name: test state=absent (expect changed=False) when already deleted (check mode)
lambda:
name: '{{lambda_function_name}}'
state: absent
register: result
check_mode: yes

- name: assert state=absent
assert:
that:
- result is not failed
- result is not changed

- name: test state=absent (expect changed=False) when already deleted
lambda:
name: '{{lambda_function_name}}'
Expand Down

0 comments on commit 455e73d

Please sign in to comment.