ESM Support
To use jest-preset-angular
with ESM support, you'll first need to check ESM Jest documentation.
jest-preset-angular
supports ESM via a ts-jest
config option useESM in combination with jest config option extensionsToTreatAsEsm.
There is also a preset to work with ESM.
We have example apps which contains base ESM setup to work with Jest and Angular.
Besides, there is utility function to ensure that Jest can set up test environment properly.
import { setupZoneTestEnv } from 'jest-preset-angular/setup-env/zone/index.mjs';
setupZoneTestEnv();
Examples
Manual configuration
import type { Config } from 'jest';
export default {
//...
extensionsToTreatAsEsm: ['.ts'],
moduleNameMapper: {
tslib: 'tslib/tslib.es6.js',
'^rxjs': '<rootDir>/node_modules/rxjs/dist/bundles/rxjs.umd.js',
},
transform: {
'^.+\\.(ts|js|mjs|html|svg)$': [
'jest-preset-angular',
{
tsconfig: '<rootDir>/tsconfig.spec.json',
stringifyContentPathRegex: '\\.(html|svg)$',
useESM: true,
},
],
},
} satisfies Config;
Use ESM presets
Jest will attempt to load ESM files from node_modules
with default jest-resolve
which usually works for most of the cases.
However, there are cases like Angular libraries ESM built files or ESM files which are outside node_modules
might not be loaded
correctly.
To fix that, one can use moduleNameMapper
in jest config to instruct Jest to load the correct ESM files or create a
custom Jest resolver.
import type { Config } from 'jest';
import presets from 'jest-preset-angular/presets';
export default {
//...
...presets.createEsmPreset(),
moduleNameMapper: {
tslib: 'tslib/tslib.es6.js',
'^rxjs': '<rootDir>/node_modules/rxjs/dist/bundles/rxjs.umd.js',
},
} satisfies Config;