.. | ||
mitt | ||
README.md | ||
tsconfig.cjs.json | ||
tsconfig.esm.json |
Vendoring third party dependencies
Because we are working towards an agnostic Puppeteer that can run in any environment (see #6125) we cannot import common dependencies in a way that relies on Node's resolution to find them. For example, import mitt from 'mitt'
works fine in Node, but in an ESM build running in the browser, the browser has no idea where to find 'mitt'
.
Therefore we put all common dependencies into this directory, vendor
. This means there are extra criteria for these dependencies; ideally they will not depend on any other modules. If they do, we should consider an alternative way of managing our dependencies.
The process for updating a vendored dependency is:
npm install {DEP NAME HERE}
cp -r node_modules/DEP vendor
- Update
eslintrc.js
to forbid importing DEP directly (see theMitt
rule already defined in there). - Use the new DEP, and run
npm run build && npm run build:dev
to check everything compiles successfully. - If the dep ships as compiled JS, you may need to disable TypeScript checking the file. Add an entry to the
excludes
property of the TSConfig files invendor
. (again, see the entry that's already there for Mitt as an example). Don't forget to update both the ESM and CJS config files.