Here are some different ways on how to set up Jest to support ESM. This applies for Jest v25, Node v13, and Babel v7.
Note: This article was written with Node v14 in mind (2021), things may have changed since.
Node v14 and Jest v26 support ESM natively with the --experimental-vm-modules flag. Install cross-env, then add NODE_OPTIONS to the scripts.test in package.json 2. See the Jest documentation for more info (jest.io).
yarn add --dev cross-env"scripts": {  "test": "cross-env NODE_OPTIONS=--experimental-vm-modules jest"}Add babel-jest. Configure Babel. We’ll use env.test here so not to interfere with your build process.
yarn add --dev \  @babel/core \  @babel/plugin-transform-modules-commonjs \  babel-jestmodule.exports = {  env: {    test: {      plugins: ['@babel/plugin-transform-modules-commonjs'],    },  },}module.exports = {  transform: {    '^.+\\.[t|j]sx?$': 'babel-jest',  },}Add jest-esm-transformer - this is a preset configuration of Babel to support ESM transpilation.
yarn add --dev jest-esm-transformermodule.exports = {  transform: {    '\\.m?jsx?$': 'jest-esm-transformer',  },}As of March 2020, using esm is currently not possible. Follow these threads for details.
See buble-jest. Buble is an alternative to Babel. Note that as of 2021, this package hasn’t been updated since 2018.
I am a web developer helping make the world a better place through JavaScript, Ruby, and UI design. I write articles like these often. If you'd like to stay in touch, subscribe to my list.