You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
109 lines
3.5 KiB
109 lines
3.5 KiB
name: Review app pipeline |
|
|
|
concurrency: |
|
group: review-${{ github.event.pull_request.number }} |
|
|
|
on: |
|
pull_request: |
|
types: |
|
- opened |
|
- synchronize |
|
- reopened |
|
workflow_dispatch: |
|
|
|
defaults: |
|
run: |
|
shell: bash |
|
|
|
env: |
|
app_repo_role: arn:aws:iam::815624722760:role/core-application-repo |
|
aws_region: eu-west-2 |
|
repository: core |
|
|
|
jobs: |
|
infra: |
|
name: Deploy review app infrastructure |
|
uses: communitiesuk/submit-social-housing-lettings-and-sales-data-infrastructure/.github/workflows/create_review_app_infra.yml@main |
|
with: |
|
key: ${{ github.event.pull_request.number }} |
|
app_repo_role: arn:aws:iam::815624722760:role/core-application-repo |
|
permissions: |
|
id-token: write |
|
|
|
code: |
|
name: Deploy review app code |
|
needs: [infra] |
|
uses: ./.github/workflows/aws_deploy.yml |
|
with: |
|
aws_account_id: 837698168072 |
|
aws_role_prefix: core-dev |
|
aws_task_prefix: core-review-${{ github.event.pull_request.number }} |
|
concurrency_tag: ${{ github.event.pull_request.number }} |
|
environment: review |
|
permissions: |
|
id-token: write |
|
|
|
performance: |
|
needs: [code] |
|
runs-on: ubuntu-latest |
|
permissions: |
|
id-token: write |
|
|
|
steps: |
|
- name: Configure AWS credentials |
|
uses: aws-actions/configure-aws-credentials@v3 |
|
with: |
|
aws-region: ${{ env.aws_region }} |
|
role-to-assume: ${{ env.app_repo_role }} |
|
|
|
- name: Configure AWS credentials for the environment |
|
uses: aws-actions/configure-aws-credentials@v3 |
|
with: |
|
aws-region: eu-west-2 |
|
role-to-assume: arn:aws:iam::837698168072:role/core-dev-deployment |
|
role-chaining: true |
|
|
|
- name: Run Performance Test |
|
env: |
|
email: performance_testing_user@example.com |
|
password: password |
|
ad_hoc_task_definition: core-review-${{ github.event.pull_request.number }}-ad-hoc |
|
cluster: core-review-${{ github.event.pull_request.number }}-app |
|
service: core-review-${{ github.event.pull_request.number }}-app |
|
run: | |
|
echo $cluster |
|
network=$(aws ecs describe-services --cluster $cluster --services $service --query services[0].networkConfiguration) |
|
overrides='{ |
|
"containerOverrides": [{ |
|
"name": "app", |
|
"command": ["sh", "./lib/tasks/performance_test.sh"] |
|
}] |
|
}' |
|
arn=$(aws ecs run-task --cluster $cluster --task-definition $ad_hoc_task_definition --network-configuration "$network" --overrides "$overrides" --group migrations --launch-type FARGATE --query tasks[0].taskArn) |
|
|
|
echo "Waiting for performance tests to run" |
|
task_id=${arn##*/} |
|
task_id=${task_id%*\"} |
|
|
|
aws ecs wait tasks-stopped --cluster $cluster --tasks $task_id |
|
|
|
succeeded=$(aws ecs describe-tasks --cluster $cluster --tasks $task_id --query "tasks[0].containers[0].exitCode == '0'") |
|
if [ "$succeeded" == "true" ]; then exit 0; else exit 1; fi |
|
|
|
comment: |
|
name: Add link to PR |
|
needs: [code] |
|
runs-on: ubuntu-latest |
|
permissions: |
|
issues: write |
|
pull-requests: write |
|
|
|
steps: |
|
- name: Comment on PR with URL |
|
uses: unsplash/comment-on-pr@v1.3.0 |
|
env: |
|
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |
|
with: |
|
msg: "Created review app at https://review.submit-social-housing-data.levellingup.gov.uk/${{ github.event.pull_request.number }}" |
|
check_for_duplicate_msg: true |
|
duplicate_msg_pattern: Created review app at*
|
|
|