forked from mapbox/mapbox-gl-js
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcheck-bundle-size.js
executable file
·140 lines (124 loc) · 5.11 KB
/
check-bundle-size.js
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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
#!/usr/bin/env node
import { Octokit } from "@octokit/rest";
import prettyBytes from 'pretty-bytes';
import fs from 'fs';
import {execSync} from 'child_process';
import zlib from 'zlib';
process.on('unhandledRejection', error => {
// don't log `error` directly, because errors from child_process.execSync
// contain an (undocumented) `envPairs` with environment variable values
console.log(error.message || 'Error');
process.exit(1)
});
const FILES = [
['JS', "dist/mapbox-gl.js"],
['CSS', "dist/mapbox-gl.css"]
];
const PK = process.env['MBX_CI_DOMAIN'];
if (!PK) {
console.log('Fork PR; not computing size.');
process.exit(0);
}
const owner = 'mapbox';
const repo = 'mapbox-gl-js';
(async () => {
// Initialize github client
const github = new Octokit({
auth: execSync('~/mbx-ci github notifier token').toString().trim()
});
//get current sizes
const currentSizes = FILES.map(([label, filePath]) => [label, getSize(filePath)]);
console.log(currentSizes);
async function getMergeBase() {
const head = process.env['CIRCLE_SHA1'];
const pr = process.env['CIRCLE_PULL_REQUEST'];
if (pr) {
const number = +pr.match(/\/(\d+)\/?$/)[1];
return github.pulls.get({
owner,
repo,
pull_number: number
}).then(({data}) => {
const base = data.base.ref;
return execSync(`git merge-base origin/${base} ${head}`).toString().trim();
});
} else {
// Walk backward through the history (maximum of 10 commits) until
// finding a commit on either master or release-*; assume that's the
// base branch.
for (const sha of execSync(`git rev-list --max-count=10 ${head}`).toString().trim().split('\n')) {
const base = execSync(`git branch -r --contains ${sha} origin/main origin/release-*`).toString().split('\n')[0].trim();
if (base) {
return Promise.resolve(execSync(`git merge-base ${base} ${head}`).toString().trim());
}
}
}
return Promise.resolve(null);
}
async function getPriorSize(mergeBase, name) {
if (!mergeBase) {
console.log('No merge base available.');
return Promise.resolve(null);
}
return github.checks.listForRef({
owner,
repo,
ref: mergeBase
}).then(({data}) => {
const run = data.check_runs.find(run => run.name === name);
if (run) {
const match = run.output.summary.match(/`[^`]+` is (\d+) bytes \([^\)]+\) uncompressed, (\d+) bytes \([^\)]+\) gzipped\./);
if (match) {
const prior = { size: +match[1], gzipSize: +match[2] };
console.log(`Prior size was ${prettyBytes(prior.size)}, gzipped ${prior.gzipSize}.`);
return prior;
}
}
console.log('No matching check found.');
return Promise.resolve(null);
});
}
const mergeBase = await getMergeBase();
// Generate a github check for each filetype
for(let check_idx=0; check_idx<FILES.length; check_idx++){
const [label, file] = FILES[check_idx];
const name = `Size - ${label}`;
const size = currentSizes[check_idx][1];
const priorSize = await getPriorSize(mergeBase, name);
console.log('priorSize: ', label, priorSize);
const title = `${formatSize(size.size, priorSize ? priorSize.size : null)}, gzipped ${formatSize(size.gzipSize, priorSize ? priorSize.gzipSize : null)}`;
const megabit = Math.pow(2, 12);
const downloadTime3G = (size.gzipSize / (3 * megabit)).toFixed(0);
const downloadTime4G = (size.gzipSize / (10 * megabit)).toFixed(0);
const summary = `\`${file}\` is ${size.size} bytes (${prettyBytes(size.size)}) uncompressed, ${size.gzipSize} bytes (${prettyBytes(size.gzipSize)}) gzipped.
That's **${downloadTime3G} seconds** over slow 3G (3 Mbps), **${downloadTime4G} seconds** over fast 4G (10 Mbps).`;
console.log('Posting check to GitHub');
console.log(`Title: ${title}`);
console.log(`Summary: ${summary}`);
await github.checks.create({
owner,
repo,
name,
head_branch: process.env['CIRCLE_BRANCH'],
head_sha: process.env['CIRCLE_SHA1'],
status: 'completed',
conclusion: 'success',
completed_at: new Date().toISOString(),
output: { title, summary }
});
}
})();
function getSize(filePath) {
const {size} = fs.statSync(filePath);
const gzipSize = zlib.gzipSync(fs.readFileSync(filePath)).length;
return {size, gzipSize};
}
function formatSize(size, priorSize) {
if (priorSize) {
const change = size - priorSize;
const percent = (change / priorSize) * 100;
return `${change >= 0 ? '+' : ''}${prettyBytes(change)} ${percent.toFixed(3)}% (${prettyBytes(size)})`;
} else {
return prettyBytes(size);
}
}