Add EFS Authorization config #81
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: "Tests: E2E" | |
concurrency: # This need to ensure that only a single job or workflow using the same concurrency group will run at a time. | |
group: ${{ github.workflow }} | |
cancel-in-progress: false | |
defaults: | |
run: | |
shell: bash | |
env: | |
AWS_REGION: us-west-2 | |
NAMESPACE: tftest | |
IZE_LOG_LEVEL: debug | |
IZE_PLAIN_TEXT: true | |
IZE_VERSION: 0.0.0-dev | |
AWS_PROFILE: debug | |
on: | |
workflow_dispatch: | |
pull_request: | |
jobs: | |
e2e: | |
runs-on: ubuntu-latest | |
timeout-minutes: 60 | |
strategy: | |
fail-fast: false | |
max-parallel: 2 # VPCs are limited | |
matrix: | |
include: | |
- name: complete-worker | |
env: e2e01 | |
test_name: TestExamplesCompleteWorker | |
- name: worker-scheduled | |
env: e2e02 | |
test_name: TestExamplesWorkerSchedule | |
- name: complete-web | |
env: e2e03 | |
test_name: TestExamplesCompleteWeb | |
- name: web-nginx-proxy | |
env: e2e04 | |
test_name: TestExamplesWebProxy | |
- name: worker-scheduled-autoscale | |
env: e2e05 | |
test_name: TestExamplesWorkerAutoScheduled | |
- name: complete-worker-ec2 | |
env: e2e06 | |
test_name: TestExamplesWorkerEc2 | |
env: | |
ENV: ${{ matrix.env }} | |
steps: | |
- name: Install Go | |
uses: actions/setup-go@v5 | |
with: | |
go-version: 1.22.x | |
- name: Checkout Code | |
uses: actions/checkout@v2 | |
- name: Configure AWS Credentials | |
uses: aws-actions/configure-aws-credentials@v1 | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID_SA }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY_SA }} | |
aws-region: ${{ env.AWS_REGION }} | |
- name: Generate Test SSH Key | |
run: ssh-keygen -q -f ~/.ssh/id_rsa | |
- name: IZE setup | |
uses: hazelops/action-setup-ize@1.0.1 | |
with: | |
version: ${{ env.IZE_VERSION }} | |
- name: IZE init | |
run: ize init | |
- name: IZE create AWS Profile | |
run: ize gen aws-profile | |
- name: IZE gen tfenv | |
run: ize gen tfenv | |
- name: Copy generated files | |
run: | | |
cp -R .ize/env/${{ env.ENV }}/*.* examples/${{ matrix.name }}/ | |
# TODO: This should be replaced by better ize integration | |
- name: "Setup Terraform" | |
uses: hashicorp/setup-terraform@v3 | |
with: | |
terraform_version: "1.1.3" | |
- name: Go TF Test | |
working-directory: test | |
run: | | |
go install github.com/gruntwork-io/terratest/cmd/terratest_log_parser@latest | |
go mod tidy | |
go test -v -timeout 60m -run ${{ matrix.test_name }} -coverprofile=coverage-${{ matrix.test_name }}.out -race -covermode=atomic | tee test_output.log | |
terratest_log_parser -testlog test_output.log -outputdir results | |
ls -la | |
- name: Test Summary | |
uses: test-summary/action@v2 | |
with: | |
paths: | | |
test/results/**/*.xml | |
test/results/*.xml | |
if: always() | |
- name: Upload test summary | |
uses: actions/upload-artifact@v3 | |
with: | |
name: test-summary-${{ matrix.test_name }} | |
path: test/test-summary-${{ matrix.test_name }}.md | |
if: always() | |
- name: Upload Go test results | |
uses: actions/upload-artifact@v4 | |
with: | |
name: coverage-${{ matrix.test_name }} | |
path: test/coverage-${{ matrix.test_name }}.out | |
if: always() | |
- name: Upload coverage reports to Codecov | |
uses: codecov/codecov-action@v4.0.1 | |
with: | |
files: test/coverage-${{ matrix.test_name }}.out | |
token: ${{ secrets.CODECOV_TOKEN }} | |
verbose: true | |
name: ${{ matrix.test_name }} | |