-
Notifications
You must be signed in to change notification settings - Fork 1
110 lines (93 loc) Β· 4.73 KB
/
lighthouse.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
name: Run lighthouse
on:
pull_request:
branches: main
push:
branches: main
jobs:
lighthouse:
name: Lighthouse CI
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Setup Node.js
uses: actions/setup-node@v3
with:
node-version: '20.18.0'
- name: Install dependencies
run: yarn install
- name: Build project
run: yarn build
- name: Run Lighthouse CI
env:
LHCI_GITHUB_APP_TOKEN: ${{ secrets.LHCI_GITHUB_APP_TOKEN }}
run: |
yarn dlx @lhci/cli autorun
- name: Format lighthouse score
id: format_lighthouse_score
uses: actions/github-script@v3
with:
github-token: ${{secrets.GITHUB_TOKEN}}
script: |
const fs = require('fs');
const results = JSON.parse(fs.readFileSync("./lhci_reports/manifest.json"));
const totals = {
summary: {
performance: 0,
accessibility: 0,
seo: 0,
'best-practices': 0
},
audits: {
'first-contentful-paint': { score: 0, value: 0 },
'largest-contentful-paint': { score: 0, value: 0 },
'cumulative-layout-shift': { score: 0, value: 0 }
}
};
results.forEach(result => {
const { summary } = result;
const details = JSON.parse(fs.readFileSync(result.jsonPath));
const { audits } = details;
Object.keys(totals.summary).forEach(key => {
totals.summary[key] += summary[key];
});
Object.keys(totals.audits).forEach(key => {
totals.audits[key].score += audits[key].score;
totals.audits[key].value += parseFloat(audits[key].displayValue);
});
});
const count = results.length;
Object.keys(totals.summary).forEach(key => {
totals.summary[key] = Math.round((totals.summary[key] / count) * 100);
});
Object.keys(totals.audits).forEach(key => {
totals.audits[key].score = totals.audits[key].score / count;
totals.audits[key].value = (totals.audits[key].value / count).toFixed(1);
});
const score = (res) => (res >= 90 ? "π’" : res >= 50 ? "π " : "π΄");
const comment = [
`## β‘οΈ Lighthouse Report (Average of ${count} runs)`,
`| Category | Score |`,
`| --- | --- |`,
`| ${score(totals.summary.performance)} Performance | ${totals.summary.performance} |`,
`| ${score(totals.summary.accessibility)} Accessibility | ${totals.summary.accessibility} |`,
`| ${score(totals.summary.seo)} SEO | ${totals.summary.seo} |`,
`| ${score(totals.summary['best-practices'])} Best Practices | ${totals.summary['best-practices']} |`,
``,
`### Core Web Vitals (Average)`,
`| Metric | Value |`,
`| --- | --- |`,
`| ${score(totals.audits['first-contentful-paint'].score * 100)} First Contentful Paint | ${totals.audits['first-contentful-paint'].value} s |`,
`| ${score(totals.audits['largest-contentful-paint'].score * 100)} Largest Contentful Paint | ${totals.audits['largest-contentful-paint'].value} s |`,
`| ${score(totals.audits['cumulative-layout-shift'].score * 100)} Cumulative Layout Shift | ${totals.audits['cumulative-layout-shift'].value} |`
].join('\n');
core.setOutput('comments', comment);
- name: Comment PR
if: github.event_name == 'pull_request'
uses: thollander/actions-comment-pull-request@v2
with:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
message: ${{ steps.format_lighthouse_score.outputs.comments }}
comment_tag: lighthouse
mode: upsert