Skip to content
55 changes: 55 additions & 0 deletions .github/workflows/pull-request-build.yaml
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
name: Build SDK
on:
pull_request_review:
types: [ submitted ]
branches: [ version-3 ]
workflow_dispatch:

concurrency:
group: start-pull-request-build-${{ github.ref }}
cancel-in-progress: true

env:
# constants
DOWNLOAD_FOLDER: '.build-scripts/'
SCRIPT_LOCATION: 'workflows/start-pull-request-build/pull-request-build-v1.sh'

# custom variables
IAM_ROLE_ARN: 'arn:aws:iam::525369684841:role/AwsSdkRubyGitHubRole'
ROLE_SESSION_DURATION_SECONDS: 7200

jobs:
aws-sdk-pr-build:
if: github.event.review.state == 'approved'
runs-on: ubuntu-latest
permissions:
id-token: write
issues: write
pull-requests: write
contents: read
steps:
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@main
with:
role-to-assume: ${{ env.IAM_ROLE_ARN }}
role-session-name: PullRequestBuildGitHubAction
role-duration-seconds: '$ROLE_SESSION_DURATION_SECONDS'
aws-region: us-west-2
- name: Download Build Script
run: |
aws s3 cp s3://aws-sdk-builds-github-assets-prod-us-west-2/$SCRIPT_LOCATION ./$DOWNLOAD_FOLDER/$SCRIPT_LOCATION --no-progress
chmod +x ./$DOWNLOAD_FOLDER/$SCRIPT_LOCATION
- name: Build
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
REPO: ${{ github.repository }}
HEAD_REF: ${{ github.event.pull_request.head.ref }}
PR_NUMBER: ${{ github.event.pull_request.number }}
RUN_ID: ${{ github.run_id }}
run: |
./$DOWNLOAD_FOLDER/$SCRIPT_LOCATION \
--repo "$REPO" \
--branch "$HEAD_REF" \
--pr-number "$PR_NUMBER" \
--run-id "$RUN_ID"
timeout-minutes: 120