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:
David Sheldrick 2024-06-27 14:48:17 +01:00 committed by GitHub
parent aa1c99fee3
commit ca5e268798
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 72 additions and 0 deletions

View file

@ -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
View file

@ -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

View file

@ -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": {

View file

@ -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"
} }

View 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()

View file

@ -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