Skip to content

Restructure project to use pyproject.toml; add secretsmanager proxy test #26

Restructure project to use pyproject.toml; add secretsmanager proxy test

Restructure project to use pyproject.toml; add secretsmanager proxy test #26

Workflow file for this run

name: LocalStack AWS Proxy Extension Tests
on:
push:
paths:
- aws-proxy/**
branches:
- main
pull_request:
paths:
- .github/workflows/aws-proxy.yml
- aws-proxy/**
workflow_dispatch:
jobs:
tests-aws-proxy:
name: Run extension tests
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Set up Python 3.x
uses: actions/setup-python@v4
with:
python-version: '3.13'
- name: Set up Terraform CLI
uses: hashicorp/setup-terraform@v2
- name: Install LocalStack and extension
env:
LOCALSTACK_AUTH_TOKEN: ${{ secrets.LOCALSTACK_AUTH_TOKEN }}
run: |
set -e
docker pull localstack/localstack-pro &
docker pull public.ecr.aws/lambda/python:3.8 &
# install latest CLI packages (dev releases)
pip install --upgrade --pre localstack localstack-ext
# TODO remove
mkdir ~/.localstack; echo '{"token":"test"}' > ~/.localstack/auth.json
# install dependencies
sudo apt-get update
sudo apt-get install -y libsasl2-dev
# build and install extension
localstack extensions init
(
cd aws-proxy
make install
. .venv/bin/activate
pip install --upgrade --pre localstack localstack-ext
make build
make enable
)
# install awslocal/tflocal command lines
pip install awscli-local[ver1]
pip install terraform-local
# Note: Install the same boto3 version as installed in the image. This is a small fix to avoid
# assertion errors (missing `BucketArn` in S3 responses). TODO: to be fixed in a future iteration!
version=$(docker run --entrypoint= --rm localstack/localstack-pro bash -c '. .venv/bin/activate; pip show boto3 | grep Version | cut -d" " -f2')
(. .venv/bin/activate; pip install "boto3==$version")
find /home/runner/.cache/localstack/volume/lib/extensions/python_venv/lib/python3.*/site-packages/aws*
ls -la /home/runner/.cache/localstack/volume/lib/extensions/python_venv/lib/python3.*/site-packages/aws*
DEBUG=1 GATEWAY_SERVER=hypercorn localstack start -d
localstack wait
- name: Run linter
run: |
cd aws-proxy
(. .venv/bin/activate; pip install --upgrade --pre localstack localstack-ext)
make lint
- name: Run integration tests
env:
AWS_DEFAULT_REGION: us-east-1
AWS_ACCESS_KEY_ID: ${{ secrets.TEST_AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.TEST_AWS_SECRET_ACCESS_KEY }}
run: |
cd aws-proxy
make test
- name: Deploy and test sample app
env:
AWS_DEFAULT_REGION: us-east-1
AWS_ACCESS_KEY_ID: ${{ secrets.TEST_AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.TEST_AWS_SECRET_ACCESS_KEY }}
LOCALSTACK_AUTH_TOKEN: ${{ secrets.LOCALSTACK_AUTH_TOKEN }}
run: |
cd aws-proxy/example
make test
- name: Print LocalStack logs
if: always()
run: localstack logs