check worker bundle sizes (#4032)
This PR aims to make sure #4030 doesn't need to happen again. We check that the worker file sizes stay within a given limit, and require people to explicitly up this limit if they decide to add new deps that grow the bundle size significantly. ### Change Type <!-- ❗ Please select a 'Type' label ❗️ --> - [ ] `feature` — New feature - [ ] `improvement` — Product improvement - [ ] `api` — API change - [ ] `bugfix` — Bug fix - [x] `other` — Changes that don't affect SDK users, e.g. internal or .com changes ### Test Plan 1. Add a step-by-step description of how to test your PR here. 2. - [ ] Unit Tests - [ ] End to end tests ### Release Notes - Add a brief release note for your PR here.
This commit is contained in:
parent
aa1c99fee3
commit
ca5e268798
6 changed files with 72 additions and 0 deletions
3
.github/workflows/checks.yml
vendored
3
.github/workflows/checks.yml
vendored
|
@ -47,6 +47,9 @@ jobs:
|
||||||
- name: Check scripts
|
- name: Check scripts
|
||||||
run: yarn check-scripts
|
run: yarn check-scripts
|
||||||
|
|
||||||
|
- name: Check bundle sizes
|
||||||
|
run: yarn lazy check-bundle-size
|
||||||
|
|
||||||
- name: Check PR template
|
- name: Check PR template
|
||||||
run: yarn update-pr-template --check
|
run: yarn update-pr-template --check
|
||||||
env:
|
env:
|
||||||
|
|
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -100,3 +100,5 @@ apps/docs/api
|
||||||
/vercel.json
|
/vercel.json
|
||||||
license-report-prod.html
|
license-report-prod.html
|
||||||
license-report.html
|
license-report.html
|
||||||
|
|
||||||
|
.bundle-meta.json
|
|
@ -18,6 +18,7 @@
|
||||||
"test-ci": "lazy inherit",
|
"test-ci": "lazy inherit",
|
||||||
"test": "yarn run -T jest",
|
"test": "yarn run -T jest",
|
||||||
"test-coverage": "lazy inherit",
|
"test-coverage": "lazy inherit",
|
||||||
|
"check-bundle-size": "yarn run -T tsx ../../scripts/check-worker-bundle.ts --entry src/lib/worker.ts --size-limit-bytes 350000",
|
||||||
"lint": "yarn run -T tsx ../../scripts/lint.ts"
|
"lint": "yarn run -T tsx ../../scripts/lint.ts"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
"deploy": "wrangler deploy",
|
"deploy": "wrangler deploy",
|
||||||
"dev": "wrangler dev",
|
"dev": "wrangler dev",
|
||||||
"start": "wrangler dev",
|
"start": "wrangler dev",
|
||||||
|
"check-bundle-size": "yarn run -T tsx ../../scripts/check-worker-bundle.ts --entry src/index.ts --size-limit-bytes 35000",
|
||||||
"lint": "yarn run -T tsx ../../scripts/lint.ts"
|
"lint": "yarn run -T tsx ../../scripts/lint.ts"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
@ -15,6 +16,7 @@
|
||||||
"@cloudflare/workers-types": "^4.20240620.0",
|
"@cloudflare/workers-types": "^4.20240620.0",
|
||||||
"@types/node": "~20.11",
|
"@types/node": "~20.11",
|
||||||
"discord-api-types": "^0.37.67",
|
"discord-api-types": "^0.37.67",
|
||||||
|
"esbuild": "^0.18.4",
|
||||||
"typescript": "^5.3.3",
|
"typescript": "^5.3.3",
|
||||||
"wrangler": "3.61.0"
|
"wrangler": "3.61.0"
|
||||||
}
|
}
|
||||||
|
|
63
scripts/check-worker-bundle.ts
Normal file
63
scripts/check-worker-bundle.ts
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
import { existsSync, readFileSync, rmSync } from 'fs'
|
||||||
|
import kleur from 'kleur'
|
||||||
|
import minimist from 'minimist'
|
||||||
|
import { resolve } from 'path'
|
||||||
|
import { exec } from './lib/exec'
|
||||||
|
|
||||||
|
const args = minimist(process.argv.slice(2))
|
||||||
|
const sizeLimit = Number(args['size-limit-bytes'])
|
||||||
|
if (!isFinite(sizeLimit) || sizeLimit < 1) {
|
||||||
|
console.error(
|
||||||
|
'Invalid usage. Usage: yarn tsx check-worker-bundle.ts --size-limit-bytes <size> --entry <entry>'
|
||||||
|
)
|
||||||
|
process.exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
const entry = args['entry']
|
||||||
|
if (!existsSync(entry)) {
|
||||||
|
console.error('Entry file does not exist:', entry)
|
||||||
|
process.exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
const bundleMetaFileName = '.bundle-meta.json'
|
||||||
|
|
||||||
|
interface Meta {
|
||||||
|
outputs: {
|
||||||
|
[fileName: string]: {
|
||||||
|
bytes: number
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async function checkBundleSize() {
|
||||||
|
rmSync(bundleMetaFileName, { force: true })
|
||||||
|
|
||||||
|
await exec('yarn', [
|
||||||
|
'esbuild',
|
||||||
|
entry,
|
||||||
|
'--bundle',
|
||||||
|
'--outfile=/dev/null',
|
||||||
|
'--minify',
|
||||||
|
'--external:cloudflare:workers',
|
||||||
|
'--metafile=' + bundleMetaFileName,
|
||||||
|
])
|
||||||
|
|
||||||
|
console.log(kleur.cyan().bold('Checking bundle size'), 'of', resolve(entry) + '\n')
|
||||||
|
|
||||||
|
const meta = JSON.parse(readFileSync(bundleMetaFileName).toString()) as Meta
|
||||||
|
const totalSize = Object.values(meta.outputs).reduce((acc, output) => acc + output.bytes, 0)
|
||||||
|
if (totalSize === 0) {
|
||||||
|
throw new Error('Invalid bundle meta in ' + process.cwd() + '/' + bundleMetaFileName)
|
||||||
|
}
|
||||||
|
|
||||||
|
if (totalSize > sizeLimit) {
|
||||||
|
console.error(
|
||||||
|
`${kleur.red().bold('ERROR')} Bundle size exceeds limit: ${totalSize} > ${sizeLimit}`
|
||||||
|
)
|
||||||
|
process.exit(1)
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log(`Bundle size is within limit: ${totalSize} < ${sizeLimit}`)
|
||||||
|
}
|
||||||
|
|
||||||
|
checkBundleSize()
|
|
@ -13344,6 +13344,7 @@ __metadata:
|
||||||
"@tldraw/utils": "workspace:*"
|
"@tldraw/utils": "workspace:*"
|
||||||
"@types/node": "npm:~20.11"
|
"@types/node": "npm:~20.11"
|
||||||
discord-api-types: "npm:^0.37.67"
|
discord-api-types: "npm:^0.37.67"
|
||||||
|
esbuild: "npm:^0.18.4"
|
||||||
typescript: "npm:^5.3.3"
|
typescript: "npm:^5.3.3"
|
||||||
wrangler: "npm:3.61.0"
|
wrangler: "npm:3.61.0"
|
||||||
languageName: unknown
|
languageName: unknown
|
||||||
|
|
Loading…
Reference in a new issue