Skip to content

format comment for mobile and desktop #414

format comment for mobile and desktop

format comment for mobile and desktop #414

Workflow file for this run

name: Lighthouse
permissions:
pull-requests: write
on:
push:
branches: [ "INFRA16" ]
#pull_request_target:
# branches: [main]
jobs:
authorize:
environment:
${{ github.event_name == 'pull_request_target' && github.event.pull_request.head.repo.full_name != github.repository && 'external' || 'internal' }}
runs-on: ubuntu-latest
steps:
- run: true
lighthouse:
needs: authorize
runs-on: ubuntu-latest
env:
PUBLIC_FIREBASE_CONFIG: ${{ secrets.FIREBASE_CONFIG }}
PUBLIC_FIREBASE_SERVICE_ACCOUNT: ${{ secrets.FIREBASE_SERVICE_ACCOUNT }}
PUBLIC_FIREBASE_STORAGE_BUCKET: ${{secrets.FIREBASE_STORAGE_BUCKET}}
strategy:
matrix:
node-version: ['20.x']
steps:
#- uses: actions/github-script@v7
# id: pr
# with:
# script: |
# const { data: pullRequest } = await github.rest.pulls.get({
# ...context.repo,
# pull_number: context.payload.pull_request.number,
# });
# return pullRequest
- uses: actions/checkout@v4
#with:
# ref: ${{fromJSON(steps.pr.outputs.result).merge_commit_sha}}
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
- uses: pnpm/action-setup@v3
name: Install pnpm
with:
version: 9
run_install: false
- name: Get pnpm store directory
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV
- uses: actions/cache@v4
name: Setup pnpm cache
with:
path: ${{ env.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- run: pnpm install --no-frozen-lockfile
- run: pnpm run build
- run: pnpm run preview & npx wait-on http://localhost:4321
- name: Run Lighthouse Mobile
id: lighthouse_audit
uses: treosh/lighthouse-ci-action@v11
with:
urls: |
http://localhost:4321
configPath: ./.github/workflows/lighthouse/lighthouserc.json
uploadArtifacts: true
temporaryPublicStorage: true
runs: 5
- name: Format Lighthouse Mobile score
uses: actions/github-script@v7
id: format_lighthouse_score
with:
script: |
const lighthouseCommentMaker = require('./.github/workflows/lighthouse/lighthouseCommentMaker.cjs');
const lighthouseOutputs = {
manifest: ${{ steps.lighthouse_audit.outputs.manifest }},
links: ${{ steps.lighthouse_audit.outputs.links }},
assertionResults: ${{ steps.lighthouse_audit.outputs.assertionResults }}
};
const prComment = lighthouseCommentMaker({ lighthouseOutputs });
core.setOutput("pr_comment", prComment);
- name: Run Lighthouse Desktop
id: lighthouse_desktop_audit
uses: treosh/lighthouse-ci-action@v11
with:
urls: |
http://localhost:4321
configPath: ./.github/workflows/lighthouse/lighthouserc-desktop.json
uploadArtifacts: true
temporaryPublicStorage: true
runs: 5
artifactName: lighthouse-desktop-results
- name: Format Lighthouse Desktop score
uses: actions/github-script@v7
id: format_lighthouse_desktop_score
with:
script: |
const lighthouseCommentMaker = require('./.github/workflows/lighthouse/lighthouseCommentMaker.cjs');
const lighthouseOutputs = {
manifest: ${{ steps.lighthouse_desktop_audit.outputs.manifest }},
links: ${{ steps.lighthouse_desktop_audit.outputs.links }},
assertionResults: ${{ steps.lighthouse_desktop_audit.outputs.assertionResults }}
};
const prComment = lighthouseCommentMaker({ lighthouseOutputs });
core.setOutput("pr_comment", prComment);
- uses: jwalton/gh-find-current-pr@v1
id: pr_number_finder
- name: Add Lighthouse stats as comment
uses: marocchino/[email protected]
with:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
header: lighthouse
number: ${{ github.event.number || steps.pr_number_finder.outputs.pr }}
message: |
```
## Mobile score
${{ steps.format_lighthouse_score.outputs.pr_comment }}
## Desktop score
${{ steps.format_lighthouse_desktop_score.outputs.pr_comment }}
```