@bahmutov/cypress-esbuild-preprocessor
Bundle Cypress specs using esbuild
Install
npm i -D cypress @bahmutov/cypress-esbuild-preprocessor esbuild
Use
In your plugin file use this module as the preprocessor
const createBundler = require('@bahmutov/cypress-esbuild-preprocessor')
module.exports = (on, config) => {
on('file:preprocessor', createBundler())
}
ESBuild options
If you want to pass your own ESBuild options
const createBundler = require('@bahmutov/cypress-esbuild-preprocessor')
module.exports = (on, config) => {
const bundler = createBundler({
})
on('file:preprocessor', bundler)
}
Debugging
Run with the environment variable DEBUG=cypress-esbuild-preprocessor
But also if something is not working, check out the alternative package: cypress-esbuild-preprocessor
Breaking changes
v1 to v2
- instead of the file preprocessor, exposes a constructor function to allow user options to ESBuild
const bundler = require('cypress-esbuild-preprocessor')
module.exports = (on, config) => {
on('file:preprocessor', bundler)
}
const createBundler = require('cypress-esbuild-preprocessor')
module.exports = (on, config) => {
const bundler = createBundler({
define: {
'process.env.NODE_ENV': '"development"',
},
})
on('file:preprocessor', bundler)
}
Small print
Author: Gleb Bahmutov <gleb.bahmutov@gmail.com> © 2022
License: MIT - do anything with the code, but don't blame me if it does not work.
Support: if you find any problems with this module, email / tweet /
open issue on Github