Skip to content

Deploy on LocalStack #74

Deploy on LocalStack

Deploy on LocalStack #74

Workflow file for this run

name: Deploy on LocalStack
on:
push:
paths-ignore:
- 'README.md'
branches:
- main
pull_request:
branches:
- main
schedule:
# “At 00:00 on Sunday.”
- cron: "0 0 * * 0"
workflow_dispatch:
jobs:
cdk:
name: Setup infrastructure using CDK
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Setup Node.js
uses: actions/setup-node@v3
with:
node-version: 18
- name: Install CDK
run: |
npm install -g aws-cdk-local aws-cdk
cdklocal --version
- name: Install dependencies
run: |
yarn
- name: Start LocalStack
env:
LOCALSTACK_API_KEY: ${{ secrets.LOCALSTACK_API_KEY }}
run: |
pip install localstack awscli-local[ver1]
pip install terraform-local
docker pull localstack/localstack-pro:latest
# Start LocalStack in the background
EXTRA_CORS_ALLOWED_ORIGINS=* DEBUG=1 localstack start -d
# Wait 30 seconds for the LocalStack container to become ready before timing out
echo "Waiting for LocalStack startup..."
localstack wait -t 15
echo "Startup complete"
- name: Deploy using CDK
run: |
cdklocal bootstrap aws://000000000000/us-east-1
cdklocal deploy --require-approval never --outputs-file cdk_outputs.json
- name: List the resources
run: |
awslocal lambda list-functions
awslocal sqs list-queues
awslocal dynamodb list-tables
- name: Send Messages
run: |
front_queue_url=$(awslocal sqs list-queues | jq -r .QueueUrls[0])
awslocal sqs send-message-batch --queue-url $front_queue_url --entries file://test/testMessagesFirst.json
awslocal sqs send-message-batch --queue-url $front_queue_url --entries file://test/testMessagesSecond.json
awslocal sqs send-message-batch --queue-url $front_queue_url --entries file://test/testMessagesThird.json
awslocal sqs send-message-batch --queue-url $front_queue_url --entries file://test/cornerCase1.json
awslocal sqs send-message-batch --queue-url $front_queue_url --entries file://test/cornerCase2.json
- name: Run tests
run: |
yarn test
endpoint_url=$(cat cdk_outputs.json | jq -r .FriendMicroservicesStack[])
result_player_1=$(curl -X GET "$endpoint_url"friends/player1 | jq -r .[0].friend_id)
result_player_2=$(curl -X GET "$endpoint_url"friends/player2 | jq -r .[0].friend_id)
if [[ $result_player_1 != "player2" ]] || [[ $result_player_2 != "player1" ]]; then
echo "unexpected response"
echo $result_player_1 $result_player_2
exit 1
fi
- name: Send a Slack notification
if: failure() || github.event_name != 'pull_request'
uses: ravsamhq/notify-slack-action@v2
with:
status: ${{ job.status }}
token: ${{ secrets.GITHUB_TOKEN }}
notification_title: "{workflow} has {status_message}"
message_format: "{emoji} *{workflow}* {status_message} in <{repo_url}|{repo}>"
footer: "Linked Repo <{repo_url}|{repo}> | <{run_url}|View Workflow run>"
notify_when: "failure"
env:
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
- name: Generate a Diagnostic Report
if: failure()
run: |
curl -s localhost:4566/_localstack/diagnose | gzip -cf > diagnose.json.gz
- name: Upload the Diagnostic Report
if: failure()
uses: actions/upload-artifact@v3
with:
name: diagnose.json.gz
path: ./diagnose.json.gz