Как опубликовать в теме sns внутри localstack

Я написал лямбда-функцию, которая публикует сообщение в тему через sns. Я бы хотел провести с ним интеграционные тесты, так что localstack кажется отличным решением.

В методе setup_class я успешно создал лямбду с заархивированным кодом и зависимостями, а также создал тему sns, в которой я хочу публиковать сообщения позже в тесте.

В фазе вызова лямбда я получаю сообщение об ошибке:

E           REPORT RequestId: f9f3bac1-3b4b-4826-a5cb-362355087929 Duration: 1906 ms Billed Duration: 2000 ms Memory Size: 1536 MB Max Memory Used: 32 MB Traceback (most recent call last):
E             File "/opt/code/localstack/localstack/services/awslambda/lambda_api.py", line 338, in run_lambda
E               event, context=context, version=version, asynchronous=asynchronous)
E             File "/opt/code/localstack/localstack/services/awslambda/lambda_executors.py", line 81, in execute
E               return do_execute()
E             File "/opt/code/localstack/localstack/services/awslambda/lambda_executors.py", line 66, in do_execute
E               result, log_output = self._execute(func_arn, func_details, event, context, version)
E             File "/opt/code/localstack/localstack/services/awslambda/lambda_executors.py", line 230, in _execute
E               result, log_output = self.run_lambda_executor(cmd, stdin, environment)
E             File "/opt/code/localstack/localstack/services/awslambda/lambda_executors.py", line 151, in run_lambda_executor
E               (return_code, log_output))
E           Exception: Lambda process returned error status code: 1. Output:
E           START RequestId: f9f3bac1-3b4b-4826-a5cb-362355087929 Version: $LATEST
E           An error occurred (InvalidClientTokenId) when calling the Publish operation: The security token included in the request is invalid.: ClientError
E           Traceback (most recent call last):
E             File "/var/task/functions/opt_in.py", line 32, in handler
E               MessageStructure='json'
E             File "/var/task/botocore/client.py", line 357, in _api_call
E               return self._make_api_call(operation_name, kwargs)
E             File "/var/task/botocore/client.py", line 661, in _make_api_call
E               raise error_class(parsed_response, operation_name)
E           botocore.exceptions.ClientError: An error occurred (InvalidClientTokenId) when calling the Publish operation: The security token included in the request is invalid.
E           
E           END RequestId: f9f3bac1-3b4b-4826-a5cb-362355087929
E           REPORT RequestId: f9f3bac1-3b4b-4826-a5cb-362355087929 Duration: 1906 ms Billed Duration: 2000 ms Memory Size: 1536 MB Max Memory Used: 32 MB

В нем говорится, что у меня есть некоторые проблемы с IAM, возможно, или ролями, но на этапе настройки любые действия, такие как создание лямбда-выражения, создание темы, выполнялись без ошибок.

Я попытался добавить URL-адрес конечной точки для клиента sns в лямбда-функцию, но внутри localstack возникает ошибка «неправильный URL-адрес» (enpoint локального стека для sns был 'http://localhost:4575 ').

Как решить проблему "botocore.exceptions.ClientError" при тестировании локального стека?


person Oleksiy    schedule 16.10.2019    source источник


Ответы (1)


Локальному стеку нужен правильный enpoint_url для sns или других ресурсов, если вы хотите выполнить его внутри.

import os
sns_url = 'http://%s:4575' % os.environ['LOCALSTACK_HOSTNAME']
sns = boto3.client('sns', region_name='us-east-2', endpoint_url=sns_url)
person Oleksiy    schedule 30.10.2019
comment
Из localstack 0.11.0 порт для всех служб одинаковый, 4566. Этот пример также отлично работает с 4566. - person Arcones; 11.04.2020