|
1 | 1 | name: pr-preview |
2 | | -on: pull_request_target |
| 2 | +on: |
| 3 | + pull_request_target: |
| 4 | + issue_comment: |
| 5 | + types: [created] |
| 6 | + |
3 | 7 | jobs: |
4 | | - build-upload: |
| 8 | + check-permissions: |
| 9 | + runs-on: ubuntu-latest |
| 10 | + if: >- |
| 11 | + github.event_name == 'pull_request_target' || |
| 12 | + (github.event_name == 'issue_comment' && |
| 13 | + github.event.issue.pull_request && |
| 14 | + contains(github.event.comment.body, '/deploy-preview')) |
| 15 | + outputs: |
| 16 | + allowed: ${{ steps.check-team.outputs.allowed }} |
| 17 | + pr-number: ${{ steps.check-team.outputs.number }} |
| 18 | + steps: |
| 19 | + - name: Get PR info and check permissions |
| 20 | + id: check-team |
| 21 | + env: |
| 22 | + EVENT_NAME: ${{ github.event_name }} |
| 23 | + PR_NUMBER: ${{ github.event.pull_request.number }} |
| 24 | + PR_ASSOCIATION: ${{ github.event.pull_request.author_association }} |
| 25 | + COMMENT_NUMBER: ${{ github.event.issue.number }} |
| 26 | + COMMENT_ASSOCIATION: ${{ github.event.comment.author_association }} |
| 27 | + run: | |
| 28 | + if [[ "$EVENT_NAME" == "pull_request_target" ]]; then |
| 29 | + echo "number=$PR_NUMBER" >> $GITHUB_OUTPUT |
| 30 | + ASSOCIATION="$PR_ASSOCIATION" |
| 31 | + else |
| 32 | + echo "number=$COMMENT_NUMBER" >> $GITHUB_OUTPUT |
| 33 | + ASSOCIATION="$COMMENT_ASSOCIATION" |
| 34 | + fi |
| 35 | +
|
| 36 | + if [[ "$ASSOCIATION" == "OWNER" || "$ASSOCIATION" == "MEMBER" || "$ASSOCIATION" == "COLLABORATOR" ]]; then |
| 37 | + echo "allowed=true" >> $GITHUB_OUTPUT |
| 38 | + echo "User is a repo $ASSOCIATION — allowed" |
| 39 | + else |
| 40 | + echo "allowed=false" >> $GITHUB_OUTPUT |
| 41 | + echo "User association is $ASSOCIATION — not allowed" |
| 42 | + fi |
| 43 | +
|
| 44 | + deploy-preview: |
5 | 45 | runs-on: ubuntu-latest |
| 46 | + needs: check-permissions |
| 47 | + if: needs.check-permissions.outputs.allowed == 'true' |
6 | 48 | env: |
7 | 49 | SURGE_LOGIN: ${{ secrets.SURGE_LOGIN }} |
8 | 50 | SURGE_TOKEN: ${{ secrets.SURGE_TOKEN }} |
9 | 51 | GH_PR_TOKEN: ${{ secrets.GH_PR_TOKEN }} |
10 | | - GH_PR_NUM: ${{ github.event.number }} |
| 52 | + GH_PR_NUM: ${{ needs.check-permissions.outputs.pr-number }} |
11 | 53 | steps: |
12 | 54 | - uses: actions/checkout@v4 |
13 | | - # Yes, we really want to checkout the PR |
14 | 55 | - run: | |
15 | 56 | git fetch origin pull/$GH_PR_NUM/head:tmp |
16 | 57 | git checkout tmp |
17 | | -
|
18 | | - - run: | |
19 | | - git rev-parse origin/main |
20 | | - git rev-parse HEAD |
21 | | - git rev-parse origin/main..HEAD |
22 | | - git log origin/main..HEAD --format="%b" |
23 | | -
|
24 | 58 | - uses: actions/setup-node@v4 |
25 | 59 | with: |
26 | 60 | node-version: '20' |
27 | | - - name: Enable Corepack |
28 | | - shell: bash |
29 | | - run: corepack enable |
| 61 | + - run: corepack enable |
30 | 62 | - uses: actions/cache@v4 |
31 | 63 | id: yarn-cache |
32 | 64 | name: Load Yarn cache |
33 | 65 | with: |
34 | 66 | path: | |
35 | 67 | .yarn/cache |
36 | | - key: ${{ runner.os }}-yarn-cache-${{ hashFiles('yarn.lock') }} |
| 68 | + key: ${{ runner.os }}-yarn-cache-${{ secrets.CACHE_VERSION }}-${{ hashFiles('yarn.lock') }} |
37 | 69 | restore-keys: | |
38 | 70 | ${{ runner.os }}-yarn-cache- |
39 | 71 | - name: Install dependencies |
40 | 72 | shell: bash |
41 | 73 | run: yarn install --immutable --network-timeout 100000 |
42 | 74 | - run: yarn build |
43 | | - name: Build component groups |
| 75 | + name: Build |
44 | 76 | - uses: actions/cache@v4 |
45 | 77 | id: docs-cache |
46 | 78 | name: Load webpack cache |
|
49 | 81 | key: ${{ runner.os }}-v4-${{ hashFiles('yarn.lock') }} |
50 | 82 | - run: yarn build:docs |
51 | 83 | name: Build docs |
52 | | - - name: Deploy preview to surge |
53 | | - if: env.SURGE_LOGIN != '' && env.SURGE_TOKEN != '' |
54 | | - run: | |
55 | | - npx surge packages/module/public --domain pr-${{ github.event.number }}-widgetized-dashboard.surge.sh |
56 | | - - name: Install Chrome for Puppeteer |
57 | | - run: npx puppeteer browsers install chrome |
58 | | - - name: a11y tests |
59 | | - run: yarn serve:docs & yarn test:a11y |
| 84 | + - name: Upload docs |
| 85 | + uses: patternfly/.github/.github/actions/surge-preview@main |
| 86 | + with: |
| 87 | + folder: packages/module/public |
0 commit comments