moto/tests/test_awslambda/utilities.py
2024-01-27 19:38:09 +00:00

227 lines
5.9 KiB
Python

import io
import time
import zipfile
from uuid import uuid4
import boto3
import pytest
from botocore.exceptions import ClientError
from moto import mock_aws, settings
_lambda_region = "us-west-2"
def _process_lambda(func_str):
zip_output = io.BytesIO()
zip_file = zipfile.ZipFile(zip_output, "w", zipfile.ZIP_DEFLATED)
zip_file.writestr("lambda_function.py", func_str)
zip_file.close()
zip_output.seek(0)
return zip_output.read()
def get_test_zip_file1():
pfunc = """
def lambda_handler(event, context):
print("custom log event")
return event
"""
return _process_lambda(pfunc)
def get_test_zip_file2():
base_url = (
"motoserver:5000"
if settings.TEST_SERVER_MODE
else "ec2.us-west-2.amazonaws.com"
)
func_str = f"""
import boto3
def lambda_handler(event, context):
ec2 = boto3.resource('ec2', region_name='us-west-2', endpoint_url='http://{base_url}')
volume_id = event.get('volume_id')
vol = ec2.Volume(volume_id)
return {{'id': vol.id, 'state': vol.state, 'size': vol.size}}
"""
return _process_lambda(func_str)
def get_lambda_using_environment_port():
func_str = """
import boto3
import os
def lambda_handler(event, context):
base_url = os.environ.get("MOTO_HOST")
port = os.environ.get("MOTO_PORT")
url = base_url + ":" + port
conn = boto3.client('lambda', region_name='us-west-2', endpoint_url=url)
full_url = os.environ["MOTO_HTTP_ENDPOINT"]
functions = conn.list_functions()["Functions"]
return {'functions': functions, 'host': full_url}
"""
return _process_lambda(func_str)
def get_lambda_using_network_mode():
func_str = """
import boto3
import os
def lambda_handler(event, context):
port = os.environ.get("MOTO_PORT")
url = "http://localhost:" + port
conn = boto3.client('lambda', region_name='us-west-2', endpoint_url=url)
functions = conn.list_functions()["Functions"]
return {'response': functions}
"""
return _process_lambda(func_str)
def get_proxy_zip_file():
func_str = """
import boto3
def lambda_handler(event, context):
ec2 = boto3.resource('ec2', region_name='us-west-2')
volume_id = event.get('volume_id')
vol = ec2.Volume(volume_id)
return {'id': vol.id, 'state': vol.state, 'size': vol.size}
"""
return _process_lambda(func_str)
def get_test_zip_file3():
pfunc = """
def lambda_handler(event, context):
print("Nr_of_records("+str(len(event['Records']))+")")
print("get_test_zip_file3 success")
return event
"""
return _process_lambda(pfunc)
def get_test_zip_file_error():
pfunc = """
def lambda_handler(event, context):
raise Exception('I failed!')
"""
return _process_lambda(pfunc)
def get_test_zip_largeresponse():
pfunc = """
def lambda_handler(event, context):
x = ["xxx" for x in range(10 ** 6)]
return {"statusCode": 200, "body": x}
"""
return _process_lambda(pfunc)
def get_zip_with_multiple_files():
pfunc = """
from utilities import util_function
def lambda_handler(event, context):
x = util_function()
event["msg"] = event["msg"] + x
return event
"""
ufunc = """
def util_function():
return "stuff"
"""
zip_output = io.BytesIO()
zip_file = zipfile.ZipFile(zip_output, "a", zipfile.ZIP_DEFLATED)
zip_file.writestr("lambda_function.py", pfunc)
zip_file.close()
zip_file = zipfile.ZipFile(zip_output, "a", zipfile.ZIP_DEFLATED)
zip_file.writestr("utilities.py", ufunc)
zip_file.close()
zip_output.seek(0)
return zip_output.read()
def get_test_zip_file_print_event():
pfunc = """
def lambda_handler(event, context):
print(event)
print("FINISHED_PRINTING_EVENT")
return event
"""
return _process_lambda(pfunc)
def create_invalid_lambda(role):
conn = boto3.client("lambda", _lambda_region)
zip_content = get_test_zip_file1()
function_name = str(uuid4())[0:6]
with pytest.raises(ClientError) as err:
conn.create_function(
FunctionName=function_name,
Runtime="python3.11",
Role=role,
Handler="lambda_function.handler",
Code={"ZipFile": zip_content},
Description="test lambda function",
Timeout=3,
MemorySize=128,
Publish=True,
)
return err
def get_role_name():
with mock_aws():
iam = boto3.client("iam", region_name=_lambda_region)
while True:
try:
return iam.get_role(RoleName="my-role")["Role"]["Arn"]
except ClientError:
try:
return iam.create_role(
RoleName="my-role",
AssumeRolePolicyDocument="some policy",
Path="/my-path/",
)["Role"]["Arn"]
except ClientError:
pass
def wait_for_log_msg(expected_msg, log_group, wait_time=30):
expected_msgs = expected_msg if isinstance(expected_msg, list) else [expected_msg]
logs_conn = boto3.client("logs", region_name="us-east-1")
received_messages = []
start = time.time()
while (time.time() - start) < wait_time:
try:
result = logs_conn.describe_log_streams(logGroupName=log_group)
log_streams = result.get("logStreams")
except ClientError:
log_streams = None # LogGroupName does not yet exist
if not log_streams:
time.sleep(1)
continue
for log_stream in log_streams:
result = logs_conn.get_log_events(
logGroupName=log_group, logStreamName=log_stream["logStreamName"]
)
received_messages.extend(
[event["message"] for event in result.get("events")]
)
for line in received_messages:
if any([msg in line for msg in expected_msgs]):
return True, set(received_messages)
time.sleep(1)
return False, set(received_messages)