forked from portive/wysimark
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjest.config.js
70 lines (67 loc) · 2.24 KB
/
jest.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/** @type {import('ts-jest/dist/types').InitialOptionsTsJest} */
const fs = require("fs")
const esmModules = require("./jest.esm-modules").join("|")
/**
* Make sure the file `tsconfig.ts-jest.json` was copied into the directory.
* If it doesn't exist, even though we've specified it, jest will run without
* it but the configuration would be incorrect leaving us with a hard to find
* error.
*
* This throws an error earlier so we can copy `tsconfig.ts-jest.json` to fix
* the error.
*/
if (!fs.existsSync("tsconfig.ts-jest.json")) {
console.log()
throw new Error("tsconfig.ts-jest.json does not exist but is required.")
}
module.exports = {
setupFiles: ["./jest.setup.js"],
globals: {
"ts-jest": {
/**
* Change the tsconfig file used to `tsconfig.ts-jest.json`
*/
tsconfig: "tsconfig.ts-jest.json",
/**
* `isolatedModules: false` is the default value but we add it here for
* clarity. Because it is not isolated, full type checking is performed
* on the test files. This makes the jest tests run slower but are more
* complete. This slow version should always be used in tests that must
* be passed before a deploy, for example, but `jest.fast.config.js`
* is useful when wanting to quickly test and get responses.
*/
isolatedModules: false,
},
},
/**
* Configuration for getting `ts-jest` running
* https://github.com/kulshekhar/ts-jest
*/
preset: "ts-jest",
testEnvironment: "node",
/**
* The `transform` and `transformIgnorePatterns` is necessary to support
* `esm` modules.
*
* https://github.com/kulshekhar/ts-jest/issues/970
*/
transform: {
"^.+\\.[tj]sx?$": "ts-jest",
},
transformIgnorePatterns: [`node_modules/(?!${esmModules})`],
/**
* Sometimes, our tests use temp files that we keep in a `.temp` directory.
* These files are manipulated during the test and we don't want that to
* cause the test to be run again.
*/
watchPathIgnorePatterns: ["[.]temp"],
/**
* This needs to match the `paths` entry in `tsconfig.base.json` or
* `tsconfig.custom.json`.
*
* TODO: Use `jest-module-name-mapper` to create mappings from tsconfig
*/
moduleNameMapper: {
"^~/(.*)$": "<rootDir>/$1",
},
}