-
Notifications
You must be signed in to change notification settings - Fork 67
Expand file tree
/
Copy pathMakefile
More file actions
78 lines (58 loc) · 2.9 KB
/
Makefile
File metadata and controls
78 lines (58 loc) · 2.9 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
export AWS_ACCESS_KEY_ID ?= test
export AWS_SECRET_ACCESS_KEY ?= test
export AWS_DEFAULT_REGION=us-east-1
usage: ## Show this help
@fgrep -h "##" $(MAKEFILE_LIST) | fgrep -v fgrep | sed -e 's/\\$$//' | sed -e 's/##//'
check: ## Check if all required prerequisites are installed
@command -v docker > /dev/null 2>&1 || { echo "Docker is not installed. Please install Docker and try again."; exit 1; }
@command -v python3 > /dev/null 2>&1 || { echo "Python 3 is not installed. Please install Python 3 and try again."; exit 1; }
@command -v localstack > /dev/null 2>&1 || { echo "LocalStack CLI is not installed. Please install it and try again."; exit 1; }
@command -v awslocal > /dev/null 2>&1 || { echo "awslocal is not installed. Please run: pip install awscli-local"; exit 1; }
@echo "All required prerequisites are available."
install: ## Install dependencies
@which awslocal || pip install awscli-local
create-lambdas: ## Create the Lambdas
awslocal iam create-role --role-name step-function-lambda --assume-role-policy-document file://step-trust-policy.json
awslocal iam attach-role-policy --role-name step-function-lambda --policy-arn arn:aws:iam::aws:policy/service-role/AWSLambdaRole
cp -f lambda_adam.py lambda_function.py
zip package.zip lambda_function.py
awslocal lambda create-function \
--function-name adam \
--role arn:aws:iam::000000000000:role/lambda-demo \
--runtime python3.9 --timeout 10 --memory-size 128 \
--handler lambda_function.lambda_handler \
--zip-file fileb://package.zip
rm package.zip lambda_function.py
cp -f lambda_cole.py lambda_function.py
zip package.zip lambda_function.py
awslocal lambda create-function \
--function-name cole \
--role arn:aws:iam::000000000000:role/lambda-demo \
--runtime python3.9 --timeout 10 --memory-size 128 \
--handler lambda_function.lambda_handler \
--zip-file fileb://package.zip
rm package.zip lambda_function.py
cp -f lambda_combine.py lambda_function.py
zip package.zip lambda_function.py
awslocal lambda create-function \
--function-name combine \
--role arn:aws:iam::000000000000:role/lambda-demo \
--runtime python3.9 --timeout 10 --memory-size 128 \
--handler lambda_function.lambda_handler \
--zip-file fileb://package.zip
rm package.zip lambda_function.py
start:
@test -n "${LOCALSTACK_AUTH_TOKEN}" || (echo "LOCALSTACK_AUTH_TOKEN is not set. Find your token at https://app.localstack.cloud/workspace/auth-token"; exit 1)
localstack start -d
stop:
@echo
localstack stop
ready:
@echo Waiting on the LocalStack container...
@localstack wait -t 30 && echo Localstack is ready to use! || (echo Gave up waiting on LocalStack, exiting. && exit 1)
logs:
@localstack logs > logs.txt
test-ci:
make start install ready create-lambdas; return_code=`echo $$?`;\
make logs; make stop; exit $$return_code;
.PHONY: usage install create-lambdas run stop ready logs test-ci