Настройка Jest
Философия Jest'а заключается в идеальном функционале "из коробки", но иногда вам нужно немного поработать с конфигурированием.
Советуем хранить конфигурации в отдельном JavaScript, TypeScript или JSON файле. The file will be discovered automatically, if it is named jest.config.js|ts|mjs|cjs|cts|json
. Используйте --config
флаг, чтобы явно указать путь к файлу конфигурации.
Keep in mind that the resulting configuration object must always be JSON-serializable.
The configuration file should simply export an object:
- JavaScript
- TypeScript
/** @type {import('jest').Config} */
const config = {
verbose: true,
};
module.exports = config;
import type {Config} from 'jest';
const config: Config = {
verbose: true,
};
export default config;
Or a function returning an object:
- JavaScript
- TypeScript
/** @returns {Promise<import('jest').Config>} */
module.exports = async () => {
return {
verbose: true,
};
};
import type {Config} from 'jest';
export default async (): Promise<Config> => {
return {
verbose: true,
};
};
To read TypeScript configuration files Jest by default requires ts-node
. You can override this behavior by adding a @jest-config-loader
docblock at the top of the file. Currently, ts-node
and esbuild-register
is supported. Make sure ts-node
or the loader you specify is installed.
/** @jest-config-loader ts-node */
// or
/** @jest-config-loader esbuild-register */
import type {Config} from 'jest';
const config: Config = {
verbose: true,
};
export default config;
You can also pass options to the loader, for instance to enable transpileOnly
.
/** @jest-config-loader ts-node */
/** @jest-config-loader-options {"transpileOnly": true} */
import type {Config} from 'jest';
const config: Config = {
verbose: true,
};
export default config;
The configuration also can be stored in a JSON file as a plain object:
{
"bail": 1,
"verbose": true
}