From 0d9809479139db4121ba1f72239f5a9b170f565f Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Mon, 28 Mar 2022 01:26:30 +0300 Subject: [PATCH 001/128] chore: run `prettier` also on JSON files (#12598) --- .prettierignore | 16 +++++++++++----- .vscode/settings.json | 2 +- .../cjs-native-without-sourcemap/package.json | 3 +-- .../cjs-with-babel-transformer/babel.config.js | 13 +++++++++++++ .../cjs-with-babel-transformer/package.json | 6 ------ .../esm-native-without-sourcemap/package.json | 3 +-- e2e/resolve-async/package.json | 3 +-- lerna.json | 4 +--- package.json | 4 ++-- .../src/__tests__/NODE_PATH_dir/package.json | 3 +-- .../src/__tests__/test_root/package.json | 3 +-- 11 files changed, 33 insertions(+), 27 deletions(-) create mode 100644 e2e/coverage-provider-v8/cjs-with-babel-transformer/babel.config.js diff --git a/.prettierignore b/.prettierignore index 9d00ca73631b..38dc19d98aa6 100644 --- a/.prettierignore +++ b/.prettierignore @@ -1,5 +1,11 @@ -fixtures/failing-jsons/ -packages/jest-diff/src/cleanupSemantic.ts -packages/jest-config/src/__tests__/jest-preset.json -packages/pretty-format/perf/world.geo.json -website/versions.json +api-extractor.json +coverage + +/packages/*/build +/packages/jest-config/src/__tests__/jest-preset.json +/packages/pretty-format/perf/world.geo.json + +/website/.docusaurus +/website/backers.json +/website/build +/website/versions.json diff --git a/.vscode/settings.json b/.vscode/settings.json index bb5f7b2d11d9..3a5ae317697f 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -1,7 +1,7 @@ { "editor.rulers": [80], "files.exclude": { - "**/.git": true, + "**/.git": true }, "javascript.validate.enable": false, "jest.pathToJest": "yarn jest --", diff --git a/e2e/coverage-provider-v8/cjs-native-without-sourcemap/package.json b/e2e/coverage-provider-v8/cjs-native-without-sourcemap/package.json index 70ac892f2653..80fef6b071ba 100644 --- a/e2e/coverage-provider-v8/cjs-native-without-sourcemap/package.json +++ b/e2e/coverage-provider-v8/cjs-native-without-sourcemap/package.json @@ -3,7 +3,6 @@ "collectCoverageFrom": [ "/*.js" ], - "transform": { - } + "transform": {} } } diff --git a/e2e/coverage-provider-v8/cjs-with-babel-transformer/babel.config.js b/e2e/coverage-provider-v8/cjs-with-babel-transformer/babel.config.js new file mode 100644 index 000000000000..19dd8862b516 --- /dev/null +++ b/e2e/coverage-provider-v8/cjs-with-babel-transformer/babel.config.js @@ -0,0 +1,13 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = { + presets: [ + ['@babel/preset-env', {targets: {node: 'current'}}], + '@babel/preset-typescript', + ], +}; diff --git a/e2e/coverage-provider-v8/cjs-with-babel-transformer/package.json b/e2e/coverage-provider-v8/cjs-with-babel-transformer/package.json index cc9f8cec07ef..ef60481c0092 100644 --- a/e2e/coverage-provider-v8/cjs-with-babel-transformer/package.json +++ b/e2e/coverage-provider-v8/cjs-with-babel-transformer/package.json @@ -1,10 +1,4 @@ { - "babel": { - "presets": [ - ["@babel/preset-env", {"targets": {"node": "current"}}], - "@babel/preset-typescript" - ] - }, "jest": { "collectCoverageFrom": [ "/*.ts" diff --git a/e2e/coverage-provider-v8/esm-native-without-sourcemap/package.json b/e2e/coverage-provider-v8/esm-native-without-sourcemap/package.json index aba08ce1d284..f0745e4dcac1 100644 --- a/e2e/coverage-provider-v8/esm-native-without-sourcemap/package.json +++ b/e2e/coverage-provider-v8/esm-native-without-sourcemap/package.json @@ -4,7 +4,6 @@ "collectCoverageFrom": [ "/*.js" ], - "transform": { - } + "transform": {} } } diff --git a/e2e/resolve-async/package.json b/e2e/resolve-async/package.json index 50e870688cbf..ea366d4b6bde 100644 --- a/e2e/resolve-async/package.json +++ b/e2e/resolve-async/package.json @@ -2,7 +2,6 @@ "type": "module", "jest": { "resolver": "/resolver.cjs", - "transform": { - } + "transform": {} } } diff --git a/lerna.json b/lerna.json index 6d8afb117b1f..f5c1b819448f 100644 --- a/lerna.json +++ b/lerna.json @@ -1,7 +1,5 @@ { - "packages": [ - "packages/*" - ], + "packages": ["packages/*"], "npmClient": "yarn", "version": "28.0.0-alpha.7" } diff --git a/package.json b/package.json index 01ecdac5d036..da9da1721c48 100644 --- a/package.json +++ b/package.json @@ -100,8 +100,8 @@ "jest-jasmine-ci": "yarn jest-jasmine --color --config jest.config.ci.js", "jest-coverage": "yarn jest --coverage", "lint": "eslint . --cache --ext js,jsx,ts,tsx,md", - "lint:prettier": "prettier '**/*.{md,yml,yaml}' 'website/**/*.{css,js}' --write --ignore-path .gitignore", - "lint:prettier:ci": "prettier '**/*.{md,yml,yaml}' 'website/**/*.{css,js}' --check --ignore-path .gitignore", + "lint:prettier": "prettier '**/*.{json,md,yml,yaml}' 'website/**/*.{css,js}' --write", + "lint:prettier:ci": "prettier '**/*.{json,md,yml,yaml}' 'website/**/*.{css,js}' --check", "remove-examples": "node ./scripts/remove-examples.js", "test-types": "yarn jest --config jest.config.tsd.js", "test-ci-partial": "yarn test-ci-partial:parallel -i", diff --git a/packages/jest-runtime/src/__tests__/NODE_PATH_dir/package.json b/packages/jest-runtime/src/__tests__/NODE_PATH_dir/package.json index 103175ed9050..65767296d91f 100644 --- a/packages/jest-runtime/src/__tests__/NODE_PATH_dir/package.json +++ b/packages/jest-runtime/src/__tests__/NODE_PATH_dir/package.json @@ -1,6 +1,5 @@ { "name": "NODE_PATH_dir", "version": "1.0.0", - "dependencies": { - } + "dependencies": {} } diff --git a/packages/jest-runtime/src/__tests__/test_root/package.json b/packages/jest-runtime/src/__tests__/test_root/package.json index 48df13f673ca..78a8484cd760 100644 --- a/packages/jest-runtime/src/__tests__/test_root/package.json +++ b/packages/jest-runtime/src/__tests__/test_root/package.json @@ -1,6 +1,5 @@ { "name": "test_root", "version": "1.0.0", - "dependencies": { - } + "dependencies": {} } From daf583c3db9d1266e76785980d5895757407c8cd Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Tue, 29 Mar 2022 15:52:44 +0800 Subject: [PATCH 002/128] fix(jest-config): add `mjs` and `cjs` to default `moduleFileExtensions` config (#12578) --- CHANGELOG.md | 1 + docs/Configuration.md | 2 +- .../__snapshots__/showConfig.test.ts.snap | 2 ++ .../__snapshots__/testMatch.test.ts.snap | 9 +++++++++ e2e/__tests__/testMatch.test.ts | 16 ++++++++++++++++ e2e/test-match/package.json | 7 +++++++ e2e/test-match/test-suites/sample-suite.mjs | 10 ++++++++++ e2e/test-match/test-suites/sample-suite2.cjs | 10 ++++++++++ .../__tests__/__snapshots__/init.test.js.snap | 2 ++ packages/jest-config/src/Defaults.ts | 11 ++++++++++- packages/jest-config/src/ValidConfig.ts | 11 ++++++++++- .../jest-config/src/__tests__/normalize.test.ts | 2 ++ packages/jest-transform/src/ScriptTransformer.ts | 5 ++++- 13 files changed, 84 insertions(+), 4 deletions(-) create mode 100644 e2e/__tests__/__snapshots__/testMatch.test.ts.snap create mode 100644 e2e/__tests__/testMatch.test.ts create mode 100644 e2e/test-match/package.json create mode 100644 e2e/test-match/test-suites/sample-suite.mjs create mode 100644 e2e/test-match/test-suites/sample-suite2.cjs diff --git a/CHANGELOG.md b/CHANGELOG.md index efa038f928b6..c5cdc9aebf2d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -50,6 +50,7 @@ - `[jest-circus, @jest/types]` Disallow undefined value in `TestContext` type ([#12507](https://github.com/facebook/jest/pull/12507)) - `[jest-config]` Correctly detect CI environment and update snapshots accordingly ([#12378](https://github.com/facebook/jest/pull/12378)) - `[jest-config]` Pass `moduleTypes` to `ts-node` to enforce CJS when transpiling ([#12397](https://github.com/facebook/jest/pull/12397)) +- `[jest-config]` [**BREAKING**] Add `mjs` and `cjs` to default `moduleFileExtensions` config ([12578](https://github.com/facebook/jest/pull/12578)) - `[jest-config, jest-haste-map]` Allow searching for tests in `node_modules` by exposing `retainAllFiles` ([#11084](https://github.com/facebook/jest/pull/11084)) - `[jest-core]` [**BREAKING**] Exit with status `1` if no tests are found with `--findRelatedTests` flag ([#12487](https://github.com/facebook/jest/pull/12487)) - `[jest-each]` `%#` is not replaced with index of the test case ([#12517](https://github.com/facebook/jest/pull/12517)) diff --git a/docs/Configuration.md b/docs/Configuration.md index 7f9fa35a1b43..8835cc19c459 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -571,7 +571,7 @@ An array of directory names to be searched recursively up from the requiring mod ### `moduleFileExtensions` \[array<string>] -Default: `["js", "jsx", "ts", "tsx", "json", "node"]` +Default: `["js", "mjs", "cjs", "jsx", "ts", "tsx", "json", "node"]` An array of file extensions your modules use. If you require modules without specifying a file extension, these are the extensions Jest will look for, in left-to-right order. diff --git a/e2e/__tests__/__snapshots__/showConfig.test.ts.snap b/e2e/__tests__/__snapshots__/showConfig.test.ts.snap index 4c7058473159..cd1ac20b6546 100644 --- a/e2e/__tests__/__snapshots__/showConfig.test.ts.snap +++ b/e2e/__tests__/__snapshots__/showConfig.test.ts.snap @@ -30,6 +30,8 @@ exports[`--showConfig outputs config info and exits 1`] = ` ], "moduleFileExtensions": [ "js", + "mjs", + "cjs", "jsx", "ts", "tsx", diff --git a/e2e/__tests__/__snapshots__/testMatch.test.ts.snap b/e2e/__tests__/__snapshots__/testMatch.test.ts.snap new file mode 100644 index 000000000000..ed8312fe8a59 --- /dev/null +++ b/e2e/__tests__/__snapshots__/testMatch.test.ts.snap @@ -0,0 +1,9 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`testMatch should able to match file with cjs and mjs extension 1`] = ` +"Test Suites: 2 passed, 2 total +Tests: 2 passed, 2 total +Snapshots: 0 total +Time: <> +Ran all test suites." +`; diff --git a/e2e/__tests__/testMatch.test.ts b/e2e/__tests__/testMatch.test.ts new file mode 100644 index 000000000000..60b10ca627af --- /dev/null +++ b/e2e/__tests__/testMatch.test.ts @@ -0,0 +1,16 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +import {extractSummary} from '../Utils'; +import runJest from '../runJest'; + +it('testMatch should able to match file with cjs and mjs extension', () => { + const result = runJest('test-match'); + expect(result.exitCode).toBe(0); + const {summary} = extractSummary(result.stderr); + expect(summary).toMatchSnapshot(); +}); diff --git a/e2e/test-match/package.json b/e2e/test-match/package.json new file mode 100644 index 000000000000..3d6779c71dd7 --- /dev/null +++ b/e2e/test-match/package.json @@ -0,0 +1,7 @@ +{ + "jest": { + "testMatch": [ + "**/test-suites/*.?js" + ] + } +} diff --git a/e2e/test-match/test-suites/sample-suite.mjs b/e2e/test-match/test-suites/sample-suite.mjs new file mode 100644 index 000000000000..0d0703ef8e57 --- /dev/null +++ b/e2e/test-match/test-suites/sample-suite.mjs @@ -0,0 +1,10 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +test('mjs extension', () => { + expect(1).toBe(1); +}); diff --git a/e2e/test-match/test-suites/sample-suite2.cjs b/e2e/test-match/test-suites/sample-suite2.cjs new file mode 100644 index 000000000000..bb80acb6f879 --- /dev/null +++ b/e2e/test-match/test-suites/sample-suite2.cjs @@ -0,0 +1,10 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +test('cjs extension', () => { + expect(1).toBe(1); +}); diff --git a/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap b/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap index 157419444c3d..fbb7b4b2ad05 100644 --- a/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap +++ b/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap @@ -191,6 +191,8 @@ module.exports = { // An array of file extensions your modules use // moduleFileExtensions: [ // "js", + // "mjs", + // "cjs", // "jsx", // "ts", // "tsx", diff --git a/packages/jest-config/src/Defaults.ts b/packages/jest-config/src/Defaults.ts index 9cc30e2d09e3..45cd6b7481d8 100644 --- a/packages/jest-config/src/Defaults.ts +++ b/packages/jest-config/src/Defaults.ts @@ -44,7 +44,16 @@ const defaultOptions: Config.DefaultOptions = { maxConcurrency: 5, maxWorkers: '50%', moduleDirectories: ['node_modules'], - moduleFileExtensions: ['js', 'jsx', 'ts', 'tsx', 'json', 'node'], + moduleFileExtensions: [ + 'js', + 'mjs', + 'cjs', + 'jsx', + 'ts', + 'tsx', + 'json', + 'node', + ], moduleNameMapper: {}, modulePathIgnorePatterns: [], noStackTrace: false, diff --git a/packages/jest-config/src/ValidConfig.ts b/packages/jest-config/src/ValidConfig.ts index 5757431123ed..53e833d76ff2 100644 --- a/packages/jest-config/src/ValidConfig.ts +++ b/packages/jest-config/src/ValidConfig.ts @@ -74,7 +74,16 @@ const initialOptions: Config.InitialOptions = { maxConcurrency: 5, maxWorkers: '50%', moduleDirectories: ['node_modules'], - moduleFileExtensions: ['js', 'json', 'jsx', 'ts', 'tsx', 'node'], + moduleFileExtensions: [ + 'js', + 'mjs', + 'cjs', + 'json', + 'jsx', + 'ts', + 'tsx', + 'node', + ], moduleNameMapper: { '^React$': '/node_modules/react', }, diff --git a/packages/jest-config/src/__tests__/normalize.test.ts b/packages/jest-config/src/__tests__/normalize.test.ts index ccca146c1c54..5139b873215c 100644 --- a/packages/jest-config/src/__tests__/normalize.test.ts +++ b/packages/jest-config/src/__tests__/normalize.test.ts @@ -1668,6 +1668,8 @@ describe('moduleFileExtensions', () => { expect(options.moduleFileExtensions).toEqual([ 'js', + 'mjs', + 'cjs', 'jsx', 'ts', 'tsx', diff --git a/packages/jest-transform/src/ScriptTransformer.ts b/packages/jest-transform/src/ScriptTransformer.ts index bfd425984283..b1ab7a935f45 100644 --- a/packages/jest-transform/src/ScriptTransformer.ts +++ b/packages/jest-transform/src/ScriptTransformer.ts @@ -759,7 +759,10 @@ class ScriptTransformer { } }, { - exts: this._config.moduleFileExtensions.map(ext => `.${ext}`), + // Exclude `mjs` extension when addHook because pirates don't support hijack es module + exts: this._config.moduleFileExtensions + .filter(ext => ext !== 'mjs') + .map(ext => `.${ext}`), ignoreNodeModules: false, matcher: filename => { if (transforming) { From f496a93a6dfe5dc1f87745afda455d065630369e Mon Sep 17 00:00:00 2001 From: Matthias Date: Tue, 29 Mar 2022 04:05:48 -0400 Subject: [PATCH 003/128] Add contexts to mocks (#12601) --- CHANGELOG.md | 1 + docs/CLI.md | 2 +- docs/Configuration.md | 2 +- docs/JestObjectAPI.md | 2 +- docs/MockFunctionAPI.md | 25 ++++++++++++-- docs/MockFunctions.md | 17 ++++++---- packages/jest-cli/src/cli/args.ts | 2 +- .../__tests__/__snapshots__/init.test.js.snap | 4 +-- packages/jest-cli/src/init/questions.ts | 2 +- packages/jest-config/src/Descriptions.ts | 2 +- packages/jest-environment/src/index.ts | 2 +- .../__typetests__/mock-functions.test.ts | 5 ++- .../jest-mock/src/__tests__/index.test.ts | 33 +++++++++++++++++++ packages/jest-mock/src/index.ts | 6 ++++ 14 files changed, 87 insertions(+), 18 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index c5cdc9aebf2d..acaed9f5f311 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -29,6 +29,7 @@ - `[jest-mock]` Improve `isMockFunction` to infer types of passed function ([#12442](https://github.com/facebook/jest/pull/12442)) - `[jest-mock]` [**BREAKING**] Improve the usage of `jest.fn` generic type argument ([#12489](https://github.com/facebook/jest/pull/12489)) - `[jest-mock]` Add support for auto-mocking async generator functions ([#11080](https://github.com/facebook/jest/pull/11080)) +- `[jest-mock]` Add `contexts` member to mock functions ([#12601](https://github.com/facebook/jest/pull/12601)) - `[jest-resolve]` [**BREAKING**] Add support for `package.json` `exports` ([#11961](https://github.com/facebook/jest/pull/11961), [#12373](https://github.com/facebook/jest/pull/12373)) - `[jest-resolve, jest-runtime]` Add support for `data:` URI import and mock ([#12392](https://github.com/facebook/jest/pull/12392)) - `[jest-resolve, jest-runtime]` Add support for async resolver ([#11540](https://github.com/facebook/jest/pull/11540)) diff --git a/docs/CLI.md b/docs/CLI.md index 7263a4676883..8a213e989bbc 100644 --- a/docs/CLI.md +++ b/docs/CLI.md @@ -158,7 +158,7 @@ Clearing the cache will reduce performance. ### `--clearMocks` -Automatically clear mock calls, instances and results before every test. Equivalent to calling [`jest.clearAllMocks()`](JestObjectAPI.md#jestclearallmocks) before each test. This does not remove any mock implementation that may have been provided. +Automatically clear mock calls, instances, contexts and results before every test. Equivalent to calling [`jest.clearAllMocks()`](JestObjectAPI.md#jestclearallmocks) before each test. This does not remove any mock implementation that may have been provided. ### `--collectCoverageFrom=` diff --git a/docs/Configuration.md b/docs/Configuration.md index 8835cc19c459..74ab2248e05e 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -150,7 +150,7 @@ Jest attempts to scan your dependency tree once (up-front) and cache it in order Default: `false` -Automatically clear mock calls, instances and results before every test. Equivalent to calling [`jest.clearAllMocks()`](JestObjectAPI.md#jestclearallmocks) before each test. This does not remove any mock implementation that may have been provided. +Automatically clear mock calls, instances, contexts and results before every test. Equivalent to calling [`jest.clearAllMocks()`](JestObjectAPI.md#jestclearallmocks) before each test. This does not remove any mock implementation that may have been provided. ### `collectCoverage` \[boolean] diff --git a/docs/JestObjectAPI.md b/docs/JestObjectAPI.md index ed99e97fc3d0..aff9a86b5ff6 100644 --- a/docs/JestObjectAPI.md +++ b/docs/JestObjectAPI.md @@ -570,7 +570,7 @@ test('plays audio', () => { ### `jest.clearAllMocks()` -Clears the `mock.calls`, `mock.instances` and `mock.results` properties of all mocks. Equivalent to calling [`.mockClear()`](MockFunctionAPI.md#mockfnmockclear) on every mocked function. +Clears the `mock.calls`, `mock.instances`, `mock.contexts` and `mock.results` properties of all mocks. Equivalent to calling [`.mockClear()`](MockFunctionAPI.md#mockfnmockclear) on every mocked function. Returns the `jest` object for chaining. diff --git a/docs/MockFunctionAPI.md b/docs/MockFunctionAPI.md index 35a28365e986..0ac4de121f65 100644 --- a/docs/MockFunctionAPI.md +++ b/docs/MockFunctionAPI.md @@ -92,6 +92,27 @@ mockFn.mock.instances[0] === a; // true mockFn.mock.instances[1] === b; // true ``` +### `mockFn.mock.contexts` + +An array that contains the contexts for all calls of the mock function. + +A context is the `this` value that a function receives when called. The context can be set using `Function.prototype.bind`, `Function.prototype.call` or `Function.prototype.apply`. + +For example: + +```js +const mockFn = jest.fn(); + +const boundMockFn = mockFn.bind(thisContext0); +boundMockFn('a', 'b'); +mockFn.call(thisContext1, 'a', 'b'); +mockFn.apply(thisContext2, ['a', 'b']); + +mockFn.mock.contexts[0] === thisContext0; // true +mockFn.mock.contexts[1] === thisContext1; // true +mockFn.mock.contexts[2] === thisContext2; // true +``` + ### `mockFn.mock.lastCall` An array containing the call arguments of the last call that was made to this mock function. If the function was not called, it will return `undefined`. @@ -104,9 +125,9 @@ For example: A mock function `f` that has been called twice, with the arguments ### `mockFn.mockClear()` -Clears all information stored in the [`mockFn.mock.calls`](#mockfnmockcalls), [`mockFn.mock.instances`](#mockfnmockinstances) and [`mockFn.mock.results`](#mockfnmockresults) arrays. Often this is useful when you want to clean up a mocks usage data between two assertions. +Clears all information stored in the [`mockFn.mock.calls`](#mockfnmockcalls), [`mockFn.mock.instances`](#mockfnmockinstances), [`mockFn.mock.contexts`](#mockfnmockcontexts) and [`mockFn.mock.results`](#mockfnmockresults) arrays. Often this is useful when you want to clean up a mocks usage data between two assertions. -Beware that `mockFn.mockClear()` will replace `mockFn.mock`, not just these three properties! You should, therefore, avoid assigning `mockFn.mock` to other variables, temporary or not, to make sure you don't access stale data. +Beware that `mockFn.mockClear()` will replace `mockFn.mock`, not just reset the values of its properties! You should, therefore, avoid assigning `mockFn.mock` to other variables, temporary or not, to make sure you don't access stale data. The [`clearMocks`](configuration#clearmocks-boolean) configuration option is available to clear mocks automatically before each tests. diff --git a/docs/MockFunctions.md b/docs/MockFunctions.md index 38870027a515..d1f1752de2d1 100644 --- a/docs/MockFunctions.md +++ b/docs/MockFunctions.md @@ -43,15 +43,17 @@ expect(mockCallback.mock.results[0].value).toBe(42); All mock functions have this special `.mock` property, which is where data about how the function has been called and what the function returned is kept. The `.mock` property also tracks the value of `this` for each call, so it is possible to inspect this as well: ```javascript -const myMock = jest.fn(); +const myMock1 = jest.fn(); +const a = new myMock1(); +console.log(myMock1.mock.instances); +// > [ ] -const a = new myMock(); +const myMock2 = jest.fn(); const b = {}; -const bound = myMock.bind(b); +const bound = myMock2.bind(b); bound(); - -console.log(myMock.mock.instances); -// > [ , ] +console.log(myMock2.mock.contexts); +// > [ ] ``` These mock members are very useful in tests to assert how these functions get called, instantiated, or what they returned: @@ -69,6 +71,9 @@ expect(someMockFunction.mock.calls[0][1]).toBe('second arg'); // The return value of the first call to the function was 'return value' expect(someMockFunction.mock.results[0].value).toBe('return value'); +// The function was called with a certain `this` context: the `element` object. +expect(someMockFunction.mock.contexts[0]).toBe(element); + // This function was instantiated exactly twice expect(someMockFunction.mock.instances.length).toBe(2); diff --git a/packages/jest-cli/src/cli/args.ts b/packages/jest-cli/src/cli/args.ts index 57c55a59f129..289c737dd8fe 100644 --- a/packages/jest-cli/src/cli/args.ts +++ b/packages/jest-cli/src/cli/args.ts @@ -154,7 +154,7 @@ export const options = { }, clearMocks: { description: - 'Automatically clear mock calls, instances and results before every test. ' + + 'Automatically clear mock calls, instances, contexts and results before every test. ' + 'Equivalent to calling jest.clearAllMocks() before each test.', type: 'boolean', }, diff --git a/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap b/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap index fbb7b4b2ad05..2c5c94dd9d4b 100644 --- a/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap +++ b/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap @@ -108,7 +108,7 @@ Array [ }, Object { "initial": false, - "message": "Automatically clear mock calls, instances and results before every test?", + "message": "Automatically clear mock calls, instances, contexts and results before every test?", "name": "clearMocks", "type": "confirm", }, @@ -131,7 +131,7 @@ module.exports = { // The directory where Jest should store its cached dependency information // cacheDirectory: "/tmp/jest", - // Automatically clear mock calls, instances and results before every test + // Automatically clear mock calls, instances, contexts and results before every test // clearMocks: false, // Indicates whether the coverage information should be collected while executing the test diff --git a/packages/jest-cli/src/init/questions.ts b/packages/jest-cli/src/init/questions.ts index fd4e9325ff7f..9d86faa6ccc2 100644 --- a/packages/jest-cli/src/init/questions.ts +++ b/packages/jest-cli/src/init/questions.ts @@ -43,7 +43,7 @@ const defaultQuestions: Array = [ { initial: false, message: - 'Automatically clear mock calls, instances and results before every test?', + 'Automatically clear mock calls, instances, contexts and results before every test?', name: 'clearMocks', type: 'confirm', }, diff --git a/packages/jest-config/src/Descriptions.ts b/packages/jest-config/src/Descriptions.ts index 795637460a1d..9f4549e5fb22 100644 --- a/packages/jest-config/src/Descriptions.ts +++ b/packages/jest-config/src/Descriptions.ts @@ -13,7 +13,7 @@ const descriptions: {[key in keyof Config.InitialOptions]: string} = { cacheDirectory: 'The directory where Jest should store its cached dependency information', clearMocks: - 'Automatically clear mock calls, instances and results before every test', + 'Automatically clear mock calls, instances, contexts and results before every test', collectCoverage: 'Indicates whether the coverage information should be collected while executing the test', collectCoverageFrom: diff --git a/packages/jest-environment/src/index.ts b/packages/jest-environment/src/index.ts index ac7fe89c30cc..6a96143ada73 100644 --- a/packages/jest-environment/src/index.ts +++ b/packages/jest-environment/src/index.ts @@ -71,7 +71,7 @@ export interface Jest { */ autoMockOn(): Jest; /** - * Clears the `mock.calls`, `mock.instances` and `mock.results` properties of + * Clears the `mock.calls`, `mock.instances`, `mock.contexts` and `mock.results` properties of * all mocks. Equivalent to calling `.mockClear()` on every mocked function. */ clearAllMocks(): Jest; diff --git a/packages/jest-mock/__typetests__/mock-functions.test.ts b/packages/jest-mock/__typetests__/mock-functions.test.ts index e1ace1d254f4..6be5a35b7b77 100644 --- a/packages/jest-mock/__typetests__/mock-functions.test.ts +++ b/packages/jest-mock/__typetests__/mock-functions.test.ts @@ -66,7 +66,8 @@ expectType never>>( ); expectError(fn('moduleName')); -const mockFn = fn((a: string, b?: number) => true); +declare const mockFnImpl: (this: Date, a: string, b?: number) => boolean; +const mockFn = fn(mockFnImpl); const mockAsyncFn = fn(async (p: boolean) => 'value'); expectType(mockFn('one', 2)); @@ -135,6 +136,8 @@ if (returnValue.type === 'throw') { expectType(returnValue.value); } +expectType>(mockFn.mock.contexts); + expectType boolean>>( mockFn.mockClear(), ); diff --git a/packages/jest-mock/src/__tests__/index.test.ts b/packages/jest-mock/src/__tests__/index.test.ts index bbfc2677d2b9..371ba0a04ea8 100644 --- a/packages/jest-mock/src/__tests__/index.test.ts +++ b/packages/jest-mock/src/__tests__/index.test.ts @@ -424,20 +424,53 @@ describe('moduleMocker', () => { expect(fn.mock.instances[1]).toBe(instance2); }); + it('tracks context objects passed to mock calls', () => { + const fn = moduleMocker.fn(); + expect(fn.mock.instances).toEqual([]); + + const ctx0 = {}; + fn.apply(ctx0, []); + expect(fn.mock.contexts[0]).toBe(ctx0); + + const ctx1 = {}; + fn.call(ctx1); + expect(fn.mock.contexts[1]).toBe(ctx1); + + const ctx2 = {}; + const bound2 = fn.bind(ctx2); + bound2(); + expect(fn.mock.contexts[2]).toBe(ctx2); + + // null context + fn.apply(null, []); + expect(fn.mock.contexts[3]).toBe(null); + fn.call(null); + expect(fn.mock.contexts[4]).toBe(null); + fn.bind(null)(); + expect(fn.mock.contexts[5]).toBe(null); + + // Unspecified context is `undefined` in strict mode (like in this test) and `window` otherwise. + fn(); + expect(fn.mock.contexts[6]).toBe(undefined); + }); + it('supports clearing mock calls', () => { const fn = moduleMocker.fn(); expect(fn.mock.calls).toEqual([]); fn(1, 2, 3); expect(fn.mock.calls).toEqual([[1, 2, 3]]); + expect(fn.mock.contexts).toEqual([undefined]); fn.mockReturnValue('abcd'); fn.mockClear(); expect(fn.mock.calls).toEqual([]); + expect(fn.mock.contexts).toEqual([]); fn('a', 'b', 'c'); expect(fn.mock.calls).toEqual([['a', 'b', 'c']]); + expect(fn.mock.contexts).toEqual([undefined]); expect(fn()).toEqual('abcd'); }); diff --git a/packages/jest-mock/src/index.ts b/packages/jest-mock/src/index.ts index 8358cbe36631..85fe4aeb229c 100644 --- a/packages/jest-mock/src/index.ts +++ b/packages/jest-mock/src/index.ts @@ -201,6 +201,10 @@ type MockFunctionState = { * List of all the object instances that have been instantiated from the mock. */ instances: Array>; + /** + * List of all the function contexts that have been applied to calls to the mock. + */ + contexts: Array>; /** * List of the call order indexes of the mock. Jest is indexing the order of * invocations of all mocks in a test file. The index is starting with `1`. @@ -569,6 +573,7 @@ export class ModuleMocker { private _defaultMockState(): MockFunctionState { return { calls: [], + contexts: [], instances: [], invocationCallOrder: [], results: [], @@ -636,6 +641,7 @@ export class ModuleMocker { const mockState = mocker._ensureMockState(f); const mockConfig = mocker._ensureMockConfig(f); mockState.instances.push(this); + mockState.contexts.push(this); mockState.calls.push(args); // Create and record an "incomplete" mock result immediately upon // calling rather than waiting for the mock to return. This avoids From 1ba867bebc91dd2ae2d0666a521c3892f8bc27ec Mon Sep 17 00:00:00 2001 From: Kaiguang Li <33639861+Kaiguang@users.noreply.github.com> Date: Wed, 30 Mar 2022 00:37:19 -0600 Subject: [PATCH 004/128] docs: fix broken link in TestingFrameworks.md (#12616) --- docs/TestingFrameworks.md | 2 +- website/versioned_docs/version-25.x/TestingFrameworks.md | 2 +- website/versioned_docs/version-26.x/TestingFrameworks.md | 2 +- website/versioned_docs/version-27.0/TestingFrameworks.md | 2 +- website/versioned_docs/version-27.1/TestingFrameworks.md | 2 +- website/versioned_docs/version-27.2/TestingFrameworks.md | 2 +- website/versioned_docs/version-27.4/TestingFrameworks.md | 2 +- website/versioned_docs/version-27.5/TestingFrameworks.md | 2 +- 8 files changed, 8 insertions(+), 8 deletions(-) diff --git a/docs/TestingFrameworks.md b/docs/TestingFrameworks.md index 5b085c8658a3..d41afbeabc21 100644 --- a/docs/TestingFrameworks.md +++ b/docs/TestingFrameworks.md @@ -42,4 +42,4 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js -- [Testing Hapi.js With Jest](http://niralar.com/testing-hapi-js-with-jest/) by Niralar ([Sivasankar](http://sivasankar.in/)) +- [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar diff --git a/website/versioned_docs/version-25.x/TestingFrameworks.md b/website/versioned_docs/version-25.x/TestingFrameworks.md index 5b085c8658a3..d41afbeabc21 100644 --- a/website/versioned_docs/version-25.x/TestingFrameworks.md +++ b/website/versioned_docs/version-25.x/TestingFrameworks.md @@ -42,4 +42,4 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js -- [Testing Hapi.js With Jest](http://niralar.com/testing-hapi-js-with-jest/) by Niralar ([Sivasankar](http://sivasankar.in/)) +- [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar diff --git a/website/versioned_docs/version-26.x/TestingFrameworks.md b/website/versioned_docs/version-26.x/TestingFrameworks.md index 5b085c8658a3..d41afbeabc21 100644 --- a/website/versioned_docs/version-26.x/TestingFrameworks.md +++ b/website/versioned_docs/version-26.x/TestingFrameworks.md @@ -42,4 +42,4 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js -- [Testing Hapi.js With Jest](http://niralar.com/testing-hapi-js-with-jest/) by Niralar ([Sivasankar](http://sivasankar.in/)) +- [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar diff --git a/website/versioned_docs/version-27.0/TestingFrameworks.md b/website/versioned_docs/version-27.0/TestingFrameworks.md index 5b085c8658a3..d41afbeabc21 100644 --- a/website/versioned_docs/version-27.0/TestingFrameworks.md +++ b/website/versioned_docs/version-27.0/TestingFrameworks.md @@ -42,4 +42,4 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js -- [Testing Hapi.js With Jest](http://niralar.com/testing-hapi-js-with-jest/) by Niralar ([Sivasankar](http://sivasankar.in/)) +- [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar diff --git a/website/versioned_docs/version-27.1/TestingFrameworks.md b/website/versioned_docs/version-27.1/TestingFrameworks.md index 5b085c8658a3..d41afbeabc21 100644 --- a/website/versioned_docs/version-27.1/TestingFrameworks.md +++ b/website/versioned_docs/version-27.1/TestingFrameworks.md @@ -42,4 +42,4 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js -- [Testing Hapi.js With Jest](http://niralar.com/testing-hapi-js-with-jest/) by Niralar ([Sivasankar](http://sivasankar.in/)) +- [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar diff --git a/website/versioned_docs/version-27.2/TestingFrameworks.md b/website/versioned_docs/version-27.2/TestingFrameworks.md index 5b085c8658a3..d41afbeabc21 100644 --- a/website/versioned_docs/version-27.2/TestingFrameworks.md +++ b/website/versioned_docs/version-27.2/TestingFrameworks.md @@ -42,4 +42,4 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js -- [Testing Hapi.js With Jest](http://niralar.com/testing-hapi-js-with-jest/) by Niralar ([Sivasankar](http://sivasankar.in/)) +- [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar diff --git a/website/versioned_docs/version-27.4/TestingFrameworks.md b/website/versioned_docs/version-27.4/TestingFrameworks.md index 5b085c8658a3..d41afbeabc21 100644 --- a/website/versioned_docs/version-27.4/TestingFrameworks.md +++ b/website/versioned_docs/version-27.4/TestingFrameworks.md @@ -42,4 +42,4 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js -- [Testing Hapi.js With Jest](http://niralar.com/testing-hapi-js-with-jest/) by Niralar ([Sivasankar](http://sivasankar.in/)) +- [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar diff --git a/website/versioned_docs/version-27.5/TestingFrameworks.md b/website/versioned_docs/version-27.5/TestingFrameworks.md index 5b085c8658a3..d41afbeabc21 100644 --- a/website/versioned_docs/version-27.5/TestingFrameworks.md +++ b/website/versioned_docs/version-27.5/TestingFrameworks.md @@ -42,4 +42,4 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js -- [Testing Hapi.js With Jest](http://niralar.com/testing-hapi-js-with-jest/) by Niralar ([Sivasankar](http://sivasankar.in/)) +- [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar From b9af5187046e9f277d5f4c720a813b5cc8129857 Mon Sep 17 00:00:00 2001 From: Bernie Reiter Date: Wed, 30 Mar 2022 09:43:04 +0200 Subject: [PATCH 005/128] feat: Add GitHub Actions Reporter (#11320) Co-authored-by: Marius Gundersen Co-authored-by: Stefan Buck --- CHANGELOG.md | 1 + .../src/GitHubActionsReporter.ts | 54 ++++++++ .../__tests__/GitHubActionsReporter.test.js | 118 ++++++++++++++++++ .../GitHubActionsReporter.test.js.snap | 6 + packages/jest-reporters/src/index.ts | 1 + 5 files changed, 180 insertions(+) create mode 100644 packages/jest-reporters/src/GitHubActionsReporter.ts create mode 100644 packages/jest-reporters/src/__tests__/GitHubActionsReporter.test.js create mode 100644 packages/jest-reporters/src/__tests__/__snapshots__/GitHubActionsReporter.test.js.snap diff --git a/CHANGELOG.md b/CHANGELOG.md index acaed9f5f311..bee7bad05887 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -30,6 +30,7 @@ - `[jest-mock]` [**BREAKING**] Improve the usage of `jest.fn` generic type argument ([#12489](https://github.com/facebook/jest/pull/12489)) - `[jest-mock]` Add support for auto-mocking async generator functions ([#11080](https://github.com/facebook/jest/pull/11080)) - `[jest-mock]` Add `contexts` member to mock functions ([#12601](https://github.com/facebook/jest/pull/12601)) +- `[jest-reporters]` Add GitHub Actions reporter ([#11320](https://github.com/facebook/jest/pull/11320)) - `[jest-resolve]` [**BREAKING**] Add support for `package.json` `exports` ([#11961](https://github.com/facebook/jest/pull/11961), [#12373](https://github.com/facebook/jest/pull/12373)) - `[jest-resolve, jest-runtime]` Add support for `data:` URI import and mock ([#12392](https://github.com/facebook/jest/pull/12392)) - `[jest-resolve, jest-runtime]` Add support for async resolver ([#11540](https://github.com/facebook/jest/pull/11540)) diff --git a/packages/jest-reporters/src/GitHubActionsReporter.ts b/packages/jest-reporters/src/GitHubActionsReporter.ts new file mode 100644 index 000000000000..dd63977df91d --- /dev/null +++ b/packages/jest-reporters/src/GitHubActionsReporter.ts @@ -0,0 +1,54 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +import stripAnsi = require('strip-ansi'); +import type {AggregatedResult, TestResult} from '@jest/test-result'; +import BaseReporter from './BaseReporter'; +import type {Context} from './types'; + +const lineAndColumnInStackTrace = /^.*?:([0-9]+):([0-9]+).*$/; + +function replaceEntities(s: string): string { + // https://github.com/actions/toolkit/blob/b4639928698a6bfe1c4bdae4b2bfdad1cb75016d/packages/core/src/command.ts#L80-L85 + const substitutions: Array<[RegExp, string]> = [ + [/%/g, '%25'], + [/\r/g, '%0D'], + [/\n/g, '%0A'], + ]; + return substitutions.reduce((acc, sub) => acc.replace(...sub), s); +} + +export default class GitHubActionsReporter extends BaseReporter { + onRunComplete( + _contexts?: Set, + aggregatedResults?: AggregatedResult, + ): void { + const messages = getMessages(aggregatedResults?.testResults); + + for (const message of messages) { + this.log(message); + } + } +} + +function getMessages(results: Array | undefined) { + if (!results) return []; + + return results.flatMap(({testFilePath, testResults}) => + testResults + .filter(r => r.status === 'failed') + .flatMap(r => r.failureMessages) + .map(m => stripAnsi(m)) + .map(m => replaceEntities(m)) + .map(m => lineAndColumnInStackTrace.exec(m)) + .filter((m): m is RegExpExecArray => m !== null) + .map( + ([message, line, col]) => + `::error file=${testFilePath},line=${line},col=${col}::${message}`, + ), + ); +} diff --git a/packages/jest-reporters/src/__tests__/GitHubActionsReporter.test.js b/packages/jest-reporters/src/__tests__/GitHubActionsReporter.test.js new file mode 100644 index 000000000000..b7939b579458 --- /dev/null +++ b/packages/jest-reporters/src/__tests__/GitHubActionsReporter.test.js @@ -0,0 +1,118 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ +'use strict'; + +let GitHubActionsReporter; + +const write = process.stderr.write; +const globalConfig = { + rootDir: 'root', + watch: false, +}; + +let results = []; + +function requireReporter() { + jest.isolateModules(() => { + GitHubActionsReporter = require('../GitHubActionsReporter').default; + }); +} + +beforeEach(() => { + process.stderr.write = result => results.push(result); +}); + +afterEach(() => { + results = []; + process.stderr.write = write; +}); + +const aggregatedResults = { + numFailedTestSuites: 1, + numFailedTests: 1, + numPassedTestSuites: 0, + numTotalTestSuites: 1, + numTotalTests: 1, + snapshot: { + added: 0, + didUpdate: false, + failure: false, + filesAdded: 0, + filesRemoved: 0, + filesRemovedList: [], + filesUnmatched: 0, + filesUpdated: 0, + matched: 0, + total: 0, + unchecked: 0, + uncheckedKeysByFile: [], + unmatched: 0, + updated: 0, + }, + startTime: 0, + success: false, + testResults: [ + { + numFailingTests: 1, + numPassingTests: 0, + numPendingTests: 0, + numTodoTests: 0, + openHandles: [], + perfStats: { + end: 1234, + runtime: 1234, + slow: false, + start: 0, + }, + skipped: false, + snapshot: { + added: 0, + fileDeleted: false, + matched: 0, + unchecked: 0, + uncheckedKeys: [], + unmatched: 0, + updated: 0, + }, + testFilePath: '/home/runner/work/jest/jest/some.test.js', + testResults: [ + { + ancestorTitles: [Array], + duration: 7, + failureDetails: [Array], + failureMessages: [ + ` + Error: \u001b[2mexpect(\u001b[22m\u001b[31mreceived\u001b[39m\u001b[2m).\u001b[22mtoBe\u001b[2m(\u001b[22m\u001b[32mexpected\u001b[39m\u001b[2m) // Object.is equality\u001b[22m\n + \n + Expected: \u001b[32m\"b\"\u001b[39m\n + Received: \u001b[31m\"a\"\u001b[39m\n + at Object. (/home/runner/work/jest/jest/some.test.js:4:17)\n + at Object.asyncJestTest (/home/runner/work/jest/jest/node_modules/jest-jasmine2/build/jasmineAsyncInstall.js:106:37)\n + at /home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:45:12\n + at new Promise ()\n + at mapper (/home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:28:19)\n + at /home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:75:41\n + at processTicksAndRejections (internal/process/task_queues.js:93:5) + `, + ], + fullName: 'asserts that a === b', + location: null, + numPassingAsserts: 0, + status: 'failed', + title: 'asserts that a === b', + }, + ], + }, + ], +}; + +test('reporter extracts the correct filename, line, and column', () => { + requireReporter(); + const testReporter = new GitHubActionsReporter(globalConfig); + testReporter.onRunComplete(new Set(), aggregatedResults); + expect(results.join('').replace(/\\/g, '/')).toMatchSnapshot(); +}); diff --git a/packages/jest-reporters/src/__tests__/__snapshots__/GitHubActionsReporter.test.js.snap b/packages/jest-reporters/src/__tests__/__snapshots__/GitHubActionsReporter.test.js.snap new file mode 100644 index 000000000000..c523c4dd3448 --- /dev/null +++ b/packages/jest-reporters/src/__tests__/__snapshots__/GitHubActionsReporter.test.js.snap @@ -0,0 +1,6 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`reporter extracts the correct filename, line, and column 1`] = ` +"::error file=/home/runner/work/jest/jest/some.test.js,line=4,col=17::%0A Error: expect(received).toBe(expected) // Object.is equality%0A%0A %0A%0A Expected: "b"%0A%0A Received: "a"%0A%0A at Object. (/home/runner/work/jest/jest/some.test.js:4:17)%0A%0A at Object.asyncJestTest (/home/runner/work/jest/jest/node_modules/jest-jasmine2/build/jasmineAsyncInstall.js:106:37)%0A%0A at /home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:45:12%0A%0A at new Promise ()%0A%0A at mapper (/home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:28:19)%0A%0A at /home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:75:41%0A%0A at processTicksAndRejections (internal/process/task_queues.js:93:5)%0A +" +`; diff --git a/packages/jest-reporters/src/index.ts b/packages/jest-reporters/src/index.ts index 9185df007f1b..3f8089c3b689 100644 --- a/packages/jest-reporters/src/index.ts +++ b/packages/jest-reporters/src/index.ts @@ -26,6 +26,7 @@ export {default as DefaultReporter} from './DefaultReporter'; export {default as NotifyReporter} from './NotifyReporter'; export {default as SummaryReporter} from './SummaryReporter'; export {default as VerboseReporter} from './VerboseReporter'; +export {default as GitHubActionsReporter} from './GitHubActionsReporter'; export type { Context, Reporter, From 80cf80055682919251b9567ef482755d5f060d47 Mon Sep 17 00:00:00 2001 From: Martin Date: Wed, 30 Mar 2022 09:55:26 +0200 Subject: [PATCH 006/128] docs: add Next.js article to "Testing Frameworks" (#12608) --- docs/TestingFrameworks.md | 4 ++++ website/versioned_docs/version-25.x/TestingFrameworks.md | 4 ++++ website/versioned_docs/version-26.x/TestingFrameworks.md | 4 ++++ website/versioned_docs/version-27.0/TestingFrameworks.md | 4 ++++ website/versioned_docs/version-27.1/TestingFrameworks.md | 4 ++++ website/versioned_docs/version-27.2/TestingFrameworks.md | 4 ++++ website/versioned_docs/version-27.4/TestingFrameworks.md | 4 ++++ website/versioned_docs/version-27.5/TestingFrameworks.md | 4 ++++ 8 files changed, 32 insertions(+) diff --git a/docs/TestingFrameworks.md b/docs/TestingFrameworks.md index d41afbeabc21..6ae4358fdf7d 100644 --- a/docs/TestingFrameworks.md +++ b/docs/TestingFrameworks.md @@ -43,3 +43,7 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js - [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar + +## Next.js + +- [Jest and React Testing Library](https://nextjs.org/docs/testing#jest-and-react-testing-library) by Next.js docs diff --git a/website/versioned_docs/version-25.x/TestingFrameworks.md b/website/versioned_docs/version-25.x/TestingFrameworks.md index d41afbeabc21..6ae4358fdf7d 100644 --- a/website/versioned_docs/version-25.x/TestingFrameworks.md +++ b/website/versioned_docs/version-25.x/TestingFrameworks.md @@ -43,3 +43,7 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js - [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar + +## Next.js + +- [Jest and React Testing Library](https://nextjs.org/docs/testing#jest-and-react-testing-library) by Next.js docs diff --git a/website/versioned_docs/version-26.x/TestingFrameworks.md b/website/versioned_docs/version-26.x/TestingFrameworks.md index d41afbeabc21..6ae4358fdf7d 100644 --- a/website/versioned_docs/version-26.x/TestingFrameworks.md +++ b/website/versioned_docs/version-26.x/TestingFrameworks.md @@ -43,3 +43,7 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js - [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar + +## Next.js + +- [Jest and React Testing Library](https://nextjs.org/docs/testing#jest-and-react-testing-library) by Next.js docs diff --git a/website/versioned_docs/version-27.0/TestingFrameworks.md b/website/versioned_docs/version-27.0/TestingFrameworks.md index d41afbeabc21..6ae4358fdf7d 100644 --- a/website/versioned_docs/version-27.0/TestingFrameworks.md +++ b/website/versioned_docs/version-27.0/TestingFrameworks.md @@ -43,3 +43,7 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js - [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar + +## Next.js + +- [Jest and React Testing Library](https://nextjs.org/docs/testing#jest-and-react-testing-library) by Next.js docs diff --git a/website/versioned_docs/version-27.1/TestingFrameworks.md b/website/versioned_docs/version-27.1/TestingFrameworks.md index d41afbeabc21..6ae4358fdf7d 100644 --- a/website/versioned_docs/version-27.1/TestingFrameworks.md +++ b/website/versioned_docs/version-27.1/TestingFrameworks.md @@ -43,3 +43,7 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js - [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar + +## Next.js + +- [Jest and React Testing Library](https://nextjs.org/docs/testing#jest-and-react-testing-library) by Next.js docs diff --git a/website/versioned_docs/version-27.2/TestingFrameworks.md b/website/versioned_docs/version-27.2/TestingFrameworks.md index d41afbeabc21..6ae4358fdf7d 100644 --- a/website/versioned_docs/version-27.2/TestingFrameworks.md +++ b/website/versioned_docs/version-27.2/TestingFrameworks.md @@ -43,3 +43,7 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js - [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar + +## Next.js + +- [Jest and React Testing Library](https://nextjs.org/docs/testing#jest-and-react-testing-library) by Next.js docs diff --git a/website/versioned_docs/version-27.4/TestingFrameworks.md b/website/versioned_docs/version-27.4/TestingFrameworks.md index d41afbeabc21..6ae4358fdf7d 100644 --- a/website/versioned_docs/version-27.4/TestingFrameworks.md +++ b/website/versioned_docs/version-27.4/TestingFrameworks.md @@ -43,3 +43,7 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js - [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar + +## Next.js + +- [Jest and React Testing Library](https://nextjs.org/docs/testing#jest-and-react-testing-library) by Next.js docs diff --git a/website/versioned_docs/version-27.5/TestingFrameworks.md b/website/versioned_docs/version-27.5/TestingFrameworks.md index d41afbeabc21..6ae4358fdf7d 100644 --- a/website/versioned_docs/version-27.5/TestingFrameworks.md +++ b/website/versioned_docs/version-27.5/TestingFrameworks.md @@ -43,3 +43,7 @@ Jest is a universal testing platform, with the ability to adapt to any JavaScrip ## Hapi.js - [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar + +## Next.js + +- [Jest and React Testing Library](https://nextjs.org/docs/testing#jest-and-react-testing-library) by Next.js docs From d873e2cb25c9280e2f43721e4f95bc93fcd80db3 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Mon, 4 Apr 2022 16:02:47 +0300 Subject: [PATCH 007/128] chore(lint): turn the ESLint rule `no-useless-call` on as an error (#12624) --- .eslintrc.js | 2 +- packages/jest-mock/src/__tests__/index.test.ts | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.eslintrc.js b/.eslintrc.js index 4d69f9235bad..8e4aec244a31 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -467,7 +467,7 @@ module.exports = { 'no-unused-expressions': 'off', 'no-unused-vars': ['error', {argsIgnorePattern: '^_'}], 'no-use-before-define': 'off', - 'no-useless-call': 'warn', + 'no-useless-call': 'error', 'no-useless-computed-key': 'error', 'no-useless-concat': 'error', 'no-var': 'error', diff --git a/packages/jest-mock/src/__tests__/index.test.ts b/packages/jest-mock/src/__tests__/index.test.ts index 371ba0a04ea8..4bb1e01af98c 100644 --- a/packages/jest-mock/src/__tests__/index.test.ts +++ b/packages/jest-mock/src/__tests__/index.test.ts @@ -442,9 +442,9 @@ describe('moduleMocker', () => { expect(fn.mock.contexts[2]).toBe(ctx2); // null context - fn.apply(null, []); + fn.apply(null, []); // eslint-disable-line no-useless-call expect(fn.mock.contexts[3]).toBe(null); - fn.call(null); + fn.call(null); // eslint-disable-line no-useless-call expect(fn.mock.contexts[4]).toBe(null); fn.bind(null)(); expect(fn.mock.contexts[5]).toBe(null); From 77b5519f5e019d036ccfa23987da09059e854fc0 Mon Sep 17 00:00:00 2001 From: nate Date: Mon, 4 Apr 2022 09:24:35 -0400 Subject: [PATCH 008/128] docs: add section about installing `ts-jest` (#12607) --- docs/GettingStarted.md | 4 ++++ website/versioned_docs/version-25.x/GettingStarted.md | 4 ++++ website/versioned_docs/version-26.x/GettingStarted.md | 4 ++++ website/versioned_docs/version-27.0/GettingStarted.md | 4 ++++ website/versioned_docs/version-27.1/GettingStarted.md | 4 ++++ website/versioned_docs/version-27.2/GettingStarted.md | 4 ++++ website/versioned_docs/version-27.4/GettingStarted.md | 4 ++++ website/versioned_docs/version-27.5/GettingStarted.md | 4 ++++ 8 files changed, 32 insertions(+) diff --git a/docs/GettingStarted.md b/docs/GettingStarted.md index b89edbf87579..870942cac091 100644 --- a/docs/GettingStarted.md +++ b/docs/GettingStarted.md @@ -150,6 +150,10 @@ However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transf [ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. +```bash npm2yarn +npm install --save-dev ts-jest +``` + #### Type definitions You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. diff --git a/website/versioned_docs/version-25.x/GettingStarted.md b/website/versioned_docs/version-25.x/GettingStarted.md index 266a05d817e3..db798b49b5c1 100644 --- a/website/versioned_docs/version-25.x/GettingStarted.md +++ b/website/versioned_docs/version-25.x/GettingStarted.md @@ -158,6 +158,10 @@ However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transf [ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. +```bash +yarn add --dev ts-jest +``` + #### Type definitions You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. diff --git a/website/versioned_docs/version-26.x/GettingStarted.md b/website/versioned_docs/version-26.x/GettingStarted.md index e4c54cc22985..f6183a371810 100644 --- a/website/versioned_docs/version-26.x/GettingStarted.md +++ b/website/versioned_docs/version-26.x/GettingStarted.md @@ -158,6 +158,10 @@ However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transf [ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. +```bash +yarn add --dev ts-jest +``` + ### Using TypeScript: type definitions You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. diff --git a/website/versioned_docs/version-27.0/GettingStarted.md b/website/versioned_docs/version-27.0/GettingStarted.md index 266a05d817e3..db798b49b5c1 100644 --- a/website/versioned_docs/version-27.0/GettingStarted.md +++ b/website/versioned_docs/version-27.0/GettingStarted.md @@ -158,6 +158,10 @@ However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transf [ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. +```bash +yarn add --dev ts-jest +``` + #### Type definitions You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. diff --git a/website/versioned_docs/version-27.1/GettingStarted.md b/website/versioned_docs/version-27.1/GettingStarted.md index 266a05d817e3..db798b49b5c1 100644 --- a/website/versioned_docs/version-27.1/GettingStarted.md +++ b/website/versioned_docs/version-27.1/GettingStarted.md @@ -158,6 +158,10 @@ However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transf [ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. +```bash +yarn add --dev ts-jest +``` + #### Type definitions You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. diff --git a/website/versioned_docs/version-27.2/GettingStarted.md b/website/versioned_docs/version-27.2/GettingStarted.md index 266a05d817e3..db798b49b5c1 100644 --- a/website/versioned_docs/version-27.2/GettingStarted.md +++ b/website/versioned_docs/version-27.2/GettingStarted.md @@ -158,6 +158,10 @@ However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transf [ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. +```bash +yarn add --dev ts-jest +``` + #### Type definitions You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. diff --git a/website/versioned_docs/version-27.4/GettingStarted.md b/website/versioned_docs/version-27.4/GettingStarted.md index ad4d45badb60..ed3e66162f7c 100644 --- a/website/versioned_docs/version-27.4/GettingStarted.md +++ b/website/versioned_docs/version-27.4/GettingStarted.md @@ -158,6 +158,10 @@ However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transf [ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. +```bash +yarn add --dev ts-jest +``` + ### Using TypeScript: type definitions You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. diff --git a/website/versioned_docs/version-27.5/GettingStarted.md b/website/versioned_docs/version-27.5/GettingStarted.md index 6adca8aeee7b..4d462922eea7 100644 --- a/website/versioned_docs/version-27.5/GettingStarted.md +++ b/website/versioned_docs/version-27.5/GettingStarted.md @@ -158,6 +158,10 @@ However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transf [ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. +```bash +yarn add --dev ts-jest +``` + You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. > For `@types/*` modules it's recommended to try to match the version of the associated module. For example, if you are using `26.4.0` of `jest` then using `26.4.x` of `@types/jest` is ideal. In general, try to match the major (`26`) and minor (`4`) version as closely as possible. From b096941c4a81e50ab2494f2909f4dcb300bdbab7 Mon Sep 17 00:00:00 2001 From: Carl-Erik Kopseng Date: Mon, 4 Apr 2022 15:37:28 +0200 Subject: [PATCH 009/128] feat: extract 'createTransformer' and use type predicates (#12407) --- CHANGELOG.md | 2 + docs/CodeTransformation.md | 91 +++++++++---------- e2e/transform/babel-jest-async/transformer.js | 4 +- .../src/__tests__/getCacheKey.test.ts | 50 ++++------ packages/babel-jest/src/__tests__/index.ts | 32 +++++-- packages/babel-jest/src/index.ts | 17 ++-- packages/jest-repl/src/cli/repl.ts | 11 ++- .../jest-transform/src/ScriptTransformer.ts | 15 ++- packages/jest-transform/src/index.ts | 1 + packages/jest-transform/src/types.ts | 24 ++++- 10 files changed, 141 insertions(+), 106 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index bee7bad05887..9421514c3e47 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -75,9 +75,11 @@ - `[*]` [**BREAKING**] Drop support for `typescript@3.8`, minimum version is now `4.2` ([#11142](https://github.com/facebook/jest/pull/11142)) - `[*]` Bundle all `.d.ts` files into a single `index.d.ts` per module ([#12345](https://github.com/facebook/jest/pull/12345)) - `[*]` Use `globalThis` instead of `global` ([#12447](https://github.com/facebook/jest/pull/12447)) +- `[babel-jest]` [**BREAKING**] Only export `createTransformer` ([#12407](https://github.com/facebook/jest/pull/12407)) - `[docs]` Add note about not mixing `done()` with Promises ([#11077](https://github.com/facebook/jest/pull/11077)) - `[docs, examples]` Update React examples to match with the new React guidelines for code examples ([#12217](https://github.com/facebook/jest/pull/12217)) - `[docs]` Add clarity for module factory hoisting limitations ([#12453](https://github.com/facebook/jest/pull/12453)) +- `[docs]` Add more information about how code transformers work ([#12407](https://github.com/facebook/jest/pull/12407)) - `[expect]` [**BREAKING**] Remove support for importing `build/utils` ([#12323](https://github.com/facebook/jest/pull/12323)) - `[expect]` [**BREAKING**] Migrate to ESM ([#12344](https://github.com/facebook/jest/pull/12344)) - `[expect]` [**BREAKING**] Snapshot matcher types are moved to `@jest/expect` ([#12404](https://github.com/facebook/jest/pull/12404)) diff --git a/docs/CodeTransformation.md b/docs/CodeTransformation.md index 3b1e0f8e3100..05ef21d770bb 100644 --- a/docs/CodeTransformation.md +++ b/docs/CodeTransformation.md @@ -22,72 +22,77 @@ If you override the `transform` configuration option `babel-jest` will no longer You can write your own transformer. The API of a transformer is as follows: ```ts +// This version of the interface you are seeing on the website has been trimmed down for brevity +// For the full definition, see `packages/jest-transform/src/types.ts` in https://github.com/facebook/jest +// (taking care in choosing the right tag/commit for your version of Jest) + +interface TransformOptions { + supportsDynamicImport: boolean; + supportsExportNamespaceFrom: boolean; + supportsStaticESM: boolean; + supportsTopLevelAwait: boolean; + instrument: boolean; + /** a cached file system which is used in jest-runtime - useful to improve performance */ + cacheFS: Map; + config: Config.ProjectConfig; + /** A stringified version of the configuration - useful in cache busting */ + configString: string; + /** the options passed through Jest's config by the user */ + transformerConfig: OptionType; +} + interface SyncTransformer { - /** - * Indicates if the transformer is capable of instrumenting the code for code coverage. - * - * If V8 coverage is _not_ active, and this is `true`, Jest will assume the code is instrumented. - * If V8 coverage is _not_ active, and this is `false`. Jest will instrument the code returned by this transformer using Babel. - */ canInstrument?: boolean; - createTransformer?: (options?: OptionType) => SyncTransformer; getCacheKey?: ( sourceText: string, - sourcePath: Config.Path, + sourcePath: string, options: TransformOptions, ) => string; getCacheKeyAsync?: ( sourceText: string, - sourcePath: Config.Path, + sourcePath: string, options: TransformOptions, ) => Promise; process: ( sourceText: string, - sourcePath: Config.Path, + sourcePath: string, options: TransformOptions, ) => TransformedSource; processAsync?: ( sourceText: string, - sourcePath: Config.Path, + sourcePath: string, options: TransformOptions, ) => Promise; } interface AsyncTransformer { - /** - * Indicates if the transformer is capable of instrumenting the code for code coverage. - * - * If V8 coverage is _not_ active, and this is `true`, Jest will assume the code is instrumented. - * If V8 coverage is _not_ active, and this is `false`. Jest will instrument the code returned by this transformer using Babel. - */ canInstrument?: boolean; - createTransformer?: (options?: OptionType) => AsyncTransformer; getCacheKey?: ( sourceText: string, - sourcePath: Config.Path, + sourcePath: string, options: TransformOptions, ) => string; getCacheKeyAsync?: ( sourceText: string, - sourcePath: Config.Path, + sourcePath: string, options: TransformOptions, ) => Promise; process?: ( sourceText: string, - sourcePath: Config.Path, + sourcePath: string, options: TransformOptions, ) => TransformedSource; processAsync: ( sourceText: string, - sourcePath: Config.Path, + sourcePath: string, options: TransformOptions, ) => Promise; } @@ -96,35 +101,25 @@ type Transformer = | SyncTransformer | AsyncTransformer; -interface TransformOptions { - /** - * If a transformer does module resolution and reads files, it should populate `cacheFS` so that - * Jest avoids reading the same files again, improving performance. `cacheFS` stores entries of - * - */ - cacheFS: Map; - config: Config.ProjectConfig; - /** A stringified version of the configuration - useful in cache busting */ - configString: string; - instrument: boolean; - // names are copied from babel: https://babeljs.io/docs/en/options#caller - supportsDynamicImport: boolean; - supportsExportNamespaceFrom: boolean; - supportsStaticESM: boolean; - supportsTopLevelAwait: boolean; - /** the options passed through Jest's config by the user */ - transformerConfig: OptionType; -} - -type TransformedSource = - | {code: string; map?: RawSourceMap | string | null} - | string; +type TransformerCreator< + X extends Transformer, + OptionType = unknown, +> = (options?: OptionType) => X; -// Config.ProjectConfig can be seen in code [here](https://github.com/facebook/jest/blob/v26.6.3/packages/jest-types/src/Config.ts#L323) -// RawSourceMap comes from [`source-map`](https://github.com/mozilla/source-map/blob/0.6.1/source-map.d.ts#L6-L12) +type TransformerFactory = { + createTransformer: TransformerCreator; +}; ``` -As can be seen, only `process` or `processAsync` is mandatory to implement, although we highly recommend implementing `getCacheKey` as well, so we don't waste resources transpiling the same source file when we can read its previous result from disk. You can use [`@jest/create-cache-key-function`](https://www.npmjs.com/package/@jest/create-cache-key-function) to help implement it. +There are a couple of ways you can import code into Jest - using Common JS (`require`) or ECMAScript Modules (`import` - which exists in static and dynamic versions). Jest passes files through code transformation on demand (for instance when a `require` or `import` is evaluated). This process, also known as "transpilation", might happen _synchronously_ (in the case of `require`), or _asynchronously_ (in the case of `import` or `import()`, the latter of which also works from Common JS modules). For this reason, the interface exposes both pairs of methods for asynchronous and synchronous processes: `process{Async}` and `getCacheKey{Async}`. The latter is called to figure out if we need to call `process{Async}` at all. Since async transformation can happen synchronously without issue, it's possible for the async case to "fall back" to the sync variant, but not vice versa. + +So if your code base is ESM only implementing the async variants is sufficient. Otherwise, if any code is loaded through `require` (including `createRequire` from within ESM), then you need to implement the synchronous variant. Be aware that `node_modules` is not transpiled with default config. + +Semi-related to this are the supports flags we pass (see `CallerTransformOptions` above), but those should be used within the transform to figure out if it should return ESM or CJS, and has no direct bearing on sync vs async + +Though not required, we _highly recommend_ implementing `getCacheKey` as well, so we do not waste resources transpiling when we could have read its previous result from disk. You can use [`@jest/create-cache-key-function`](https://www.npmjs.com/package/@jest/create-cache-key-function) to help implement it. + +Instead of having your custom transformer implement the `Transformer` interface directly, you can choose to export `createTransformer`, a factory function to dynamically create transformers. This is to allow having a transformer config in your jest config. Note that [ECMAScript module](ECMAScriptModules.md) support is indicated by the passed in `supports*` options. Specifically `supportsDynamicImport: true` means the transformer can return `import()` expressions, which is supported by both ESM and CJS. If `supportsStaticESM: true` it means top level `import` statements are supported and the code will be interpreted as ESM and not CJS. See [Node's docs](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs) for details on the differences. diff --git a/e2e/transform/babel-jest-async/transformer.js b/e2e/transform/babel-jest-async/transformer.js index 9bc35a2a9ad1..41a96de04751 100644 --- a/e2e/transform/babel-jest-async/transformer.js +++ b/e2e/transform/babel-jest-async/transformer.js @@ -6,10 +6,10 @@ */ import {fileURLToPath} from 'url'; -import babelJest from 'babel-jest'; +import {createTransformer} from 'babel-jest'; export default { - ...babelJest.default.createTransformer({ + ...createTransformer({ presets: ['@babel/preset-flow'], root: fileURLToPath(import.meta.url), }), diff --git a/packages/babel-jest/src/__tests__/getCacheKey.test.ts b/packages/babel-jest/src/__tests__/getCacheKey.test.ts index 63e38cff3cb3..d6eaa5d9295b 100644 --- a/packages/babel-jest/src/__tests__/getCacheKey.test.ts +++ b/packages/babel-jest/src/__tests__/getCacheKey.test.ts @@ -9,6 +9,8 @@ import type {TransformOptions as BabelTransformOptions} from '@babel/core'; import type {TransformOptions as JestTransformOptions} from '@jest/transform'; import babelJest from '../index'; +const {getCacheKey} = babelJest.createTransformer(); + const processVersion = process.version; const nodeEnv = process.env.NODE_ENV; const babelEnv = process.env.BABEL_ENV; @@ -39,11 +41,7 @@ describe('getCacheKey', () => { instrument: true, } as JestTransformOptions; - const oldCacheKey = babelJest.getCacheKey( - sourceText, - sourcePath, - transformOptions, - ); + const oldCacheKey = getCacheKey(sourceText, sourcePath, transformOptions); test('returns cache key hash', () => { expect(oldCacheKey.length).toEqual(32); @@ -54,9 +52,9 @@ describe('getCacheKey', () => { readFileSync: () => 'new this file', })); - const {default: babelJest}: typeof import('../index') = require('../index'); + const {createTransformer}: typeof import('../index') = require('../index'); - const newCacheKey = babelJest.getCacheKey( + const newCacheKey = createTransformer().getCacheKey( sourceText, sourcePath, transformOptions, @@ -77,9 +75,9 @@ describe('getCacheKey', () => { }; }); - const {default: babelJest}: typeof import('../index') = require('../index'); + const {createTransformer}: typeof import('../index') = require('../index'); - const newCacheKey = babelJest.getCacheKey( + const newCacheKey = createTransformer().getCacheKey( sourceText, sourcePath, transformOptions, @@ -89,7 +87,7 @@ describe('getCacheKey', () => { }); test('if `sourceText` value is changing', () => { - const newCacheKey = babelJest.getCacheKey( + const newCacheKey = getCacheKey( 'new source text', sourcePath, transformOptions, @@ -99,7 +97,7 @@ describe('getCacheKey', () => { }); test('if `sourcePath` value is changing', () => { - const newCacheKey = babelJest.getCacheKey( + const newCacheKey = getCacheKey( sourceText, 'new-source-path.js', transformOptions, @@ -109,7 +107,7 @@ describe('getCacheKey', () => { }); test('if `configString` value is changing', () => { - const newCacheKey = babelJest.getCacheKey(sourceText, sourcePath, { + const newCacheKey = getCacheKey(sourceText, sourcePath, { ...transformOptions, configString: 'new-config-string', }); @@ -129,9 +127,9 @@ describe('getCacheKey', () => { }; }); - const {default: babelJest}: typeof import('../index') = require('../index'); + const {createTransformer}: typeof import('../index') = require('../index'); - const newCacheKey = babelJest.getCacheKey( + const newCacheKey = createTransformer().getCacheKey( sourceText, sourcePath, transformOptions, @@ -152,9 +150,9 @@ describe('getCacheKey', () => { }; }); - const {default: babelJest}: typeof import('../index') = require('../index'); + const {createTransformer}: typeof import('../index') = require('../index'); - const newCacheKey = babelJest.getCacheKey( + const newCacheKey = createTransformer().getCacheKey( sourceText, sourcePath, transformOptions, @@ -164,7 +162,7 @@ describe('getCacheKey', () => { }); test('if `instrument` value is changing', () => { - const newCacheKey = babelJest.getCacheKey(sourceText, sourcePath, { + const newCacheKey = getCacheKey(sourceText, sourcePath, { ...transformOptions, instrument: false, }); @@ -175,11 +173,7 @@ describe('getCacheKey', () => { test('if `process.env.NODE_ENV` value is changing', () => { process.env.NODE_ENV = 'NEW_NODE_ENV'; - const newCacheKey = babelJest.getCacheKey( - sourceText, - sourcePath, - transformOptions, - ); + const newCacheKey = getCacheKey(sourceText, sourcePath, transformOptions); expect(oldCacheKey).not.toEqual(newCacheKey); }); @@ -187,11 +181,7 @@ describe('getCacheKey', () => { test('if `process.env.BABEL_ENV` value is changing', () => { process.env.BABEL_ENV = 'NEW_BABEL_ENV'; - const newCacheKey = babelJest.getCacheKey( - sourceText, - sourcePath, - transformOptions, - ); + const newCacheKey = getCacheKey(sourceText, sourcePath, transformOptions); expect(oldCacheKey).not.toEqual(newCacheKey); }); @@ -200,11 +190,7 @@ describe('getCacheKey', () => { delete process.version; process.version = 'new-node-version'; - const newCacheKey = babelJest.getCacheKey( - sourceText, - sourcePath, - transformOptions, - ); + const newCacheKey = getCacheKey(sourceText, sourcePath, transformOptions); expect(oldCacheKey).not.toEqual(newCacheKey); }); diff --git a/packages/babel-jest/src/__tests__/index.ts b/packages/babel-jest/src/__tests__/index.ts index 7d3db19bdc7a..46dd4677eee3 100644 --- a/packages/babel-jest/src/__tests__/index.ts +++ b/packages/babel-jest/src/__tests__/index.ts @@ -6,7 +6,7 @@ */ import {makeProjectConfig} from '@jest/test-utils'; -import babelJest from '../index'; +import babelJest, {createTransformer} from '../index'; import {loadPartialConfig} from '../loadBabelConfig'; jest.mock('../loadBabelConfig', () => { @@ -20,6 +20,8 @@ jest.mock('../loadBabelConfig', () => { }; }); +const defaultBabelJestTransformer = babelJest.createTransformer(null); + //Mock data for all the tests const sourceString = ` const sum = (a, b) => a+b; @@ -38,11 +40,17 @@ beforeEach(() => { }); test('Returns source string with inline maps when no transformOptions is passed', () => { - const result = babelJest.process(sourceString, 'dummy_path.js', { - config: makeProjectConfig(), - configString: JSON.stringify(makeProjectConfig()), - instrument: false, - }) as any; + const result = defaultBabelJestTransformer.process( + sourceString, + 'dummy_path.js', + { + cacheFS: new Map(), + config: makeProjectConfig(), + configString: JSON.stringify(makeProjectConfig()), + instrument: false, + transformerConfig: {}, + }, + ) as any; expect(typeof result).toBe('object'); expect(result.code).toBeDefined(); expect(result.map).toBeDefined(); @@ -53,13 +61,15 @@ test('Returns source string with inline maps when no transformOptions is passed' }); test('Returns source string with inline maps when no transformOptions is passed async', async () => { - const result: any = await babelJest.processAsync!( + const result: any = await defaultBabelJestTransformer.processAsync!( sourceString, 'dummy_path.js', { + cacheFS: new Map(), config: makeProjectConfig(), configString: JSON.stringify(makeProjectConfig()), instrument: false, + transformerConfig: {}, }, ); expect(typeof result).toBe('object'); @@ -108,10 +118,12 @@ describe('caller option correctly merges from defaults and options', () => { }, ], ])('%j -> %j', (input, output) => { - babelJest.process(sourceString, 'dummy_path.js', { + defaultBabelJestTransformer.process(sourceString, 'dummy_path.js', { + cacheFS: new Map(), config: makeProjectConfig(), configString: JSON.stringify(makeProjectConfig()), instrument: false, + transformerConfig: {}, ...input, }); @@ -130,11 +142,13 @@ describe('caller option correctly merges from defaults and options', () => { }); test('can pass null to createTransformer', () => { - const transformer = babelJest.createTransformer(null); + const transformer = createTransformer(null); transformer.process(sourceString, 'dummy_path.js', { + cacheFS: new Map(), config: makeProjectConfig(), configString: JSON.stringify(makeProjectConfig()), instrument: false, + transformerConfig: {}, }); expect(loadPartialConfig).toHaveBeenCalledTimes(1); diff --git a/packages/babel-jest/src/index.ts b/packages/babel-jest/src/index.ts index 522d5cc58390..ff5fc8b85ce6 100644 --- a/packages/babel-jest/src/index.ts +++ b/packages/babel-jest/src/index.ts @@ -19,6 +19,7 @@ import slash = require('slash'); import type { TransformOptions as JestTransformOptions, SyncTransformer, + TransformerCreator, } from '@jest/transform'; import {loadPartialConfig, loadPartialConfigAsync} from './loadBabelConfig'; @@ -26,8 +27,6 @@ const THIS_FILE = fs.readFileSync(__filename); const jestPresetPath = require.resolve('babel-preset-jest'); const babelIstanbulPlugin = require.resolve('babel-plugin-istanbul'); -type CreateTransformer = SyncTransformer['createTransformer']; - function assertLoadedBabelConfig( babelConfig: Readonly | null, cwd: string, @@ -148,7 +147,10 @@ async function loadBabelOptionsAsync( return addIstanbulInstrumentation(options, jestTransformOptions); } -export const createTransformer: CreateTransformer = userOptions => { +export const createTransformer: TransformerCreator< + SyncTransformer, + TransformOptions +> = userOptions => { const inputOptions = userOptions ?? {}; const options = { @@ -269,11 +271,10 @@ export const createTransformer: CreateTransformer = userOptions => { }; }; -const transformer: SyncTransformer = { - ...createTransformer(), - // Assigned here so only the exported transformer has `createTransformer`, - // instead of all created transformers by the function +const transformerFactory = { + // Assigned here, instead of as a separate export, due to limitations in Jest's + // requireOrImportModule, requiring all exports to be on the `default` export createTransformer, }; -export default transformer; +export default transformerFactory; diff --git a/packages/jest-repl/src/cli/repl.ts b/packages/jest-repl/src/cli/repl.ts index 94cb896c9e68..757af8df679e 100644 --- a/packages/jest-repl/src/cli/repl.ts +++ b/packages/jest-repl/src/cli/repl.ts @@ -78,7 +78,16 @@ if (jestProjectConfig.transform) { } } if (transformerPath) { - transformer = interopRequireDefault(require(transformerPath)).default; + const transformerOrFactory = interopRequireDefault( + require(transformerPath), + ).default; + + if (typeof transformerOrFactory.createTransformer === 'function') { + transformer = transformerOrFactory.createTransformer(transformerConfig); + } else { + transformer = transformerOrFactory; + } + if (typeof transformer.process !== 'function') { throw new TypeError( 'Jest: a transformer must export a `process` function.', diff --git a/packages/jest-transform/src/ScriptTransformer.ts b/packages/jest-transform/src/ScriptTransformer.ts index b1ab7a935f45..4959c200d5cc 100644 --- a/packages/jest-transform/src/ScriptTransformer.ts +++ b/packages/jest-transform/src/ScriptTransformer.ts @@ -42,6 +42,7 @@ import type { TransformResult, TransformedSource, Transformer, + TransformerFactory, } from './types'; // Use `require` to avoid TS rootDir const {version: VERSION} = require('../package.json'); @@ -72,6 +73,13 @@ async function waitForPromiseWithCleanup( } } +// type predicate +function isTransformerFactory( + t: Transformer | TransformerFactory, +): t is TransformerFactory { + return typeof (t as TransformerFactory).createTransformer === 'function'; +} + class ScriptTransformer { private readonly _cache: ProjectCache; private readonly _transformCache = new Map< @@ -259,14 +267,13 @@ class ScriptTransformer { await Promise.all( this._config.transform.map( async ([, transformPath, transformerConfig]) => { - let transformer: Transformer = await requireOrImportModule( - transformPath, - ); + let transformer: Transformer | TransformerFactory = + await requireOrImportModule(transformPath); if (!transformer) { throw new Error(makeInvalidTransformerError(transformPath)); } - if (typeof transformer.createTransformer === 'function') { + if (isTransformerFactory(transformer)) { transformer = transformer.createTransformer(transformerConfig); } if ( diff --git a/packages/jest-transform/src/index.ts b/packages/jest-transform/src/index.ts index 90ac16070cee..e81fe036ba4f 100644 --- a/packages/jest-transform/src/index.ts +++ b/packages/jest-transform/src/index.ts @@ -18,6 +18,7 @@ export type { AsyncTransformer, ShouldInstrumentOptions, Options as TransformationOptions, + TransformerCreator, TransformOptions, TransformResult, TransformedSource, diff --git a/packages/jest-transform/src/types.ts b/packages/jest-transform/src/types.ts index 1d28cbdb30ea..85bb4a31ba54 100644 --- a/packages/jest-transform/src/types.ts +++ b/packages/jest-transform/src/types.ts @@ -76,7 +76,6 @@ export interface SyncTransformer { * If V8 coverage is _not_ active, and this is `false`. Jest will instrument the code returned by this transformer using Babel. */ canInstrument?: boolean; - createTransformer?: (options?: OptionType) => SyncTransformer; getCacheKey?: ( sourceText: string, @@ -111,7 +110,6 @@ export interface AsyncTransformer { * If V8 coverage is _not_ active, and this is `false`. Jest will instrument the code returned by this transformer using Babel. */ canInstrument?: boolean; - createTransformer?: (options?: OptionType) => AsyncTransformer; getCacheKey?: ( sourceText: string, @@ -138,6 +136,28 @@ export interface AsyncTransformer { ) => Promise; } +/** + * We have both sync (`process`) and async (`processAsync`) code transformation, which both can be provided. + * `require` will always use `process`, and `import` will use `processAsync` if it exists, otherwise fall back to `process`. + * Meaning, if you use `import` exclusively you do not need `process`, but in most cases supplying both makes sense: + * Jest transpiles on demand rather than ahead of time, so the sync one needs to exist. + * + * For more info on the sync vs async model, see https://jestjs.io/docs/code-transformation#writing-custom-transformers + */ export type Transformer = | SyncTransformer | AsyncTransformer; + +export type TransformerCreator< + X extends Transformer, + OptionType = unknown, +> = (options?: OptionType) => X; + +/** + * Instead of having your custom transformer implement the Transformer interface + * directly, you can choose to export a factory function to dynamically create + * transformers. This is to allow having a transformer config in your jest config. + */ +export type TransformerFactory = { + createTransformer: TransformerCreator; +}; From f88b7db7241298dd847dcd61380c72e9a72e67ce Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Mon, 4 Apr 2022 15:43:27 +0200 Subject: [PATCH 010/128] chore(ci): split TS and ESLint runs on CI (#12630) --- .github/workflows/nodejs.yml | 20 ++++++++++++++++++-- 1 file changed, 18 insertions(+), 2 deletions(-) diff --git a/.github/workflows/nodejs.yml b/.github/workflows/nodejs.yml index 7fdbb93b150c..7281963ff76c 100644 --- a/.github/workflows/nodejs.yml +++ b/.github/workflows/nodejs.yml @@ -38,8 +38,8 @@ jobs: YARN_ENABLE_SCRIPTS: false run: yarn --immutable - lint-and-typecheck: - name: Running TypeScript compiler & ESLint + typecheck: + name: Running TypeScript compiler runs-on: ubuntu-latest needs: prepare-yarn-cache @@ -57,6 +57,22 @@ jobs: run: yarn test-types - name: verify TypeScript@4.2 compatibility run: yarn verify-old-ts + + lint: + name: Running ESLint + runs-on: ubuntu-latest + needs: prepare-yarn-cache + + steps: + - uses: actions/checkout@v3 + - uses: actions/setup-node@v3 + with: + node-version: lts/* + cache: yarn + - name: install + run: yarn --immutable + - name: build + run: yarn build:js - name: verify Yarn PnP compatibility run: yarn verify-pnp - name: run eslint From eb2146f191b4fa97d8ae408fa0f1a88d7172a937 Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Mon, 4 Apr 2022 21:45:23 +0800 Subject: [PATCH 011/128] Add `--ignoreProjects` CLI argument to ignore test suites by project name (#12620) --- CHANGELOG.md | 1 + docs/CLI.md | 6 +- e2e/__tests__/selectProjects.test.ts | 153 ++++++++++++++++++ .../jest-cli/src/__tests__/cli/args.test.ts | 6 + packages/jest-cli/src/cli/args.ts | 21 ++- packages/jest-core/src/cli/index.ts | 21 ++- .../src/getConfigsOfProjectsToRun.ts | 32 +++- .../src/getProjectNamesMissingWarning.ts | 13 +- .../jest-core/src/getSelectProjectsMessage.ts | 34 +++- packages/jest-types/src/Config.ts | 1 + 10 files changed, 267 insertions(+), 21 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9421514c3e47..e4f92643ebbd 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,6 +14,7 @@ - `[jest-config]` [**BREAKING**] Rename `extraGlobals` to `sandboxInjectedGlobals` ([#10817](https://github.com/facebook/jest/pull/10817)) - `[jest-config]` [**BREAKING**] Throw an error instead of showing a warning if multiple configs are used ([#12510](https://github.com/facebook/jest/pull/12510)) - `[jest-core]` Pass project config to `globalSetup`/`globalTeardown` function as second argument ([#12440](https://github.com/facebook/jest/pull/12440)) +- `[jest-cli, jest-core]` Add `--ignoreProjects` CLI argument to ignore test suites by project name ([#12620](https://github.com/facebook/jest/pull/12620)) - `[jest-environment-jsdom]` [**BREAKING**] Upgrade jsdom to 19.0.0 ([#12290](https://github.com/facebook/jest/pull/12290)) - `[jest-environment-jsdom]` [**BREAKING**] Add default `browser` condition to `exportConditions` for `jsdom` environment ([#11924](https://github.com/facebook/jest/pull/11924)) - `[jest-environment-jsdom]` [**BREAKING**] Pass global config to Jest environment constructor for `jsdom` environment ([#12461](https://github.com/facebook/jest/pull/12461)) diff --git a/docs/CLI.md b/docs/CLI.md index 8a213e989bbc..a08018b955e5 100644 --- a/docs/CLI.md +++ b/docs/CLI.md @@ -224,6 +224,10 @@ This feature is an escape-hatch. If Jest doesn't exit at the end of a test run, Show the help information, similar to this page. +### `--ignoreProjects ... ` + +Ignore the tests of the specified projects. Jest uses the attribute `displayName` in the configuration to identify each project. If you use this option, you should provide a `displayName` to all your projects. + ### `--init` Generate a basic configuration file. Based on your project, Jest will ask you a few questions that will help to generate a `jest.config.js` file with a short description for each option. @@ -332,7 +336,7 @@ The default regex matching works fine on small runs, but becomes slow if provide ### `--selectProjects ... ` -Run only the tests of the specified projects. Jest uses the attribute `displayName` in the configuration to identify each project. If you use this option, you should provide a `displayName` to all your projects. +Run the tests of the specified projects. Jest uses the attribute `displayName` in the configuration to identify each project. If you use this option, you should provide a `displayName` to all your projects. ### `--setupFilesAfterEnv ... ` diff --git a/e2e/__tests__/selectProjects.test.ts b/e2e/__tests__/selectProjects.test.ts index 2e48085b6cf1..2928fc8c2b18 100644 --- a/e2e/__tests__/selectProjects.test.ts +++ b/e2e/__tests__/selectProjects.test.ts @@ -111,6 +111,131 @@ describe('Given a config with two named projects, first-project and second-proje ); }); }); + + describe('when Jest is started with `--ignoreProjects first-project', () => { + let result: RunJestJsonResult; + beforeAll(() => { + result = runWithJson('select-projects', [ + '--ignoreProjects', + 'first-project', + ]); + }); + it('runs the tests in the second project only', () => { + expect(result.json).toHaveProperty('success', true); + expect(result.json).toHaveProperty('numTotalTests', 1); + expect(result.json.testResults.map(({name}) => name)).toEqual([ + resolve(dir, '__tests__/second-project.test.js'), + ]); + }); + it('prints that only second-project will run', () => { + expect(result.stderr).toMatch(/^Running one project: second-project/); + }); + }); + + describe('when Jest is started with `--ignoreProjects second-project', () => { + let result: RunJestJsonResult; + beforeAll(() => { + result = runWithJson('select-projects', [ + '--ignoreProjects', + 'second-project', + ]); + }); + it('runs the tests in the first project only', () => { + expect(result.json).toHaveProperty('success', true); + expect(result.json).toHaveProperty('numTotalTests', 1); + expect(result.json.testResults.map(({name}) => name)).toEqual([ + resolve(dir, '__tests__/first-project.test.js'), + ]); + }); + it('prints that only first-project will run', () => { + expect(result.stderr).toMatch(/^Running one project: first-project/); + }); + }); + + describe('when Jest is started with `--ignoreProjects third-project`', () => { + let result: RunJestJsonResult; + beforeAll(() => { + result = runWithJson('select-projects', [ + '--ignoreProjects', + 'third-project', + ]); + }); + it('runs the tests in the first and second projects', () => { + expect(result.json).toHaveProperty('success', true); + expect(result.json).toHaveProperty('numTotalTests', 2); + expect(result.json.testResults.map(({name}) => name).sort()).toEqual([ + resolve(dir, '__tests__/first-project.test.js'), + resolve(dir, '__tests__/second-project.test.js'), + ]); + }); + it('prints that both first-project and second-project will run', () => { + expect(result.stderr).toMatch( + /^Running 2 projects:\n- first-project\n- second-project/, + ); + }); + }); + + describe('when Jest is started with `--ignoreProjects first-project second-project`', () => { + let result: RunJestResult; + beforeAll(() => { + result = run('select-projects', [ + '--ignoreProjects', + 'first-project', + 'second-project', + ]); + }); + it('fails', () => { + expect(result).toHaveProperty('failed', true); + }); + it.skip('prints that no project was found', () => { + expect(result.stdout).toMatch( + /^You provided values for --ignoreProjects, but no projects were found matching the selection/, + ); + }); + }); + + describe('when Jest is started with `--selectProjects first-project second-project --ignoreProjects first-project` ', () => { + let result: RunJestJsonResult; + beforeAll(() => { + result = runWithJson('select-projects', [ + '--selectProjects', + 'first-project', + 'second-project', + '--ignoreProjects', + 'first-project', + ]); + }); + it('runs the tests in the second project only', () => { + expect(result.json).toHaveProperty('success', true); + expect(result.json).toHaveProperty('numTotalTests', 1); + expect(result.json.testResults.map(({name}) => name)).toEqual([ + resolve(dir, '__tests__/second-project.test.js'), + ]); + }); + it('prints that only second-project will run', () => { + expect(result.stderr).toMatch(/^Running one project: second-project/); + }); + }); + + describe('when Jest is started with `--selectProjects first-project --ignoreProjects first-project` ', () => { + let result: RunJestResult; + beforeAll(() => { + result = run('select-projects', [ + '--selectProjects', + 'first-project', + '--ignoreProjects', + 'first-project', + ]); + }); + it('fails', () => { + expect(result).toHaveProperty('failed', true); + }); + it.skip('prints that no project was found', () => { + expect(result.stdout).toMatch( + /^You provided values for --selectProjects and --ignoreProjects, but no projects were found matching the selection./, + ); + }); + }); }); describe('Given a config with two projects, first-project and an unnamed project', () => { @@ -185,4 +310,32 @@ describe('Given a config with two projects, first-project and an unnamed project ); }); }); + + describe('when Jest is started with `--ignoreProjects first-project`', () => { + let result: RunJestJsonResult; + beforeAll(() => { + result = runWithJson('select-projects-missing-name', [ + '--ignoreProjects', + 'first-project', + ]); + }); + it('runs the tests in the second project only', () => { + expect(result.json.success).toBe(true); + expect(result.json.numTotalTests).toBe(1); + expect(result.json.testResults.map(({name}) => name)).toEqual([ + resolve(dir, '__tests__/second-project.test.js'), + ]); + }); + it('prints that a project does not have a name', () => { + expect(result.stderr).toMatch( + /^You provided values for --ignoreProjects but a project does not have a name/, + ); + }); + it('prints that only second-project will run', () => { + const stderrThirdLine = result.stderr.split('\n')[2]; + expect(stderrThirdLine).toMatch( + /^Running one project: /, + ); + }); + }); }); diff --git a/packages/jest-cli/src/__tests__/cli/args.test.ts b/packages/jest-cli/src/__tests__/cli/args.test.ts index f40f37aeb873..89593f889ebd 100644 --- a/packages/jest-cli/src/__tests__/cli/args.test.ts +++ b/packages/jest-cli/src/__tests__/cli/args.test.ts @@ -81,6 +81,12 @@ describe('check', () => { ); }); + it('raises an exception if ignoreProjects is not provided any project names', () => { + expect(() => check(argv({ignoreProjects: []}))).toThrow( + 'The --ignoreProjects option requires the name of at least one project to be specified.\n', + ); + }); + it('raises an exception if config is not a valid JSON string', () => { expect(() => check(argv({config: 'x:1'}))).toThrow( 'The --config option requires a JSON string literal, or a file path with one of these extensions: .js, .ts, .mjs, .cjs, .json', diff --git a/packages/jest-cli/src/cli/args.ts b/packages/jest-cli/src/cli/args.ts index 289c737dd8fe..2a1b1797db6f 100644 --- a/packages/jest-cli/src/cli/args.ts +++ b/packages/jest-cli/src/cli/args.ts @@ -5,6 +5,7 @@ * LICENSE file in the root directory of this source tree. */ +import type {Options} from 'yargs'; import type {Config} from '@jest/types'; import {constants, isJSONString} from 'jest-config'; @@ -68,6 +69,13 @@ export function check(argv: Config.Argv): true { ); } + if (argv.ignoreProjects && argv.ignoreProjects.length === 0) { + throw new Error( + 'The --ignoreProjects option requires the name of at least one project to be specified.\n' + + 'Example usage: jest --ignoreProjects my-first-project my-second-project', + ); + } + if ( argv.config && !isJSONString(argv.config) && @@ -95,7 +103,7 @@ export const usage = export const docs = 'Documentation: https://jestjs.io/'; // The default values are all set in jest-config -export const options = { +export const options: {[key: string]: Options} = { all: { description: 'The opposite of `onlyChanged`. If `onlyChanged` is set by ' + @@ -301,6 +309,13 @@ export const options = { 'A JSON string with map of variables for the haste module system', type: 'string', }, + ignoreProjects: { + description: + 'Ignore the tests of the specified projects.' + + 'Jest uses the attribute `displayName` in the configuration to identify each project.', + string: true, + type: 'array', + }, init: { description: 'Generate a basic configuration file', type: 'boolean', @@ -502,7 +517,7 @@ export const options = { }, selectProjects: { description: - 'Run only the tests of the specified projects.' + + 'Run the tests of the specified projects.' + 'Jest uses the attribute `displayName` in the configuration to identify each project.', string: true, type: 'array', @@ -695,4 +710,4 @@ export const options = { '--no-watchman.', type: 'boolean', }, -} as const; +}; diff --git a/packages/jest-core/src/cli/index.ts b/packages/jest-core/src/cli/index.ts index 61bdb12d8d8f..b7727a263b93 100644 --- a/packages/jest-core/src/cli/index.ts +++ b/packages/jest-core/src/cli/index.ts @@ -71,17 +71,24 @@ export async function runCLI( exit(0); } - let configsOfProjectsToRun = configs; - if (argv.selectProjects) { - const namesMissingWarning = getProjectNamesMissingWarning(configs); + const configsOfProjectsToRun = getConfigsOfProjectsToRun(configs, { + ignoreProjects: argv.ignoreProjects, + selectProjects: argv.selectProjects, + }); + if (argv.selectProjects || argv.ignoreProjects) { + const namesMissingWarning = getProjectNamesMissingWarning(configs, { + ignoreProjects: argv.ignoreProjects, + selectProjects: argv.selectProjects, + }); if (namesMissingWarning) { outputStream.write(namesMissingWarning); } - configsOfProjectsToRun = getConfigsOfProjectsToRun( - argv.selectProjects, - configs, + outputStream.write( + getSelectProjectsMessage(configsOfProjectsToRun, { + ignoreProjects: argv.ignoreProjects, + selectProjects: argv.selectProjects, + }), ); - outputStream.write(getSelectProjectsMessage(configsOfProjectsToRun)); } await _run10000( diff --git a/packages/jest-core/src/getConfigsOfProjectsToRun.ts b/packages/jest-core/src/getConfigsOfProjectsToRun.ts index b8b8288ccc68..75542c3d2e7d 100644 --- a/packages/jest-core/src/getConfigsOfProjectsToRun.ts +++ b/packages/jest-core/src/getConfigsOfProjectsToRun.ts @@ -9,12 +9,38 @@ import type {Config} from '@jest/types'; import getProjectDisplayName from './getProjectDisplayName'; export default function getConfigsOfProjectsToRun( - namesOfProjectsToRun: Array, projectConfigs: Array, + opts: { + ignoreProjects: Array | undefined; + selectProjects: Array | undefined; + }, ): Array { - const setOfProjectsToRun = new Set(namesOfProjectsToRun); + const projectFilter = createProjectFilter(opts); return projectConfigs.filter(config => { const name = getProjectDisplayName(config); - return name && setOfProjectsToRun.has(name); + return projectFilter(name); }); } + +function createProjectFilter(opts: { + ignoreProjects: Array | undefined; + selectProjects: Array | undefined; +}) { + const {selectProjects, ignoreProjects} = opts; + + const always = () => true; + + const selected = selectProjects + ? (name: string | undefined) => name && selectProjects.includes(name) + : always; + + const notIgnore = ignoreProjects + ? (name: string | undefined) => !(name && ignoreProjects.includes(name)) + : always; + + function test(name: string | undefined) { + return selected(name) && notIgnore(name); + } + + return test; +} diff --git a/packages/jest-core/src/getProjectNamesMissingWarning.ts b/packages/jest-core/src/getProjectNamesMissingWarning.ts index 53f0543d1cc8..947955dfefcf 100644 --- a/packages/jest-core/src/getProjectNamesMissingWarning.ts +++ b/packages/jest-core/src/getProjectNamesMissingWarning.ts @@ -11,6 +11,10 @@ import getProjectDisplayName from './getProjectDisplayName'; export default function getProjectNamesMissingWarning( projectConfigs: Array, + opts: { + ignoreProjects: Array | undefined; + selectProjects: Array | undefined; + }, ): string | undefined { const numberOfProjectsWithoutAName = projectConfigs.filter( config => !getProjectDisplayName(config), @@ -18,8 +22,15 @@ export default function getProjectNamesMissingWarning( if (numberOfProjectsWithoutAName === 0) { return undefined; } + const args: Array = []; + if (opts.selectProjects) { + args.push('--selectProjects'); + } + if (opts.ignoreProjects) { + args.push('--ignoreProjects'); + } return chalk.yellow( - `You provided values for --selectProjects but ${ + `You provided values for ${args.join(' and ')} but ${ numberOfProjectsWithoutAName === 1 ? 'a project does not have a name' : `${numberOfProjectsWithoutAName} projects do not have a name` diff --git a/packages/jest-core/src/getSelectProjectsMessage.ts b/packages/jest-core/src/getSelectProjectsMessage.ts index 5d3fff3577b4..b8a3a9f40c88 100644 --- a/packages/jest-core/src/getSelectProjectsMessage.ts +++ b/packages/jest-core/src/getSelectProjectsMessage.ts @@ -11,24 +11,46 @@ import getProjectDisplayName from './getProjectDisplayName'; export default function getSelectProjectsMessage( projectConfigs: Array, + opts: { + ignoreProjects: Array | undefined; + selectProjects: Array | undefined; + }, ): string { if (projectConfigs.length === 0) { - return getNoSelectionWarning(); + return getNoSelectionWarning(opts); } return getProjectsRunningMessage(projectConfigs); } -function getNoSelectionWarning(): string { - return chalk.yellow( - 'You provided values for --selectProjects but no projects were found matching the selection.\n', - ); +function getNoSelectionWarning(opts: { + ignoreProjects: Array | undefined; + selectProjects: Array | undefined; +}): string { + if (opts.ignoreProjects && opts.selectProjects) { + return chalk.yellow( + 'You provided values for --selectProjects and --ignoreProjects, but no projects were found matching the selection.\n' + + 'Are you ignoring all the selected projects?\n', + ); + } else if (opts.ignoreProjects) { + return chalk.yellow( + 'You provided values for --ignoreProjects, but no projects were found matching the selection.\n' + + 'Are you ignoring all projects?\n', + ); + } else if (opts.selectProjects) { + return chalk.yellow( + 'You provided values for --selectProjects but no projects were found matching the selection.\n', + ); + } else { + return chalk.yellow('No projects were found.\n'); + } } function getProjectsRunningMessage( projectConfigs: Array, ): string { if (projectConfigs.length === 1) { - const name = getProjectDisplayName(projectConfigs[0]); + const name = + getProjectDisplayName(projectConfigs[0]) ?? ''; return `Running one project: ${chalk.bold(name)}\n`; } const projectsList = projectConfigs diff --git a/packages/jest-types/src/Config.ts b/packages/jest-types/src/Config.ts index 80243eb45512..d93d77c87b69 100644 --- a/packages/jest-types/src/Config.ts +++ b/packages/jest-types/src/Config.ts @@ -440,6 +440,7 @@ export type Argv = Arguments< globalSetup: string | null | undefined; globalTeardown: string | null | undefined; haste: string; + ignoreProjects: Array; init: boolean; injectGlobals: boolean; json: boolean; From b82fd89d16fdbe74d9bc80dd86ae4912966adc1d Mon Sep 17 00:00:00 2001 From: Muhammad Hammad <33136628+mhnaeem@users.noreply.github.com> Date: Mon, 4 Apr 2022 11:20:43 -0230 Subject: [PATCH 012/128] docs: add note about line discrepancies and returning source maps in code transformers (#12566) --- docs/CodeTransformation.md | 6 ++++++ website/versioned_docs/version-27.0/CodeTransformation.md | 6 ++++++ website/versioned_docs/version-27.1/CodeTransformation.md | 6 ++++++ website/versioned_docs/version-27.2/CodeTransformation.md | 6 ++++++ website/versioned_docs/version-27.4/CodeTransformation.md | 6 ++++++ website/versioned_docs/version-27.5/CodeTransformation.md | 6 ++++++ 6 files changed, 36 insertions(+) diff --git a/docs/CodeTransformation.md b/docs/CodeTransformation.md index 05ef21d770bb..2393fac9928e 100644 --- a/docs/CodeTransformation.md +++ b/docs/CodeTransformation.md @@ -123,6 +123,12 @@ Instead of having your custom transformer implement the `Transformer` interface Note that [ECMAScript module](ECMAScriptModules.md) support is indicated by the passed in `supports*` options. Specifically `supportsDynamicImport: true` means the transformer can return `import()` expressions, which is supported by both ESM and CJS. If `supportsStaticESM: true` it means top level `import` statements are supported and the code will be interpreted as ESM and not CJS. See [Node's docs](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs) for details on the differences. +:::tip + +Make sure `TransformedSource` contains a source map, so it is possible to report line information accurately in code coverage and test errors. Inline source maps also work but are slower. + +::: + ### Examples ### TypeScript with type checking diff --git a/website/versioned_docs/version-27.0/CodeTransformation.md b/website/versioned_docs/version-27.0/CodeTransformation.md index 3b1e0f8e3100..7189b6f98602 100644 --- a/website/versioned_docs/version-27.0/CodeTransformation.md +++ b/website/versioned_docs/version-27.0/CodeTransformation.md @@ -128,6 +128,12 @@ As can be seen, only `process` or `processAsync` is mandatory to implement, alth Note that [ECMAScript module](ECMAScriptModules.md) support is indicated by the passed in `supports*` options. Specifically `supportsDynamicImport: true` means the transformer can return `import()` expressions, which is supported by both ESM and CJS. If `supportsStaticESM: true` it means top level `import` statements are supported and the code will be interpreted as ESM and not CJS. See [Node's docs](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs) for details on the differences. +:::tip + +Make sure `TransformedSource` contains a source map, so it is possible to report line information accurately in code coverage and test errors. Inline source maps also work but are slower. + +::: + ### Examples ### TypeScript with type checking diff --git a/website/versioned_docs/version-27.1/CodeTransformation.md b/website/versioned_docs/version-27.1/CodeTransformation.md index 3b1e0f8e3100..7189b6f98602 100644 --- a/website/versioned_docs/version-27.1/CodeTransformation.md +++ b/website/versioned_docs/version-27.1/CodeTransformation.md @@ -128,6 +128,12 @@ As can be seen, only `process` or `processAsync` is mandatory to implement, alth Note that [ECMAScript module](ECMAScriptModules.md) support is indicated by the passed in `supports*` options. Specifically `supportsDynamicImport: true` means the transformer can return `import()` expressions, which is supported by both ESM and CJS. If `supportsStaticESM: true` it means top level `import` statements are supported and the code will be interpreted as ESM and not CJS. See [Node's docs](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs) for details on the differences. +:::tip + +Make sure `TransformedSource` contains a source map, so it is possible to report line information accurately in code coverage and test errors. Inline source maps also work but are slower. + +::: + ### Examples ### TypeScript with type checking diff --git a/website/versioned_docs/version-27.2/CodeTransformation.md b/website/versioned_docs/version-27.2/CodeTransformation.md index 3b1e0f8e3100..7189b6f98602 100644 --- a/website/versioned_docs/version-27.2/CodeTransformation.md +++ b/website/versioned_docs/version-27.2/CodeTransformation.md @@ -128,6 +128,12 @@ As can be seen, only `process` or `processAsync` is mandatory to implement, alth Note that [ECMAScript module](ECMAScriptModules.md) support is indicated by the passed in `supports*` options. Specifically `supportsDynamicImport: true` means the transformer can return `import()` expressions, which is supported by both ESM and CJS. If `supportsStaticESM: true` it means top level `import` statements are supported and the code will be interpreted as ESM and not CJS. See [Node's docs](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs) for details on the differences. +:::tip + +Make sure `TransformedSource` contains a source map, so it is possible to report line information accurately in code coverage and test errors. Inline source maps also work but are slower. + +::: + ### Examples ### TypeScript with type checking diff --git a/website/versioned_docs/version-27.4/CodeTransformation.md b/website/versioned_docs/version-27.4/CodeTransformation.md index 3b1e0f8e3100..7189b6f98602 100644 --- a/website/versioned_docs/version-27.4/CodeTransformation.md +++ b/website/versioned_docs/version-27.4/CodeTransformation.md @@ -128,6 +128,12 @@ As can be seen, only `process` or `processAsync` is mandatory to implement, alth Note that [ECMAScript module](ECMAScriptModules.md) support is indicated by the passed in `supports*` options. Specifically `supportsDynamicImport: true` means the transformer can return `import()` expressions, which is supported by both ESM and CJS. If `supportsStaticESM: true` it means top level `import` statements are supported and the code will be interpreted as ESM and not CJS. See [Node's docs](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs) for details on the differences. +:::tip + +Make sure `TransformedSource` contains a source map, so it is possible to report line information accurately in code coverage and test errors. Inline source maps also work but are slower. + +::: + ### Examples ### TypeScript with type checking diff --git a/website/versioned_docs/version-27.5/CodeTransformation.md b/website/versioned_docs/version-27.5/CodeTransformation.md index 3b1e0f8e3100..7189b6f98602 100644 --- a/website/versioned_docs/version-27.5/CodeTransformation.md +++ b/website/versioned_docs/version-27.5/CodeTransformation.md @@ -128,6 +128,12 @@ As can be seen, only `process` or `processAsync` is mandatory to implement, alth Note that [ECMAScript module](ECMAScriptModules.md) support is indicated by the passed in `supports*` options. Specifically `supportsDynamicImport: true` means the transformer can return `import()` expressions, which is supported by both ESM and CJS. If `supportsStaticESM: true` it means top level `import` statements are supported and the code will be interpreted as ESM and not CJS. See [Node's docs](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs) for details on the differences. +:::tip + +Make sure `TransformedSource` contains a source map, so it is possible to report line information accurately in code coverage and test errors. Inline source maps also work but are slower. + +::: + ### Examples ### TypeScript with type checking From c7b15385a67c4380af9eea83638f8203b8472225 Mon Sep 17 00:00:00 2001 From: Araxeus Date: Mon, 4 Apr 2022 22:07:47 +0300 Subject: [PATCH 013/128] fix(jest-environment-node): Add `structuredClone` to globals (#12631) --- CHANGELOG.md | 3 ++- packages/jest-environment-node/src/index.ts | 6 ++++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e4f92643ebbd..af484a94a4f1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -59,7 +59,8 @@ - `[jest-each]` `%#` is not replaced with index of the test case ([#12517](https://github.com/facebook/jest/pull/12517)) - `[jest-environment-jsdom]` Make `jsdom` accessible to extending environments again ([#12232](https://github.com/facebook/jest/pull/12232)) - `[jest-environment-jsdom]` Log JSDOM errors more cleanly ([#12386](https://github.com/facebook/jest/pull/12386)) -- `[jest-environment-node]` Add MessageChannel, MessageEvent to globals ([#12553](https://github.com/facebook/jest/pull/12553)) +- `[jest-environment-node]` Add `MessageChannel`, `MessageEvent` to globals ([#12553](https://github.com/facebook/jest/pull/12553)) +- `[jest-environment-node]` Add `structuredClone` to globals ([#12631](https://github.com/facebook/jest/pull/12631)) - `[@jest/expect-utils]` [**BREAKING**] Fix false positives when looking for `undefined` prop ([#8923](https://github.com/facebook/jest/pull/8923)) - `[jest-haste-map]` Don't use partial results if file crawl errors ([#12420](https://github.com/facebook/jest/pull/12420)) - `[jest-jasmine2, jest-types]` [**BREAKING**] Move all `jasmine` specific types from `@jest/types` to its own package ([#12125](https://github.com/facebook/jest/pull/12125)) diff --git a/packages/jest-environment-node/src/index.ts b/packages/jest-environment-node/src/index.ts index bd9718943383..f6f8576bd6e6 100644 --- a/packages/jest-environment-node/src/index.ts +++ b/packages/jest-environment-node/src/index.ts @@ -95,6 +95,12 @@ export default class NodeEnvironment implements JestEnvironment { global.atob = atob; global.btoa = btoa; } + // structuredClone is global in Node >= 17 + // @ts-expect-error type definition for structuredClone is missing + if (typeof structuredClone !== 'undefined') { + // @ts-expect-error type definition for structuredClone is missing + global.structuredClone = structuredClone; + } installCommonGlobals(global, projectConfig.globals); this.moduleMocker = new ModuleMocker(global); From 8aac27bc7f61ca8e8b096ff5dac22a6d9b56ae20 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Tue, 5 Apr 2022 17:48:15 +0300 Subject: [PATCH 014/128] feat(fake-timers)!: allow `jest.useFakeTimers()` and `projectConfig.fakeTimers` to take an options bag (#12572) --- CHANGELOG.md | 3 + docs/Configuration.md | 110 ++++++++++- docs/JestObjectAPI.md | 127 +++++++++++- docs/TimerMocks.md | 80 ++++---- .../__snapshots__/showConfig.test.ts.snap | 4 +- e2e/__tests__/fakeTimers.test.ts | 32 +++- e2e/__tests__/fakeTimersLegacy.test.ts | 15 +- e2e/fake-promises/asap/package.json | 7 +- e2e/fake-promises/immediate/package.json | 7 +- .../__tests__/enableGlobally.test.js | 8 +- .../enable-globally/package.json | 5 +- .../__tests__/legacyFakeTimers.test.js | 28 +++ .../enable-legacy-fake-timers/package.json | 8 + .../__tests__/requestAnimationFrame.test.js | 5 +- .../reset-all-mocks/package.json | 6 +- .../{resetMock.test.js => resetMocks.test.js} | 1 - .../reset-mocks/package.json | 7 +- .../set-immediate/package.json | 5 +- .../__tests__/useFakeTimers.test.js | 6 +- .../__tests__/useFakeTimers.test.js | 18 ++ .../use-legacy-fake-timers/package.json | 3 + .../use-real-timers/package.json | 5 +- .../__tests__/advanceTimers.test.js | 43 +++++ e2e/fake-timers/advance-timers/package.json | 3 + .../__tests__/clearRealTimers.test.js | 18 ++ .../clear-real-timers/package.json | 3 + .../do-not-fake/__tests__/doNotFake.test.js | 25 +++ e2e/fake-timers/do-not-fake/package.json | 6 + .../__tests__/enableGlobally.test.js | 2 +- e2e/fake-timers/enable-globally/package.json | 4 +- .../__tests__/requestAnimationFrame.test.js | 3 +- e2e/fake-timers/set-immediate/package.json | 4 +- .../timer-limit/__tests__/timerLimit.test.js | 50 +++++ e2e/fake-timers/timer-limit/package.json | 9 + .../__tests__/useFakeTimers.test.js | 4 +- e2e/fake-timers/use-real-timers/package.json | 4 +- .../legacy-code-todo-rewrite/jestAdapter.ts | 17 +- packages/jest-cli/src/cli/args.ts | 6 - .../__tests__/__snapshots__/init.test.js.snap | 8 +- packages/jest-config/src/Defaults.ts | 2 +- packages/jest-config/src/Deprecated.ts | 6 + packages/jest-config/src/Descriptions.ts | 3 +- packages/jest-config/src/ValidConfig.ts | 25 ++- .../__snapshots__/normalize.test.ts.snap | 24 +++ .../src/__tests__/normalize.test.ts | 18 ++ packages/jest-config/src/index.ts | 2 +- packages/jest-config/src/normalize.ts | 2 +- .../logDebugMessages.test.ts.snap | 4 +- packages/jest-environment/src/index.ts | 21 +- packages/jest-fake-timers/package.json | 3 +- .../legacyFakeTimers.test.ts.snap | 6 +- .../modernFakeTimers.test.ts.snap | 2 +- .../src/__tests__/modernFakeTimers.test.ts | 100 +++++----- .../src/__tests__/sinon-integration.test.ts | 181 ++++++++++++++++++ .../jest-fake-timers/src/legacyFakeTimers.ts | 19 +- .../jest-fake-timers/src/modernFakeTimers.ts | 72 ++++--- packages/jest-fake-timers/tsconfig.json | 3 +- packages/jest-jasmine2/src/index.ts | 15 +- packages/jest-runtime/src/index.ts | 23 ++- .../ScriptTransformer.test.ts.snap | 28 +-- .../jest-types/__typetests__/config.test.ts | 80 +++++++- .../jest-types/__typetests__/jest.test.ts | 53 ++++- packages/jest-types/src/Config.ts | 96 +++++++++- .../src/__tests__/fixtures/jestConfig.ts | 4 +- .../workers/__tests__/processChild.test.js | 2 - .../src/workers/__tests__/threadChild.test.js | 2 - packages/test-utils/src/config.ts | 2 +- yarn.lock | 11 +- 68 files changed, 1250 insertions(+), 258 deletions(-) create mode 100644 e2e/fake-timers-legacy/enable-legacy-fake-timers/__tests__/legacyFakeTimers.test.js create mode 100644 e2e/fake-timers-legacy/enable-legacy-fake-timers/package.json rename e2e/fake-timers-legacy/reset-mocks/__tests__/{resetMock.test.js => resetMocks.test.js} (94%) create mode 100644 e2e/fake-timers-legacy/use-legacy-fake-timers/__tests__/useFakeTimers.test.js create mode 100644 e2e/fake-timers-legacy/use-legacy-fake-timers/package.json create mode 100644 e2e/fake-timers/advance-timers/__tests__/advanceTimers.test.js create mode 100644 e2e/fake-timers/advance-timers/package.json create mode 100644 e2e/fake-timers/clear-real-timers/__tests__/clearRealTimers.test.js create mode 100644 e2e/fake-timers/clear-real-timers/package.json create mode 100644 e2e/fake-timers/do-not-fake/__tests__/doNotFake.test.js create mode 100644 e2e/fake-timers/do-not-fake/package.json create mode 100644 e2e/fake-timers/timer-limit/__tests__/timerLimit.test.js create mode 100644 e2e/fake-timers/timer-limit/package.json create mode 100644 packages/jest-fake-timers/src/__tests__/sinon-integration.test.ts diff --git a/CHANGELOG.md b/CHANGELOG.md index af484a94a4f1..ce5503c5fcf3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,7 @@ - `[jest-circus, jest-jasmine2]` Allowed classes and functions as `describe` and `it`/`test` names ([#12484](https://github.com/facebook/jest/pull/12484)) - `[jest-cli, jest-config]` [**BREAKING**] Remove `testURL` config, use `testEnvironmentOptions.url` instead ([#10797](https://github.com/facebook/jest/pull/10797)) - `[jest-cli, jest-core]` Add `--shard` parameter for distributed parallel test execution ([#12546](https://github.com/facebook/jest/pull/12546)) +- `[jest-cli]` [**BREAKING**] Remove undocumented `--timers` option ([#12572](https://github.com/facebook/jest/pull/12572)) - `[jest-config]` [**BREAKING**] Stop shipping `jest-environment-jsdom` by default ([#12354](https://github.com/facebook/jest/pull/12354)) - `[jest-config]` [**BREAKING**] Stop shipping `jest-jasmine2` by default ([#12355](https://github.com/facebook/jest/pull/12355)) - `[jest-config, @jest/types]` Add `ci` to `GlobalConfig` ([#12378](https://github.com/facebook/jest/pull/12378)) @@ -24,6 +25,8 @@ - `[jest-environment-node]` [**BREAKING**] Second argument `context` to constructor is mandatory ([#12469](https://github.com/facebook/jest/pull/12469)) - `[@jest/expect]` New module which extends `expect` with `jest-snapshot` matchers ([#12404](https://github.com/facebook/jest/pull/12404), [#12410](https://github.com/facebook/jest/pull/12410), [#12418](https://github.com/facebook/jest/pull/12418)) - `[@jest/expect-utils]` New module exporting utils for `expect` ([#12323](https://github.com/facebook/jest/pull/12323)) +- `[@jest/fake-timers]` [**BREAKING**] Rename `timers` configuration option to `fakeTimers` ([#12572](https://github.com/facebook/jest/pull/12572)) +- `[@jest/fake-timers]` [**BREAKING**] Allow `jest.useFakeTimers()` and `projectConfig.fakeTimers` to take an options bag ([#12572](https://github.com/facebook/jest/pull/12572)) - `[jest-haste-map]` [**BREAKING**] `HasteMap.create` now returns a promise ([#12008](https://github.com/facebook/jest/pull/12008)) - `[jest-haste-map]` Add support for `dependencyExtractor` written in ESM ([#12008](https://github.com/facebook/jest/pull/12008)) - `[jest-mock]` [**BREAKING**] Rename exported utility types `ClassLike`, `FunctionLike`, `ConstructorLikeKeys`, `MethodLikeKeys`, `PropertyLikeKeys`; remove exports of utility types `ArgumentsOf`, `ArgsType`, `ConstructorArgumentsOf` - TS builtin utility types `ConstructorParameters` and `Parameters` should be used instead ([#12435](https://github.com/facebook/jest/pull/12435), [#12489](https://github.com/facebook/jest/pull/12489)) diff --git a/docs/Configuration.md b/docs/Configuration.md index 74ab2248e05e..277cf0b8f990 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -395,6 +395,108 @@ Jest's ESM support is still experimental, see [its docs for more details](ECMASc } ``` +### `fakeTimers` \[object] + +Default: `{}` + +The fake timers may be useful when a piece of code sets a long timeout that we don't want to wait for in a test. For additional details see [Fake Timers guide](TimerMocks.md) and [API documentation](JestObjectAPI.md#fake-timers). + +This option provides the default configuration of fake timers for all tests. Calling `jest.useFakeTimers()` in a test file will use these options or will override them if a configuration object is passed. For example, you can tell Jest to keep the original implementation of `process.nextTick()` and adjust the limit of recursive timers that will be run: + +```json +{ + "fakeTimers": { + "doNotFake": ["nextTick"], + "timerLimit": 1000 + } +} +``` + +```js title="fakeTime.test.js" +// install fake timers for this file using the options from Jest configuration +jest.useFakeTimers(); + +test('increase the limit of recursive timers for this and following tests', () => { + jest.useFakeTimers({timerLimit: 5000}); + // ... +}); +``` + +:::tip + +Instead of including `jest.useFakeTimers()` in each test file, you can enable fake timers globally for all tests: + +```json +{ + "fakeTimers": { + "enableGlobally": true + } +} +``` + +::: + +Configuration options: + +```ts +type FakeableAPI = + | 'Date' + | 'hrtime' + | 'nextTick' + | 'performance' + | 'queueMicrotask' + | 'requestAnimationFrame' + | 'cancelAnimationFrame' + | 'requestIdleCallback' + | 'cancelIdleCallback' + | 'setImmediate' + | 'clearImmediate' + | 'setInterval' + | 'clearInterval' + | 'setTimeout' + | 'clearTimeout'; + +type ModernFakeTimersConfig = { + /** + * If set to `true` all timers will be advanced automatically by 20 milliseconds + * every 20 milliseconds. A custom time delta may be provided by passing a number. + * The default is `false`. + */ + advanceTimers?: boolean | number; + /** + * List of names of APIs that should not be faked. The default is `[]`, meaning + * all APIs are faked. + */ + doNotFake?: Array; + /** Whether fake timers should be enabled for all test files. The default is `false`. */ + enableGlobally?: boolean; + /** + * Use the old fake timers implementation instead of one backed by `@sinonjs/fake-timers`. + * The default is `false`. + */ + legacyFakeTimers?: boolean; + /** Sets current system time to be used by fake timers. The default is `Date.now()`. */ + now?: number; + /** Maximum number of recursive timers that will be run. The default is `100_000` timers. */ + timerLimit?: number; +}; +``` + +:::info Legacy Fake Timers + +For some reason you might have to use legacy implementation of fake timers. Here is how to enable it globally (additional options are not supported): + +```json +{ + "fakeTimers": { + "enableGlobally": true, + "legacyFakeTimers": true + } +} +``` + +::: + ### `forceCoverageMatch` \[array<string>] Default: `['']` @@ -1458,14 +1560,6 @@ Default: `5000` Default timeout of a test in milliseconds. -### `timers` \[string] - -Default: `real` - -Setting this value to `fake` or `modern` enables fake timers for all tests by default. Fake timers are useful when a piece of code sets a long timeout that we don't want to wait for in a test. You can learn more about fake timers [here](JestObjectAPI.md#jestusefaketimersimplementation-modern--legacy). - -If the value is `legacy`, the old implementation will be used as implementation instead of one backed by [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). - ### `transform` \[object<string, pathToTransformer | \[pathToTransformer, object]>] Default: `{"\\.[jt]sx?$": "babel-jest"}` diff --git a/docs/JestObjectAPI.md b/docs/JestObjectAPI.md index aff9a86b5ff6..23df34442ba0 100644 --- a/docs/JestObjectAPI.md +++ b/docs/JestObjectAPI.md @@ -628,19 +628,118 @@ test('direct', () => { }); ``` -## Mock Timers +## Fake Timers -### `jest.useFakeTimers(implementation?: 'modern' | 'legacy')` +### `jest.useFakeTimers(fakeTimersConfig?)` -Instructs Jest to use fake versions of the standard timer functions (`setTimeout`, `setInterval`, `clearTimeout`, `clearInterval`, `nextTick`, `setImmediate` and `clearImmediate` as well as `Date`). +Instructs Jest to use fake versions of the global date, performance, time and timer APIs. Fake timers implementation is backed by [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). -If you pass `'legacy'` as an argument, Jest's legacy implementation will be used rather than one based on [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). +Fake timers will swap out `Date`, `performance.now()`, `queueMicrotask()`, `setImmediate()`, `clearImmediate()`, `setInterval()`, `clearInterval()`, `setTimeout()`, `clearTimeout()` with an implementation that gets its time from the fake clock. + +In Node environment `process.hrtime`, `process.nextTick()` and in JSDOM environment `requestAnimationFrame()`, `cancelAnimationFrame()`, `requestIdleCallback()`, `cancelIdleCallback()` will be replaced as well. + +Configuration options: + +```ts +type FakeableAPI = + | 'Date' + | 'hrtime' + | 'nextTick' + | 'performance' + | 'queueMicrotask' + | 'requestAnimationFrame' + | 'cancelAnimationFrame' + | 'requestIdleCallback' + | 'cancelIdleCallback' + | 'setImmediate' + | 'clearImmediate' + | 'setInterval' + | 'clearInterval' + | 'setTimeout' + | 'clearTimeout'; + +type FakeTimersConfig = { + /** + * If set to `true` all timers will be advanced automatically by 20 milliseconds + * every 20 milliseconds. A custom time delta may be provided by passing a number. + * The default is `false`. + */ + advanceTimers?: boolean | number; + /** + * List of names of APIs that should not be faked. The default is `[]`, meaning + * all APIs are faked. + */ + doNotFake?: Array; + /** + * Use the old fake timers implementation instead of one backed by `@sinonjs/fake-timers`. + * The default is `false`. + */ + legacyFakeTimers?: boolean; + /** Sets current system time to be used by fake timers. The default is `Date.now()`. */ + now?: number | Date; + /** + * The maximum number of recursive timers that will be run when calling `jest.runAllTimers()`. + * The default is `100_000` timers. + */ + timerLimit?: number; +}; +``` + +Calling `jest.useFakeTimers()` will use fake timers for all tests within the file, until original timers are restored with `jest.useRealTimers()`. + +You can call `jest.useFakeTimers()` or `jest.useRealTimers()` from anywhere: top level, inside an `test` block, etc. Keep in mind that this is a **global operation** and will affect other tests within the same file. Calling `jest.useFakeTimers()` once again in the same test file would reset the internal state (e.g. timer count) and reinstall fake timers using the provided options: + +```js +test('advance the timers automatically', () => { + jest.useFakeTimers({advanceTimers: true}); + // ... +}); + +test('do not advance the timers and do not fake `performance`', () => { + jest.useFakeTimers({doNotFake: ['performance']}); + // ... +}); + +test('uninstall fake timers for the rest of tests in the file', () => { + jest.useRealTimers(); + // ... +}); +``` + +:::info Legacy Fake Timers + +For some reason you might have to use legacy implementation of fake timers. It can be enabled like this (additional options are not supported): + +```js +jest.useFakeTimers({ + legacyFakeTimers: true, +}); +``` + +Legacy fake timers will swap out `setImmediate()`, `clearImmediate()`, `setInterval()`, `clearInterval()`, `setTimeout()`, `clearTimeout()` with Jest [mock functions](MockFunctionAPI.md). In Node environment `process.nextTick()` and in JSDOM environment `requestAnimationFrame()`, `cancelAnimationFrame()` will be also replaced. + +::: Returns the `jest` object for chaining. ### `jest.useRealTimers()` -Instructs Jest to use the real versions of the standard timer functions. +Instructs Jest to restore the original implementations of the global date, performance, time and timer APIs. For example, you may call `jest.useRealTimers()` inside `afterEach` hook to restore timers after each test: + +```js +afterEach(() => { + jest.useRealTimers(); +}); + +test('do something with fake timers', () => { + jest.useFakeTimers(); + // ... +}); + +test('do something with real timers', () => { + // ... +}); +``` Returns the `jest` object for chaining. @@ -662,7 +761,11 @@ This is often useful for synchronously executing setTimeouts during a test in or Exhausts all tasks queued by `setImmediate()`. -> Note: This function is not available when using modern fake timers implementation +:::info + +This function is only available when using legacy fake timers implementation. + +::: ### `jest.advanceTimersByTime(msToRun)` @@ -696,13 +799,21 @@ Returns the number of fake timers still left to run. Set the current system time used by fake timers. Simulates a user changing the system clock while your program is running. It affects the current time but it does not in itself cause e.g. timers to fire; they will fire exactly as they would have done without the call to `jest.setSystemTime()`. -> Note: This function is only available when using modern fake timers implementation +:::info + +This function is not available when using legacy fake timers implementation. + +::: ### `jest.getRealSystemTime()` When mocking time, `Date.now()` will also be mocked. If you for some reason need access to the real current time, you can invoke this function. -> Note: This function is only available when using modern fake timers implementation +:::info + +This function is not available when using legacy fake timers implementation. + +::: ## Misc diff --git a/docs/TimerMocks.md b/docs/TimerMocks.md index 6f811abee6b4..1e0260c7def6 100644 --- a/docs/TimerMocks.md +++ b/docs/TimerMocks.md @@ -3,11 +3,19 @@ id: timer-mocks title: Timer Mocks --- -The native timer functions (i.e., `setTimeout`, `setInterval`, `clearTimeout`, `clearInterval`) are less than ideal for a testing environment since they depend on real time to elapse. Jest can swap out timers with functions that allow you to control the passage of time. [Great Scott!](https://www.youtube.com/watch?v=QZoJ2Pt27BY) +The native timer functions (i.e., `setTimeout()`, `setInterval()`, `clearTimeout()`, `clearInterval()`) are less than ideal for a testing environment since they depend on real time to elapse. Jest can swap out timers with functions that allow you to control the passage of time. [Great Scott!](https://www.youtube.com/watch?v=QZoJ2Pt27BY) -```javascript title="timerGame.js" -'use strict'; +:::info + +Also see [Fake Timers API](JestObjectAPI.md#fake-timers) documentation. + +::: + +## Enable Fake Timers + +In the following example we enable fake timers by calling `jest.useFakeTimers()`. This is replacing the original implementation of `setTimeout()` and other timer functions. Timers can be restored to their normal behavior with `jest.useRealTimers()`. +```javascript title="timerGame.js" function timerGame(callback) { console.log('Ready....go!'); setTimeout(() => { @@ -20,8 +28,6 @@ module.exports = timerGame; ``` ```javascript title="__tests__/timerGame-test.js" -'use strict'; - jest.useFakeTimers(); jest.spyOn(global, 'setTimeout'); @@ -34,27 +40,6 @@ test('waits 1 second before ending the game', () => { }); ``` -Here we enable fake timers by calling `jest.useFakeTimers()`. This mocks out `setTimeout` and other timer functions with mock functions. Timers can be restored to their normal behavior with `jest.useRealTimers()`. - -While you can call `jest.useFakeTimers()` or `jest.useRealTimers()` from anywhere (top level, inside an `it` block, etc.), it is a **global operation** and will affect other tests within the same file. Additionally, you need to call `jest.useFakeTimers()` to reset internal counters before each test. If you plan to not use fake timers in all your tests, you will want to clean up manually, as otherwise the faked timers will leak across tests: - -```javascript -afterEach(() => { - jest.useRealTimers(); -}); - -test('do something with fake timers', () => { - jest.useFakeTimers(); - // ... -}); - -test('do something with real timers', () => { - // ... -}); -``` - -Currently, two implementations of the fake timers are included - `modern` and `legacy`, where `modern` is the default one. See [configuration](Configuration.md#timers-string) for how to configure it. - ## Run All Timers Another test we might want to write for this module is one that asserts that the callback is called after 1 second. To do this, we're going to use Jest's timer control APIs to fast-forward time right in the middle of the test: @@ -81,17 +66,11 @@ test('calls the callback after 1 second', () => { ## Run Pending Timers -There are also scenarios where you might have a recursive timer -- that is a timer that sets a new timer in its own callback. For these, running all the timers would be an endless loop, throwing the following error: +There are also scenarios where you might have a recursive timer – that is a timer that sets a new timer in its own callback. For these, running all the timers would be an endless loop, throwing the following error: "Aborting after running 100000 timers, assuming an infinite loop!" -``` -Ran 100000 timers, and there are still more! Assuming we've hit an infinite recursion and bailing out... -``` - -So something like `jest.runAllTimers()` is not desirable. For these cases you might use `jest.runOnlyPendingTimers()`: +If that is your case, using `jest.runOnlyPendingTimers()` will solve the problem: ```javascript title="infiniteTimerGame.js" -'use strict'; - function infiniteTimerGame(callback) { console.log('Ready....go!'); @@ -110,8 +89,6 @@ module.exports = infiniteTimerGame; ``` ```javascript title="__tests__/infiniteTimerGame-test.js" -'use strict'; - jest.useFakeTimers(); jest.spyOn(global, 'setTimeout'); @@ -142,13 +119,21 @@ describe('infiniteTimerGame', () => { }); ``` +:::note + +For debugging or any other reason you can change the limit of timers that will be run before throwing an error: + +```js +jest.useFakeTimers({timerLimit: 100}); +``` + +::: + ## Advance Timers by Time Another possibility is use `jest.advanceTimersByTime(msToRun)`. When this API is called, all timers are advanced by `msToRun` milliseconds. All pending "macro-tasks" that have been queued via setTimeout() or setInterval(), and would be executed during this time frame, will be executed. Additionally, if those macro-tasks schedule new macro-tasks that would be executed within the same time frame, those will be executed until there are no more macro-tasks remaining in the queue that should be run within msToRun milliseconds. ```javascript title="timerGame.js" -'use strict'; - function timerGame(callback) { console.log('Ready....go!'); setTimeout(() => { @@ -182,4 +167,21 @@ it('calls the callback after 1 second via advanceTimersByTime', () => { Lastly, it may occasionally be useful in some tests to be able to clear all of the pending timers. For this, we have `jest.clearAllTimers()`. -The code for this example is available at [examples/timer](https://github.com/facebook/jest/tree/main/examples/timer). +## Selective Faking + +Sometimes your code may require to avoid overwriting the original implementation of one or another API. If that is the case, you can use `doNotFake` option. For example, here is how you could provide a custom mock function for `performance.mark()` in jsdom environment: + +```js +/** + * @jest-environment jsdom + */ + +const mockPerformanceMark = jest.fn(); +window.performance.mark = mockPerformanceMark; + +test('allows mocking `performance.mark()`', () => { + jest.useFakeTimers({doNotFake: ['performance']}); + + expect(window.performance.mark).toBe(mockPerformanceMark); +}); +``` diff --git a/e2e/__tests__/__snapshots__/showConfig.test.ts.snap b/e2e/__tests__/__snapshots__/showConfig.test.ts.snap index cd1ac20b6546..dd05871f8ae6 100644 --- a/e2e/__tests__/__snapshots__/showConfig.test.ts.snap +++ b/e2e/__tests__/__snapshots__/showConfig.test.ts.snap @@ -16,6 +16,9 @@ exports[`--showConfig outputs config info and exits 1`] = ` "detectOpenHandles": false, "errorOnDeprecated": false, "extensionsToTreatAsEsm": [], + "fakeTimers": { + "enableGlobally": false + }, "forceCoverageMatch": [], "globals": {}, "haste": { @@ -68,7 +71,6 @@ exports[`--showConfig outputs config info and exits 1`] = ` ], "testRegex": [], "testRunner": "<>/jest-circus/runner.js", - "timers": "real", "transform": [ [ "\\\\.[jt]sx?$", diff --git a/e2e/__tests__/fakeTimers.test.ts b/e2e/__tests__/fakeTimers.test.ts index ce1afb178804..4adefe0f056c 100644 --- a/e2e/__tests__/fakeTimers.test.ts +++ b/e2e/__tests__/fakeTimers.test.ts @@ -19,13 +19,24 @@ describe('useFakeTimers', () => { const result = runJest('fake-timers/use-fake-timers'); expect(result.exitCode).toBe(0); }); -}); -describe('requestAnimationFrame', () => { - test('fakes requestAnimationFrame', () => { - const result = runJest('fake-timers/request-animation-frame'); + test('allows to pass advanceTimers option', () => { + const result = runJest('fake-timers/advance-timers'); + expect(result.exitCode).toBe(0); + }); - expect(result.stderr).toMatch('requestAnimationFrame test'); + test('allows to pass doNotFake option', () => { + const result = runJest('fake-timers/do-not-fake'); + expect(result.exitCode).toBe(0); + }); + + test('allows to pass timerLimit option', () => { + const result = runJest('fake-timers/timer-limit'); + expect(result.exitCode).toBe(0); + }); + + test('allows clearing not faked timers', () => { + const result = runJest('fake-timers/clear-real-timers'); expect(result.exitCode).toBe(0); }); }); @@ -39,10 +50,19 @@ describe('setImmediate', () => { }); }); +describe('requestAnimationFrame', () => { + test('fakes requestAnimationFrame', () => { + const result = runJest('fake-timers/request-animation-frame'); + + expect(result.stderr).toMatch('requestAnimationFrame test'); + expect(result.exitCode).toBe(0); + }); +}); + describe('useRealTimers', () => { test('restores timers to the native implementation', () => { const result = runJest('fake-timers/use-real-timers'); - expect(result.stdout).toMatch('API is not mocked with fake timers.'); + expect(result.stdout).toMatch('APIs are not replaced with fake timers.'); expect(result.exitCode).toBe(0); }); }); diff --git a/e2e/__tests__/fakeTimersLegacy.test.ts b/e2e/__tests__/fakeTimersLegacy.test.ts index dbc612382ba3..52571da9d4d0 100644 --- a/e2e/__tests__/fakeTimersLegacy.test.ts +++ b/e2e/__tests__/fakeTimersLegacy.test.ts @@ -8,15 +8,22 @@ import runJest from '../runJest'; describe('enableGlobally', () => { - test('enables fake timers from Jest config', () => { + test('enables legacy fake timers from Jest config', () => { const result = runJest('fake-timers-legacy/enable-globally'); expect(result.exitCode).toBe(0); }); }); +describe('legacyFakeTimers', () => { + test('toggles legacy fake timers from Jest config', () => { + const result = runJest('fake-timers-legacy/enable-legacy-fake-timers'); + expect(result.exitCode).toBe(0); + }); +}); + describe('useFakeTimers', () => { - test('enables fake timers from Jest object', () => { - const result = runJest('fake-timers-legacy/use-fake-timers'); + test('enables legacy fake timers from Jest object', () => { + const result = runJest('fake-timers-legacy/use-legacy-fake-timers'); expect(result.exitCode).toBe(0); }); }); @@ -42,7 +49,7 @@ describe('setImmediate', () => { describe('useRealTimers', () => { test('restores timers to the native implementation', () => { const result = runJest('fake-timers-legacy/use-real-timers'); - expect(result.stdout).toMatch('API is not mocked with fake timers.'); + expect(result.stdout).toMatch('APIs are not mocked with fake timers.'); expect(result.exitCode).toBe(0); }); }); diff --git a/e2e/fake-promises/asap/package.json b/e2e/fake-promises/asap/package.json index 0f50640514e1..b873db8ccbb8 100644 --- a/e2e/fake-promises/asap/package.json +++ b/e2e/fake-promises/asap/package.json @@ -1,9 +1,10 @@ { "jest": { - "timers": "fake", + "fakeTimers": { + "enableGlobally": true + }, "setupFiles": [ "/fake-promises" - ], - "testEnvironment": "node" + ] } } diff --git a/e2e/fake-promises/immediate/package.json b/e2e/fake-promises/immediate/package.json index 0f50640514e1..b873db8ccbb8 100644 --- a/e2e/fake-promises/immediate/package.json +++ b/e2e/fake-promises/immediate/package.json @@ -1,9 +1,10 @@ { "jest": { - "timers": "fake", + "fakeTimers": { + "enableGlobally": true + }, "setupFiles": [ "/fake-promises" - ], - "testEnvironment": "node" + ] } } diff --git a/e2e/fake-timers-legacy/enable-globally/__tests__/enableGlobally.test.js b/e2e/fake-timers-legacy/enable-globally/__tests__/enableGlobally.test.js index c02789c9bd43..674b8cb3810c 100644 --- a/e2e/fake-timers-legacy/enable-globally/__tests__/enableGlobally.test.js +++ b/e2e/fake-timers-legacy/enable-globally/__tests__/enableGlobally.test.js @@ -9,12 +9,6 @@ test('getRealSystemTime', () => { expect(() => jest.getRealSystemTime()).toThrow( - 'getRealSystemTime is not available when not using modern timers', - ); -}); - -test('setSystemTime', () => { - expect(() => jest.setSystemTime(0)).toThrow( - 'setSystemTime is not available when not using modern timers', + '`jest.getRealSystemTime()` is not available when using legacy fake timers.', ); }); diff --git a/e2e/fake-timers-legacy/enable-globally/package.json b/e2e/fake-timers-legacy/enable-globally/package.json index ad49f336e7a7..3cd8baba5623 100644 --- a/e2e/fake-timers-legacy/enable-globally/package.json +++ b/e2e/fake-timers-legacy/enable-globally/package.json @@ -1,6 +1,9 @@ { "name": "enable-globally-legacy", "jest": { - "timers": "legacy" + "fakeTimers": { + "enableGlobally": true, + "legacyFakeTimers": true + } } } diff --git a/e2e/fake-timers-legacy/enable-legacy-fake-timers/__tests__/legacyFakeTimers.test.js b/e2e/fake-timers-legacy/enable-legacy-fake-timers/__tests__/legacyFakeTimers.test.js new file mode 100644 index 000000000000..c781899e02dc --- /dev/null +++ b/e2e/fake-timers-legacy/enable-legacy-fake-timers/__tests__/legacyFakeTimers.test.js @@ -0,0 +1,28 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +'use strict'; + +test('fake timers', () => { + jest.useFakeTimers(); + const f = jest.fn(); + setTimeout(f, 0); + jest.runAllTimers(); + expect(f).toHaveBeenCalledTimes(1); +}); + +test('getRealSystemTime', () => { + expect(() => jest.getRealSystemTime()).toThrow( + '`jest.getRealSystemTime()` is not available when using legacy fake timers.', + ); +}); + +test('setSystemTime', () => { + expect(() => jest.setSystemTime(0)).toThrow( + '`jest.setSystemTime()` is not available when using legacy fake timers.', + ); +}); diff --git a/e2e/fake-timers-legacy/enable-legacy-fake-timers/package.json b/e2e/fake-timers-legacy/enable-legacy-fake-timers/package.json new file mode 100644 index 000000000000..9935c2240d23 --- /dev/null +++ b/e2e/fake-timers-legacy/enable-legacy-fake-timers/package.json @@ -0,0 +1,8 @@ +{ + "name": "enable-legacy-fake-timers", + "jest": { + "fakeTimers": { + "legacyFakeTimers": true + } + } +} diff --git a/e2e/fake-timers-legacy/request-animation-frame/__tests__/requestAnimationFrame.test.js b/e2e/fake-timers-legacy/request-animation-frame/__tests__/requestAnimationFrame.test.js index 502ce365a3c6..0dd9668303ea 100644 --- a/e2e/fake-timers-legacy/request-animation-frame/__tests__/requestAnimationFrame.test.js +++ b/e2e/fake-timers-legacy/request-animation-frame/__tests__/requestAnimationFrame.test.js @@ -10,7 +10,10 @@ 'use strict'; test('requestAnimationFrame test', () => { - jest.useFakeTimers('legacy'); + jest.useFakeTimers({ + legacyFakeTimers: true, + }); + let frameTimestamp = -1; requestAnimationFrame(timestamp => { frameTimestamp = timestamp; diff --git a/e2e/fake-timers-legacy/reset-all-mocks/package.json b/e2e/fake-timers-legacy/reset-all-mocks/package.json index 3d15b9a19778..9859a3b1aacb 100644 --- a/e2e/fake-timers-legacy/reset-all-mocks/package.json +++ b/e2e/fake-timers-legacy/reset-all-mocks/package.json @@ -1,7 +1,9 @@ { "name": "reset-all-mocks", "jest": { - "resetMocks": false, - "timers": "legacy" + "fakeTimers": { + "legacyFakeTimers": true + }, + "resetMocks": false } } diff --git a/e2e/fake-timers-legacy/reset-mocks/__tests__/resetMock.test.js b/e2e/fake-timers-legacy/reset-mocks/__tests__/resetMocks.test.js similarity index 94% rename from e2e/fake-timers-legacy/reset-mocks/__tests__/resetMock.test.js rename to e2e/fake-timers-legacy/reset-mocks/__tests__/resetMocks.test.js index 2710469e093e..05d594015029 100644 --- a/e2e/fake-timers-legacy/reset-mocks/__tests__/resetMock.test.js +++ b/e2e/fake-timers-legacy/reset-mocks/__tests__/resetMocks.test.js @@ -8,7 +8,6 @@ 'use strict'; test('works when resetMocks is set in Jest config', () => { - jest.useFakeTimers(); const f = jest.fn(); setTimeout(f, 0); jest.runAllTimers(); diff --git a/e2e/fake-timers-legacy/reset-mocks/package.json b/e2e/fake-timers-legacy/reset-mocks/package.json index 2a41b1e6782d..d999103bf1d1 100644 --- a/e2e/fake-timers-legacy/reset-mocks/package.json +++ b/e2e/fake-timers-legacy/reset-mocks/package.json @@ -1,7 +1,10 @@ { "name": "reset-mocks", "jest": { - "resetMocks": true, - "timers": "legacy" + "fakeTimers": { + "enableGlobally": true, + "legacyFakeTimers": true + }, + "resetMocks": true } } diff --git a/e2e/fake-timers-legacy/set-immediate/package.json b/e2e/fake-timers-legacy/set-immediate/package.json index 88cb67703874..d9c70d1fd4e5 100644 --- a/e2e/fake-timers-legacy/set-immediate/package.json +++ b/e2e/fake-timers-legacy/set-immediate/package.json @@ -1,6 +1,9 @@ { "name": "set-immediate-legacy", "jest": { - "timers": "legacy" + "fakeTimers": { + "enableGlobally": true, + "legacyFakeTimers": true + } } } diff --git a/e2e/fake-timers-legacy/use-fake-timers/__tests__/useFakeTimers.test.js b/e2e/fake-timers-legacy/use-fake-timers/__tests__/useFakeTimers.test.js index 982b23cbf809..843dace7b7af 100644 --- a/e2e/fake-timers-legacy/use-fake-timers/__tests__/useFakeTimers.test.js +++ b/e2e/fake-timers-legacy/use-fake-timers/__tests__/useFakeTimers.test.js @@ -8,9 +8,11 @@ 'use strict'; test('fake timers', () => { - jest.useFakeTimers('legacy'); + jest.useFakeTimers({ + legacyFakeTimers: true, + }); expect(() => jest.setSystemTime(0)).toThrow( - 'setSystemTime is not available when not using modern timers', + '`jest.setSystemTime()` is not available when using legacy fake timers.', ); }); diff --git a/e2e/fake-timers-legacy/use-legacy-fake-timers/__tests__/useFakeTimers.test.js b/e2e/fake-timers-legacy/use-legacy-fake-timers/__tests__/useFakeTimers.test.js new file mode 100644 index 000000000000..843dace7b7af --- /dev/null +++ b/e2e/fake-timers-legacy/use-legacy-fake-timers/__tests__/useFakeTimers.test.js @@ -0,0 +1,18 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +'use strict'; + +test('fake timers', () => { + jest.useFakeTimers({ + legacyFakeTimers: true, + }); + + expect(() => jest.setSystemTime(0)).toThrow( + '`jest.setSystemTime()` is not available when using legacy fake timers.', + ); +}); diff --git a/e2e/fake-timers-legacy/use-legacy-fake-timers/package.json b/e2e/fake-timers-legacy/use-legacy-fake-timers/package.json new file mode 100644 index 000000000000..2223ef489425 --- /dev/null +++ b/e2e/fake-timers-legacy/use-legacy-fake-timers/package.json @@ -0,0 +1,3 @@ +{ + "name": "use-legacy-fake-timers" +} diff --git a/e2e/fake-timers-legacy/use-real-timers/package.json b/e2e/fake-timers-legacy/use-real-timers/package.json index e0052f4b506f..9f83a4f4086f 100644 --- a/e2e/fake-timers-legacy/use-real-timers/package.json +++ b/e2e/fake-timers-legacy/use-real-timers/package.json @@ -1,6 +1,9 @@ { "name": "use-real-timers-legacy", "jest": { - "timers": "legacy" + "fakeTimers": { + "enableGlobally": true, + "legacyFakeTimers": true + } } } diff --git a/e2e/fake-timers/advance-timers/__tests__/advanceTimers.test.js b/e2e/fake-timers/advance-timers/__tests__/advanceTimers.test.js new file mode 100644 index 000000000000..c62b7cda7260 --- /dev/null +++ b/e2e/fake-timers/advance-timers/__tests__/advanceTimers.test.js @@ -0,0 +1,43 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +'use strict'; + +test('advances timers if true is passed', done => { + jest.useFakeTimers({advanceTimers: true}); + + const start = Date.now(); + + setTimeout(() => { + done(); + expect(Date.now() - start).toEqual(45); + }, 45); +}); + +test('advances timers if a number is passed', done => { + jest.useFakeTimers({advanceTimers: 40}); + + const start = Date.now(); + + setTimeout(() => { + done(); + expect(Date.now() - start).toEqual(35); + }, 35); +}); + +test('works with `now` option', done => { + jest.useFakeTimers({advanceTimers: 30, now: new Date('2015-09-25')}); + + expect(Date.now()).toEqual(1443139200000); + + const start = Date.now(); + + setTimeout(() => { + done(); + expect(Date.now() - start).toEqual(25); + }, 25); +}); diff --git a/e2e/fake-timers/advance-timers/package.json b/e2e/fake-timers/advance-timers/package.json new file mode 100644 index 000000000000..19979034fc88 --- /dev/null +++ b/e2e/fake-timers/advance-timers/package.json @@ -0,0 +1,3 @@ +{ + "name": "advance-timers" +} diff --git a/e2e/fake-timers/clear-real-timers/__tests__/clearRealTimers.test.js b/e2e/fake-timers/clear-real-timers/__tests__/clearRealTimers.test.js new file mode 100644 index 000000000000..0e5ebdc640a0 --- /dev/null +++ b/e2e/fake-timers/clear-real-timers/__tests__/clearRealTimers.test.js @@ -0,0 +1,18 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +'use strict'; + +test('allows clearing not faked timers', () => { + const timer = setTimeout(() => { + throw new Error('Should not throw'); + }, 1000); + + jest.useFakeTimers(); + + clearTimeout(timer); +}); diff --git a/e2e/fake-timers/clear-real-timers/package.json b/e2e/fake-timers/clear-real-timers/package.json new file mode 100644 index 000000000000..7c7d151e8229 --- /dev/null +++ b/e2e/fake-timers/clear-real-timers/package.json @@ -0,0 +1,3 @@ +{ + "name": "clear-real-timers" +} diff --git a/e2e/fake-timers/do-not-fake/__tests__/doNotFake.test.js b/e2e/fake-timers/do-not-fake/__tests__/doNotFake.test.js new file mode 100644 index 000000000000..8d4f5f149a78 --- /dev/null +++ b/e2e/fake-timers/do-not-fake/__tests__/doNotFake.test.js @@ -0,0 +1,25 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +/* global window */ + +'use strict'; + +const mockPerformanceMark = jest.fn(); +window.performance.mark = mockPerformanceMark; + +test('fakes all APIs', () => { + jest.useFakeTimers(); + + expect(window.performance.mark).toBeUndefined(); +}); + +test('does not fake `performance` instance', () => { + jest.useFakeTimers({doNotFake: ['performance']}); + + expect(window.performance.mark).toBe(mockPerformanceMark); +}); diff --git a/e2e/fake-timers/do-not-fake/package.json b/e2e/fake-timers/do-not-fake/package.json new file mode 100644 index 000000000000..eed48bf98af2 --- /dev/null +++ b/e2e/fake-timers/do-not-fake/package.json @@ -0,0 +1,6 @@ +{ + "name": "do-not-fake", + "jest": { + "testEnvironment": "jsdom" + } +} diff --git a/e2e/fake-timers/enable-globally/__tests__/enableGlobally.test.js b/e2e/fake-timers/enable-globally/__tests__/enableGlobally.test.js index 1d488f487a17..d5dbdc8878bd 100644 --- a/e2e/fake-timers/enable-globally/__tests__/enableGlobally.test.js +++ b/e2e/fake-timers/enable-globally/__tests__/enableGlobally.test.js @@ -29,6 +29,6 @@ test('fake timers with Date argument', () => { test('runAllImmediates', () => { expect(() => jest.runAllImmediates()).toThrow( - 'runAllImmediates is not available when using modern timers', + '`jest.runAllImmediates()` is only available when using legacy fake timers.', ); }); diff --git a/e2e/fake-timers/enable-globally/package.json b/e2e/fake-timers/enable-globally/package.json index 6bc480418b0d..8d75224d03c3 100644 --- a/e2e/fake-timers/enable-globally/package.json +++ b/e2e/fake-timers/enable-globally/package.json @@ -1,6 +1,8 @@ { "name": "enable-globally", "jest": { - "timers": "modern" + "fakeTimers": { + "enableGlobally": true + } } } diff --git a/e2e/fake-timers/request-animation-frame/__tests__/requestAnimationFrame.test.js b/e2e/fake-timers/request-animation-frame/__tests__/requestAnimationFrame.test.js index 6f4316230a0b..5548e95b0005 100644 --- a/e2e/fake-timers/request-animation-frame/__tests__/requestAnimationFrame.test.js +++ b/e2e/fake-timers/request-animation-frame/__tests__/requestAnimationFrame.test.js @@ -10,7 +10,8 @@ 'use strict'; test('requestAnimationFrame test', () => { - jest.useFakeTimers('modern'); + jest.useFakeTimers(); + let frameTimestamp = -1; requestAnimationFrame(timestamp => { frameTimestamp = timestamp; diff --git a/e2e/fake-timers/set-immediate/package.json b/e2e/fake-timers/set-immediate/package.json index b0c2eeea2314..2826715e9705 100644 --- a/e2e/fake-timers/set-immediate/package.json +++ b/e2e/fake-timers/set-immediate/package.json @@ -1,6 +1,8 @@ { "name": "set-immediate", "jest": { - "timers": "fake" + "fakeTimers": { + "enableGlobally": true + } } } diff --git a/e2e/fake-timers/timer-limit/__tests__/timerLimit.test.js b/e2e/fake-timers/timer-limit/__tests__/timerLimit.test.js new file mode 100644 index 000000000000..7f326e93f54c --- /dev/null +++ b/e2e/fake-timers/timer-limit/__tests__/timerLimit.test.js @@ -0,0 +1,50 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +'use strict'; + +test('reads timerLimit from Jest config', () => { + jest.useFakeTimers(); + + setTimeout(function infinitelyRecursingCallback() { + setTimeout(infinitelyRecursingCallback, 0); + }, 0); + + expect(() => { + jest.runAllTimers(); + }).toThrow( + new Error('Aborting after running 10 timers, assuming an infinite loop!'), + ); +}); + +test('allows to override timerLimit set via Jest config', () => { + jest.useFakeTimers({timerLimit: 100}); + + setTimeout(function infinitelyRecursingCallback() { + setTimeout(infinitelyRecursingCallback, 0); + }, 0); + + expect(() => { + jest.runAllTimers(); + }).toThrow( + new Error('Aborting after running 100 timers, assuming an infinite loop!'), + ); +}); + +test('allows to override timerLimit set via Jest object', () => { + jest.useFakeTimers({timerLimit: 1000}); + + setTimeout(function infinitelyRecursingCallback() { + setTimeout(infinitelyRecursingCallback, 0); + }, 0); + + expect(() => { + jest.runAllTimers(); + }).toThrow( + new Error('Aborting after running 1000 timers, assuming an infinite loop!'), + ); +}); diff --git a/e2e/fake-timers/timer-limit/package.json b/e2e/fake-timers/timer-limit/package.json new file mode 100644 index 000000000000..81b4c8e4fb99 --- /dev/null +++ b/e2e/fake-timers/timer-limit/package.json @@ -0,0 +1,9 @@ +{ + "name": "timer-limit", + "jest": { + "fakeTimers": { + "enableGlobally": true, + "timerLimit": 10 + } + } +} diff --git a/e2e/fake-timers/use-fake-timers/__tests__/useFakeTimers.test.js b/e2e/fake-timers/use-fake-timers/__tests__/useFakeTimers.test.js index 6fd28535c2bd..fd294d2323e3 100644 --- a/e2e/fake-timers/use-fake-timers/__tests__/useFakeTimers.test.js +++ b/e2e/fake-timers/use-fake-timers/__tests__/useFakeTimers.test.js @@ -8,7 +8,7 @@ 'use strict'; test('fake timers with number argument', () => { - jest.useFakeTimers('modern'); + jest.useFakeTimers(); jest.setSystemTime(0); @@ -20,7 +20,7 @@ test('fake timers with number argument', () => { }); test('fake timers with Date argument', () => { - jest.useFakeTimers('modern'); + jest.useFakeTimers(); jest.setSystemTime(new Date(0)); diff --git a/e2e/fake-timers/use-real-timers/package.json b/e2e/fake-timers/use-real-timers/package.json index 56af25025716..9e31cf9ea744 100644 --- a/e2e/fake-timers/use-real-timers/package.json +++ b/e2e/fake-timers/use-real-timers/package.json @@ -1,6 +1,8 @@ { "name": "use-real-timers", "jest": { - "timers": "fake" + "fakeTimers": { + "enableGlobally": true + } } } diff --git a/packages/jest-circus/src/legacy-code-todo-rewrite/jestAdapter.ts b/packages/jest-circus/src/legacy-code-todo-rewrite/jestAdapter.ts index dc8059b39acf..9df215a6d5b3 100644 --- a/packages/jest-circus/src/legacy-code-todo-rewrite/jestAdapter.ts +++ b/packages/jest-circus/src/legacy-code-todo-rewrite/jestAdapter.ts @@ -38,11 +38,13 @@ const jestAdapter = async ( testPath, }); - if (config.timers === 'fake' || config.timers === 'modern') { - // during setup, this cannot be null (and it's fine to explode if it is) - environment.fakeTimersModern!.useFakeTimers(); - } else if (config.timers === 'legacy') { - environment.fakeTimers!.useFakeTimers(); + if (config.fakeTimers.enableGlobally) { + if (config.fakeTimers.legacyFakeTimers) { + // during setup, this cannot be null (and it's fine to explode if it is) + environment.fakeTimers!.useFakeTimers(); + } else { + environment.fakeTimersModern!.useFakeTimers(); + } } globals.beforeEach(() => { @@ -57,7 +59,10 @@ const jestAdapter = async ( if (config.resetMocks) { runtime.resetAllMocks(); - if (config.timers === 'legacy') { + if ( + config.fakeTimers.enableGlobally && + config.fakeTimers.legacyFakeTimers + ) { // during setup, this cannot be null (and it's fine to explode if it is) environment.fakeTimers!.useFakeTimers(); } diff --git a/packages/jest-cli/src/cli/args.ts b/packages/jest-cli/src/cli/args.ts index 2a1b1797db6f..da80102fc9c9 100644 --- a/packages/jest-cli/src/cli/args.ts +++ b/packages/jest-cli/src/cli/args.ts @@ -637,12 +637,6 @@ export const options: {[key: string]: Options} = { description: 'This option sets the default timeouts of test cases.', type: 'number', }, - timers: { - description: - 'Setting this value to fake allows the use of fake timers ' + - 'for functions such as setTimeout.', - type: 'string', - }, transform: { description: 'A JSON string which maps from regular expressions to paths ' + diff --git a/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap b/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap index 2c5c94dd9d4b..31cca289857e 100644 --- a/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap +++ b/packages/jest-cli/src/init/__tests__/__snapshots__/init.test.js.snap @@ -168,6 +168,11 @@ module.exports = { // Make calling deprecated APIs throw helpful error messages // errorOnDeprecated: false, + // The default configuration for fake timers + // fakeTimers: { + // "enableGlobally": false + // }, + // Force coverage collection from ignored files using an array of glob patterns // forceCoverageMatch: [], @@ -285,9 +290,6 @@ module.exports = { // This option allows use of a custom test runner // testRunner: "jest-circus/runner", - // Setting this value to "fake" allows the use of fake timers for functions such as "setTimeout" - // timers: "real", - // A map from regular expressions to paths to transformers // transform: undefined, diff --git a/packages/jest-config/src/Defaults.ts b/packages/jest-config/src/Defaults.ts index 45cd6b7481d8..cb85437b3593 100644 --- a/packages/jest-config/src/Defaults.ts +++ b/packages/jest-config/src/Defaults.ts @@ -31,6 +31,7 @@ const defaultOptions: Config.DefaultOptions = { errorOnDeprecated: false, expand: false, extensionsToTreatAsEsm: [], + fakeTimers: {enableGlobally: false}, forceCoverageMatch: [], globals: {}, haste: { @@ -81,7 +82,6 @@ const defaultOptions: Config.DefaultOptions = { testRegex: [], testRunner: 'jest-circus/runner', testSequencer: '@jest/test-sequencer', - timers: 'real', transformIgnorePatterns: [NODE_MODULES_REGEXP, `\\.pnp\\.[^\\${sep}]+$`], useStderr: false, watch: false, diff --git a/packages/jest-config/src/Deprecated.ts b/packages/jest-config/src/Deprecated.ts index 4568d7fed3c0..905d3ebdde5b 100644 --- a/packages/jest-config/src/Deprecated.ts +++ b/packages/jest-config/src/Deprecated.ts @@ -94,6 +94,12 @@ const deprecatedOptions: DeprecatedOptions = { )}. Please update your configuration.`, + + timers: (_options: {timers?: string}) => ` Option ${chalk.bold( + '"timers"', + )} was replaced by ${chalk.bold('"fakeTimers"')}. + + Please update your configuration.`, }; export default deprecatedOptions; diff --git a/packages/jest-config/src/Descriptions.ts b/packages/jest-config/src/Descriptions.ts index 9f4549e5fb22..cd5ecb00cef1 100644 --- a/packages/jest-config/src/Descriptions.ts +++ b/packages/jest-config/src/Descriptions.ts @@ -31,6 +31,7 @@ const descriptions: {[key in keyof Config.InitialOptions]: string} = { dependencyExtractor: 'A path to a custom dependency extractor', errorOnDeprecated: 'Make calling deprecated APIs throw helpful error messages', + fakeTimers: 'The default configuration for fake timers', forceCoverageMatch: 'Force coverage collection from ignored files using an array of glob patterns', globalSetup: @@ -84,8 +85,6 @@ const descriptions: {[key in keyof Config.InitialOptions]: string} = { testResultsProcessor: 'This option allows the use of a custom results processor', testRunner: 'This option allows use of a custom test runner', - timers: - 'Setting this value to "fake" allows the use of fake timers for functions such as "setTimeout"', transform: 'A map from regular expressions to paths to transformers', transformIgnorePatterns: 'An array of regexp pattern strings that are matched against all source file paths, matched files will skip transformation', diff --git a/packages/jest-config/src/ValidConfig.ts b/packages/jest-config/src/ValidConfig.ts index 53e833d76ff2..4cac317e0971 100644 --- a/packages/jest-config/src/ValidConfig.ts +++ b/packages/jest-config/src/ValidConfig.ts @@ -49,6 +49,30 @@ const initialOptions: Config.InitialOptions = { errorOnDeprecated: false, expand: false, extensionsToTreatAsEsm: [], + fakeTimers: { + advanceTimers: multipleValidOptions(40, true), + doNotFake: [ + 'Date', + 'hrtime', + 'nextTick', + 'performance', + 'queueMicrotask', + 'requestAnimationFrame', + 'cancelAnimationFrame', + 'requestIdleCallback', + 'cancelIdleCallback', + 'setImmediate', + 'clearImmediate', + 'setInterval', + 'clearInterval', + 'setTimeout', + 'clearTimeout', + ], + enableGlobally: true, + legacyFakeTimers: false, + now: 1483228800000, + timerLimit: 1000, + }, filter: '/filter.js', forceCoverageMatch: ['**/*.t.js'], forceExit: false, @@ -141,7 +165,6 @@ const initialOptions: Config.InitialOptions = { testRunner: 'circus', testSequencer: '@jest/test-sequencer', testTimeout: 5000, - timers: 'real', transform: { '\\.js$': '/preprocessor.js', }, diff --git a/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap b/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap index 46538f039b17..a3d700f5b943 100644 --- a/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap +++ b/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap @@ -301,6 +301,30 @@ exports[`testURL logs a deprecation warning when \`testURL\` is used 1`] = ` } `; +exports[`timers logs a deprecation warning when \`timers\` is used 1`] = ` +[MockFunction] { + "calls": Array [ + Array [ + " Deprecation Warning: + + Option "timers" was replaced by "fakeTimers". + + Please update your configuration. + + Configuration Documentation: + https://jestjs.io/docs/configuration +", + ], + ], + "results": Array [ + Object { + "type": "return", + "value": undefined, + }, + ], +} +`; + exports[`watchPlugins throw error when a watch plugin is not found 1`] = ` "Validation Error: diff --git a/packages/jest-config/src/__tests__/normalize.test.ts b/packages/jest-config/src/__tests__/normalize.test.ts index 5139b873215c..077b3be65d02 100644 --- a/packages/jest-config/src/__tests__/normalize.test.ts +++ b/packages/jest-config/src/__tests__/normalize.test.ts @@ -1939,6 +1939,24 @@ describe('testURL', () => { }); }); +describe('timers', () => { + beforeEach(() => { + jest.mocked(console.warn).mockImplementation(() => {}); + }); + + it('logs a deprecation warning when `timers` is used', async () => { + await normalize( + { + rootDir: '/root/', + timers: 'real', + }, + {} as Config.Argv, + ); + + expect(console.warn).toMatchSnapshot(); + }); +}); + describe('extraGlobals', () => { beforeEach(() => { jest.mocked(console.warn).mockImplementation(() => {}); diff --git a/packages/jest-config/src/index.ts b/packages/jest-config/src/index.ts index 229bdf750921..e44d23bc5f23 100644 --- a/packages/jest-config/src/index.ts +++ b/packages/jest-config/src/index.ts @@ -185,6 +185,7 @@ const groupOptions = ( displayName: options.displayName, errorOnDeprecated: options.errorOnDeprecated, extensionsToTreatAsEsm: options.extensionsToTreatAsEsm, + fakeTimers: options.fakeTimers, filter: options.filter, forceCoverageMatch: options.forceCoverageMatch, globalSetup: options.globalSetup, @@ -223,7 +224,6 @@ const groupOptions = ( testPathIgnorePatterns: options.testPathIgnorePatterns, testRegex: options.testRegex, testRunner: options.testRunner, - timers: options.timers, transform: options.transform, transformIgnorePatterns: options.transformIgnorePatterns, unmockedModulePathPatterns: options.unmockedModulePathPatterns, diff --git a/packages/jest-config/src/normalize.ts b/packages/jest-config/src/normalize.ts index 6a09c510435f..a07ec04a372a 100644 --- a/packages/jest-config/src/normalize.ts +++ b/packages/jest-config/src/normalize.ts @@ -980,6 +980,7 @@ export default async function normalize( case 'expand': case 'extensionsToTreatAsEsm': case 'globals': + case 'fakeTimers': case 'findRelatedTests': case 'forceCoverageMatch': case 'forceExit': @@ -1014,7 +1015,6 @@ export default async function normalize( case 'testFailureExitCode': case 'testLocationInResults': case 'testNamePattern': - case 'timers': case 'useStderr': case 'verbose': case 'watch': diff --git a/packages/jest-core/src/lib/__tests__/__snapshots__/logDebugMessages.test.ts.snap b/packages/jest-core/src/lib/__tests__/__snapshots__/logDebugMessages.test.ts.snap index dea4afbba9ef..fb42e183f896 100644 --- a/packages/jest-core/src/lib/__tests__/__snapshots__/logDebugMessages.test.ts.snap +++ b/packages/jest-core/src/lib/__tests__/__snapshots__/logDebugMessages.test.ts.snap @@ -13,6 +13,9 @@ exports[`prints the config object 1`] = ` "detectOpenHandles": false, "errorOnDeprecated": false, "extensionsToTreatAsEsm": [], + "fakeTimers": { + "enableGlobally": false + }, "forceCoverageMatch": [], "globals": {}, "haste": {}, @@ -52,7 +55,6 @@ exports[`prints the config object 1`] = ` "\\\\.test\\\\.js$" ], "testRunner": "myRunner", - "timers": "real", "transform": [], "transformIgnorePatterns": [], "watchPathIgnorePatterns": [] diff --git a/packages/jest-environment/src/index.ts b/packages/jest-environment/src/index.ts index 6a96143ada73..67b57c37fa03 100644 --- a/packages/jest-environment/src/index.ts +++ b/packages/jest-environment/src/index.ts @@ -140,7 +140,7 @@ export interface Jest { * need access to the real current time, you can invoke this function. * * @remarks - * Only available when using 'modern' fake timers implementation. + * Not available when using legacy fake timers implementation. */ getRealSystemTime(): number; /** @@ -236,7 +236,7 @@ export interface Jest { * Exhausts tasks queued by `setImmediate()`. * * @remarks - * Not available when using 'modern' timers implementation. + * Only available when using legacy fake timers implementation. */ runAllImmediates(): void; /** @@ -272,7 +272,7 @@ export interface Jest { * as they would have done without the call to `jest.setSystemTime()`. * * @remarks - * Only available when using 'modern' fake timers implementation. + * Not available when using legacy fake timers implementation. */ setSystemTime(now?: number | Date): void; /** @@ -302,11 +302,20 @@ export interface Jest { */ unmock(moduleName: string): Jest; /** - * Instructs Jest to use fake versions of the standard timer functions. + * Instructs Jest to use fake versions of the global date, performance, + * time and timer APIs. Fake timers implementation is backed by + * [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). + * + * @remarks + * Calling `jest.useFakeTimers()` once again in the same test file would reinstall + * fake timers using the provided options. */ - useFakeTimers(implementation?: 'modern' | 'legacy'): Jest; + useFakeTimers( + fakeTimersConfig?: Config.FakeTimersConfig | Config.LegacyFakeTimersConfig, + ): Jest; /** - * Instructs Jest to use the real versions of the standard timer functions. + * Instructs Jest to restore the original implementations of the global date, + * performance, time and timer APIs. */ useRealTimers(): Jest; } diff --git a/packages/jest-fake-timers/package.json b/packages/jest-fake-timers/package.json index 264beaa4f5b0..b029cb30b8ab 100644 --- a/packages/jest-fake-timers/package.json +++ b/packages/jest-fake-timers/package.json @@ -25,7 +25,8 @@ "jest-util": "^28.0.0-alpha.7" }, "devDependencies": { - "@types/sinonjs__fake-timers": "^8.1.1" + "@jest/test-utils": "^28.0.0-alpha.7", + "@types/sinonjs__fake-timers": "^8.1.2" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-fake-timers/src/__tests__/__snapshots__/legacyFakeTimers.test.ts.snap b/packages/jest-fake-timers/src/__tests__/__snapshots__/legacyFakeTimers.test.ts.snap index 035160d483e5..4a1286a87aed 100644 --- a/packages/jest-fake-timers/src/__tests__/__snapshots__/legacyFakeTimers.test.ts.snap +++ b/packages/jest-fake-timers/src/__tests__/__snapshots__/legacyFakeTimers.test.ts.snap @@ -1,7 +1,3 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`FakeTimers runAllTimers warns when trying to advance timers while real timers are used 1`] = ` -"A function to advance timers was called but the timers API is not mocked with fake timers. Call \`jest.useFakeTimers()\` in this test or enable fake timers globally by setting \`"timers": "fake"\` in the configuration file. This warning is likely a result of a default configuration change in Jest 15. - -Release Blog Post: https://jestjs.io/blog/2016/09/01/jest-15" -`; +exports[`FakeTimers runAllTimers warns when trying to advance timers while real timers are used 1`] = `"A function to advance timers was called but the timers APIs are not mocked with fake timers. Call \`jest.useFakeTimers({legacyFakeTimers: true})\` in this test file or enable fake timers for all tests by setting {'enableGlobally': true, 'legacyFakeTimers': true} in Jest configuration file."`; diff --git a/packages/jest-fake-timers/src/__tests__/__snapshots__/modernFakeTimers.test.ts.snap b/packages/jest-fake-timers/src/__tests__/__snapshots__/modernFakeTimers.test.ts.snap index 8b00458786e1..daf980ad8701 100644 --- a/packages/jest-fake-timers/src/__tests__/__snapshots__/modernFakeTimers.test.ts.snap +++ b/packages/jest-fake-timers/src/__tests__/__snapshots__/modernFakeTimers.test.ts.snap @@ -1,3 +1,3 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`FakeTimers runAllTimers warns when trying to advance timers while real timers are used 1`] = `"A function to advance timers was called but the timers API is not mocked with fake timers. Call \`jest.useFakeTimers()\` in this test or enable fake timers globally by setting \`"timers": "fake"\` in the configuration file"`; +exports[`FakeTimers runAllTimers warns when trying to advance timers while real timers are used 1`] = `"A function to advance timers was called but the timers APIs are not replaced with fake timers. Call \`jest.useFakeTimers()\` in this test file or enable fake timers for all tests by setting 'fakeTimers': {'enableGlobally': true} in Jest configuration file."`; diff --git a/packages/jest-fake-timers/src/__tests__/modernFakeTimers.test.ts b/packages/jest-fake-timers/src/__tests__/modernFakeTimers.test.ts index 36b14aecc128..a2cddb4a871d 100644 --- a/packages/jest-fake-timers/src/__tests__/modernFakeTimers.test.ts +++ b/packages/jest-fake-timers/src/__tests__/modernFakeTimers.test.ts @@ -6,6 +6,7 @@ * */ +import {makeProjectConfig} from '@jest/test-utils'; import FakeTimers from '../modernFakeTimers'; describe('FakeTimers', () => { @@ -17,7 +18,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); expect(global.setTimeout).not.toBe(undefined); }); @@ -29,7 +30,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); expect(global.clearTimeout).not.toBe(undefined); }); @@ -41,7 +42,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); expect(global.setInterval).not.toBe(undefined); }); @@ -53,7 +54,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); expect(global.clearInterval).not.toBe(undefined); }); @@ -68,7 +69,7 @@ describe('FakeTimers', () => { }, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); expect(global.process.nextTick).not.toBe(origNextTick); }); @@ -82,7 +83,7 @@ describe('FakeTimers', () => { setImmediate: origSetImmediate, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); expect(global.setImmediate).not.toBe(origSetImmediate); }); @@ -98,7 +99,7 @@ describe('FakeTimers', () => { setImmediate: origSetImmediate, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); expect(global.clearImmediate).not.toBe(origClearImmediate); }); @@ -115,7 +116,7 @@ describe('FakeTimers', () => { setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const runOrder = []; @@ -146,7 +147,7 @@ describe('FakeTimers', () => { setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); timers.runAllTicks(); @@ -163,7 +164,7 @@ describe('FakeTimers', () => { setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const mock1 = jest.fn(); @@ -187,7 +188,10 @@ describe('FakeTimers', () => { setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global, maxLoops: 100}); + const timers = new FakeTimers({ + config: makeProjectConfig({fakeTimers: {timerLimit: 100}}), + global, + }); timers.useFakeTimers(); @@ -211,7 +215,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const runOrder = []; @@ -247,9 +251,7 @@ describe('FakeTimers', () => { const consoleWarn = console.warn; console.warn = jest.fn(); const timers = new FakeTimers({ - config: { - rootDir: __dirname, - }, + config: makeProjectConfig({rootDir: __dirname}), global: globalThis, }); timers.runAllTimers(); @@ -268,7 +270,7 @@ describe('FakeTimers', () => { setTimeout: nativeSetTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); timers.runAllTimers(); }); @@ -280,7 +282,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const fn = jest.fn(); @@ -301,7 +303,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const fn = jest.fn(); @@ -322,7 +324,7 @@ describe('FakeTimers', () => { setTimeout: nativeSetTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); // @sinonjs/fake-timers uses `setTimeout` during init to figure out if it's in Node or // browser env. So clear its calls before we install them into the env nativeSetTimeout.mockClear(); @@ -343,7 +345,10 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global, maxLoops: 100}); + const timers = new FakeTimers({ + config: makeProjectConfig({fakeTimers: {timerLimit: 1000}}), + global, + }); timers.useFakeTimers(); global.setTimeout(function infinitelyRecursingCallback() { @@ -354,7 +359,7 @@ describe('FakeTimers', () => { timers.runAllTimers(); }).toThrow( new Error( - 'Aborting after running 100 timers, assuming an infinite loop!', + 'Aborting after running 1000 timers, assuming an infinite loop!', ), ); }); @@ -366,7 +371,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const fn = jest.fn(); @@ -388,7 +393,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const runOrder = []; @@ -432,7 +437,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); timers.advanceTimersByTime(100); @@ -447,7 +452,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const runOrder: Array = []; @@ -487,7 +492,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const runOrder: Array = []; @@ -526,7 +531,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const runOrder: Array = []; @@ -554,7 +559,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); timers.advanceTimersToNextTimer(); @@ -569,7 +574,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const mock1 = jest.fn(); @@ -587,7 +592,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const mock1 = jest.fn(); @@ -608,7 +613,7 @@ describe('FakeTimers', () => { setImmediate: () => {}, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const mock1 = jest.fn(); @@ -627,7 +632,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const mock1 = jest.fn(); @@ -654,7 +659,7 @@ describe('FakeTimers', () => { setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const runOrder = []; @@ -719,7 +724,7 @@ describe('FakeTimers', () => { process, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); const fn = jest.fn(); @@ -748,7 +753,7 @@ describe('FakeTimers', () => { setInterval: nativeSetInterval, setTimeout: nativeSetTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); // Ensure that timers has overridden the native timer APIs @@ -775,7 +780,7 @@ describe('FakeTimers', () => { process: {nextTick: nativeProcessNextTick}, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); // Ensure that timers has overridden the native timer APIs @@ -799,7 +804,7 @@ describe('FakeTimers', () => { setImmediate: nativeSetImmediate, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useFakeTimers(); // Ensure that timers has overridden the native timer APIs @@ -829,7 +834,7 @@ describe('FakeTimers', () => { setInterval: nativeSetInterval, setTimeout: nativeSetTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useRealTimers(); // Ensure that the real timers are installed at this point @@ -856,7 +861,7 @@ describe('FakeTimers', () => { process: {nextTick: nativeProcessNextTick}, setTimeout, } as unknown as typeof globalThis; - const timers = new FakeTimers({global}); + const timers = new FakeTimers({config: makeProjectConfig(), global}); timers.useRealTimers(); // Ensure that the real timers are installed at this point @@ -880,7 +885,7 @@ describe('FakeTimers', () => { setImmediate: nativeSetImmediate, setTimeout, } as unknown as typeof globalThis; - const fakeTimers = new FakeTimers({global}); + const fakeTimers = new FakeTimers({config: makeProjectConfig(), global}); fakeTimers.useRealTimers(); // Ensure that the real timers are installed at this point @@ -897,7 +902,10 @@ describe('FakeTimers', () => { describe('getTimerCount', () => { it('returns the correct count', () => { - const timers = new FakeTimers({global: globalThis}); + const timers = new FakeTimers({ + config: makeProjectConfig(), + global: globalThis, + }); timers.useFakeTimers(); @@ -917,7 +925,10 @@ describe('FakeTimers', () => { }); it('includes immediates and ticks', () => { - const timers = new FakeTimers({global: globalThis}); + const timers = new FakeTimers({ + config: makeProjectConfig(), + global: globalThis, + }); timers.useFakeTimers(); @@ -929,7 +940,10 @@ describe('FakeTimers', () => { }); it('not includes cancelled immediates', () => { - const timers = new FakeTimers({global: globalThis}); + const timers = new FakeTimers({ + config: makeProjectConfig(), + global: globalThis, + }); timers.useFakeTimers(); diff --git a/packages/jest-fake-timers/src/__tests__/sinon-integration.test.ts b/packages/jest-fake-timers/src/__tests__/sinon-integration.test.ts new file mode 100644 index 000000000000..528e2d15937c --- /dev/null +++ b/packages/jest-fake-timers/src/__tests__/sinon-integration.test.ts @@ -0,0 +1,181 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + * + */ + +import {makeProjectConfig} from '@jest/test-utils'; +import FakeTimers from '../modernFakeTimers'; + +jest.spyOn(Date, 'now').mockImplementation(() => 123456); + +const mockInstall = jest.fn(); + +const mockWithGlobal = { + install: mockInstall, + timers: { + Date: jest.fn(), + clearImmediate: jest.fn(), + clearInterval: jest.fn(), + clearTimeout: jest.fn(), + hrtime: jest.fn(), + nextTick: jest.fn(), + performance: jest.fn(), + queueMicrotask: jest.fn(), + setImmediate: jest.fn(), + setInterval: jest.fn(), + setTimeout: jest.fn(), + }, +}; + +jest.mock('@sinonjs/fake-timers', () => { + return { + withGlobal: jest.fn(() => mockWithGlobal), + }; +}); + +afterEach(() => { + jest.clearAllMocks(); +}); + +describe('`@sinonjs/fake-timers` integration', () => { + test('uses default global config, when `useFakeTimers()` is called without options', () => { + const timers = new FakeTimers({ + config: makeProjectConfig(), + global: globalThis, + }); + + timers.useFakeTimers(); + + expect(mockInstall).toBeCalledWith({ + advanceTimeDelta: undefined, + loopLimit: 100_000, + now: 123456, + shouldAdvanceTime: false, + shouldClearNativeTimers: true, + toFake: [ + 'Date', + 'clearImmediate', + 'clearInterval', + 'clearTimeout', + 'hrtime', + 'nextTick', + 'performance', + 'queueMicrotask', + 'setImmediate', + 'setInterval', + 'setTimeout', + ], + }); + }); + + test('uses custom global config, when `useFakeTimers()` is called without options', () => { + const timers = new FakeTimers({ + config: makeProjectConfig({ + fakeTimers: { + advanceTimers: true, + doNotFake: ['Date', 'nextTick'], + now: 0, + timerLimit: 100, + }, + }), + global: globalThis, + }); + + timers.useFakeTimers(); + + expect(mockInstall).toBeCalledWith({ + advanceTimeDelta: undefined, + loopLimit: 100, + now: 0, + shouldAdvanceTime: true, + shouldClearNativeTimers: true, + toFake: [ + 'clearImmediate', + 'clearInterval', + 'clearTimeout', + 'hrtime', + 'performance', + 'queueMicrotask', + 'setImmediate', + 'setInterval', + 'setTimeout', + ], + }); + }); + + test('overrides default global config, when `useFakeTimers()` is called with options,', () => { + const timers = new FakeTimers({ + config: makeProjectConfig(), + global: globalThis, + }); + + timers.useFakeTimers({ + advanceTimers: 40, + doNotFake: ['Date', 'queueMicrotask'], + now: new Date('1995-12-17'), + timerLimit: 2000, + }); + + expect(mockInstall).toBeCalledWith({ + advanceTimeDelta: 40, + loopLimit: 2000, + now: new Date('1995-12-17'), + shouldAdvanceTime: true, + shouldClearNativeTimers: true, + toFake: [ + 'clearImmediate', + 'clearInterval', + 'clearTimeout', + 'hrtime', + 'nextTick', + 'performance', + 'setImmediate', + 'setInterval', + 'setTimeout', + ], + }); + }); + + test('overrides custom global config, when `useFakeTimers()` is called with options,', () => { + const timers = new FakeTimers({ + config: makeProjectConfig({ + fakeTimers: { + advanceTimers: 20, + doNotFake: ['Date', 'nextTick'], + now: 0, + timerLimit: 1000, + }, + }), + global: globalThis, + }); + + timers.useFakeTimers({ + advanceTimers: false, + doNotFake: ['hrtime'], + now: 123456, + }); + + expect(mockInstall).toBeCalledWith({ + advanceTimeDelta: undefined, + loopLimit: 1000, + now: 123456, + shouldAdvanceTime: false, + shouldClearNativeTimers: true, + toFake: [ + 'Date', + 'clearImmediate', + 'clearInterval', + 'clearTimeout', + 'nextTick', + 'performance', + 'queueMicrotask', + 'setImmediate', + 'setInterval', + 'setTimeout', + ], + }); + }); +}); diff --git a/packages/jest-fake-timers/src/legacyFakeTimers.ts b/packages/jest-fake-timers/src/legacyFakeTimers.ts index ee957b0444fb..e4b719f5d6b3 100644 --- a/packages/jest-fake-timers/src/legacyFakeTimers.ts +++ b/packages/jest-fake-timers/src/legacyFakeTimers.ts @@ -402,16 +402,15 @@ export default class FakeTimers { // @ts-expect-error: condition always returns 'true' if (this._global.setTimeout !== this._fakeTimerAPIs?.setTimeout) { this._global.console.warn( - 'A function to advance timers was called but the timers API is not ' + - 'mocked with fake timers. Call `jest.useFakeTimers()` in this ' + - 'test or enable fake timers globally by setting ' + - '`"timers": "fake"` in ' + - 'the configuration file. This warning is likely a result of a ' + - 'default configuration change in Jest 15.\n\n' + - 'Release Blog Post: https://jestjs.io/blog/2016/09/01/jest-15\n' + - `Stack Trace:\n${formatStackTrace(new Error().stack!, this._config, { - noStackTrace: false, - })}`, + 'A function to advance timers was called but the timers APIs are not mocked ' + + 'with fake timers. Call `jest.useFakeTimers({legacyFakeTimers: true})` ' + + 'in this test file or enable fake timers for all tests by setting ' + + "{'enableGlobally': true, 'legacyFakeTimers': true} in " + + `Jest configuration file.\nStack Trace:\n${formatStackTrace( + new Error().stack!, + this._config, + {noStackTrace: false}, + )}`, ); } } diff --git a/packages/jest-fake-timers/src/modernFakeTimers.ts b/packages/jest-fake-timers/src/modernFakeTimers.ts index 93abce4dd4c9..f8363388c9ce 100644 --- a/packages/jest-fake-timers/src/modernFakeTimers.ts +++ b/packages/jest-fake-timers/src/modernFakeTimers.ts @@ -7,31 +7,30 @@ import { FakeTimerWithContext, + FakeMethod as FakeableAPI, InstalledClock, + FakeTimerInstallOpts as SinonFakeTimersConfig, withGlobal, } from '@sinonjs/fake-timers'; -import {StackTraceConfig, formatStackTrace} from 'jest-message-util'; +import type {Config} from '@jest/types'; +import {formatStackTrace} from 'jest-message-util'; export default class FakeTimers { private _clock!: InstalledClock; - private _config: StackTraceConfig; + private _config: Config.ProjectConfig; private _fakingTime: boolean; private _global: typeof globalThis; private _fakeTimers: FakeTimerWithContext; - private _maxLoops: number; constructor({ global, config, - maxLoops, }: { global: typeof globalThis; - config: StackTraceConfig; - maxLoops?: number; + config: Config.ProjectConfig; }) { this._global = global; this._config = config; - this._maxLoops = maxLoops || 100000; this._fakingTime = false; this._fakeTimers = withGlobal(global); @@ -93,20 +92,16 @@ export default class FakeTimers { } } - useFakeTimers(): void { - if (!this._fakingTime) { - const toFake = Object.keys(this._fakeTimers.timers) as Array< - keyof FakeTimerWithContext['timers'] - >; + useFakeTimers(fakeTimersConfig?: Config.FakeTimersConfig): void { + if (this._fakingTime) { + this._clock.uninstall(); + } - this._clock = this._fakeTimers.install({ - loopLimit: this._maxLoops, - now: Date.now(), - toFake, - }); + this._clock = this._fakeTimers.install( + this._toSinonFakeTimersConfig(fakeTimersConfig), + ); - this._fakingTime = true; - } + this._fakingTime = true; } reset(): void { @@ -138,10 +133,10 @@ export default class FakeTimers { private _checkFakeTimers() { if (!this._fakingTime) { this._global.console.warn( - 'A function to advance timers was called but the timers API is not ' + - 'mocked with fake timers. Call `jest.useFakeTimers()` in this test or ' + - 'enable fake timers globally by setting `"timers": "fake"` in the ' + - `configuration file\nStack Trace:\n${formatStackTrace( + 'A function to advance timers was called but the timers APIs are not replaced ' + + 'with fake timers. Call `jest.useFakeTimers()` in this test file or enable ' + + "fake timers for all tests by setting 'fakeTimers': {'enableGlobally': true} " + + `in Jest configuration file.\nStack Trace:\n${formatStackTrace( new Error().stack!, this._config, {noStackTrace: false}, @@ -151,4 +146,35 @@ export default class FakeTimers { return this._fakingTime; } + + private _toSinonFakeTimersConfig( + fakeTimersConfig: Config.FakeTimersConfig = {}, + ): SinonFakeTimersConfig { + fakeTimersConfig = { + ...this._config.fakeTimers, + ...fakeTimersConfig, + } as Config.FakeTimersConfig; + + const advanceTimeDelta = + typeof fakeTimersConfig.advanceTimers === 'number' + ? fakeTimersConfig.advanceTimers + : undefined; + + const toFake = new Set( + Object.keys(this._fakeTimers.timers) as Array, + ); + + fakeTimersConfig.doNotFake?.forEach(nameOfFakeableAPI => { + toFake.delete(nameOfFakeableAPI); + }); + + return { + advanceTimeDelta, + loopLimit: fakeTimersConfig.timerLimit || 100_000, + now: fakeTimersConfig.now ?? Date.now(), + shouldAdvanceTime: Boolean(fakeTimersConfig.advanceTimers), + shouldClearNativeTimers: true, + toFake: Array.from(toFake), + }; + } } diff --git a/packages/jest-fake-timers/tsconfig.json b/packages/jest-fake-timers/tsconfig.json index 0bdcddc53258..4a4b01562562 100644 --- a/packages/jest-fake-timers/tsconfig.json +++ b/packages/jest-fake-timers/tsconfig.json @@ -10,6 +10,7 @@ {"path": "../jest-message-util"}, {"path": "../jest-mock"}, {"path": "../jest-types"}, - {"path": "../jest-util"} + {"path": "../jest-util"}, + {"path": "../test-utils"} ] } diff --git a/packages/jest-jasmine2/src/index.ts b/packages/jest-jasmine2/src/index.ts index d8f1a14bc4f5..cf7c8bf5b4b1 100644 --- a/packages/jest-jasmine2/src/index.ts +++ b/packages/jest-jasmine2/src/index.ts @@ -88,10 +88,12 @@ export default async function jasmine2( environment.global.describe.skip = environment.global.xdescribe; environment.global.describe.only = environment.global.fdescribe; - if (config.timers === 'fake' || config.timers === 'modern') { - environment.fakeTimersModern!.useFakeTimers(); - } else if (config.timers === 'legacy') { - environment.fakeTimers!.useFakeTimers(); + if (config.fakeTimers.enableGlobally) { + if (config.fakeTimers.legacyFakeTimers) { + environment.fakeTimers!.useFakeTimers(); + } else { + environment.fakeTimersModern!.useFakeTimers(); + } } env.beforeEach(() => { @@ -106,7 +108,10 @@ export default async function jasmine2( if (config.resetMocks) { runtime.resetAllMocks(); - if (config.timers === 'legacy') { + if ( + config.fakeTimers.enableGlobally && + config.fakeTimers.legacyFakeTimers + ) { environment.fakeTimers!.useFakeTimers(); } } diff --git a/packages/jest-runtime/src/index.ts b/packages/jest-runtime/src/index.ts index 7fc8a91f6af3..abc76358872b 100644 --- a/packages/jest-runtime/src/index.ts +++ b/packages/jest-runtime/src/index.ts @@ -279,10 +279,9 @@ export default class Runtime { this._shouldUnmockTransitiveDependenciesCache = new Map(); this._transitiveShouldMock = new Map(); - this._fakeTimersImplementation = - config.timers === 'legacy' - ? this._environment.fakeTimers - : this._environment.fakeTimersModern; + this._fakeTimersImplementation = config.fakeTimers.legacyFakeTimers + ? this._environment.fakeTimers + : this._environment.fakeTimersModern; this._unmockList = unmockRegExpCache.get(config); if (!this._unmockList && config.unmockedModulePathPatterns) { @@ -2065,13 +2064,17 @@ export default class Runtime { return this._fakeTimersImplementation!; }; - const useFakeTimers: Jest['useFakeTimers'] = (type = 'modern') => { - if (type === 'legacy') { + const useFakeTimers: Jest['useFakeTimers'] = fakeTimersConfig => { + fakeTimersConfig = { + ...this._config.fakeTimers, + ...fakeTimersConfig, + } as Config.FakeTimersConfig; + if (fakeTimersConfig?.legacyFakeTimers) { this._fakeTimersImplementation = this._environment.fakeTimers; } else { this._fakeTimersImplementation = this._environment.fakeTimersModern; } - this._fakeTimersImplementation!.useFakeTimers(); + this._fakeTimersImplementation!.useFakeTimers(fakeTimersConfig); return jestObject; }; const useRealTimers = () => { @@ -2134,7 +2137,7 @@ export default class Runtime { return fakeTimers.getRealSystemTime(); } else { throw new TypeError( - 'getRealSystemTime is not available when not using modern timers', + '`jest.getRealSystemTime()` is not available when using legacy fake timers.', ); } }, @@ -2156,7 +2159,7 @@ export default class Runtime { fakeTimers.runAllImmediates(); } else { throw new TypeError( - 'runAllImmediates is not available when using modern timers', + '`jest.runAllImmediates()` is only available when using legacy fake timers.', ); } }, @@ -2172,7 +2175,7 @@ export default class Runtime { fakeTimers.setSystemTime(now); } else { throw new TypeError( - 'setSystemTime is not available when not using modern timers', + '`jest.setSystemTime()` is not available when using legacy fake timers.', ); } }, diff --git a/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap b/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap index 7d89d8bbf339..582da17801e8 100644 --- a/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap +++ b/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap @@ -34,6 +34,9 @@ exports[`ScriptTransformer in async mode, passes expected transform options to g "displayName": undefined, "errorOnDeprecated": false, "extensionsToTreatAsEsm": Array [], + "fakeTimers": Object { + "enableGlobally": false, + }, "filter": undefined, "forceCoverageMatch": Array [], "globalSetup": undefined, @@ -76,7 +79,6 @@ exports[`ScriptTransformer in async mode, passes expected transform options to g "\\.test\\.js$", ], "testRunner": "jest-circus/runner", - "timers": "real", "transform": Array [ Array [ "\\.js$", @@ -92,7 +94,7 @@ exports[`ScriptTransformer in async mode, passes expected transform options to g "unmockedModulePathPatterns": undefined, "watchPathIgnorePatterns": Array [], }, - "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","timers":"real","transform":[["\\\\.js$","test_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", + "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", "coverageProvider": "babel", "instrument": true, "supportsDynamicImport": false, @@ -118,7 +120,7 @@ exports[`ScriptTransformer in async mode, uses the supplied async preprocessor 1 "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","timers":"real","transform":[["\\\\.js$","test_async_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"timers\\":\\"real\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_async_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_async_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_async_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; @@ -128,7 +130,7 @@ exports[`ScriptTransformer in async mode, uses the supplied preprocessor 1`] = ` "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","timers":"real","transform":[["\\\\.js$","test_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"timers\\":\\"real\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; @@ -165,6 +167,9 @@ exports[`ScriptTransformer passes expected transform options to getCacheKey 1`] "displayName": undefined, "errorOnDeprecated": false, "extensionsToTreatAsEsm": Array [], + "fakeTimers": Object { + "enableGlobally": false, + }, "filter": undefined, "forceCoverageMatch": Array [], "globalSetup": undefined, @@ -207,7 +212,6 @@ exports[`ScriptTransformer passes expected transform options to getCacheKey 1`] "\\.test\\.js$", ], "testRunner": "jest-circus/runner", - "timers": "real", "transform": Array [ Array [ "\\.js$", @@ -223,7 +227,7 @@ exports[`ScriptTransformer passes expected transform options to getCacheKey 1`] "unmockedModulePathPatterns": undefined, "watchPathIgnorePatterns": Array [], }, - "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","timers":"real","transform":[["\\\\.js$","test_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", + "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", "coverageProvider": "babel", "instrument": true, "supportsDynamicImport": false, @@ -270,6 +274,9 @@ exports[`ScriptTransformer passes expected transform options to getCacheKeyAsync "displayName": undefined, "errorOnDeprecated": false, "extensionsToTreatAsEsm": Array [], + "fakeTimers": Object { + "enableGlobally": false, + }, "filter": undefined, "forceCoverageMatch": Array [], "globalSetup": undefined, @@ -312,7 +319,6 @@ exports[`ScriptTransformer passes expected transform options to getCacheKeyAsync "\\.test\\.js$", ], "testRunner": "jest-circus/runner", - "timers": "real", "transform": Array [ Array [ "\\.js$", @@ -328,7 +334,7 @@ exports[`ScriptTransformer passes expected transform options to getCacheKeyAsync "unmockedModulePathPatterns": undefined, "watchPathIgnorePatterns": Array [], }, - "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","timers":"real","transform":[["\\\\.js$","test_async_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", + "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_async_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", "coverageProvider": "babel", "instrument": true, "supportsDynamicImport": false, @@ -676,7 +682,7 @@ exports[`ScriptTransformer uses mixture of sync/async preprocessors 1`] = ` "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","timers":"real","transform":[["\\\\.js$","test_async_preprocessor",{}],["\\\\.css$","css-preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"timers\\":\\"real\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_async_preprocessor\\",{}],[\\"\\\\\\\\.css$\\",\\"css-preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_async_preprocessor",{}],["\\\\.css$","css-preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_async_preprocessor\\",{}],[\\"\\\\\\\\.css$\\",\\"css-preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; @@ -693,7 +699,7 @@ exports[`ScriptTransformer uses multiple preprocessors 1`] = ` "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","timers":"real","transform":[["\\\\.js$","test_preprocessor",{}],["\\\\.css$","css-preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"timers\\":\\"real\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}],[\\"\\\\\\\\.css$\\",\\"css-preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{}],["\\\\.css$","css-preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}],[\\"\\\\\\\\.css$\\",\\"css-preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; @@ -710,7 +716,7 @@ exports[`ScriptTransformer uses the supplied preprocessor 1`] = ` "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","timers":"real","transform":[["\\\\.js$","test_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"timers\\":\\"real\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; diff --git a/packages/jest-types/__typetests__/config.test.ts b/packages/jest-types/__typetests__/config.test.ts index dd69249ea7b6..04027cae0dcb 100644 --- a/packages/jest-types/__typetests__/config.test.ts +++ b/packages/jest-types/__typetests__/config.test.ts @@ -5,9 +5,11 @@ * LICENSE file in the root directory of this source tree. */ -import {expectAssignable} from 'tsd-lite'; +import {expectAssignable, expectError, expectNotAssignable} from 'tsd-lite'; import type {Config} from '@jest/types'; +expectAssignable({}); + expectAssignable({ coverageThreshold: { './src/api/very-important-module.js': { @@ -39,3 +41,79 @@ expectAssignable({ }, ], }); + +const doNotFake: Array = [ + 'Date', + 'hrtime', + 'nextTick', + 'performance', + 'queueMicrotask', + 'requestAnimationFrame', + 'cancelAnimationFrame', + 'requestIdleCallback', + 'cancelIdleCallback', + 'setImmediate', + 'clearImmediate', + 'setInterval', + 'clearInterval', + 'setTimeout', + 'clearTimeout', +]; + +expectAssignable({ + fakeTimers: { + advanceTimers: true, + doNotFake, + enableGlobally: true, + now: 1483228800000, + timerLimit: 1000, + }, +}); + +expectAssignable({ + fakeTimers: { + advanceTimers: 40, + now: Date.now(), + }, +}); + +expectError({ + fakeTimers: { + now: new Date(), + }, +}); + +expectAssignable({ + fakeTimers: { + enableGlobally: true, + legacyFakeTimers: true, + }, +}); + +expectError({ + fakeTimers: { + advanceTimers: true, + legacyFakeTimers: true, + }, +}); + +expectError({ + fakeTimers: { + doNotFake, + legacyFakeTimers: true, + }, +}); + +expectError({ + fakeTimers: { + legacyFakeTimers: true, + now: 1483228800000, + }, +}); + +expectError({ + fakeTimers: { + legacyFakeTimers: true, + timerLimit: 1000, + }, +}); diff --git a/packages/jest-types/__typetests__/jest.test.ts b/packages/jest-types/__typetests__/jest.test.ts index 6c2a9f17b75a..ae46c5e4e372 100644 --- a/packages/jest-types/__typetests__/jest.test.ts +++ b/packages/jest-types/__typetests__/jest.test.ts @@ -43,8 +43,7 @@ expectType( .setTimeout(6000) .unmock('moduleName') .useFakeTimers() - .useFakeTimers('modern') - .useFakeTimers('legacy') + .useFakeTimers({legacyFakeTimers: true}) .useRealTimers(), ); @@ -248,9 +247,53 @@ expectType(jest.setSystemTime(new Date(1995, 11, 17))); expectError(jest.setSystemTime('1995-12-17T03:24:00')); expectType(jest.useFakeTimers()); -expectType(jest.useFakeTimers('modern')); -expectType(jest.useFakeTimers('legacy')); -expectError(jest.useFakeTimers('latest')); + +expectType(jest.useFakeTimers({advanceTimers: true})); +expectType(jest.useFakeTimers({advanceTimers: 10})); +expectError(jest.useFakeTimers({advanceTimers: 'fast'})); + +expectType(jest.useFakeTimers({doNotFake: ['Date']})); +expectType( + jest.useFakeTimers({ + doNotFake: [ + 'Date', + 'hrtime', + 'nextTick', + 'performance', + 'queueMicrotask', + 'requestAnimationFrame', + 'cancelAnimationFrame', + 'requestIdleCallback', + 'cancelIdleCallback', + 'setImmediate', + 'clearImmediate', + 'setInterval', + 'clearInterval', + 'setTimeout', + 'clearTimeout', + ], + }), +); +expectError(jest.useFakeTimers({doNotFake: ['globalThis']})); + +expectType(jest.useFakeTimers({legacyFakeTimers: true})); +expectError(jest.useFakeTimers({legacyFakeTimers: 1000})); +expectError(jest.useFakeTimers({doNotFake: ['Date'], legacyFakeTimers: true})); +expectError(jest.useFakeTimers({enableGlobally: true, legacyFakeTimers: true})); +expectError(jest.useFakeTimers({legacyFakeTimers: true, now: 1483228800000})); +expectError(jest.useFakeTimers({legacyFakeTimers: true, timerLimit: 1000})); + +expectType(jest.useFakeTimers({now: 1483228800000})); +expectType(jest.useFakeTimers({now: Date.now()})); +expectType(jest.useFakeTimers({now: new Date(1995, 11, 17)})); +expectError(jest.useFakeTimers({now: '1995-12-17T03:24:00'})); + +expectType(jest.useFakeTimers({timerLimit: 1000})); +expectError(jest.useFakeTimers({timerLimit: true})); + +expectError(jest.useFakeTimers({enableGlobally: true})); +expectError(jest.useFakeTimers('legacy')); +expectError(jest.useFakeTimers('modern')); expectType(jest.useRealTimers()); expectError(jest.useRealTimers(true)); diff --git a/packages/jest-types/src/Config.ts b/packages/jest-types/src/Config.ts index d93d77c87b69..3b9d14cf76ab 100644 --- a/packages/jest-types/src/Config.ts +++ b/packages/jest-types/src/Config.ts @@ -12,7 +12,94 @@ import type {SnapshotFormat} from '@jest/schemas'; type CoverageProvider = 'babel' | 'v8'; -type Timers = 'real' | 'fake' | 'modern' | 'legacy'; +export type FakeableAPI = + | 'Date' + | 'hrtime' + | 'nextTick' + | 'performance' + | 'queueMicrotask' + | 'requestAnimationFrame' + | 'cancelAnimationFrame' + | 'requestIdleCallback' + | 'cancelIdleCallback' + | 'setImmediate' + | 'clearImmediate' + | 'setInterval' + | 'clearInterval' + | 'setTimeout' + | 'clearTimeout'; + +export type GlobalFakeTimersConfig = { + /** + * Whether fake timers should be enabled globally for all test files. + * + * @defaultValue + * The default is `false`. + * */ + enableGlobally?: boolean; +}; + +export type FakeTimersConfig = { + /** + * If set to `true` all timers will be advanced automatically + * by 20 milliseconds every 20 milliseconds. A custom time delta + * may be provided by passing a number. + * + * @defaultValue + * The default is `false`. + */ + advanceTimers?: boolean | number; + /** + * List of names of APIs (e.g. `Date`, `nextTick()`, `setImmediate()`, + * `setTimeout()`) that should not be faked. + * + * @defaultValue + * The default is `[]`, meaning all APIs are faked. + * */ + doNotFake?: Array; + /** + * Sets current system time to be used by fake timers. + * + * @defaultValue + * The default is `Date.now()`. + */ + now?: number | Date; + /** + * The maximum number of recursive timers that will be run when calling + * `jest.runAllTimers()`. + * + * @defaultValue + * The default is `100_000` timers. + */ + timerLimit?: number; + /** + * Use the old fake timers implementation instead of one backed by + * [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). + * + * @defaultValue + * The default is `false`. + */ + legacyFakeTimers?: false; +}; + +export type LegacyFakeTimersConfig = { + /** + * Use the old fake timers implementation instead of one backed by + * [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). + * + * @defaultValue + * The default is `false`. + */ + legacyFakeTimers?: true; +}; + +type FakeTimers = GlobalFakeTimersConfig & + ( + | (FakeTimersConfig & { + now?: Exclude; + }) + | LegacyFakeTimersConfig + ); export type HasteConfig = { /** Whether to hash files using SHA-1. */ @@ -76,6 +163,7 @@ export type DefaultOptions = { errorOnDeprecated: boolean; expand: boolean; extensionsToTreatAsEsm: Array; + fakeTimers: FakeTimers; forceCoverageMatch: Array; globals: ConfigGlobals; haste: HasteConfig; @@ -112,7 +200,6 @@ export type DefaultOptions = { testRegex: Array; testRunner: string; testSequencer: string; - timers: Timers; transformIgnorePatterns: Array; useStderr: boolean; watch: boolean; @@ -158,6 +245,7 @@ export type InitialOptions = Partial<{ displayName: string | DisplayName; expand: boolean; extensionsToTreatAsEsm: Array; + fakeTimers: FakeTimers; filter: string; findRelatedTests: boolean; forceCoverageMatch: Array; @@ -241,7 +329,6 @@ export type InitialOptions = Partial<{ testRunner: string; testSequencer: string; testTimeout: number; - timers: Timers; transform: { [regex: string]: string | TransformerConfig; }; @@ -363,6 +450,7 @@ export type ProjectConfig = { displayName?: DisplayName; errorOnDeprecated: boolean; extensionsToTreatAsEsm: Array; + fakeTimers: FakeTimers; filter?: string; forceCoverageMatch: Array; globalSetup?: string; @@ -401,7 +489,6 @@ export type ProjectConfig = { testPathIgnorePatterns: Array; testRegex: Array; testRunner: string; - timers: Timers; transform: Array<[string, string, Record]>; transformIgnorePatterns: Array; watchPathIgnorePatterns: Array; @@ -487,7 +574,6 @@ export type Argv = Arguments< testRunner: string; testSequencer: string; testTimeout: number | null | undefined; - timers: string; transform: string; transformIgnorePatterns: Array; unmockedModulePathPatterns: Array | null | undefined; diff --git a/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts b/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts index 6f2b022d2ee8..bcc54ead1baf 100644 --- a/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts +++ b/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts @@ -28,6 +28,7 @@ const defaultConfig = { coveragePathIgnorePatterns: [NODE_MODULES_REGEXP], coverageReporters: ['json', 'text', 'lcov', 'clover'], expand: false, + fakeTimers: {enableGlobally: false}, globals: {}, haste: {}, moduleDirectories: ['node_modules'], @@ -48,7 +49,6 @@ const defaultConfig = { testPathIgnorePatterns: [NODE_MODULES_REGEXP], testRegex: '(/__tests__/.*|(\\.|/)(test|spec))\\.[jt]sx?$', testResultsProcessor: null, - timers: 'real', transformIgnorePatterns: [NODE_MODULES_REGEXP], useStderr: false, verbose: null, @@ -77,6 +77,7 @@ const validConfig = { }, }, expand: false, + fakeTimers: {enableGlobally: false}, forceExit: false, globals: {}, haste: {}, @@ -111,7 +112,6 @@ const validConfig = { testRegex: '(/__tests__/.*|(\\.|/)(test|spec))\\.[jt]sx?$', testResultsProcessor: 'processor-node-module', testRunner: 'circus', - timers: 'real', transform: { '\\.js$': '/preprocessor.js', }, diff --git a/packages/jest-worker/src/workers/__tests__/processChild.test.js b/packages/jest-worker/src/workers/__tests__/processChild.test.js index ba579e052efe..55b29107bdf7 100644 --- a/packages/jest-worker/src/workers/__tests__/processChild.test.js +++ b/packages/jest-worker/src/workers/__tests__/processChild.test.js @@ -241,8 +241,6 @@ it('returns results immediately when function is synchronous', () => { }); it('returns results when it gets resolved if function is asynchronous', async () => { - jest.useRealTimers(); - process.emit('message', [ CHILD_MESSAGE_INITIALIZE, true, // Not really used here, but for flow type purity. diff --git a/packages/jest-worker/src/workers/__tests__/threadChild.test.js b/packages/jest-worker/src/workers/__tests__/threadChild.test.js index 657ce23a33bb..fe0107a926f2 100644 --- a/packages/jest-worker/src/workers/__tests__/threadChild.test.js +++ b/packages/jest-worker/src/workers/__tests__/threadChild.test.js @@ -268,8 +268,6 @@ it('returns results immediately when function is synchronous', () => { }); it('returns results when it gets resolved if function is asynchronous', async () => { - jest.useRealTimers(); - thread.emit('message', [ CHILD_MESSAGE_INITIALIZE, true, // Not really used here, but for flow type purity. diff --git a/packages/test-utils/src/config.ts b/packages/test-utils/src/config.ts index f86bbd3f0c65..448547d46749 100644 --- a/packages/test-utils/src/config.ts +++ b/packages/test-utils/src/config.ts @@ -78,6 +78,7 @@ const DEFAULT_PROJECT_CONFIG: Config.ProjectConfig = { displayName: undefined, errorOnDeprecated: false, extensionsToTreatAsEsm: [], + fakeTimers: {enableGlobally: false}, filter: undefined, forceCoverageMatch: [], globalSetup: undefined, @@ -116,7 +117,6 @@ const DEFAULT_PROJECT_CONFIG: Config.ProjectConfig = { testPathIgnorePatterns: [], testRegex: ['\\.test\\.js$'], testRunner: 'jest-circus/runner', - timers: 'real', transform: [], transformIgnorePatterns: [], unmockedModulePathPatterns: undefined, diff --git a/yarn.lock b/yarn.lock index 1c1b0414cf1f..ad5fc5a79327 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2651,10 +2651,11 @@ __metadata: version: 0.0.0-use.local resolution: "@jest/fake-timers@workspace:packages/jest-fake-timers" dependencies: + "@jest/test-utils": ^28.0.0-alpha.7 "@jest/types": ^28.0.0-alpha.7 "@sinonjs/fake-timers": ^9.1.1 "@types/node": "*" - "@types/sinonjs__fake-timers": ^8.1.1 + "@types/sinonjs__fake-timers": ^8.1.2 jest-message-util: ^28.0.0-alpha.7 jest-mock: ^28.0.0-alpha.7 jest-util: ^28.0.0-alpha.7 @@ -5424,10 +5425,10 @@ __metadata: languageName: node linkType: hard -"@types/sinonjs__fake-timers@npm:^8.1.1": - version: 8.1.1 - resolution: "@types/sinonjs__fake-timers@npm:8.1.1" - checksum: ca09d54d47091d87020824a73f026300fa06b17cd9f2f9b9387f28b549364b141ef194ee28db762f6588de71d8febcd17f753163cb7ea116b8387c18e80ebd5c +"@types/sinonjs__fake-timers@npm:^8.1.2": + version: 8.1.2 + resolution: "@types/sinonjs__fake-timers@npm:8.1.2" + checksum: bbc73a5ab6c0ec974929392f3d6e1e8db4ebad97ec506d785301e1c3d8a4f98a35b1aa95b97035daef02886fd8efd7788a2fa3ced2ec7105988bfd8dce61eedd languageName: node linkType: hard From d915e7df92b220dbe6e124585ba6459838a6c41c Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Tue, 5 Apr 2022 16:59:31 +0200 Subject: [PATCH 015/128] v28.0.0-alpha.8 --- lerna.json | 6 ++- packages/babel-jest/package.json | 6 +-- packages/expect-utils/package.json | 4 +- packages/expect/package.json | 10 ++--- packages/jest-circus/package.json | 24 +++++------ packages/jest-cli/package.json | 14 +++---- packages/jest-config/package.json | 22 +++++----- packages/jest-console/package.json | 10 ++--- packages/jest-core/package.json | 40 +++++++++---------- .../package.json | 6 +-- packages/jest-diff/package.json | 6 +-- packages/jest-each/package.json | 8 ++-- packages/jest-environment-jsdom/package.json | 14 +++---- packages/jest-environment-node/package.json | 14 +++---- packages/jest-environment/package.json | 8 ++-- packages/jest-expect/package.json | 6 +-- packages/jest-fake-timers/package.json | 12 +++--- packages/jest-globals/package.json | 8 ++-- packages/jest-haste-map/package.json | 10 ++--- packages/jest-jasmine2/package.json | 24 +++++------ packages/jest-leak-detector/package.json | 4 +- packages/jest-matcher-utils/package.json | 8 ++-- packages/jest-message-util/package.json | 6 +-- packages/jest-mock/package.json | 4 +- packages/jest-phabricator/package.json | 4 +- packages/jest-repl/package.json | 18 ++++----- packages/jest-reporters/package.json | 20 +++++----- .../jest-resolve-dependencies/package.json | 14 +++---- packages/jest-resolve/package.json | 8 ++-- packages/jest-runner/package.json | 30 +++++++------- packages/jest-runtime/package.json | 30 +++++++------- packages/jest-snapshot/package.json | 24 +++++------ packages/jest-test-result/package.json | 6 +-- packages/jest-test-sequencer/package.json | 10 ++--- packages/jest-transform/package.json | 10 ++--- packages/jest-types/package.json | 2 +- packages/jest-util/package.json | 4 +- packages/jest-validate/package.json | 6 +-- packages/jest-watcher/package.json | 8 ++-- packages/jest-worker/package.json | 4 +- packages/jest/package.json | 6 +-- packages/pretty-format/package.json | 4 +- packages/test-utils/package.json | 6 +-- 43 files changed, 245 insertions(+), 243 deletions(-) diff --git a/lerna.json b/lerna.json index f5c1b819448f..e21772fafa37 100644 --- a/lerna.json +++ b/lerna.json @@ -1,5 +1,7 @@ { - "packages": ["packages/*"], + "packages": [ + "packages/*" + ], "npmClient": "yarn", - "version": "28.0.0-alpha.7" + "version": "28.0.0-alpha.8" } diff --git a/packages/babel-jest/package.json b/packages/babel-jest/package.json index 61fbbffad96b..e4f440ac0341 100644 --- a/packages/babel-jest/package.json +++ b/packages/babel-jest/package.json @@ -1,7 +1,7 @@ { "name": "babel-jest", "description": "Jest plugin to use babel for transformation.", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,7 +18,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/transform": "^28.0.0-alpha.7", + "@jest/transform": "^28.0.0-alpha.8", "@types/babel__core": "^7.1.14", "babel-plugin-istanbul": "^6.1.1", "babel-preset-jest": "^28.0.0-alpha.6", @@ -28,7 +28,7 @@ }, "devDependencies": { "@babel/core": "^7.8.0", - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/graceful-fs": "^4.1.3" }, "peerDependencies": { diff --git a/packages/expect-utils/package.json b/packages/expect-utils/package.json index 86fe0fd74870..5d27746dbdac 100644 --- a/packages/expect-utils/package.json +++ b/packages/expect-utils/package.json @@ -1,6 +1,6 @@ { "name": "@jest/expect-utils", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -20,7 +20,7 @@ "jest-get-type": "^28.0.0-alpha.3" }, "devDependencies": { - "jest-matcher-utils": "^28.0.0-alpha.7" + "jest-matcher-utils": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/expect/package.json b/packages/expect/package.json index ec2734c77251..d2c688d7b5cc 100644 --- a/packages/expect/package.json +++ b/packages/expect/package.json @@ -1,6 +1,6 @@ { "name": "expect", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,13 +18,13 @@ "./build/matchers": "./build/matchers.js" }, "dependencies": { - "@jest/expect-utils": "^28.0.0-alpha.7", + "@jest/expect-utils": "^28.0.0-alpha.8", "jest-get-type": "^28.0.0-alpha.3", - "jest-matcher-utils": "^28.0.0-alpha.7", - "jest-message-util": "^28.0.0-alpha.7" + "jest-matcher-utils": "^28.0.0-alpha.8", + "jest-message-util": "^28.0.0-alpha.8" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@tsd/typescript": "~4.6.2", "chalk": "^4.0.0", "fast-check": "^2.0.0", diff --git a/packages/jest-circus/package.json b/packages/jest-circus/package.json index b0585d5e670e..2af0ca3d196b 100644 --- a/packages/jest-circus/package.json +++ b/packages/jest-circus/package.json @@ -1,6 +1,6 @@ { "name": "jest-circus", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,22 +18,22 @@ "./runner": "./runner.js" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.7", - "@jest/expect": "^28.0.0-alpha.7", - "@jest/test-result": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/environment": "^28.0.0-alpha.8", + "@jest/expect": "^28.0.0-alpha.8", + "@jest/test-result": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "chalk": "^4.0.0", "co": "^4.6.0", "dedent": "^0.7.0", "is-generator-fn": "^2.0.0", - "jest-each": "^28.0.0-alpha.7", - "jest-matcher-utils": "^28.0.0-alpha.7", - "jest-message-util": "^28.0.0-alpha.7", - "jest-runtime": "^28.0.0-alpha.7", - "jest-snapshot": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", - "pretty-format": "^28.0.0-alpha.7", + "jest-each": "^28.0.0-alpha.8", + "jest-matcher-utils": "^28.0.0-alpha.8", + "jest-message-util": "^28.0.0-alpha.8", + "jest-runtime": "^28.0.0-alpha.8", + "jest-snapshot": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", + "pretty-format": "^28.0.0-alpha.8", "slash": "^3.0.0", "stack-utils": "^2.0.3", "throat": "^6.0.1" diff --git a/packages/jest-cli/package.json b/packages/jest-cli/package.json index 15dad3d10dba..044cc532c4b4 100644 --- a/packages/jest-cli/package.json +++ b/packages/jest-cli/package.json @@ -1,7 +1,7 @@ { "name": "jest-cli", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,16 +13,16 @@ "./bin/jest": "./bin/jest.js" }, "dependencies": { - "@jest/core": "^28.0.0-alpha.7", - "@jest/test-result": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/core": "^28.0.0-alpha.8", + "@jest/test-result": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "chalk": "^4.0.0", "exit": "^0.1.2", "graceful-fs": "^4.2.9", "import-local": "^3.0.2", - "jest-config": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", - "jest-validate": "^28.0.0-alpha.7", + "jest-config": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", + "jest-validate": "^28.0.0-alpha.8", "prompts": "^2.0.1", "yargs": "^17.3.1" }, diff --git a/packages/jest-config/package.json b/packages/jest-config/package.json index fad9b7cb360a..ed1166374e3d 100644 --- a/packages/jest-config/package.json +++ b/packages/jest-config/package.json @@ -1,6 +1,6 @@ { "name": "jest-config", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -30,25 +30,25 @@ }, "dependencies": { "@babel/core": "^7.8.0", - "@jest/test-sequencer": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", - "babel-jest": "^28.0.0-alpha.7", + "@jest/test-sequencer": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", + "babel-jest": "^28.0.0-alpha.8", "chalk": "^4.0.0", "ci-info": "^3.2.0", "deepmerge": "^4.2.2", "glob": "^7.1.1", "graceful-fs": "^4.2.9", - "jest-circus": "^28.0.0-alpha.7", - "jest-environment-node": "^28.0.0-alpha.7", + "jest-circus": "^28.0.0-alpha.8", + "jest-environment-node": "^28.0.0-alpha.8", "jest-get-type": "^28.0.0-alpha.3", "jest-regex-util": "^28.0.0-alpha.6", - "jest-resolve": "^28.0.0-alpha.7", - "jest-runner": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", - "jest-validate": "^28.0.0-alpha.7", + "jest-resolve": "^28.0.0-alpha.8", + "jest-runner": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", + "jest-validate": "^28.0.0-alpha.8", "micromatch": "^4.0.4", "parse-json": "^5.2.0", - "pretty-format": "^28.0.0-alpha.7", + "pretty-format": "^28.0.0-alpha.8", "slash": "^3.0.0", "strip-json-comments": "^3.1.1" }, diff --git a/packages/jest-console/package.json b/packages/jest-console/package.json index fd3ea09ad91d..1d958cec5e19 100644 --- a/packages/jest-console/package.json +++ b/packages/jest-console/package.json @@ -1,6 +1,6 @@ { "name": "@jest/console", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,15 +17,15 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "chalk": "^4.0.0", - "jest-message-util": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", + "jest-message-util": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", "slash": "^3.0.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/node": "*" }, "engines": { diff --git a/packages/jest-core/package.json b/packages/jest-core/package.json index 71af163c66be..cd2bb18539dc 100644 --- a/packages/jest-core/package.json +++ b/packages/jest-core/package.json @@ -1,7 +1,7 @@ { "name": "@jest/core", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -12,11 +12,11 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/console": "^28.0.0-alpha.7", - "@jest/reporters": "^28.0.0-alpha.7", - "@jest/test-result": "^28.0.0-alpha.7", - "@jest/transform": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/console": "^28.0.0-alpha.8", + "@jest/reporters": "^28.0.0-alpha.8", + "@jest/test-result": "^28.0.0-alpha.8", + "@jest/transform": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "ansi-escapes": "^4.2.1", "chalk": "^4.0.0", @@ -24,27 +24,27 @@ "exit": "^0.1.2", "graceful-fs": "^4.2.9", "jest-changed-files": "^28.0.0-alpha.3", - "jest-config": "^28.0.0-alpha.7", - "jest-haste-map": "^28.0.0-alpha.7", - "jest-message-util": "^28.0.0-alpha.7", + "jest-config": "^28.0.0-alpha.8", + "jest-haste-map": "^28.0.0-alpha.8", + "jest-message-util": "^28.0.0-alpha.8", "jest-regex-util": "^28.0.0-alpha.6", - "jest-resolve": "^28.0.0-alpha.7", - "jest-resolve-dependencies": "^28.0.0-alpha.7", - "jest-runner": "^28.0.0-alpha.7", - "jest-runtime": "^28.0.0-alpha.7", - "jest-snapshot": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", - "jest-validate": "^28.0.0-alpha.7", - "jest-watcher": "^28.0.0-alpha.7", + "jest-resolve": "^28.0.0-alpha.8", + "jest-resolve-dependencies": "^28.0.0-alpha.8", + "jest-runner": "^28.0.0-alpha.8", + "jest-runtime": "^28.0.0-alpha.8", + "jest-snapshot": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", + "jest-validate": "^28.0.0-alpha.8", + "jest-watcher": "^28.0.0-alpha.8", "micromatch": "^4.0.4", - "pretty-format": "^28.0.0-alpha.7", + "pretty-format": "^28.0.0-alpha.8", "rimraf": "^3.0.0", "slash": "^3.0.0", "strip-ansi": "^6.0.0" }, "devDependencies": { - "@jest/test-sequencer": "^28.0.0-alpha.7", - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-sequencer": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/exit": "^0.1.30", "@types/graceful-fs": "^4.1.2", "@types/micromatch": "^4.0.1", diff --git a/packages/jest-create-cache-key-function/package.json b/packages/jest-create-cache-key-function/package.json index d739a1331cb9..cd16da4ab3cc 100644 --- a/packages/jest-create-cache-key-function/package.json +++ b/packages/jest-create-cache-key-function/package.json @@ -1,17 +1,17 @@ { "name": "@jest/create-cache-key-function", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", "directory": "packages/jest-create-cache-key-function" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.7" + "@jest/types": "^28.0.0-alpha.8" }, "devDependencies": { "@types/node": "*", - "jest-util": "^28.0.0-alpha.7" + "jest-util": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-diff/package.json b/packages/jest-diff/package.json index cf8a5383b42a..cf94c5f0a8fa 100644 --- a/packages/jest-diff/package.json +++ b/packages/jest-diff/package.json @@ -1,6 +1,6 @@ { "name": "jest-diff", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -20,10 +20,10 @@ "chalk": "^4.0.0", "diff-sequences": "^28.0.0-alpha.6", "jest-get-type": "^28.0.0-alpha.3", - "pretty-format": "^28.0.0-alpha.7" + "pretty-format": "^28.0.0-alpha.8" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "strip-ansi": "^6.0.0" }, "engines": { diff --git a/packages/jest-each/package.json b/packages/jest-each/package.json index b8f6de4f0f8d..8dae4cabb5d1 100644 --- a/packages/jest-each/package.json +++ b/packages/jest-each/package.json @@ -1,6 +1,6 @@ { "name": "jest-each", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "description": "Parameterised tests for Jest", "main": "./build/index.js", "types": "./build/index.d.ts", @@ -25,11 +25,11 @@ "author": "Matt Phillips (mattphillips)", "license": "MIT", "dependencies": { - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "chalk": "^4.0.0", "jest-get-type": "^28.0.0-alpha.3", - "jest-util": "^28.0.0-alpha.7", - "pretty-format": "^28.0.0-alpha.7" + "jest-util": "^28.0.0-alpha.8", + "pretty-format": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-environment-jsdom/package.json b/packages/jest-environment-jsdom/package.json index 3573314ac941..d5e29636b9db 100644 --- a/packages/jest-environment-jsdom/package.json +++ b/packages/jest-environment-jsdom/package.json @@ -1,6 +1,6 @@ { "name": "jest-environment-jsdom", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,17 +17,17 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.7", - "@jest/fake-timers": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/environment": "^28.0.0-alpha.8", + "@jest/fake-timers": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/jsdom": "^16.2.4", "@types/node": "*", - "jest-mock": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", + "jest-mock": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", "jsdom": "^19.0.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7" + "@jest/test-utils": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-environment-node/package.json b/packages/jest-environment-node/package.json index 8f98b71474bb..90d155384481 100644 --- a/packages/jest-environment-node/package.json +++ b/packages/jest-environment-node/package.json @@ -1,6 +1,6 @@ { "name": "jest-environment-node", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,15 +17,15 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.7", - "@jest/fake-timers": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/environment": "^28.0.0-alpha.8", + "@jest/fake-timers": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", - "jest-mock": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7" + "jest-mock": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7" + "@jest/test-utils": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-environment/package.json b/packages/jest-environment/package.json index 37f913825012..78158980bae5 100644 --- a/packages/jest-environment/package.json +++ b/packages/jest-environment/package.json @@ -1,6 +1,6 @@ { "name": "@jest/environment", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,10 +17,10 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/fake-timers": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/fake-timers": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", - "jest-mock": "^28.0.0-alpha.7" + "jest-mock": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-expect/package.json b/packages/jest-expect/package.json index 25c9936d766c..79e909ed9d9c 100644 --- a/packages/jest-expect/package.json +++ b/packages/jest-expect/package.json @@ -1,6 +1,6 @@ { "name": "@jest/expect", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,8 +17,8 @@ "./package.json": "./package.json" }, "dependencies": { - "expect": "^28.0.0-alpha.7", - "jest-snapshot": "^28.0.0-alpha.7" + "expect": "^28.0.0-alpha.8", + "jest-snapshot": "^28.0.0-alpha.8" }, "devDependencies": { "@tsd/typescript": "~4.6.2", diff --git a/packages/jest-fake-timers/package.json b/packages/jest-fake-timers/package.json index b029cb30b8ab..1f2c80dec533 100644 --- a/packages/jest-fake-timers/package.json +++ b/packages/jest-fake-timers/package.json @@ -1,6 +1,6 @@ { "name": "@jest/fake-timers", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,15 +17,15 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "@sinonjs/fake-timers": "^9.1.1", "@types/node": "*", - "jest-message-util": "^28.0.0-alpha.7", - "jest-mock": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7" + "jest-message-util": "^28.0.0-alpha.8", + "jest-mock": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/sinonjs__fake-timers": "^8.1.2" }, "engines": { diff --git a/packages/jest-globals/package.json b/packages/jest-globals/package.json index 8f30e0a3c787..7cf73b85cc3d 100644 --- a/packages/jest-globals/package.json +++ b/packages/jest-globals/package.json @@ -1,6 +1,6 @@ { "name": "@jest/globals", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -20,9 +20,9 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.7", - "@jest/expect": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7" + "@jest/environment": "^28.0.0-alpha.8", + "@jest/expect": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8" }, "publishConfig": { "access": "public" diff --git a/packages/jest-haste-map/package.json b/packages/jest-haste-map/package.json index 74b870927cd7..5cde56afce8c 100644 --- a/packages/jest-haste-map/package.json +++ b/packages/jest-haste-map/package.json @@ -1,6 +1,6 @@ { "name": "jest-haste-map", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,20 +17,20 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "@types/graceful-fs": "^4.1.2", "@types/node": "*", "anymatch": "^3.0.3", "fb-watchman": "^2.0.0", "graceful-fs": "^4.2.9", "jest-regex-util": "^28.0.0-alpha.6", - "jest-util": "^28.0.0-alpha.7", - "jest-worker": "^28.0.0-alpha.7", + "jest-util": "^28.0.0-alpha.8", + "jest-worker": "^28.0.0-alpha.8", "micromatch": "^4.0.4", "walker": "^1.0.7" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/fb-watchman": "^2.0.0", "@types/micromatch": "^4.0.1", "slash": "^3.0.0" diff --git a/packages/jest-jasmine2/package.json b/packages/jest-jasmine2/package.json index 9f6d1c8dcf14..24ae48e171fd 100644 --- a/packages/jest-jasmine2/package.json +++ b/packages/jest-jasmine2/package.json @@ -1,6 +1,6 @@ { "name": "jest-jasmine2", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,22 +17,22 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.7", - "@jest/expect": "^28.0.0-alpha.7", + "@jest/environment": "^28.0.0-alpha.8", + "@jest/expect": "^28.0.0-alpha.8", "@jest/source-map": "^28.0.0-alpha.6", - "@jest/test-result": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/test-result": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "chalk": "^4.0.0", "co": "^4.6.0", "is-generator-fn": "^2.0.0", - "jest-each": "^28.0.0-alpha.7", - "jest-matcher-utils": "^28.0.0-alpha.7", - "jest-message-util": "^28.0.0-alpha.7", - "jest-runtime": "^28.0.0-alpha.7", - "jest-snapshot": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", - "pretty-format": "^28.0.0-alpha.7", + "jest-each": "^28.0.0-alpha.8", + "jest-matcher-utils": "^28.0.0-alpha.8", + "jest-message-util": "^28.0.0-alpha.8", + "jest-runtime": "^28.0.0-alpha.8", + "jest-snapshot": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", + "pretty-format": "^28.0.0-alpha.8", "throat": "^6.0.1" }, "devDependencies": { diff --git a/packages/jest-leak-detector/package.json b/packages/jest-leak-detector/package.json index a28f49446ebc..8763a0ceb5af 100644 --- a/packages/jest-leak-detector/package.json +++ b/packages/jest-leak-detector/package.json @@ -1,6 +1,6 @@ { "name": "jest-leak-detector", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,7 +18,7 @@ }, "dependencies": { "jest-get-type": "^28.0.0-alpha.3", - "pretty-format": "^28.0.0-alpha.7" + "pretty-format": "^28.0.0-alpha.8" }, "devDependencies": { "@types/weak-napi": "^2.0.0", diff --git a/packages/jest-matcher-utils/package.json b/packages/jest-matcher-utils/package.json index 5bfe3412db4b..ff34ef3bd8a2 100644 --- a/packages/jest-matcher-utils/package.json +++ b/packages/jest-matcher-utils/package.json @@ -1,7 +1,7 @@ { "name": "jest-matcher-utils", "description": "A set of utility functions for expect and related packages", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -22,12 +22,12 @@ }, "dependencies": { "chalk": "^4.0.0", - "jest-diff": "^28.0.0-alpha.7", + "jest-diff": "^28.0.0-alpha.8", "jest-get-type": "^28.0.0-alpha.3", - "pretty-format": "^28.0.0-alpha.7" + "pretty-format": "^28.0.0-alpha.8" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/node": "*" }, "publishConfig": { diff --git a/packages/jest-message-util/package.json b/packages/jest-message-util/package.json index cbf467bee325..4ba9f7f236cd 100644 --- a/packages/jest-message-util/package.json +++ b/packages/jest-message-util/package.json @@ -1,6 +1,6 @@ { "name": "jest-message-util", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -21,12 +21,12 @@ }, "dependencies": { "@babel/code-frame": "^7.12.13", - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "@types/stack-utils": "^2.0.0", "chalk": "^4.0.0", "graceful-fs": "^4.2.9", "micromatch": "^4.0.4", - "pretty-format": "^28.0.0-alpha.7", + "pretty-format": "^28.0.0-alpha.8", "slash": "^3.0.0", "stack-utils": "^2.0.3" }, diff --git a/packages/jest-mock/package.json b/packages/jest-mock/package.json index 99dd15bd7656..bdb0c0afcf6f 100644 --- a/packages/jest-mock/package.json +++ b/packages/jest-mock/package.json @@ -1,6 +1,6 @@ { "name": "jest-mock", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,7 +17,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*" }, "devDependencies": { diff --git a/packages/jest-phabricator/package.json b/packages/jest-phabricator/package.json index 078f3cfd1ff6..231a1893a5b0 100644 --- a/packages/jest-phabricator/package.json +++ b/packages/jest-phabricator/package.json @@ -1,6 +1,6 @@ { "name": "jest-phabricator", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -15,7 +15,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/test-result": "^28.0.0-alpha.7" + "@jest/test-result": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-repl/package.json b/packages/jest-repl/package.json index 7373f5316d88..c223965d108a 100644 --- a/packages/jest-repl/package.json +++ b/packages/jest-repl/package.json @@ -1,6 +1,6 @@ { "name": "jest-repl", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -19,15 +19,15 @@ "./bin/jest-runtime-cli": "./bin/jest-runtime-cli.js" }, "dependencies": { - "@jest/console": "^28.0.0-alpha.7", - "@jest/environment": "^28.0.0-alpha.7", - "@jest/transform": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/console": "^28.0.0-alpha.8", + "@jest/environment": "^28.0.0-alpha.8", + "@jest/transform": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "chalk": "^4.0.0", - "jest-config": "^28.0.0-alpha.7", - "jest-runtime": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", - "jest-validate": "^28.0.0-alpha.7", + "jest-config": "^28.0.0-alpha.8", + "jest-runtime": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", + "jest-validate": "^28.0.0-alpha.8", "repl": "^0.1.3", "yargs": "^17.3.1" }, diff --git a/packages/jest-reporters/package.json b/packages/jest-reporters/package.json index f0e22116a7c1..6f1d4006813b 100644 --- a/packages/jest-reporters/package.json +++ b/packages/jest-reporters/package.json @@ -1,7 +1,7 @@ { "name": "@jest/reporters", "description": "Jest's reporters", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,10 +13,10 @@ }, "dependencies": { "@bcoe/v8-coverage": "^0.2.3", - "@jest/console": "^28.0.0-alpha.7", - "@jest/test-result": "^28.0.0-alpha.7", - "@jest/transform": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/console": "^28.0.0-alpha.8", + "@jest/test-result": "^28.0.0-alpha.8", + "@jest/transform": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "chalk": "^4.0.0", "collect-v8-coverage": "^1.0.0", @@ -28,10 +28,10 @@ "istanbul-lib-report": "^3.0.0", "istanbul-lib-source-maps": "^4.0.0", "istanbul-reports": "^3.1.3", - "jest-haste-map": "^28.0.0-alpha.7", - "jest-resolve": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", - "jest-worker": "^28.0.0-alpha.7", + "jest-haste-map": "^28.0.0-alpha.8", + "jest-resolve": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", + "jest-worker": "^28.0.0-alpha.8", "slash": "^3.0.0", "source-map": "^0.6.0", "string-length": "^4.0.1", @@ -39,7 +39,7 @@ "v8-to-istanbul": "^8.1.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/exit": "^0.1.30", "@types/glob": "^7.1.1", "@types/graceful-fs": "^4.1.3", diff --git a/packages/jest-resolve-dependencies/package.json b/packages/jest-resolve-dependencies/package.json index d8c59f7dca86..b17dd116adfc 100644 --- a/packages/jest-resolve-dependencies/package.json +++ b/packages/jest-resolve-dependencies/package.json @@ -1,6 +1,6 @@ { "name": "jest-resolve-dependencies", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,14 +18,14 @@ }, "dependencies": { "jest-regex-util": "^28.0.0-alpha.6", - "jest-snapshot": "^28.0.0-alpha.7" + "jest-snapshot": "^28.0.0-alpha.8" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", - "jest-haste-map": "^28.0.0-alpha.7", - "jest-resolve": "^28.0.0-alpha.7", - "jest-runtime": "^28.0.0-alpha.7" + "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", + "jest-haste-map": "^28.0.0-alpha.8", + "jest-resolve": "^28.0.0-alpha.8", + "jest-runtime": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-resolve/package.json b/packages/jest-resolve/package.json index 963c984e88c5..2affa9109365 100644 --- a/packages/jest-resolve/package.json +++ b/packages/jest-resolve/package.json @@ -1,6 +1,6 @@ { "name": "jest-resolve", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -19,10 +19,10 @@ "dependencies": { "chalk": "^4.0.0", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.7", + "jest-haste-map": "^28.0.0-alpha.8", "jest-pnp-resolver": "^1.2.2", - "jest-util": "^28.0.0-alpha.7", - "jest-validate": "^28.0.0-alpha.7", + "jest-util": "^28.0.0-alpha.8", + "jest-validate": "^28.0.0-alpha.8", "resolve": "^1.20.0", "resolve.exports": "^1.1.0", "slash": "^3.0.0" diff --git a/packages/jest-runner/package.json b/packages/jest-runner/package.json index 71cadb54a11d..6a9d5137755d 100644 --- a/packages/jest-runner/package.json +++ b/packages/jest-runner/package.json @@ -1,6 +1,6 @@ { "name": "jest-runner", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,24 +17,24 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/console": "^28.0.0-alpha.7", - "@jest/environment": "^28.0.0-alpha.7", - "@jest/test-result": "^28.0.0-alpha.7", - "@jest/transform": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/console": "^28.0.0-alpha.8", + "@jest/environment": "^28.0.0-alpha.8", + "@jest/test-result": "^28.0.0-alpha.8", + "@jest/transform": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "chalk": "^4.0.0", "emittery": "^0.8.1", "graceful-fs": "^4.2.9", "jest-docblock": "^28.0.0-alpha.6", - "jest-environment-node": "^28.0.0-alpha.7", - "jest-haste-map": "^28.0.0-alpha.7", - "jest-leak-detector": "^28.0.0-alpha.7", - "jest-message-util": "^28.0.0-alpha.7", - "jest-resolve": "^28.0.0-alpha.7", - "jest-runtime": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", - "jest-worker": "^28.0.0-alpha.7", + "jest-environment-node": "^28.0.0-alpha.8", + "jest-haste-map": "^28.0.0-alpha.8", + "jest-leak-detector": "^28.0.0-alpha.8", + "jest-message-util": "^28.0.0-alpha.8", + "jest-resolve": "^28.0.0-alpha.8", + "jest-runtime": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", + "jest-worker": "^28.0.0-alpha.8", "source-map-support": "^0.5.6", "throat": "^6.0.1" }, @@ -42,7 +42,7 @@ "@types/exit": "^0.1.30", "@types/graceful-fs": "^4.1.2", "@types/source-map-support": "^0.5.0", - "jest-jasmine2": "^28.0.0-alpha.7" + "jest-jasmine2": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-runtime/package.json b/packages/jest-runtime/package.json index 8e35b220bd36..f5fd2705e56c 100644 --- a/packages/jest-runtime/package.json +++ b/packages/jest-runtime/package.json @@ -1,6 +1,6 @@ { "name": "jest-runtime", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,35 +17,35 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.7", - "@jest/fake-timers": "^28.0.0-alpha.7", - "@jest/globals": "^28.0.0-alpha.7", + "@jest/environment": "^28.0.0-alpha.8", + "@jest/fake-timers": "^28.0.0-alpha.8", + "@jest/globals": "^28.0.0-alpha.8", "@jest/source-map": "^28.0.0-alpha.6", - "@jest/test-result": "^28.0.0-alpha.7", - "@jest/transform": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/test-result": "^28.0.0-alpha.8", + "@jest/transform": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "chalk": "^4.0.0", "cjs-module-lexer": "^1.0.0", "collect-v8-coverage": "^1.0.0", "execa": "^5.0.0", "glob": "^7.1.3", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.7", - "jest-message-util": "^28.0.0-alpha.7", - "jest-mock": "^28.0.0-alpha.7", + "jest-haste-map": "^28.0.0-alpha.8", + "jest-message-util": "^28.0.0-alpha.8", + "jest-mock": "^28.0.0-alpha.8", "jest-regex-util": "^28.0.0-alpha.6", - "jest-resolve": "^28.0.0-alpha.7", - "jest-snapshot": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", + "jest-resolve": "^28.0.0-alpha.8", + "jest-snapshot": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", "slash": "^3.0.0", "strip-bom": "^4.0.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/glob": "^7.1.1", "@types/graceful-fs": "^4.1.2", "@types/node": "^14.0.27", - "jest-environment-node": "^28.0.0-alpha.7" + "jest-environment-node": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-snapshot/package.json b/packages/jest-snapshot/package.json index 8d1d71f9ac16..cfea828d9016 100644 --- a/packages/jest-snapshot/package.json +++ b/packages/jest-snapshot/package.json @@ -1,6 +1,6 @@ { "name": "jest-snapshot", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -22,29 +22,29 @@ "@babel/plugin-syntax-typescript": "^7.7.2", "@babel/traverse": "^7.7.2", "@babel/types": "^7.0.0", - "@jest/expect-utils": "^28.0.0-alpha.7", - "@jest/transform": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/expect-utils": "^28.0.0-alpha.8", + "@jest/transform": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/babel__traverse": "^7.0.4", "@types/prettier": "^2.1.5", "babel-preset-current-node-syntax": "^1.0.0", "chalk": "^4.0.0", - "expect": "^28.0.0-alpha.7", + "expect": "^28.0.0-alpha.8", "graceful-fs": "^4.2.9", - "jest-diff": "^28.0.0-alpha.7", + "jest-diff": "^28.0.0-alpha.8", "jest-get-type": "^28.0.0-alpha.3", - "jest-haste-map": "^28.0.0-alpha.7", - "jest-matcher-utils": "^28.0.0-alpha.7", - "jest-message-util": "^28.0.0-alpha.7", - "jest-util": "^28.0.0-alpha.7", + "jest-haste-map": "^28.0.0-alpha.8", + "jest-matcher-utils": "^28.0.0-alpha.8", + "jest-message-util": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.8", "natural-compare": "^1.4.0", - "pretty-format": "^28.0.0-alpha.7", + "pretty-format": "^28.0.0-alpha.8", "semver": "^7.3.2" }, "devDependencies": { "@babel/preset-flow": "^7.7.2", "@babel/preset-react": "^7.7.2", - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/graceful-fs": "^4.1.3", "@types/natural-compare": "^1.4.0", "@types/semver": "^7.1.0", diff --git a/packages/jest-test-result/package.json b/packages/jest-test-result/package.json index ff7679b2c649..ed707e86e1ca 100644 --- a/packages/jest-test-result/package.json +++ b/packages/jest-test-result/package.json @@ -1,6 +1,6 @@ { "name": "@jest/test-result", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,8 +17,8 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/console": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/console": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/istanbul-lib-coverage": "^2.0.0", "collect-v8-coverage": "^1.0.0" }, diff --git a/packages/jest-test-sequencer/package.json b/packages/jest-test-sequencer/package.json index 6793d7b923ea..7b843967dce2 100644 --- a/packages/jest-test-sequencer/package.json +++ b/packages/jest-test-sequencer/package.json @@ -1,6 +1,6 @@ { "name": "@jest/test-sequencer", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,14 +17,14 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/test-result": "^28.0.0-alpha.7", + "@jest/test-result": "^28.0.0-alpha.8", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.7", - "jest-runtime": "^28.0.0-alpha.7", + "jest-haste-map": "^28.0.0-alpha.8", + "jest-runtime": "^28.0.0-alpha.8", "slash": "^3.0.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/graceful-fs": "^4.1.3" }, "engines": { diff --git a/packages/jest-transform/package.json b/packages/jest-transform/package.json index 47e4f5ff93be..8b869bda2754 100644 --- a/packages/jest-transform/package.json +++ b/packages/jest-transform/package.json @@ -1,6 +1,6 @@ { "name": "@jest/transform", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,15 +18,15 @@ }, "dependencies": { "@babel/core": "^7.1.0", - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "babel-plugin-istanbul": "^6.1.1", "chalk": "^4.0.0", "convert-source-map": "^1.4.0", "fast-json-stable-stringify": "^2.0.0", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.7", + "jest-haste-map": "^28.0.0-alpha.8", "jest-regex-util": "^28.0.0-alpha.6", - "jest-util": "^28.0.0-alpha.7", + "jest-util": "^28.0.0-alpha.8", "micromatch": "^4.0.4", "pirates": "^4.0.4", "slash": "^3.0.0", @@ -34,7 +34,7 @@ "write-file-atomic": "^4.0.1" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.7", + "@jest/test-utils": "^28.0.0-alpha.8", "@types/babel__core": "^7.1.0", "@types/convert-source-map": "^1.5.1", "@types/fast-json-stable-stringify": "^2.0.0", diff --git a/packages/jest-types/package.json b/packages/jest-types/package.json index 121bf752b188..ce7eb1d1fc55 100644 --- a/packages/jest-types/package.json +++ b/packages/jest-types/package.json @@ -1,6 +1,6 @@ { "name": "@jest/types", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/jest-util/package.json b/packages/jest-util/package.json index ac98886612ec..56a708729741 100644 --- a/packages/jest-util/package.json +++ b/packages/jest-util/package.json @@ -1,6 +1,6 @@ { "name": "jest-util", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,7 +17,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "chalk": "^4.0.0", "ci-info": "^3.2.0", diff --git a/packages/jest-validate/package.json b/packages/jest-validate/package.json index 48374155fa90..39e66e80b1bc 100644 --- a/packages/jest-validate/package.json +++ b/packages/jest-validate/package.json @@ -1,6 +1,6 @@ { "name": "jest-validate", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,12 +17,12 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "camelcase": "^6.2.0", "chalk": "^4.0.0", "jest-get-type": "^28.0.0-alpha.3", "leven": "^3.1.0", - "pretty-format": "^28.0.0-alpha.7" + "pretty-format": "^28.0.0-alpha.8" }, "devDependencies": { "@types/yargs": "^17.0.8" diff --git a/packages/jest-watcher/package.json b/packages/jest-watcher/package.json index ee49673ad755..b44d8a1bb73a 100644 --- a/packages/jest-watcher/package.json +++ b/packages/jest-watcher/package.json @@ -1,7 +1,7 @@ { "name": "jest-watcher", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -12,12 +12,12 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/test-result": "^28.0.0-alpha.7", - "@jest/types": "^28.0.0-alpha.7", + "@jest/test-result": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "ansi-escapes": "^4.2.1", "chalk": "^4.0.0", - "jest-util": "^28.0.0-alpha.7", + "jest-util": "^28.0.0-alpha.8", "string-length": "^4.0.1" }, "repository": { diff --git a/packages/jest-worker/package.json b/packages/jest-worker/package.json index 6cf6c4818039..2172efdf53e9 100644 --- a/packages/jest-worker/package.json +++ b/packages/jest-worker/package.json @@ -1,6 +1,6 @@ { "name": "jest-worker", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -25,7 +25,7 @@ "@types/merge-stream": "^1.1.2", "@types/supports-color": "^8.1.0", "get-stream": "^6.0.0", - "jest-leak-detector": "^28.0.0-alpha.7", + "jest-leak-detector": "^28.0.0-alpha.8", "worker-farm": "^1.6.0" }, "engines": { diff --git a/packages/jest/package.json b/packages/jest/package.json index bcaa39dcd172..5fc40a9d42e4 100644 --- a/packages/jest/package.json +++ b/packages/jest/package.json @@ -1,7 +1,7 @@ { "name": "jest", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,9 +13,9 @@ "./bin/jest": "./bin/jest.js" }, "dependencies": { - "@jest/core": "^28.0.0-alpha.7", + "@jest/core": "^28.0.0-alpha.8", "import-local": "^3.0.2", - "jest-cli": "^28.0.0-alpha.7" + "jest-cli": "^28.0.0-alpha.8" }, "peerDependencies": { "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" diff --git a/packages/pretty-format/package.json b/packages/pretty-format/package.json index ce24c3d35e5f..2d40b5cf389a 100644 --- a/packages/pretty-format/package.json +++ b/packages/pretty-format/package.json @@ -1,6 +1,6 @@ { "name": "pretty-format", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -30,7 +30,7 @@ "@types/react-is": "^17.0.0", "@types/react-test-renderer": "*", "immutable": "^4.0.0", - "jest-util": "^28.0.0-alpha.7", + "jest-util": "^28.0.0-alpha.8", "react": "*", "react-dom": "*", "react-test-renderer": "*" diff --git a/packages/test-utils/package.json b/packages/test-utils/package.json index d05164c8ab92..a2fec8186e93 100644 --- a/packages/test-utils/package.json +++ b/packages/test-utils/package.json @@ -1,6 +1,6 @@ { "name": "@jest/test-utils", - "version": "28.0.0-alpha.7", + "version": "28.0.0-alpha.8", "private": true, "license": "MIT", "main": "./build/index.js", @@ -13,11 +13,11 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.7", + "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "ansi-regex": "^5.0.1", "ansi-styles": "^5.0.0", - "pretty-format": "^28.0.0-alpha.7", + "pretty-format": "^28.0.0-alpha.8", "semver": "^7.3.2" }, "devDependencies": { From a592ee05c0be0bd7be728f157226a73a29faa73c Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Tue, 5 Apr 2022 17:02:55 +0200 Subject: [PATCH 016/128] chore: update lockfile after release --- yarn.lock | 468 +++++++++++++++++++++++++++--------------------------- 1 file changed, 234 insertions(+), 234 deletions(-) diff --git a/yarn.lock b/yarn.lock index ad5fc5a79327..649a9eb95f00 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2531,16 +2531,16 @@ __metadata: languageName: node linkType: hard -"@jest/console@^28.0.0-alpha.7, @jest/console@workspace:packages/jest-console": +"@jest/console@^28.0.0-alpha.8, @jest/console@workspace:packages/jest-console": version: 0.0.0-use.local resolution: "@jest/console@workspace:packages/jest-console" dependencies: - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/node": "*" chalk: ^4.0.0 - jest-message-util: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 + jest-message-util: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 slash: ^3.0.0 languageName: unknown linkType: soft @@ -2559,17 +2559,17 @@ __metadata: languageName: node linkType: hard -"@jest/core@^28.0.0-alpha.7, @jest/core@workspace:packages/jest-core": +"@jest/core@^28.0.0-alpha.8, @jest/core@workspace:packages/jest-core": version: 0.0.0-use.local resolution: "@jest/core@workspace:packages/jest-core" dependencies: - "@jest/console": ^28.0.0-alpha.7 - "@jest/reporters": ^28.0.0-alpha.7 - "@jest/test-result": ^28.0.0-alpha.7 - "@jest/test-sequencer": ^28.0.0-alpha.7 - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/transform": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/console": ^28.0.0-alpha.8 + "@jest/reporters": ^28.0.0-alpha.8 + "@jest/test-result": ^28.0.0-alpha.8 + "@jest/test-sequencer": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/transform": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/exit": ^0.1.30 "@types/graceful-fs": ^4.1.2 "@types/micromatch": ^4.0.1 @@ -2581,20 +2581,20 @@ __metadata: exit: ^0.1.2 graceful-fs: ^4.2.9 jest-changed-files: ^28.0.0-alpha.3 - jest-config: ^28.0.0-alpha.7 - jest-haste-map: ^28.0.0-alpha.7 - jest-message-util: ^28.0.0-alpha.7 + jest-config: ^28.0.0-alpha.8 + jest-haste-map: ^28.0.0-alpha.8 + jest-message-util: ^28.0.0-alpha.8 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.7 - jest-resolve-dependencies: ^28.0.0-alpha.7 - jest-runner: ^28.0.0-alpha.7 - jest-runtime: ^28.0.0-alpha.7 - jest-snapshot: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 - jest-validate: ^28.0.0-alpha.7 - jest-watcher: ^28.0.0-alpha.7 + jest-resolve: ^28.0.0-alpha.8 + jest-resolve-dependencies: ^28.0.0-alpha.8 + jest-runner: ^28.0.0-alpha.8 + jest-runtime: ^28.0.0-alpha.8 + jest-snapshot: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 + jest-validate: ^28.0.0-alpha.8 + jest-watcher: ^28.0.0-alpha.8 micromatch: ^4.0.4 - pretty-format: ^28.0.0-alpha.7 + pretty-format: ^28.0.0-alpha.8 rimraf: ^3.0.0 slash: ^3.0.0 strip-ansi: ^6.0.0 @@ -2610,65 +2610,65 @@ __metadata: version: 0.0.0-use.local resolution: "@jest/create-cache-key-function@workspace:packages/jest-create-cache-key-function" dependencies: - "@jest/types": ^28.0.0-alpha.7 + "@jest/types": ^28.0.0-alpha.8 "@types/node": "*" - jest-util: ^28.0.0-alpha.7 + jest-util: ^28.0.0-alpha.8 languageName: unknown linkType: soft -"@jest/environment@^28.0.0-alpha.7, @jest/environment@workspace:packages/jest-environment": +"@jest/environment@^28.0.0-alpha.8, @jest/environment@workspace:packages/jest-environment": version: 0.0.0-use.local resolution: "@jest/environment@workspace:packages/jest-environment" dependencies: - "@jest/fake-timers": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/fake-timers": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/node": "*" - jest-mock: ^28.0.0-alpha.7 + jest-mock: ^28.0.0-alpha.8 languageName: unknown linkType: soft -"@jest/expect-utils@^28.0.0-alpha.7, @jest/expect-utils@workspace:packages/expect-utils": +"@jest/expect-utils@^28.0.0-alpha.8, @jest/expect-utils@workspace:packages/expect-utils": version: 0.0.0-use.local resolution: "@jest/expect-utils@workspace:packages/expect-utils" dependencies: jest-get-type: ^28.0.0-alpha.3 - jest-matcher-utils: ^28.0.0-alpha.7 + jest-matcher-utils: ^28.0.0-alpha.8 languageName: unknown linkType: soft -"@jest/expect@^28.0.0-alpha.7, @jest/expect@workspace:packages/jest-expect": +"@jest/expect@^28.0.0-alpha.8, @jest/expect@workspace:packages/jest-expect": version: 0.0.0-use.local resolution: "@jest/expect@workspace:packages/jest-expect" dependencies: "@tsd/typescript": ~4.6.2 - expect: ^28.0.0-alpha.7 - jest-snapshot: ^28.0.0-alpha.7 + expect: ^28.0.0-alpha.8 + jest-snapshot: ^28.0.0-alpha.8 tsd-lite: ^0.5.1 languageName: unknown linkType: soft -"@jest/fake-timers@^28.0.0-alpha.7, @jest/fake-timers@workspace:packages/jest-fake-timers": +"@jest/fake-timers@^28.0.0-alpha.8, @jest/fake-timers@workspace:packages/jest-fake-timers": version: 0.0.0-use.local resolution: "@jest/fake-timers@workspace:packages/jest-fake-timers" dependencies: - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@sinonjs/fake-timers": ^9.1.1 "@types/node": "*" "@types/sinonjs__fake-timers": ^8.1.2 - jest-message-util: ^28.0.0-alpha.7 - jest-mock: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 + jest-message-util: ^28.0.0-alpha.8 + jest-mock: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 languageName: unknown linkType: soft -"@jest/globals@^28.0.0-alpha.7, @jest/globals@workspace:*, @jest/globals@workspace:packages/jest-globals": +"@jest/globals@^28.0.0-alpha.8, @jest/globals@workspace:*, @jest/globals@workspace:packages/jest-globals": version: 0.0.0-use.local resolution: "@jest/globals@workspace:packages/jest-globals" dependencies: - "@jest/environment": ^28.0.0-alpha.7 - "@jest/expect": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/environment": ^28.0.0-alpha.8 + "@jest/expect": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 languageName: unknown linkType: soft @@ -2759,16 +2759,16 @@ __metadata: languageName: unknown linkType: soft -"@jest/reporters@^28.0.0-alpha.7, @jest/reporters@workspace:packages/jest-reporters": +"@jest/reporters@^28.0.0-alpha.8, @jest/reporters@workspace:packages/jest-reporters": version: 0.0.0-use.local resolution: "@jest/reporters@workspace:packages/jest-reporters" dependencies: "@bcoe/v8-coverage": ^0.2.3 - "@jest/console": ^28.0.0-alpha.7 - "@jest/test-result": ^28.0.0-alpha.7 - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/transform": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/console": ^28.0.0-alpha.8 + "@jest/test-result": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/transform": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/exit": ^0.1.30 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 @@ -2789,10 +2789,10 @@ __metadata: istanbul-lib-report: ^3.0.0 istanbul-lib-source-maps: ^4.0.0 istanbul-reports: ^3.1.3 - jest-haste-map: ^28.0.0-alpha.7 - jest-resolve: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 - jest-worker: ^28.0.0-alpha.7 + jest-haste-map: ^28.0.0-alpha.8 + jest-resolve: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 + jest-worker: ^28.0.0-alpha.8 mock-fs: ^5.1.2 slash: ^3.0.0 source-map: ^0.6.0 @@ -2827,12 +2827,12 @@ __metadata: languageName: unknown linkType: soft -"@jest/test-result@^28.0.0-alpha.7, @jest/test-result@workspace:packages/jest-test-result": +"@jest/test-result@^28.0.0-alpha.8, @jest/test-result@workspace:packages/jest-test-result": version: 0.0.0-use.local resolution: "@jest/test-result@workspace:packages/jest-test-result" dependencies: - "@jest/console": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/console": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/istanbul-lib-coverage": ^2.0.0 collect-v8-coverage: ^1.0.0 languageName: unknown @@ -2850,41 +2850,41 @@ __metadata: languageName: node linkType: hard -"@jest/test-sequencer@^28.0.0-alpha.7, @jest/test-sequencer@workspace:packages/jest-test-sequencer": +"@jest/test-sequencer@^28.0.0-alpha.8, @jest/test-sequencer@workspace:packages/jest-test-sequencer": version: 0.0.0-use.local resolution: "@jest/test-sequencer@workspace:packages/jest-test-sequencer" dependencies: - "@jest/test-result": ^28.0.0-alpha.7 - "@jest/test-utils": ^28.0.0-alpha.7 + "@jest/test-result": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.8 "@types/graceful-fs": ^4.1.3 graceful-fs: ^4.2.9 - jest-haste-map: ^28.0.0-alpha.7 - jest-runtime: ^28.0.0-alpha.7 + jest-haste-map: ^28.0.0-alpha.8 + jest-runtime: ^28.0.0-alpha.8 slash: ^3.0.0 languageName: unknown linkType: soft -"@jest/test-utils@^28.0.0-alpha.7, @jest/test-utils@workspace:*, @jest/test-utils@workspace:packages/test-utils": +"@jest/test-utils@^28.0.0-alpha.8, @jest/test-utils@workspace:*, @jest/test-utils@workspace:packages/test-utils": version: 0.0.0-use.local resolution: "@jest/test-utils@workspace:packages/test-utils" dependencies: - "@jest/types": ^28.0.0-alpha.7 + "@jest/types": ^28.0.0-alpha.8 "@types/node": "*" "@types/semver": ^7.1.0 ansi-regex: ^5.0.1 ansi-styles: ^5.0.0 - pretty-format: ^28.0.0-alpha.7 + pretty-format: ^28.0.0-alpha.8 semver: ^7.3.2 languageName: unknown linkType: soft -"@jest/transform@^28.0.0-alpha.7, @jest/transform@workspace:packages/jest-transform": +"@jest/transform@^28.0.0-alpha.8, @jest/transform@workspace:packages/jest-transform": version: 0.0.0-use.local resolution: "@jest/transform@workspace:packages/jest-transform" dependencies: "@babel/core": ^7.1.0 - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/babel__core": ^7.1.0 "@types/convert-source-map": ^1.5.1 "@types/fast-json-stable-stringify": ^2.0.0 @@ -2897,9 +2897,9 @@ __metadata: dedent: ^0.7.0 fast-json-stable-stringify: ^2.0.0 graceful-fs: ^4.2.9 - jest-haste-map: ^28.0.0-alpha.7 + jest-haste-map: ^28.0.0-alpha.8 jest-regex-util: ^28.0.0-alpha.6 - jest-util: ^28.0.0-alpha.7 + jest-util: ^28.0.0-alpha.8 micromatch: ^4.0.4 pirates: ^4.0.4 slash: ^3.0.0 @@ -2908,7 +2908,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/types@^28.0.0-alpha.7, @jest/types@workspace:packages/jest-types": +"@jest/types@^28.0.0-alpha.8, @jest/types@workspace:packages/jest-types": version: 0.0.0-use.local resolution: "@jest/types@workspace:packages/jest-types" dependencies: @@ -6664,8 +6664,8 @@ __metadata: resolution: "babel-jest@workspace:packages/babel-jest" dependencies: "@babel/core": ^7.8.0 - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/transform": ^28.0.0-alpha.7 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/transform": ^28.0.0-alpha.8 "@types/babel__core": ^7.1.14 "@types/graceful-fs": ^4.1.3 babel-plugin-istanbul: ^6.1.1 @@ -10288,19 +10288,19 @@ __metadata: languageName: node linkType: hard -"expect@^28.0.0-alpha.7, expect@workspace:*, expect@workspace:packages/expect": +"expect@^28.0.0-alpha.8, expect@workspace:*, expect@workspace:packages/expect": version: 0.0.0-use.local resolution: "expect@workspace:packages/expect" dependencies: - "@jest/expect-utils": ^28.0.0-alpha.7 - "@jest/test-utils": ^28.0.0-alpha.7 + "@jest/expect-utils": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.8 "@tsd/typescript": ~4.6.2 chalk: ^4.0.0 fast-check: ^2.0.0 immutable: ^4.0.0 jest-get-type: ^28.0.0-alpha.3 - jest-matcher-utils: ^28.0.0-alpha.7 - jest-message-util: ^28.0.0-alpha.7 + jest-matcher-utils: ^28.0.0-alpha.8 + jest-message-util: ^28.0.0-alpha.8 tsd-lite: ^0.5.1 languageName: unknown linkType: soft @@ -13008,16 +13008,16 @@ __metadata: languageName: unknown linkType: soft -"jest-circus@^28.0.0-alpha.7, jest-circus@workspace:packages/jest-circus": +"jest-circus@^28.0.0-alpha.8, jest-circus@workspace:packages/jest-circus": version: 0.0.0-use.local resolution: "jest-circus@workspace:packages/jest-circus" dependencies: "@babel/core": ^7.1.0 "@babel/register": ^7.0.0 - "@jest/environment": ^28.0.0-alpha.7 - "@jest/expect": ^28.0.0-alpha.7 - "@jest/test-result": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/environment": ^28.0.0-alpha.8 + "@jest/expect": ^28.0.0-alpha.8 + "@jest/test-result": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/co": ^4.6.0 "@types/dedent": ^0.7.0 "@types/graceful-fs": ^4.1.3 @@ -13029,26 +13029,26 @@ __metadata: execa: ^5.0.0 graceful-fs: ^4.2.9 is-generator-fn: ^2.0.0 - jest-each: ^28.0.0-alpha.7 - jest-matcher-utils: ^28.0.0-alpha.7 - jest-message-util: ^28.0.0-alpha.7 - jest-runtime: ^28.0.0-alpha.7 - jest-snapshot: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 - pretty-format: ^28.0.0-alpha.7 + jest-each: ^28.0.0-alpha.8 + jest-matcher-utils: ^28.0.0-alpha.8 + jest-message-util: ^28.0.0-alpha.8 + jest-runtime: ^28.0.0-alpha.8 + jest-snapshot: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.8 slash: ^3.0.0 stack-utils: ^2.0.3 throat: ^6.0.1 languageName: unknown linkType: soft -"jest-cli@^28.0.0-alpha.7, jest-cli@workspace:packages/jest-cli": +"jest-cli@^28.0.0-alpha.8, jest-cli@workspace:packages/jest-cli": version: 0.0.0-use.local resolution: "jest-cli@workspace:packages/jest-cli" dependencies: - "@jest/core": ^28.0.0-alpha.7 - "@jest/test-result": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/core": ^28.0.0-alpha.8 + "@jest/test-result": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/exit": ^0.1.30 "@types/graceful-fs": ^4.1.3 "@types/prompts": ^2.0.1 @@ -13057,9 +13057,9 @@ __metadata: exit: ^0.1.2 graceful-fs: ^4.2.9 import-local: ^3.0.2 - jest-config: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 - jest-validate: ^28.0.0-alpha.7 + jest-config: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 + jest-validate: ^28.0.0-alpha.8 prompts: ^2.0.1 yargs: ^17.3.1 peerDependencies: @@ -13072,33 +13072,33 @@ __metadata: languageName: unknown linkType: soft -"jest-config@^28.0.0-alpha.7, jest-config@workspace:packages/jest-config": +"jest-config@^28.0.0-alpha.8, jest-config@workspace:packages/jest-config": version: 0.0.0-use.local resolution: "jest-config@workspace:packages/jest-config" dependencies: "@babel/core": ^7.8.0 - "@jest/test-sequencer": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/test-sequencer": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 - babel-jest: ^28.0.0-alpha.7 + babel-jest: ^28.0.0-alpha.8 chalk: ^4.0.0 ci-info: ^3.2.0 deepmerge: ^4.2.2 glob: ^7.1.1 graceful-fs: ^4.2.9 - jest-circus: ^28.0.0-alpha.7 - jest-environment-node: ^28.0.0-alpha.7 + jest-circus: ^28.0.0-alpha.8 + jest-environment-node: ^28.0.0-alpha.8 jest-get-type: ^28.0.0-alpha.3 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.7 - jest-runner: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 - jest-validate: ^28.0.0-alpha.7 + jest-resolve: ^28.0.0-alpha.8 + jest-runner: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 + jest-validate: ^28.0.0-alpha.8 micromatch: ^4.0.4 parse-json: ^5.2.0 - pretty-format: ^28.0.0-alpha.7 + pretty-format: ^28.0.0-alpha.8 semver: ^7.3.5 slash: ^3.0.0 strip-json-comments: ^3.1.1 @@ -13115,15 +13115,15 @@ __metadata: languageName: unknown linkType: soft -"jest-diff@^28.0.0-alpha.7, jest-diff@workspace:packages/jest-diff": +"jest-diff@^28.0.0-alpha.8, jest-diff@workspace:packages/jest-diff": version: 0.0.0-use.local resolution: "jest-diff@workspace:packages/jest-diff" dependencies: - "@jest/test-utils": ^28.0.0-alpha.7 + "@jest/test-utils": ^28.0.0-alpha.8 chalk: ^4.0.0 diff-sequences: ^28.0.0-alpha.6 jest-get-type: ^28.0.0-alpha.3 - pretty-format: ^28.0.0-alpha.7 + pretty-format: ^28.0.0-alpha.8 strip-ansi: ^6.0.0 languageName: unknown linkType: soft @@ -13149,15 +13149,15 @@ __metadata: languageName: unknown linkType: soft -"jest-each@^28.0.0-alpha.7, jest-each@workspace:packages/jest-each": +"jest-each@^28.0.0-alpha.8, jest-each@workspace:packages/jest-each": version: 0.0.0-use.local resolution: "jest-each@workspace:packages/jest-each" dependencies: - "@jest/types": ^28.0.0-alpha.7 + "@jest/types": ^28.0.0-alpha.8 chalk: ^4.0.0 jest-get-type: ^28.0.0-alpha.3 - jest-util: ^28.0.0-alpha.7 - pretty-format: ^28.0.0-alpha.7 + jest-util: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.8 languageName: unknown linkType: soft @@ -13165,14 +13165,14 @@ __metadata: version: 0.0.0-use.local resolution: "jest-environment-jsdom@workspace:packages/jest-environment-jsdom" dependencies: - "@jest/environment": ^28.0.0-alpha.7 - "@jest/fake-timers": ^28.0.0-alpha.7 - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/environment": ^28.0.0-alpha.8 + "@jest/fake-timers": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/jsdom": ^16.2.4 "@types/node": "*" - jest-mock: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 + jest-mock: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 jsdom: ^19.0.0 languageName: unknown linkType: soft @@ -13181,13 +13181,13 @@ __metadata: version: 0.0.0-use.local resolution: "jest-environment-node@workspace:packages/jest-environment-node" dependencies: - "@jest/environment": ^28.0.0-alpha.7 - "@jest/fake-timers": ^28.0.0-alpha.7 - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/environment": ^28.0.0-alpha.8 + "@jest/fake-timers": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/node": "*" - jest-mock: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 + jest-mock: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 languageName: unknown linkType: soft @@ -13211,12 +13211,12 @@ __metadata: languageName: node linkType: hard -"jest-haste-map@^28.0.0-alpha.7, jest-haste-map@workspace:packages/jest-haste-map": +"jest-haste-map@^28.0.0-alpha.8, jest-haste-map@workspace:packages/jest-haste-map": version: 0.0.0-use.local resolution: "jest-haste-map@workspace:packages/jest-haste-map" dependencies: - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/fb-watchman": ^2.0.0 "@types/graceful-fs": ^4.1.2 "@types/micromatch": ^4.0.1 @@ -13226,8 +13226,8 @@ __metadata: fsevents: ^2.3.2 graceful-fs: ^4.2.9 jest-regex-util: ^28.0.0-alpha.6 - jest-util: ^28.0.0-alpha.7 - jest-worker: ^28.0.0-alpha.7 + jest-util: ^28.0.0-alpha.8 + jest-worker: ^28.0.0-alpha.8 micromatch: ^4.0.4 slash: ^3.0.0 walker: ^1.0.7 @@ -13262,27 +13262,27 @@ __metadata: languageName: node linkType: hard -"jest-jasmine2@^28.0.0-alpha.7, jest-jasmine2@workspace:packages/jest-jasmine2": +"jest-jasmine2@^28.0.0-alpha.8, jest-jasmine2@workspace:packages/jest-jasmine2": version: 0.0.0-use.local resolution: "jest-jasmine2@workspace:packages/jest-jasmine2" dependencies: - "@jest/environment": ^28.0.0-alpha.7 - "@jest/expect": ^28.0.0-alpha.7 + "@jest/environment": ^28.0.0-alpha.8 + "@jest/expect": ^28.0.0-alpha.8 "@jest/source-map": ^28.0.0-alpha.6 - "@jest/test-result": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/test-result": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/co": ^4.6.2 "@types/node": "*" chalk: ^4.0.0 co: ^4.6.0 is-generator-fn: ^2.0.0 - jest-each: ^28.0.0-alpha.7 - jest-matcher-utils: ^28.0.0-alpha.7 - jest-message-util: ^28.0.0-alpha.7 - jest-runtime: ^28.0.0-alpha.7 - jest-snapshot: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 - pretty-format: ^28.0.0-alpha.7 + jest-each: ^28.0.0-alpha.8 + jest-matcher-utils: ^28.0.0-alpha.8 + jest-message-util: ^28.0.0-alpha.8 + jest-runtime: ^28.0.0-alpha.8 + jest-snapshot: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.8 throat: ^6.0.1 languageName: unknown linkType: soft @@ -13299,27 +13299,27 @@ __metadata: languageName: node linkType: hard -"jest-leak-detector@^28.0.0-alpha.7, jest-leak-detector@workspace:packages/jest-leak-detector": +"jest-leak-detector@^28.0.0-alpha.8, jest-leak-detector@workspace:packages/jest-leak-detector": version: 0.0.0-use.local resolution: "jest-leak-detector@workspace:packages/jest-leak-detector" dependencies: "@types/weak-napi": ^2.0.0 jest-get-type: ^28.0.0-alpha.3 - pretty-format: ^28.0.0-alpha.7 + pretty-format: ^28.0.0-alpha.8 weak-napi: ^2.0.1 languageName: unknown linkType: soft -"jest-matcher-utils@^28.0.0-alpha.7, jest-matcher-utils@workspace:packages/jest-matcher-utils": +"jest-matcher-utils@^28.0.0-alpha.8, jest-matcher-utils@workspace:packages/jest-matcher-utils": version: 0.0.0-use.local resolution: "jest-matcher-utils@workspace:packages/jest-matcher-utils" dependencies: - "@jest/test-utils": ^28.0.0-alpha.7 + "@jest/test-utils": ^28.0.0-alpha.8 "@types/node": "*" chalk: ^4.0.0 - jest-diff: ^28.0.0-alpha.7 + jest-diff: ^28.0.0-alpha.8 jest-get-type: ^28.0.0-alpha.3 - pretty-format: ^28.0.0-alpha.7 + pretty-format: ^28.0.0-alpha.8 languageName: unknown linkType: soft @@ -13335,12 +13335,12 @@ __metadata: languageName: node linkType: hard -"jest-message-util@^28.0.0-alpha.7, jest-message-util@workspace:packages/jest-message-util": +"jest-message-util@^28.0.0-alpha.8, jest-message-util@workspace:packages/jest-message-util": version: 0.0.0-use.local resolution: "jest-message-util@workspace:packages/jest-message-util" dependencies: "@babel/code-frame": ^7.12.13 - "@jest/types": ^28.0.0-alpha.7 + "@jest/types": ^28.0.0-alpha.8 "@types/babel__code-frame": ^7.0.0 "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 @@ -13348,7 +13348,7 @@ __metadata: chalk: ^4.0.0 graceful-fs: ^4.2.9 micromatch: ^4.0.4 - pretty-format: ^28.0.0-alpha.7 + pretty-format: ^28.0.0-alpha.8 slash: ^3.0.0 stack-utils: ^2.0.3 languageName: unknown @@ -13371,11 +13371,11 @@ __metadata: languageName: node linkType: hard -"jest-mock@^28.0.0-alpha.7, jest-mock@workspace:*, jest-mock@workspace:packages/jest-mock": +"jest-mock@^28.0.0-alpha.8, jest-mock@workspace:*, jest-mock@workspace:packages/jest-mock": version: 0.0.0-use.local resolution: "jest-mock@workspace:packages/jest-mock" dependencies: - "@jest/types": ^28.0.0-alpha.7 + "@jest/types": ^28.0.0-alpha.8 "@tsd/typescript": ~4.6.2 "@types/node": "*" tsd-lite: ^0.5.1 @@ -13386,7 +13386,7 @@ __metadata: version: 0.0.0-use.local resolution: "jest-phabricator@workspace:packages/jest-phabricator" dependencies: - "@jest/test-result": ^28.0.0-alpha.7 + "@jest/test-result": ^28.0.0-alpha.8 languageName: unknown linkType: soft @@ -13428,17 +13428,17 @@ __metadata: version: 0.0.0-use.local resolution: "jest-repl@workspace:packages/jest-repl" dependencies: - "@jest/console": ^28.0.0-alpha.7 - "@jest/environment": ^28.0.0-alpha.7 - "@jest/transform": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/console": ^28.0.0-alpha.8 + "@jest/environment": ^28.0.0-alpha.8 + "@jest/transform": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/yargs": ^17.0.8 chalk: ^4.0.0 execa: ^5.0.0 - jest-config: ^28.0.0-alpha.7 - jest-runtime: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 - jest-validate: ^28.0.0-alpha.7 + jest-config: ^28.0.0-alpha.8 + jest-runtime: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 + jest-validate: ^28.0.0-alpha.8 repl: ^0.1.3 yargs: ^17.3.1 bin: @@ -13447,21 +13447,21 @@ __metadata: languageName: unknown linkType: soft -"jest-resolve-dependencies@^28.0.0-alpha.7, jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies": +"jest-resolve-dependencies@^28.0.0-alpha.8, jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies": version: 0.0.0-use.local resolution: "jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies" dependencies: - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 - jest-haste-map: ^28.0.0-alpha.7 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 + jest-haste-map: ^28.0.0-alpha.8 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.7 - jest-runtime: ^28.0.0-alpha.7 - jest-snapshot: ^28.0.0-alpha.7 + jest-resolve: ^28.0.0-alpha.8 + jest-runtime: ^28.0.0-alpha.8 + jest-snapshot: ^28.0.0-alpha.8 languageName: unknown linkType: soft -"jest-resolve@^28.0.0-alpha.7, jest-resolve@workspace:packages/jest-resolve": +"jest-resolve@^28.0.0-alpha.8, jest-resolve@workspace:packages/jest-resolve": version: 0.0.0-use.local resolution: "jest-resolve@workspace:packages/jest-resolve" dependencies: @@ -13469,10 +13469,10 @@ __metadata: "@types/resolve": ^1.20.0 chalk: ^4.0.0 graceful-fs: ^4.2.9 - jest-haste-map: ^28.0.0-alpha.7 + jest-haste-map: ^28.0.0-alpha.8 jest-pnp-resolver: ^1.2.2 - jest-util: ^28.0.0-alpha.7 - jest-validate: ^28.0.0-alpha.7 + jest-util: ^28.0.0-alpha.8 + jest-validate: ^28.0.0-alpha.8 resolve: ^1.20.0 resolve.exports: ^1.1.0 slash: ^3.0.0 @@ -13493,15 +13493,15 @@ __metadata: languageName: node linkType: hard -"jest-runner@^28.0.0-alpha.7, jest-runner@workspace:packages/jest-runner": +"jest-runner@^28.0.0-alpha.8, jest-runner@workspace:packages/jest-runner": version: 0.0.0-use.local resolution: "jest-runner@workspace:packages/jest-runner" dependencies: - "@jest/console": ^28.0.0-alpha.7 - "@jest/environment": ^28.0.0-alpha.7 - "@jest/test-result": ^28.0.0-alpha.7 - "@jest/transform": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/console": ^28.0.0-alpha.8 + "@jest/environment": ^28.0.0-alpha.8 + "@jest/test-result": ^28.0.0-alpha.8 + "@jest/transform": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/exit": ^0.1.30 "@types/graceful-fs": ^4.1.2 "@types/node": "*" @@ -13510,32 +13510,32 @@ __metadata: emittery: ^0.8.1 graceful-fs: ^4.2.9 jest-docblock: ^28.0.0-alpha.6 - jest-environment-node: ^28.0.0-alpha.7 - jest-haste-map: ^28.0.0-alpha.7 - jest-jasmine2: ^28.0.0-alpha.7 - jest-leak-detector: ^28.0.0-alpha.7 - jest-message-util: ^28.0.0-alpha.7 - jest-resolve: ^28.0.0-alpha.7 - jest-runtime: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 - jest-worker: ^28.0.0-alpha.7 + jest-environment-node: ^28.0.0-alpha.8 + jest-haste-map: ^28.0.0-alpha.8 + jest-jasmine2: ^28.0.0-alpha.8 + jest-leak-detector: ^28.0.0-alpha.8 + jest-message-util: ^28.0.0-alpha.8 + jest-resolve: ^28.0.0-alpha.8 + jest-runtime: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 + jest-worker: ^28.0.0-alpha.8 source-map-support: ^0.5.6 throat: ^6.0.1 languageName: unknown linkType: soft -"jest-runtime@^28.0.0-alpha.7, jest-runtime@workspace:packages/jest-runtime": +"jest-runtime@^28.0.0-alpha.8, jest-runtime@workspace:packages/jest-runtime": version: 0.0.0-use.local resolution: "jest-runtime@workspace:packages/jest-runtime" dependencies: - "@jest/environment": ^28.0.0-alpha.7 - "@jest/fake-timers": ^28.0.0-alpha.7 - "@jest/globals": ^28.0.0-alpha.7 + "@jest/environment": ^28.0.0-alpha.8 + "@jest/fake-timers": ^28.0.0-alpha.8 + "@jest/globals": ^28.0.0-alpha.8 "@jest/source-map": ^28.0.0-alpha.6 - "@jest/test-result": ^28.0.0-alpha.7 - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/transform": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/test-result": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/transform": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.2 "@types/node": ^14.0.27 @@ -13545,14 +13545,14 @@ __metadata: execa: ^5.0.0 glob: ^7.1.3 graceful-fs: ^4.2.9 - jest-environment-node: ^28.0.0-alpha.7 - jest-haste-map: ^28.0.0-alpha.7 - jest-message-util: ^28.0.0-alpha.7 - jest-mock: ^28.0.0-alpha.7 + jest-environment-node: ^28.0.0-alpha.8 + jest-haste-map: ^28.0.0-alpha.8 + jest-message-util: ^28.0.0-alpha.8 + jest-mock: ^28.0.0-alpha.8 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.7 - jest-snapshot: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 + jest-resolve: ^28.0.0-alpha.8 + jest-snapshot: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 slash: ^3.0.0 strip-bom: ^4.0.0 languageName: unknown @@ -13588,7 +13588,7 @@ __metadata: languageName: node linkType: hard -"jest-snapshot@^28.0.0-alpha.7, jest-snapshot@workspace:*, jest-snapshot@workspace:packages/jest-snapshot": +"jest-snapshot@^28.0.0-alpha.8, jest-snapshot@workspace:*, jest-snapshot@workspace:packages/jest-snapshot": version: 0.0.0-use.local resolution: "jest-snapshot@workspace:packages/jest-snapshot" dependencies: @@ -13599,10 +13599,10 @@ __metadata: "@babel/preset-react": ^7.7.2 "@babel/traverse": ^7.7.2 "@babel/types": ^7.0.0 - "@jest/expect-utils": ^28.0.0-alpha.7 - "@jest/test-utils": ^28.0.0-alpha.7 - "@jest/transform": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/expect-utils": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/transform": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/babel__traverse": ^7.0.4 "@types/graceful-fs": ^4.1.3 "@types/natural-compare": ^1.4.0 @@ -13612,26 +13612,26 @@ __metadata: ansi-styles: ^5.0.0 babel-preset-current-node-syntax: ^1.0.0 chalk: ^4.0.0 - expect: ^28.0.0-alpha.7 + expect: ^28.0.0-alpha.8 graceful-fs: ^4.2.9 - jest-diff: ^28.0.0-alpha.7 + jest-diff: ^28.0.0-alpha.8 jest-get-type: ^28.0.0-alpha.3 - jest-haste-map: ^28.0.0-alpha.7 - jest-matcher-utils: ^28.0.0-alpha.7 - jest-message-util: ^28.0.0-alpha.7 - jest-util: ^28.0.0-alpha.7 + jest-haste-map: ^28.0.0-alpha.8 + jest-matcher-utils: ^28.0.0-alpha.8 + jest-message-util: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.8 natural-compare: ^1.4.0 prettier: ^2.0.0 - pretty-format: ^28.0.0-alpha.7 + pretty-format: ^28.0.0-alpha.8 semver: ^7.3.2 languageName: unknown linkType: soft -"jest-util@^28.0.0-alpha.7, jest-util@workspace:packages/jest-util": +"jest-util@^28.0.0-alpha.8, jest-util@workspace:packages/jest-util": version: 0.0.0-use.local resolution: "jest-util@workspace:packages/jest-util" dependencies: - "@jest/types": ^28.0.0-alpha.7 + "@jest/types": ^28.0.0-alpha.8 "@types/graceful-fs": ^4.1.2 "@types/node": "*" "@types/picomatch": ^2.2.2 @@ -13670,17 +13670,17 @@ __metadata: languageName: node linkType: hard -"jest-validate@^28.0.0-alpha.7, jest-validate@workspace:packages/jest-validate": +"jest-validate@^28.0.0-alpha.8, jest-validate@workspace:packages/jest-validate": version: 0.0.0-use.local resolution: "jest-validate@workspace:packages/jest-validate" dependencies: - "@jest/types": ^28.0.0-alpha.7 + "@jest/types": ^28.0.0-alpha.8 "@types/yargs": ^17.0.8 camelcase: ^6.2.0 chalk: ^4.0.0 jest-get-type: ^28.0.0-alpha.3 leven: ^3.1.0 - pretty-format: ^28.0.0-alpha.7 + pretty-format: ^28.0.0-alpha.8 languageName: unknown linkType: soft @@ -13715,16 +13715,16 @@ __metadata: languageName: node linkType: hard -"jest-watcher@^28.0.0-alpha.7, jest-watcher@workspace:packages/jest-watcher": +"jest-watcher@^28.0.0-alpha.8, jest-watcher@workspace:packages/jest-watcher": version: 0.0.0-use.local resolution: "jest-watcher@workspace:packages/jest-watcher" dependencies: - "@jest/test-result": ^28.0.0-alpha.7 - "@jest/types": ^28.0.0-alpha.7 + "@jest/test-result": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.8 "@types/node": "*" ansi-escapes: ^4.2.1 chalk: ^4.0.0 - jest-util: ^28.0.0-alpha.7 + jest-util: ^28.0.0-alpha.8 string-length: ^4.0.1 languageName: unknown linkType: soft @@ -13768,7 +13768,7 @@ __metadata: languageName: unknown linkType: soft -"jest-worker@^28.0.0-alpha.7, jest-worker@workspace:packages/jest-worker": +"jest-worker@^28.0.0-alpha.8, jest-worker@workspace:packages/jest-worker": version: 0.0.0-use.local resolution: "jest-worker@workspace:packages/jest-worker" dependencies: @@ -13776,7 +13776,7 @@ __metadata: "@types/node": "*" "@types/supports-color": ^8.1.0 get-stream: ^6.0.0 - jest-leak-detector: ^28.0.0-alpha.7 + jest-leak-detector: ^28.0.0-alpha.8 merge-stream: ^2.0.0 supports-color: ^8.0.0 worker-farm: ^1.6.0 @@ -13818,9 +13818,9 @@ __metadata: version: 0.0.0-use.local resolution: "jest@workspace:packages/jest" dependencies: - "@jest/core": ^28.0.0-alpha.7 + "@jest/core": ^28.0.0-alpha.8 import-local: ^3.0.2 - jest-cli: ^28.0.0-alpha.7 + jest-cli: ^28.0.0-alpha.8 peerDependencies: node-notifier: ^8.0.1 || ^9.0.0 || ^10.0.0 peerDependenciesMeta: @@ -17941,7 +17941,7 @@ __metadata: languageName: node linkType: hard -"pretty-format@^28.0.0-alpha.7, pretty-format@workspace:packages/pretty-format": +"pretty-format@^28.0.0-alpha.8, pretty-format@workspace:packages/pretty-format": version: 0.0.0-use.local resolution: "pretty-format@workspace:packages/pretty-format" dependencies: @@ -17952,7 +17952,7 @@ __metadata: ansi-regex: ^5.0.1 ansi-styles: ^5.0.0 immutable: ^4.0.0 - jest-util: ^28.0.0-alpha.7 + jest-util: ^28.0.0-alpha.8 react: "*" react-dom: "*" react-is: ^17.0.1 From fd2a9c305ffda5dbb66d31fa6e551e255734dc34 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Wed, 6 Apr 2022 07:49:55 +0200 Subject: [PATCH 017/128] chore(deps): bump codecov/codecov-action from 2 to 3 (#12634) --- .github/workflows/nodejs.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/nodejs.yml b/.github/workflows/nodejs.yml index 7281963ff76c..fef63f5fa0c1 100644 --- a/.github/workflows/nodejs.yml +++ b/.github/workflows/nodejs.yml @@ -179,7 +179,7 @@ jobs: - name: map coverage run: node ./scripts/mapCoverage.js if: always() - - uses: codecov/codecov-action@v2 + - uses: codecov/codecov-action@v3 if: always() with: directory: ./coverage From 72ae96aed9865e7f24e6db89024ca7b04fe62cb9 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 6 Apr 2022 08:14:53 +0200 Subject: [PATCH 018/128] chore: format lerna.json --- package.json | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/package.json b/package.json index da9da1721c48..6bb11a6a134e 100644 --- a/package.json +++ b/package.json @@ -131,6 +131,12 @@ "options": { "trailingComma": "es5" } + }, + { + "files": "lerna.json", + "options": { + "parser": "json-stringify" + } }, { "files": ".yarnrc.yml", From 65139c0bec88d7312d58dc3ed56bf5f54a01e0e2 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 6 Apr 2022 09:39:32 +0200 Subject: [PATCH 019/128] chore: bump babel (#12637) --- package.json | 3 +- yarn.lock | 149 +++++++++++++++++++++++++++------------------------ 2 files changed, 80 insertions(+), 72 deletions(-) diff --git a/package.json b/package.json index 6bb11a6a134e..7671053f75bf 100644 --- a/package.json +++ b/package.json @@ -132,7 +132,7 @@ "trailingComma": "es5" } }, - { + { "files": "lerna.json", "options": { "parser": "json-stringify" @@ -164,7 +164,6 @@ "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" }, "resolutions": { - "@jest/create-cache-key-function": "workspace:*", "@testing-library/dom/pretty-format": "26.6.1", "babel-jest": "workspace:*", "jest": "workspace:*", diff --git a/yarn.lock b/yarn.lock index 649a9eb95f00..7876f4cf96ec 100644 --- a/yarn.lock +++ b/yarn.lock @@ -378,9 +378,9 @@ __metadata: languageName: node linkType: hard -"@babel/helper-create-class-features-plugin@npm:^7.16.10, @babel/helper-create-class-features-plugin@npm:^7.16.7, @babel/helper-create-class-features-plugin@npm:^7.17.1": - version: 7.17.1 - resolution: "@babel/helper-create-class-features-plugin@npm:7.17.1" +"@babel/helper-create-class-features-plugin@npm:^7.16.10, @babel/helper-create-class-features-plugin@npm:^7.16.7, @babel/helper-create-class-features-plugin@npm:^7.17.6": + version: 7.17.6 + resolution: "@babel/helper-create-class-features-plugin@npm:7.17.6" dependencies: "@babel/helper-annotate-as-pure": ^7.16.7 "@babel/helper-environment-visitor": ^7.16.7 @@ -391,7 +391,7 @@ __metadata: "@babel/helper-split-export-declaration": ^7.16.7 peerDependencies: "@babel/core": ^7.0.0 - checksum: fb791071dcaa664640d7f1d041772c6b57a8a456720bf7cb21aa055845fad98c644cc7707f03aa94abe8720d19a7c69fd5984fe02fe57b7e99a69f77aa501fc8 + checksum: d85a5b3f9a18a661372d77462e6ea2a6a03f1083f8b3055ed165284214af9ea6ad677f6bcc4b5ce215da27f95fa93064580d4b6723b578c480ecf17dd31a4307 languageName: node linkType: hard @@ -473,11 +473,11 @@ __metadata: linkType: hard "@babel/helper-member-expression-to-functions@npm:^7.16.7": - version: 7.16.7 - resolution: "@babel/helper-member-expression-to-functions@npm:7.16.7" + version: 7.17.7 + resolution: "@babel/helper-member-expression-to-functions@npm:7.17.7" dependencies: - "@babel/types": ^7.16.7 - checksum: e275378022278a7e7974a3f65566690f1804ac88c5f4e848725cf936f61cd1e2557e88cfb6cb4fea92ae5a95ad89d78dbccc9a53715d4363f84c9fd109272c18 + "@babel/types": ^7.17.0 + checksum: 70f361bab627396c714c3938e94a569cb0da522179328477cdbc4318e4003c2666387ad4931d6bd5de103338c667c9e4bbe3e917fc8c527b3f3eb6175b888b7d languageName: node linkType: hard @@ -553,7 +553,7 @@ __metadata: languageName: node linkType: hard -"@babel/helper-simple-access@npm:^7.16.7, @babel/helper-simple-access@npm:^7.17.7": +"@babel/helper-simple-access@npm:^7.17.7": version: 7.17.7 resolution: "@babel/helper-simple-access@npm:7.17.7" dependencies: @@ -687,30 +687,30 @@ __metadata: linkType: hard "@babel/plugin-proposal-class-static-block@npm:^7.16.7": - version: 7.16.7 - resolution: "@babel/plugin-proposal-class-static-block@npm:7.16.7" + version: 7.17.6 + resolution: "@babel/plugin-proposal-class-static-block@npm:7.17.6" dependencies: - "@babel/helper-create-class-features-plugin": ^7.16.7 + "@babel/helper-create-class-features-plugin": ^7.17.6 "@babel/helper-plugin-utils": ^7.16.7 "@babel/plugin-syntax-class-static-block": ^7.14.5 peerDependencies: "@babel/core": ^7.12.0 - checksum: 3b95b5137e089f0be17de667299ea2e28867b6310ab94219a5a89ac7675824e69f316d31930586142b9f432122ef3b98eb05fffdffae01b5587019ce9aab4ef3 + checksum: 0ef00d73b4a7667059f71614669fb5ec989a0a6d5fe58118310c892507f2556a6f3ae66f0c547cd06e50bdf3ff528ef486e611079d41ef321300c967d2c26e1d languageName: node linkType: hard "@babel/plugin-proposal-decorators@npm:*": - version: 7.17.2 - resolution: "@babel/plugin-proposal-decorators@npm:7.17.2" + version: 7.17.8 + resolution: "@babel/plugin-proposal-decorators@npm:7.17.8" dependencies: - "@babel/helper-create-class-features-plugin": ^7.17.1 + "@babel/helper-create-class-features-plugin": ^7.17.6 "@babel/helper-plugin-utils": ^7.16.7 "@babel/helper-replace-supers": ^7.16.7 "@babel/plugin-syntax-decorators": ^7.17.0 charcodes: ^0.2.0 peerDependencies: "@babel/core": ^7.0.0-0 - checksum: da5424d51e49912a1784a7074e8fb7b2d55b4a41c32bf05a829a81987274068e170f469de81d95d177def3480f7de3402a1808d599ad91f98fdaa44023a416da + checksum: 8687de0ef0d671bc0c7e2ae0a7970055f8f6a0c8a50dcf81fe54bad85ffb59447ad7d75169f891244ef4a5a7bc2d146d753b7077635597fd998a44db632481ae languageName: node linkType: hard @@ -1207,13 +1207,13 @@ __metadata: linkType: hard "@babel/plugin-transform-destructuring@npm:^7.0.0, @babel/plugin-transform-destructuring@npm:^7.16.7": - version: 7.17.3 - resolution: "@babel/plugin-transform-destructuring@npm:7.17.3" + version: 7.17.7 + resolution: "@babel/plugin-transform-destructuring@npm:7.17.7" dependencies: "@babel/helper-plugin-utils": ^7.16.7 peerDependencies: "@babel/core": ^7.0.0-0 - checksum: af58115da1b5f1b7aa9c07af8fee53c1db05d2d68be3ba67aae162242d22e5ccd1bcd0fb149fced4618b31c0c6b4f99d32b472567c5f0807586b7fe5216ba7f0 + checksum: 767ecf6640fea9a06a4859f0c34daa30ac7d146a96476caa1f77081d5b6e43699f45e14acd52682078f2b7c230ff0814312b41f61b21ca2b5f9c5a2cc93c2b58 languageName: node linkType: hard @@ -1324,31 +1324,31 @@ __metadata: linkType: hard "@babel/plugin-transform-modules-commonjs@npm:^7.0.0, @babel/plugin-transform-modules-commonjs@npm:^7.1.0, @babel/plugin-transform-modules-commonjs@npm:^7.16.8": - version: 7.16.8 - resolution: "@babel/plugin-transform-modules-commonjs@npm:7.16.8" + version: 7.17.7 + resolution: "@babel/plugin-transform-modules-commonjs@npm:7.17.7" dependencies: - "@babel/helper-module-transforms": ^7.16.7 + "@babel/helper-module-transforms": ^7.17.7 "@babel/helper-plugin-utils": ^7.16.7 - "@babel/helper-simple-access": ^7.16.7 + "@babel/helper-simple-access": ^7.17.7 babel-plugin-dynamic-import-node: ^2.3.3 peerDependencies: "@babel/core": ^7.0.0-0 - checksum: c0ac00f5457e12cac7825b14725b6fc787bef78945181469ff79f07ef0fd7df021cb00fe1d3a9f35fc9bc92ae59e6e3fc9075a70b627dfe10e00d0907892aace + checksum: d84385d89465f8241cbeed8069dc54fb15ee0465119a3326c65ee93ce93019b7a9953b23e22a67203aa2ebf81ac444eadf6d37912d453ec7ba2dce9872bb6490 languageName: node linkType: hard "@babel/plugin-transform-modules-systemjs@npm:^7.16.7": - version: 7.16.7 - resolution: "@babel/plugin-transform-modules-systemjs@npm:7.16.7" + version: 7.17.8 + resolution: "@babel/plugin-transform-modules-systemjs@npm:7.17.8" dependencies: "@babel/helper-hoist-variables": ^7.16.7 - "@babel/helper-module-transforms": ^7.16.7 + "@babel/helper-module-transforms": ^7.17.7 "@babel/helper-plugin-utils": ^7.16.7 "@babel/helper-validator-identifier": ^7.16.7 babel-plugin-dynamic-import-node: ^2.3.3 peerDependencies: "@babel/core": ^7.0.0-0 - checksum: 2e50ae45a725eeafac5a9d30e07a5e17ab8dcf62c3528cf4efe444fc6f12cd3c4e42e911a9aa37abab169687a98b29a4418eeafcf2031f9917162ac36105cb1b + checksum: 058c0e7987aab64c4019bc9eab3f80c5dd05bec737e230e5c60e9222dfb3d01b2dfa3aa1db6cbb75a4095c40af3bba2e3a60170b1570a158d3e781376569ce49 languageName: node linkType: hard @@ -1785,8 +1785,8 @@ __metadata: linkType: hard "@babel/register@npm:^7.0.0": - version: 7.17.0 - resolution: "@babel/register@npm:7.17.0" + version: 7.17.7 + resolution: "@babel/register@npm:7.17.7" dependencies: clone-deep: ^4.0.1 find-cache-dir: ^2.0.0 @@ -1795,7 +1795,7 @@ __metadata: source-map-support: ^0.5.16 peerDependencies: "@babel/core": ^7.0.0-0 - checksum: 1d8e888c104022c2924803fc9e217c99f8a9b87dc5bf8ea1ddd9921765102c8267d2bd92d4f42aaa1b5ca3713ea400580b29702bb89829a59d63baf0321eb284 + checksum: b4b352a29487e9a45f3694e3f7cacc24668add2c3f9a45a5c8768a39cf495b1b49b7c95f0ebc6e415db4ac66317d20de15b3de96ca40f76d192137c4ad4cc7ce languageName: node linkType: hard @@ -2606,7 +2606,16 @@ __metadata: languageName: unknown linkType: soft -"@jest/create-cache-key-function@workspace:*, @jest/create-cache-key-function@workspace:packages/jest-create-cache-key-function": +"@jest/create-cache-key-function@npm:^27.0.1": + version: 27.5.1 + resolution: "@jest/create-cache-key-function@npm:27.5.1" + dependencies: + "@jest/types": ^27.5.1 + checksum: a6c3a8c769aca6f66f5dc80f1c77e66980b4f213a6b2a15a92ba3595f032848a1261c06c9c798dcf2b672b1ffbefad5085af89d130548741c85ddbe0cf4284e7 + languageName: node + linkType: hard + +"@jest/create-cache-key-function@workspace:packages/jest-create-cache-key-function": version: 0.0.0-use.local resolution: "@jest/create-cache-key-function@workspace:packages/jest-create-cache-key-function" dependencies: @@ -4113,11 +4122,11 @@ __metadata: linkType: hard "@react-native-community/cli-debugger-ui@npm:^6.0.0-rc.0": - version: 6.0.0-rc.0 - resolution: "@react-native-community/cli-debugger-ui@npm:6.0.0-rc.0" + version: 6.0.0 + resolution: "@react-native-community/cli-debugger-ui@npm:6.0.0" dependencies: serve-static: ^1.13.1 - checksum: 8e044f8cf7744cd42a1459283d47ccc6a41746fd07760a1422f76744ed79cf258ffe69c3fa93f83a0438c68586af046573fa7e9687c87a464f063353366eae41 + checksum: 3257e7efcd9849124adca07facd414729c0402774fb5593cd0b5343f4410c8306f0b2a65d0ef2f676a372fd5ca130fe21365fa3411b5c490bd27b1fc1911bf9c languageName: node linkType: hard @@ -4187,8 +4196,8 @@ __metadata: linkType: hard "@react-native-community/cli-server-api@npm:^6.4.0": - version: 6.4.0 - resolution: "@react-native-community/cli-server-api@npm:6.4.0" + version: 6.4.3 + resolution: "@react-native-community/cli-server-api@npm:6.4.3" dependencies: "@react-native-community/cli-debugger-ui": ^6.0.0-rc.0 "@react-native-community/cli-tools": ^6.2.0 @@ -4199,7 +4208,7 @@ __metadata: pretty-format: ^26.6.2 serve-static: ^1.13.1 ws: ^1.1.0 - checksum: 287998dccc417a6fa82e43f18934341d637d1a68c8e52ccaf4d48c13dc93786f5ea8d7ab9ba1618e7895e21c8371889c403d0a676ec5dda2732f9d302db97f08 + checksum: 52b36ebbfc19c2f39350cbd01069703ed64885f90fccdd6e3f71b5e464fcb49ce41308bd6eb9b1306206122277f4b5bd2416fe326b7948b8d99300916aa738fa languageName: node linkType: hard @@ -5188,9 +5197,9 @@ __metadata: linkType: hard "@types/node@npm:^14.0.27": - version: 14.18.11 - resolution: "@types/node@npm:14.18.11" - checksum: 58f75d05406004b83f1fd4c72115d2c180f22812bd48187b89b27dd9ea09f90774b2261f068e94bf6a6792a1f33a585b624135be3c4b6e2acd766043148754a7 + version: 14.18.12 + resolution: "@types/node@npm:14.18.12" + checksum: 8a0273caa0584020adb8802784fc7d4f18f05e6c205335b7f3818a91d6b0c22736b9f51da3428d5bc54076ad47f1a4d6d57990a3ce8489a520ac66b2b3ff24bc languageName: node linkType: hard @@ -6205,9 +6214,9 @@ __metadata: linkType: hard "ansi-regex@npm:^4.1.0": - version: 4.1.0 - resolution: "ansi-regex@npm:4.1.0" - checksum: 97aa4659538d53e5e441f5ef2949a3cffcb838e57aeaad42c4194e9d7ddb37246a6526c4ca85d3940a9d1e19b11cc2e114530b54c9d700c8baf163c31779baf8 + version: 4.1.1 + resolution: "ansi-regex@npm:4.1.1" + checksum: b1a6ee44cb6ecdabaa770b2ed500542714d4395d71c7e5c25baa631f680fb2ad322eb9ba697548d498a6fd366949fc8b5bfcf48d49a32803611f648005b01888 languageName: node linkType: hard @@ -7101,12 +7110,12 @@ __metadata: languageName: node linkType: hard -"bplist-parser@npm:0.3.0": - version: 0.3.0 - resolution: "bplist-parser@npm:0.3.0" +"bplist-parser@npm:0.3.1": + version: 0.3.1 + resolution: "bplist-parser@npm:0.3.1" dependencies: big-integer: 1.6.x - checksum: f1c49e4850eabda94b63a1764507cfa33c4e85f6289164964de06cb781d753cca63ccde4c2334999b6fd58ac85cab11f716a1e2fcdc31cd2213f718439c5383c + checksum: 7cabc5beadb7530f100cfdcce2b2f1d5d1674309b20f281b9b376022b2de55e86904598f1fd67254ec7f6ac1b74d67dc92c3445eb4cef5dec21c36c58d4a1106 languageName: node linkType: hard @@ -8701,9 +8710,9 @@ __metadata: linkType: hard "dayjs@npm:^1.8.15": - version: 1.10.7 - resolution: "dayjs@npm:1.10.7" - checksum: a0a4ca95abaa03d0702161dc2c35d16121188e342f5052b9c61cdf784dab68af766f477c04f87f71c6af666fd4d13db9b9853b87265850d6093b7b04e1bb1cd7 + version: 1.11.0 + resolution: "dayjs@npm:1.11.0" + checksum: 2d36f6d71345114cdcd89147adf9e05b4f8fe81684e08c8bf1f86b140aa0b86ecc3cae661a9348d96feb7fbefd03e1bc3697303688e95209670abcb36b4ece15 languageName: node linkType: hard @@ -10732,9 +10741,9 @@ __metadata: linkType: hard "flow-parser@npm:0.*": - version: 0.171.0 - resolution: "flow-parser@npm:0.171.0" - checksum: fbeab8e8324050efaeb7b1def51bb6224000803e12f50987a0f471d8e959913ae8774b07de6325465dff41caa3fb950f2d5adba8b365bde7c57b9ea109a9baa1 + version: 0.175.1 + resolution: "flow-parser@npm:0.175.1" + checksum: 85e9597aa8a5d572fc3a867bd65c5579d0f2fb624faaeca47e3abc20c57c49305b5224a65cbbd28d131824990b3d99f6dfb7d94f049d731e82093435fe923b96 languageName: node linkType: hard @@ -11393,9 +11402,9 @@ __metadata: linkType: hard "graceful-fs@npm:^4.1.11, graceful-fs@npm:^4.1.15, graceful-fs@npm:^4.1.2, graceful-fs@npm:^4.1.3, graceful-fs@npm:^4.1.6, graceful-fs@npm:^4.1.9, graceful-fs@npm:^4.2.0, graceful-fs@npm:^4.2.2, graceful-fs@npm:^4.2.3, graceful-fs@npm:^4.2.4, graceful-fs@npm:^4.2.6, graceful-fs@npm:^4.2.9": - version: 4.2.9 - resolution: "graceful-fs@npm:4.2.9" - checksum: 68ea4e07ff2c041ada184f9278b830375f8e0b75154e3f080af6b70f66172fabb4108d19b3863a96b53fc068a310b9b6493d86d1291acc5f3861eb4b79d26ad6 + version: 4.2.10 + resolution: "graceful-fs@npm:4.2.10" + checksum: 3f109d70ae123951905d85032ebeae3c2a5a7a997430df00ea30df0e3a6c60cf6689b109654d6fdacd28810a053348c4d14642da1d075049e6be1ba5216218da languageName: node linkType: hard @@ -15754,9 +15763,9 @@ __metadata: linkType: hard "minimist@npm:^1.1.1, minimist@npm:^1.2.0, minimist@npm:^1.2.5": - version: 1.2.5 - resolution: "minimist@npm:1.2.5" - checksum: 86706ce5b36c16bfc35c5fe3dbb01d5acdc9a22f2b6cc810b6680656a1d2c0e44a0159c9a3ba51fb072bb5c203e49e10b51dcd0eec39c481f4c42086719bae52 + version: 1.2.6 + resolution: "minimist@npm:1.2.6" + checksum: d15428cd1e11eb14e1233bcfb88ae07ed7a147de251441d61158619dfb32c4d7e9061d09cab4825fdee18ecd6fce323228c8c47b5ba7cd20af378ca4048fb3fb languageName: node linkType: hard @@ -17413,13 +17422,13 @@ __metadata: languageName: node linkType: hard -"plist@npm:^3.0.2, plist@npm:^3.0.4": - version: 3.0.4 - resolution: "plist@npm:3.0.4" +"plist@npm:^3.0.2, plist@npm:^3.0.5": + version: 3.0.5 + resolution: "plist@npm:3.0.5" dependencies: base64-js: ^1.5.1 xmlbuilder: ^9.0.7 - checksum: cb5883ed1b1aa227ddc5f99003750d312a8ac5cfd6f58d3ce0b24939255b175b54f25ebc6adcbd4266105ffd54f6831acb6cb06f529652bb3344215c10f5601b + checksum: f8b82816f66559965a4dabf139bd8dd95cdec7e51f32742bb353af276ea8228b9807113743b860eda3e867f6ed70d2bcbc1e135b3204d92b5c37ac765f68444e languageName: node linkType: hard @@ -20105,13 +20114,13 @@ __metadata: linkType: hard "simple-plist@npm:^1.0.0": - version: 1.3.0 - resolution: "simple-plist@npm:1.3.0" + version: 1.3.1 + resolution: "simple-plist@npm:1.3.1" dependencies: bplist-creator: 0.1.0 - bplist-parser: 0.3.0 - plist: ^3.0.4 - checksum: 60955ac24ce73b9c5ba71c450bc9b1b90b4e21e862735e4fd33073e451bcb2dc543bf2d364527ae78c6b76354eb5674c5a1163ec78428598fdd8fde60ce24bb3 + bplist-parser: 0.3.1 + plist: ^3.0.5 + checksum: 3890b49db544096e6f35f53268901112be859c44b187528979f1a67e604b5b48b4cd6e5d6ee9e2e32aeb1e2535fe93e1cb102e2cf2bf5a37200d8884cb65b918 languageName: node linkType: hard From c4d43893dfa1fd1d390f447b5096185a1c4e83f3 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 6 Apr 2022 11:14:28 +0200 Subject: [PATCH 020/128] chore: bump react-native (#12639) --- .yarnrc.yml | 5 + .../{.babelrc.js => babel.config.js} | 0 examples/react-native/package.json | 4 +- package.json | 2 +- yarn.lock | 800 +++++++++--------- 5 files changed, 422 insertions(+), 389 deletions(-) rename examples/react-native/{.babelrc.js => babel.config.js} (100%) diff --git a/.yarnrc.yml b/.yarnrc.yml index 24f3369457b2..64407cf3b66e 100644 --- a/.yarnrc.yml +++ b/.yarnrc.yml @@ -17,7 +17,12 @@ packageExtensions: react-native-codegen@*: peerDependencies: "@babel/preset-env": ^7.1.6 + react-native-gradle-plugin@*: + peerDependencies: + "@babel/preset-env": ^7.1.6 react-native@*: + dependencies: + metro-babel-register: 0.67.0 peerDependencies: "@babel/preset-env": ^7.1.6 diff --git a/examples/react-native/.babelrc.js b/examples/react-native/babel.config.js similarity index 100% rename from examples/react-native/.babelrc.js rename to examples/react-native/babel.config.js diff --git a/examples/react-native/package.json b/examples/react-native/package.json index b0dcd1dfd028..40fd30d4eca4 100644 --- a/examples/react-native/package.json +++ b/examples/react-native/package.json @@ -8,14 +8,14 @@ }, "dependencies": { "react": "17.0.2", - "react-native": "0.67.2" + "react-native": "0.68.0" }, "devDependencies": { "@babel/core": "*", "@babel/preset-env": "*", "babel-jest": "*", "jest": "*", - "metro-react-native-babel-preset": "0.66.2", + "metro-react-native-babel-preset": "0.67.0", "react-test-renderer": "17.0.2" } } diff --git a/package.json b/package.json index 7671053f75bf..3dd98afc3ab7 100644 --- a/package.json +++ b/package.json @@ -168,7 +168,7 @@ "babel-jest": "workspace:*", "jest": "workspace:*", "jest-environment-node": "workspace:*", - "react-native": "patch:react-native@0.67.2#./patches/react-native.patch" + "react-native": "patch:react-native@0.68.0#./patches/react-native.patch" }, "packageManager": "yarn@3.2.0" } diff --git a/yarn.lock b/yarn.lock index 7876f4cf96ec..9cdc0bab46f4 100644 --- a/yarn.lock +++ b/yarn.lock @@ -287,7 +287,7 @@ __metadata: languageName: node linkType: hard -"@babel/core@npm:*, @babel/core@npm:^7.0.0, @babel/core@npm:^7.1.0, @babel/core@npm:^7.1.6, @babel/core@npm:^7.11.1, @babel/core@npm:^7.11.6, @babel/core@npm:^7.12.3, @babel/core@npm:^7.14.0, @babel/core@npm:^7.15.5, @babel/core@npm:^7.17.8, @babel/core@npm:^7.3.4, @babel/core@npm:^7.7.2, @babel/core@npm:^7.8.0": +"@babel/core@npm:*, @babel/core@npm:^7.0.0, @babel/core@npm:^7.1.0, @babel/core@npm:^7.11.1, @babel/core@npm:^7.11.6, @babel/core@npm:^7.12.3, @babel/core@npm:^7.13.16, @babel/core@npm:^7.14.0, @babel/core@npm:^7.15.5, @babel/core@npm:^7.17.8, @babel/core@npm:^7.3.4, @babel/core@npm:^7.7.2, @babel/core@npm:^7.8.0": version: 7.17.8 resolution: "@babel/core@npm:7.17.8" dependencies: @@ -628,7 +628,7 @@ __metadata: languageName: node linkType: hard -"@babel/parser@npm:^7.1.0, @babel/parser@npm:^7.1.6, @babel/parser@npm:^7.12.7, @babel/parser@npm:^7.14.0, @babel/parser@npm:^7.14.7, @babel/parser@npm:^7.16.7, @babel/parser@npm:^7.17.3, @babel/parser@npm:^7.17.8": +"@babel/parser@npm:^7.1.0, @babel/parser@npm:^7.12.7, @babel/parser@npm:^7.13.16, @babel/parser@npm:^7.14.0, @babel/parser@npm:^7.14.7, @babel/parser@npm:^7.16.7, @babel/parser@npm:^7.17.3, @babel/parser@npm:^7.17.8": version: 7.17.8 resolution: "@babel/parser@npm:7.17.8" bin: @@ -674,7 +674,7 @@ __metadata: languageName: node linkType: hard -"@babel/plugin-proposal-class-properties@npm:^7.0.0, @babel/plugin-proposal-class-properties@npm:^7.1.0, @babel/plugin-proposal-class-properties@npm:^7.16.7": +"@babel/plugin-proposal-class-properties@npm:^7.0.0, @babel/plugin-proposal-class-properties@npm:^7.13.0, @babel/plugin-proposal-class-properties@npm:^7.16.7": version: 7.16.7 resolution: "@babel/plugin-proposal-class-properties@npm:7.16.7" dependencies: @@ -774,7 +774,7 @@ __metadata: languageName: node linkType: hard -"@babel/plugin-proposal-nullish-coalescing-operator@npm:^7.0.0, @babel/plugin-proposal-nullish-coalescing-operator@npm:^7.1.0, @babel/plugin-proposal-nullish-coalescing-operator@npm:^7.16.7": +"@babel/plugin-proposal-nullish-coalescing-operator@npm:^7.0.0, @babel/plugin-proposal-nullish-coalescing-operator@npm:^7.13.8, @babel/plugin-proposal-nullish-coalescing-operator@npm:^7.16.7": version: 7.16.7 resolution: "@babel/plugin-proposal-nullish-coalescing-operator@npm:7.16.7" dependencies: @@ -838,7 +838,7 @@ __metadata: languageName: node linkType: hard -"@babel/plugin-proposal-optional-chaining@npm:^7.0.0, @babel/plugin-proposal-optional-chaining@npm:^7.1.0, @babel/plugin-proposal-optional-chaining@npm:^7.16.7": +"@babel/plugin-proposal-optional-chaining@npm:^7.0.0, @babel/plugin-proposal-optional-chaining@npm:^7.13.12, @babel/plugin-proposal-optional-chaining@npm:^7.16.7": version: 7.16.7 resolution: "@babel/plugin-proposal-optional-chaining@npm:7.16.7" dependencies: @@ -1323,7 +1323,7 @@ __metadata: languageName: node linkType: hard -"@babel/plugin-transform-modules-commonjs@npm:^7.0.0, @babel/plugin-transform-modules-commonjs@npm:^7.1.0, @babel/plugin-transform-modules-commonjs@npm:^7.16.8": +"@babel/plugin-transform-modules-commonjs@npm:^7.0.0, @babel/plugin-transform-modules-commonjs@npm:^7.1.0, @babel/plugin-transform-modules-commonjs@npm:^7.13.8, @babel/plugin-transform-modules-commonjs@npm:^7.16.8": version: 7.17.7 resolution: "@babel/plugin-transform-modules-commonjs@npm:7.17.7" dependencies: @@ -1727,7 +1727,7 @@ __metadata: languageName: node linkType: hard -"@babel/preset-flow@npm:^7.0.0, @babel/preset-flow@npm:^7.7.2": +"@babel/preset-flow@npm:^7.13.13, @babel/preset-flow@npm:^7.7.2": version: 7.16.7 resolution: "@babel/preset-flow@npm:7.16.7" dependencies: @@ -1771,7 +1771,7 @@ __metadata: languageName: node linkType: hard -"@babel/preset-typescript@npm:*, @babel/preset-typescript@npm:^7.0.0, @babel/preset-typescript@npm:^7.1.0, @babel/preset-typescript@npm:^7.15.0, @babel/preset-typescript@npm:^7.16.7": +"@babel/preset-typescript@npm:*, @babel/preset-typescript@npm:^7.0.0, @babel/preset-typescript@npm:^7.13.0, @babel/preset-typescript@npm:^7.15.0, @babel/preset-typescript@npm:^7.16.7": version: 7.16.7 resolution: "@babel/preset-typescript@npm:7.16.7" dependencies: @@ -1784,7 +1784,7 @@ __metadata: languageName: node linkType: hard -"@babel/register@npm:^7.0.0": +"@babel/register@npm:^7.0.0, @babel/register@npm:^7.13.16": version: 7.17.7 resolution: "@babel/register@npm:7.17.7" dependencies: @@ -1864,18 +1864,6 @@ __metadata: languageName: node linkType: hard -"@cnakazawa/watch@npm:^1.0.3": - version: 1.0.4 - resolution: "@cnakazawa/watch@npm:1.0.4" - dependencies: - exec-sh: ^0.3.2 - minimist: ^1.2.0 - bin: - watch: cli.js - checksum: 88f395ca0af2f3c0665b8ce7bb29e83647ec5d141e8735712aeeee4117081555436712966b6957aa1c461f6f826a4d23b0034e379c443a10e919f81c8748bf29 - languageName: node - linkType: hard - "@crowdin/cli@npm:^3.5.2": version: 3.7.7 resolution: "@crowdin/cli@npm:3.7.7" @@ -4121,12 +4109,12 @@ __metadata: languageName: node linkType: hard -"@react-native-community/cli-debugger-ui@npm:^6.0.0-rc.0": - version: 6.0.0 - resolution: "@react-native-community/cli-debugger-ui@npm:6.0.0" +"@react-native-community/cli-debugger-ui@npm:^7.0.3": + version: 7.0.3 + resolution: "@react-native-community/cli-debugger-ui@npm:7.0.3" dependencies: serve-static: ^1.13.1 - checksum: 3257e7efcd9849124adca07facd414729c0402774fb5593cd0b5343f4410c8306f0b2a65d0ef2f676a372fd5ca130fe21365fa3411b5c490bd27b1fc1911bf9c + checksum: ea90b321a375185f2f7d52e9ff5c13d943c193aa0301c7893f70132dbda4099e64b99adb61687ae6b9b78403e290ce2b8d40690daceb96300535b072dab67170 languageName: node linkType: hard @@ -4143,7 +4131,7 @@ __metadata: languageName: node linkType: hard -"@react-native-community/cli-platform-android@npm:^6.0.0, @react-native-community/cli-platform-android@npm:^6.3.0": +"@react-native-community/cli-platform-android@npm:^6.3.0": version: 6.3.0 resolution: "@react-native-community/cli-platform-android@npm:6.3.0" dependencies: @@ -4161,45 +4149,64 @@ __metadata: languageName: node linkType: hard -"@react-native-community/cli-platform-ios@npm:^6.0.0": - version: 6.2.0 - resolution: "@react-native-community/cli-platform-ios@npm:6.2.0" +"@react-native-community/cli-platform-android@npm:^7.0.1": + version: 7.0.1 + resolution: "@react-native-community/cli-platform-android@npm:7.0.1" dependencies: - "@react-native-community/cli-tools": ^6.2.0 + "@react-native-community/cli-tools": ^7.0.1 + chalk: ^4.1.2 + execa: ^1.0.0 + fs-extra: ^8.1.0 + glob: ^7.1.3 + jetifier: ^1.6.2 + lodash: ^4.17.15 + logkitty: ^0.7.1 + slash: ^3.0.0 + xmldoc: ^1.1.2 + checksum: 35f741153cffc202058b6f9ba3d1d012bccc4268ab62853b455da11090fe21cd8fd90a85d4b09cc04ffc3ee97d9af70b34ced26a4003e6a18f7814566107b0d4 + languageName: node + linkType: hard + +"@react-native-community/cli-platform-ios@npm:^7.0.1": + version: 7.0.1 + resolution: "@react-native-community/cli-platform-ios@npm:7.0.1" + dependencies: + "@react-native-community/cli-tools": ^7.0.1 chalk: ^4.1.2 + execa: ^1.0.0 glob: ^7.1.3 js-yaml: ^3.13.1 lodash: ^4.17.15 - ora: ^3.4.0 + ora: ^5.4.1 plist: ^3.0.2 - xcode: ^2.0.0 - checksum: 827ce62aa978964817d21b5b7f77ce5e58a9d57ea9e96abc1d17a5dddc3f51eb4623c4619d149eb9a28c8799537649913d37a0eb4a8b931727547ee2d2a478e9 + xcode: ^3.0.0 + checksum: 4b9e06cbf4232cac27a2018dce73996f9e715d4b0495c7c3cc1d9dff96ce6e7e936ea1a09fa8b32c86ed443875f226d93aeae7c68f320c8dde7813e7c28ceda3 languageName: node linkType: hard -"@react-native-community/cli-plugin-metro@npm:^6.4.0": - version: 6.4.0 - resolution: "@react-native-community/cli-plugin-metro@npm:6.4.0" +"@react-native-community/cli-plugin-metro@npm:^7.0.3": + version: 7.0.3 + resolution: "@react-native-community/cli-plugin-metro@npm:7.0.3" dependencies: - "@react-native-community/cli-server-api": ^6.4.0 + "@react-native-community/cli-server-api": ^7.0.3 "@react-native-community/cli-tools": ^6.2.0 chalk: ^4.1.2 - metro: ^0.66.1 - metro-config: ^0.66.1 - metro-core: ^0.66.1 - metro-react-native-babel-transformer: ^0.66.1 - metro-resolver: ^0.66.1 - metro-runtime: ^0.66.1 + metro: ^0.67.0 + metro-config: ^0.67.0 + metro-core: ^0.67.0 + metro-react-native-babel-transformer: ^0.67.0 + metro-resolver: ^0.67.0 + metro-runtime: ^0.67.0 readline: ^1.3.0 - checksum: b9bedad5daded5b633401a6eaffef723da0ecf755991742cd138927bfd7995e463c3b6a22283d8ec1c8c39e300e983a238affb64fbf4a1cc33f089a5414281e8 + checksum: ca91f10586b40b8e43ca378c567bde8b8215d9e7dda88fe3562126aeaa1a0da150e0823fe6c511e3953cac8b47376fecbd397cc956b71dc906f31b3fcfed5e33 languageName: node linkType: hard -"@react-native-community/cli-server-api@npm:^6.4.0": - version: 6.4.3 - resolution: "@react-native-community/cli-server-api@npm:6.4.3" +"@react-native-community/cli-server-api@npm:^7.0.3": + version: 7.0.3 + resolution: "@react-native-community/cli-server-api@npm:7.0.3" dependencies: - "@react-native-community/cli-debugger-ui": ^6.0.0-rc.0 + "@react-native-community/cli-debugger-ui": ^7.0.3 "@react-native-community/cli-tools": ^6.2.0 compression: ^1.7.1 connect: ^3.6.5 @@ -4207,8 +4214,8 @@ __metadata: nocache: ^2.1.0 pretty-format: ^26.6.2 serve-static: ^1.13.1 - ws: ^1.1.0 - checksum: 52b36ebbfc19c2f39350cbd01069703ed64885f90fccdd6e3f71b5e464fcb49ce41308bd6eb9b1306206122277f4b5bd2416fe326b7948b8d99300916aa738fa + ws: ^7.5.1 + checksum: 300ed63bd5ee9991cdca84a8026af6abc1624f32743c25389c101de1414c258676796b512d9dfb2e096c7ab8901cd624a956ea9685bc25fc6dabce3980bcff38 languageName: node linkType: hard @@ -4228,6 +4235,23 @@ __metadata: languageName: node linkType: hard +"@react-native-community/cli-tools@npm:^7.0.1": + version: 7.0.1 + resolution: "@react-native-community/cli-tools@npm:7.0.1" + dependencies: + appdirsjs: ^1.2.4 + chalk: ^4.1.2 + lodash: ^4.17.15 + mime: ^2.4.1 + node-fetch: ^2.6.0 + open: ^6.2.0 + ora: ^5.4.1 + semver: ^6.3.0 + shell-quote: ^1.7.3 + checksum: 11b40438499b3926b55f897f8f276be7092caccbd87b3bd8fd53513190f1743d8bb30673bfb8a6a3a0d2a57837c972b45a4847dae5a5bed3fd18d029bdbe190e + languageName: node + linkType: hard + "@react-native-community/cli-types@npm:^6.0.0": version: 6.0.0 resolution: "@react-native-community/cli-types@npm:6.0.0" @@ -4237,14 +4261,14 @@ __metadata: languageName: node linkType: hard -"@react-native-community/cli@npm:^6.0.0": - version: 6.4.0 - resolution: "@react-native-community/cli@npm:6.4.0" +"@react-native-community/cli@npm:^7.0.3": + version: 7.0.3 + resolution: "@react-native-community/cli@npm:7.0.3" dependencies: - "@react-native-community/cli-debugger-ui": ^6.0.0-rc.0 + "@react-native-community/cli-debugger-ui": ^7.0.3 "@react-native-community/cli-hermes": ^6.3.0 - "@react-native-community/cli-plugin-metro": ^6.4.0 - "@react-native-community/cli-server-api": ^6.4.0 + "@react-native-community/cli-plugin-metro": ^7.0.3 + "@react-native-community/cli-server-api": ^7.0.3 "@react-native-community/cli-tools": ^6.2.0 "@react-native-community/cli-types": ^6.0.0 appdirsjs: ^1.2.4 @@ -4276,7 +4300,7 @@ __metadata: react-native: "*" bin: react-native: build/bin.js - checksum: d42cf2f91869b991a01a507710432f352b34203a66a39ed03918de6098365522f1717a3615ac9ecba2f621b1125e0dbc98c617bd0584ba8414f866f418cf6117 + checksum: 5f2907e4e77f1013f41b1f0e2ca6e2fce5e0fcefb8ba3c4163f04e8c3af022a451d5b54b7f41303f966273da88b3b16f3ec718a37179515e72d7ac1ec387e073 languageName: node linkType: hard @@ -4287,7 +4311,7 @@ __metadata: languageName: node linkType: hard -"@react-native/normalize-color@npm:2.0.0": +"@react-native/normalize-color@npm:*, @react-native/normalize-color@npm:2.0.0": version: 2.0.0 resolution: "@react-native/normalize-color@npm:2.0.0" checksum: 2da373297f0d22b700edb9ab1b2cca34684e94a5dfe172e1cfd114e74ac17e139e802bc671e9868e0a580190eccbf3fa804f67be8cc1d9cbd0e216e994495931 @@ -6266,16 +6290,6 @@ __metadata: languageName: node linkType: hard -"anymatch@npm:^2.0.0": - version: 2.0.0 - resolution: "anymatch@npm:2.0.0" - dependencies: - micromatch: ^3.1.4 - normalize-path: ^2.1.1 - checksum: f7bb1929842b4585cdc28edbb385767d499ce7d673f96a8f11348d2b2904592ffffc594fe9229b9a1e9e4dccb9329b7692f9f45e6a11dcefbb76ecdc9ab740f6 - languageName: node - linkType: hard - "anymatch@npm:^3.0.3, anymatch@npm:~3.1.2": version: 3.1.2 resolution: "anymatch@npm:3.1.2" @@ -6808,6 +6822,13 @@ __metadata: languageName: node linkType: hard +"babel-plugin-replace-ts-export-assignment@npm:^0.0.2": + version: 0.0.2 + resolution: "babel-plugin-replace-ts-export-assignment@npm:0.0.2" + checksum: da749130fe0479cd9da73f8b3aafc62e05885b12732ce0e25976a7138dad1688a03366791b12633afdd8a702e2018ec01764c4ddb0ed0dbc3783b7e75b1b148a + languageName: node + linkType: hard + "babel-plugin-syntax-trailing-function-commas@npm:^7.0.0-beta.0": version: 7.0.0-beta.0 resolution: "babel-plugin-syntax-trailing-function-commas@npm:7.0.0-beta.0" @@ -7012,7 +7033,7 @@ __metadata: languageName: node linkType: hard -"bl@npm:^4.0.3": +"bl@npm:^4.0.3, bl@npm:^4.1.0": version: 4.1.0 resolution: "bl@npm:4.1.0" dependencies: @@ -7430,15 +7451,6 @@ __metadata: languageName: node linkType: hard -"capture-exit@npm:^2.0.0": - version: 2.0.0 - resolution: "capture-exit@npm:2.0.0" - dependencies: - rsvp: ^4.8.4 - checksum: 0b9f10daca09e521da9599f34c8e7af14ad879c336e2bdeb19955b375398ae1c5bcc91ac9f2429944343057ee9ed028b1b2fb28816c384e0e55d70c439b226f4 - languageName: node - linkType: hard - "caseless@npm:~0.12.0": version: 0.12.0 resolution: "caseless@npm:0.12.0" @@ -7703,7 +7715,7 @@ __metadata: languageName: node linkType: hard -"cli-spinners@npm:^2.0.0": +"cli-spinners@npm:^2.0.0, cli-spinners@npm:^2.5.0": version: 2.6.1 resolution: "cli-spinners@npm:2.6.1" checksum: 423409baaa7a58e5104b46ca1745fbfc5888bbd0b0c5a626e052ae1387060839c8efd512fb127e25769b3dc9562db1dc1b5add6e0b93b7ef64f477feb6416a45 @@ -7895,7 +7907,7 @@ __metadata: languageName: node linkType: hard -"colors@npm:1.4.0, colors@npm:^1.1.2": +"colors@npm:1.4.0": version: 1.4.0 resolution: "colors@npm:1.4.0" checksum: 98aa2c2418ad87dedf25d781be69dc5fc5908e279d9d30c34d8b702e586a0474605b3a189511482b9d5ed0d20c867515d22749537f7bc546256c6014f3ebdcec @@ -8971,6 +8983,17 @@ __metadata: languageName: node linkType: hard +"deprecated-react-native-prop-types@npm:^2.3.0": + version: 2.3.0 + resolution: "deprecated-react-native-prop-types@npm:2.3.0" + dependencies: + "@react-native/normalize-color": "*" + invariant: "*" + prop-types: "*" + checksum: d14f4be1dfe780a7fa9197a31b4a9a2b409c8cf1bf677713fd92d06733dee1043578662d1a8858541cf06164ae91d295db6e595f29bf13e808d9fb37bc58c90b + languageName: node + linkType: hard + "deprecation@npm:^2.0.0, deprecation@npm:^2.3.1": version: 2.3.1 resolution: "deprecation@npm:2.3.1" @@ -10158,9 +10181,9 @@ __metadata: "@babel/preset-env": "*" babel-jest: "*" jest: "*" - metro-react-native-babel-preset: 0.66.2 + metro-react-native-babel-preset: 0.67.0 react: 17.0.2 - react-native: 0.67.2 + react-native: 0.68.0 react-test-renderer: 17.0.2 languageName: unknown linkType: soft @@ -10236,13 +10259,6 @@ __metadata: languageName: unknown linkType: soft -"exec-sh@npm:^0.3.2": - version: 0.3.6 - resolution: "exec-sh@npm:0.3.6" - checksum: 0be4f06929c8e4834ea4812f29fe59e2dfcc1bc3fc4b4bb71acb38a500c3b394628a05ef7ba432520bc6c5ec4fadab00cc9c513c4ff6a32104965af302e998e0 - languageName: node - linkType: hard - "execa@npm:^1.0.0": version: 1.0.0 resolution: "execa@npm:1.0.0" @@ -10979,7 +10995,7 @@ __metadata: languageName: node linkType: hard -"fsevents@npm:^2.1.2, fsevents@npm:^2.3.2, fsevents@npm:~2.3.2": +"fsevents@npm:^2.3.2, fsevents@npm:~2.3.2": version: 2.3.2 resolution: "fsevents@npm:2.3.2" dependencies: @@ -10989,7 +11005,7 @@ __metadata: languageName: node linkType: hard -"fsevents@patch:fsevents@^2.1.2#~builtin, fsevents@patch:fsevents@^2.3.2#~builtin, fsevents@patch:fsevents@~2.3.2#~builtin": +"fsevents@patch:fsevents@^2.3.2#~builtin, fsevents@patch:fsevents@~2.3.2#~builtin": version: 2.3.2 resolution: "fsevents@patch:fsevents@npm%3A2.3.2#~builtin::version=2.3.2&hash=18f3a7" dependencies: @@ -11725,17 +11741,26 @@ __metadata: languageName: node linkType: hard -"hermes-engine@npm:~0.9.0": - version: 0.9.0 - resolution: "hermes-engine@npm:0.9.0" - checksum: 384549c544de9efb07e9d84202f45bde00e62539a5b56fed2fd2763dbd02560eb37786e61349119966e3086e95a6b8e008822730180a679e229b43a611718f4c +"hermes-engine@npm:~0.11.0": + version: 0.11.0 + resolution: "hermes-engine@npm:0.11.0" + checksum: 34dcd016b373337306be0e5b15923fc2756b17253264443a1a07a14d3326d00eb433af13c08ae11f3a2ddcbcc44ae9a9ac9b071ce72efdd056745327dc3201d7 languageName: node linkType: hard -"hermes-parser@npm:0.4.7": - version: 0.4.7 - resolution: "hermes-parser@npm:0.4.7" - checksum: 1210d9139b048993938403e8bcf26249bac942512996449ed88522f3e1d31f206cfd54c3095fc279f51e9f4794dfaaab1a3dce828925a0aa784faeb6abe6863c +"hermes-estree@npm:0.5.0": + version: 0.5.0 + resolution: "hermes-estree@npm:0.5.0" + checksum: 16741229afcda60637b7672ccaf978784147eb21ff55e14418763dff7947717e9a0e962a121a55963aa78ae772cdfd0539b56317c4c63913c7701141335bf0de + languageName: node + linkType: hard + +"hermes-parser@npm:0.5.0": + version: 0.5.0 + resolution: "hermes-parser@npm:0.5.0" + dependencies: + hermes-estree: 0.5.0 + checksum: ef3c9aee01162fe1958e084540aa663bd9001acb6aa5d1c724bb8d7aa947dcc2961e0d572adda60895ebfe59f2caef102925f201445698e196c5626fb21e2ba6 languageName: node linkType: hard @@ -12309,7 +12334,7 @@ __metadata: languageName: node linkType: hard -"invariant@npm:^2.2.4": +"invariant@npm:*, invariant@npm:^2.2.4": version: 2.2.4 resolution: "invariant@npm:2.2.4" dependencies: @@ -12611,6 +12636,13 @@ __metadata: languageName: node linkType: hard +"is-interactive@npm:^1.0.0": + version: 1.0.0 + resolution: "is-interactive@npm:1.0.0" + checksum: 824808776e2d468b2916cdd6c16acacebce060d844c35ca6d82267da692e92c3a16fdba624c50b54a63f38bdc4016055b6f443ce57d7147240de4f8cdabaf6f9 + languageName: node + linkType: hard + "is-lambda@npm:^1.0.1": version: 1.0.1 resolution: "is-lambda@npm:1.0.1" @@ -12838,6 +12870,13 @@ __metadata: languageName: node linkType: hard +"is-unicode-supported@npm:^0.1.0": + version: 0.1.0 + resolution: "is-unicode-supported@npm:0.1.0" + checksum: a2aab86ee7712f5c2f999180daaba5f361bdad1efadc9610ff5b8ab5495b86e4f627839d085c6530363c6d6d4ecbde340fb8e54bdb83da4ba8e0865ed5513c52 + languageName: node + linkType: hard + "is-weakref@npm:^1.0.1": version: 1.0.2 resolution: "is-weakref@npm:1.0.2" @@ -13246,28 +13285,27 @@ __metadata: languageName: unknown linkType: soft -"jest-haste-map@npm:^26.5.2": - version: 26.6.2 - resolution: "jest-haste-map@npm:26.6.2" +"jest-haste-map@npm:^27.3.1": + version: 27.5.1 + resolution: "jest-haste-map@npm:27.5.1" dependencies: - "@jest/types": ^26.6.2 + "@jest/types": ^27.5.1 "@types/graceful-fs": ^4.1.2 "@types/node": "*" anymatch: ^3.0.3 fb-watchman: ^2.0.0 - fsevents: ^2.1.2 - graceful-fs: ^4.2.4 - jest-regex-util: ^26.0.0 - jest-serializer: ^26.6.2 - jest-util: ^26.6.2 - jest-worker: ^26.6.2 - micromatch: ^4.0.2 - sane: ^4.0.3 + fsevents: ^2.3.2 + graceful-fs: ^4.2.9 + jest-regex-util: ^27.5.1 + jest-serializer: ^27.5.1 + jest-util: ^27.5.1 + jest-worker: ^27.5.1 + micromatch: ^4.0.4 walker: ^1.0.7 dependenciesMeta: fsevents: optional: true - checksum: 8ad5236d5646d2388d2bd58a57ea53698923434f43d59ea9ebdc58bce4d0b8544c8de2f7acaa9a6d73171f04460388b2b6d7d6b6c256aea4ebb8780140781596 + checksum: e092a1412829a9254b4725531ee72926de530f77fda7b0d9ea18008fb7623c16f72e772d8e93be71cac9e591b2c6843a669610887dd2c89bd9eb528856e3ab47 languageName: node linkType: hard @@ -13419,14 +13457,7 @@ __metadata: languageName: unknown linkType: soft -"jest-regex-util@npm:^26.0.0": - version: 26.0.0 - resolution: "jest-regex-util@npm:26.0.0" - checksum: 930a00665e8dfbedc29140678b4a54f021b41b895cf35050f76f557c1da3ac48ff42dd7b18ba2ccba6f4e518c6445d6753730d03ec7049901b93992db1ef0483 - languageName: node - linkType: hard - -"jest-regex-util@npm:^27.0.0": +"jest-regex-util@npm:^27.0.0, jest-regex-util@npm:^27.5.1": version: 27.5.1 resolution: "jest-regex-util@npm:27.5.1" checksum: d45ca7a9543616a34f7f3079337439cf07566e677a096472baa2810e274b9808b76767c97b0a4029b8a5b82b9d256dee28ef9ad4138b2b9e5933f6fac106c418 @@ -13567,13 +13598,13 @@ __metadata: languageName: unknown linkType: soft -"jest-serializer@npm:^26.6.2": - version: 26.6.2 - resolution: "jest-serializer@npm:26.6.2" +"jest-serializer@npm:^27.5.1": + version: 27.5.1 + resolution: "jest-serializer@npm:27.5.1" dependencies: "@types/node": "*" - graceful-fs: ^4.2.4 - checksum: dbecfb0d01462fe486a0932cf1680cf6abb204c059db2a8f72c6c2a7c9842a82f6d256874112774cea700764ed8f38fc9e3db982456c138d87353e3390e746fe + graceful-fs: ^4.2.9 + checksum: 803e03a552278610edc6753c0dd9fa5bb5cd3ca47414a7b2918106efb62b79fd5e9ae785d0a21f12a299fa599fea8acc1fa6dd41283328cee43962cf7df9bb44 languageName: node linkType: hard @@ -13651,7 +13682,7 @@ __metadata: languageName: unknown linkType: soft -"jest-util@npm:^26.0.0, jest-util@npm:^26.6.2": +"jest-util@npm:^26.0.0": version: 26.6.2 resolution: "jest-util@npm:26.6.2" dependencies: @@ -13792,7 +13823,7 @@ __metadata: languageName: unknown linkType: soft -"jest-worker@npm:^26.0.0, jest-worker@npm:^26.2.1, jest-worker@npm:^26.6.2": +"jest-worker@npm:^26.0.0, jest-worker@npm:^26.2.1": version: 26.6.2 resolution: "jest-worker@npm:26.6.2" dependencies: @@ -13803,7 +13834,7 @@ __metadata: languageName: node linkType: hard -"jest-worker@npm:^27.0.2, jest-worker@npm:^27.0.6, jest-worker@npm:^27.4.5": +"jest-worker@npm:^27.0.2, jest-worker@npm:^27.0.6, jest-worker@npm:^27.4.5, jest-worker@npm:^27.5.1": version: 27.5.1 resolution: "jest-worker@npm:27.5.1" dependencies: @@ -13922,34 +13953,34 @@ __metadata: languageName: node linkType: hard -"jscodeshift@npm:^0.11.0": - version: 0.11.0 - resolution: "jscodeshift@npm:0.11.0" - dependencies: - "@babel/core": ^7.1.6 - "@babel/parser": ^7.1.6 - "@babel/plugin-proposal-class-properties": ^7.1.0 - "@babel/plugin-proposal-nullish-coalescing-operator": ^7.1.0 - "@babel/plugin-proposal-optional-chaining": ^7.1.0 - "@babel/plugin-transform-modules-commonjs": ^7.1.0 - "@babel/preset-flow": ^7.0.0 - "@babel/preset-typescript": ^7.1.0 - "@babel/register": ^7.0.0 +"jscodeshift@npm:^0.13.1": + version: 0.13.1 + resolution: "jscodeshift@npm:0.13.1" + dependencies: + "@babel/core": ^7.13.16 + "@babel/parser": ^7.13.16 + "@babel/plugin-proposal-class-properties": ^7.13.0 + "@babel/plugin-proposal-nullish-coalescing-operator": ^7.13.8 + "@babel/plugin-proposal-optional-chaining": ^7.13.12 + "@babel/plugin-transform-modules-commonjs": ^7.13.8 + "@babel/preset-flow": ^7.13.13 + "@babel/preset-typescript": ^7.13.0 + "@babel/register": ^7.13.16 babel-core: ^7.0.0-bridge.0 - colors: ^1.1.2 + chalk: ^4.1.2 flow-parser: 0.* graceful-fs: ^4.2.4 micromatch: ^3.1.10 neo-async: ^2.5.0 node-dir: ^0.1.17 - recast: ^0.20.3 - temp: ^0.8.1 + recast: ^0.20.4 + temp: ^0.8.4 write-file-atomic: ^2.3.0 peerDependencies: "@babel/preset-env": ^7.1.6 bin: jscodeshift: bin/jscodeshift.js - checksum: 647dc36a50d417b14659f81109685f9ea3924daf604d50d7d2b522c4a658d6abff921dedb4cf74a6d2173c1c48195f9e92cca3df1cb535c6d5f67455d35a19ce + checksum: 1c35938de5fc29cafec80e2c37d5c3411f85cd5d40e0243b52f2da0c1ab4b659daddfd62de558eca5d562303616f7838097727b651f4ad8e32b1e96f169cdd76 languageName: node linkType: hard @@ -14638,6 +14669,16 @@ __metadata: languageName: node linkType: hard +"log-symbols@npm:^4.1.0": + version: 4.1.0 + resolution: "log-symbols@npm:4.1.0" + dependencies: + chalk: ^4.1.0 + is-unicode-supported: ^0.1.0 + checksum: fce1497b3135a0198803f9f07464165e9eb83ed02ceb2273930a6f8a508951178d8cf4f0378e9d28300a2ed2bc49050995d2bd5f53ab716bb15ac84d58c6ef74 + languageName: node + linkType: hard + "logkitty@npm:^0.7.1": version: 0.7.1 resolution: "logkitty@npm:0.7.1" @@ -15034,9 +15075,9 @@ __metadata: languageName: node linkType: hard -"metro-babel-register@npm:0.66.2": - version: 0.66.2 - resolution: "metro-babel-register@npm:0.66.2" +"metro-babel-register@npm:0.67.0": + version: 0.67.0 + resolution: "metro-babel-register@npm:0.67.0" dependencies: "@babel/core": ^7.14.0 "@babel/plugin-proposal-nullish-coalescing-operator": ^7.0.0 @@ -15044,100 +15085,102 @@ __metadata: "@babel/plugin-syntax-class-properties": ^7.0.0 "@babel/plugin-transform-flow-strip-types": ^7.0.0 "@babel/plugin-transform-modules-commonjs": ^7.0.0 + "@babel/preset-typescript": ^7.15.0 "@babel/register": ^7.0.0 + babel-plugin-replace-ts-export-assignment: ^0.0.2 escape-string-regexp: ^1.0.5 - checksum: 03a467a8144837c6a75cdec19d384f24f1f4dfc6d4ffabe1ab82e3235d5b12c16483704990660b9f37f0a19d7b7e2754e284b63f9f4a67595e9197a5996dfae9 + checksum: 4aabb6884db027326ca97e8c9f3943e9af9f455439fa7e361002e3c5b5c3600e9f4aae141018bebec7a242f6950f822945fd464fa6f14c134f893d6542afc081 languageName: node linkType: hard -"metro-babel-transformer@npm:0.66.2": - version: 0.66.2 - resolution: "metro-babel-transformer@npm:0.66.2" +"metro-babel-transformer@npm:0.67.0": + version: 0.67.0 + resolution: "metro-babel-transformer@npm:0.67.0" dependencies: "@babel/core": ^7.14.0 - hermes-parser: 0.4.7 - metro-source-map: 0.66.2 + hermes-parser: 0.5.0 + metro-source-map: 0.67.0 nullthrows: ^1.1.1 - checksum: fbec39283db17c819c4ee7adbcdc9174468e767bd4093b3d0eb863c248b7c8d57e848baf45df8d26803442928ace11bb94a0bc0fde19603fed48389456a8ebe1 + checksum: f2029702c8c5f901c72ee9db47a93e4bbe188bc019051756b7a1b5c8c754c575e8727801fc058218f329dbae6a2fab9498b6bc10972433b6fe68a1aafebe1504 languageName: node linkType: hard -"metro-cache-key@npm:0.66.2": - version: 0.66.2 - resolution: "metro-cache-key@npm:0.66.2" - checksum: c252fc9f67a7a0ec46cb9bd689f1d8f3fc707eae51954b55d3d0c9f5ed97dcec1e48503515cea937cc6b3d02bf17d4169d1b1e3b9a249eb73bde009443e3f542 +"metro-cache-key@npm:0.67.0": + version: 0.67.0 + resolution: "metro-cache-key@npm:0.67.0" + checksum: 13b23f2e1a413b7a79d6f48fb739e92ba1b457c77eba14f65f6bcd1caf1832f314b319e4d690bd6bf9de94c896427b44d5da6e65ab1cde71d07306e00888e014 languageName: node linkType: hard -"metro-cache@npm:0.66.2": - version: 0.66.2 - resolution: "metro-cache@npm:0.66.2" +"metro-cache@npm:0.67.0": + version: 0.67.0 + resolution: "metro-cache@npm:0.67.0" dependencies: - metro-core: 0.66.2 + metro-core: 0.67.0 mkdirp: ^0.5.1 rimraf: ^2.5.4 - checksum: 10dcc142e2bbef97fbbb487fb922ac3c2cf9900428c726b26499b03476a2f8c18f5581e99d54edda104c4b3e76881c04b70325282056fc91d146a666644663ec + checksum: 4d9fba435d3adbe0c4c883ef0361d41acf427ba57e74daa52f55d66bbb564e907c9ceec40c98fac792217e9d1efbc91e1531ec8db907165274c524e30a0dfcde languageName: node linkType: hard -"metro-config@npm:0.66.2, metro-config@npm:^0.66.1": - version: 0.66.2 - resolution: "metro-config@npm:0.66.2" +"metro-config@npm:0.67.0, metro-config@npm:^0.67.0": + version: 0.67.0 + resolution: "metro-config@npm:0.67.0" dependencies: cosmiconfig: ^5.0.5 jest-validate: ^26.5.2 - metro: 0.66.2 - metro-cache: 0.66.2 - metro-core: 0.66.2 - metro-runtime: 0.66.2 - checksum: 9ea773267723bf9eae6fd2c4aeff4d491a75eb18bc1e748748d97f4214b48b2b0d55e06b22ea941383474e51c26c5c0163cdad18c399b6fc8bd8998f77d1ef4b + metro: 0.67.0 + metro-cache: 0.67.0 + metro-core: 0.67.0 + metro-runtime: 0.67.0 + checksum: 0e8685e52f22470251fd3d56f9f71dae4dab266bc7393feebd97fb9513311d2b18c04fd019c13ad30aafe472e5515b31b2373caddd51e2cc7109d1156345aa1a languageName: node linkType: hard -"metro-core@npm:0.66.2, metro-core@npm:^0.66.1": - version: 0.66.2 - resolution: "metro-core@npm:0.66.2" +"metro-core@npm:0.67.0, metro-core@npm:^0.67.0": + version: 0.67.0 + resolution: "metro-core@npm:0.67.0" dependencies: - jest-haste-map: ^26.5.2 + jest-haste-map: ^27.3.1 lodash.throttle: ^4.1.1 - metro-resolver: 0.66.2 - checksum: cfaacdac2cab60de8032bb7ffa100aea3e797b9cbda4fed314e6dc9defe72c428def57410d91f792e3130f13b426088791762f4952d92f828ca83c52d464b0a3 + metro-resolver: 0.67.0 + checksum: c3183ad2950f6e796675cb52fe7d0228f6147da617f15d43baa9362a73c3cf33b108b0084d7956a6541129599cf16ea8e68b693742df21adae45a75fd0fd5f98 languageName: node linkType: hard -"metro-hermes-compiler@npm:0.66.2": - version: 0.66.2 - resolution: "metro-hermes-compiler@npm:0.66.2" - checksum: c1dc1627d006b9202c70f4ace8fc5ceaf5a786667bdf324adb7c7c3c796d0aa62dc4fc635a4073b78c79c206a87a3b0d78ae9f85bfda7b7f4bb7e926e63ca891 +"metro-hermes-compiler@npm:0.67.0": + version: 0.67.0 + resolution: "metro-hermes-compiler@npm:0.67.0" + checksum: 02926d5ae44f08cfec7a80d8b23c7096a44e65e5d400e6123517efffff14b5e547a25394914b7478aedb22994b317d7a3091e659089fd182b92e5afec740bd4b languageName: node linkType: hard -"metro-inspector-proxy@npm:0.66.2": - version: 0.66.2 - resolution: "metro-inspector-proxy@npm:0.66.2" +"metro-inspector-proxy@npm:0.67.0": + version: 0.67.0 + resolution: "metro-inspector-proxy@npm:0.67.0" dependencies: connect: ^3.6.5 debug: ^2.2.0 - ws: ^1.1.5 + ws: ^7.5.1 yargs: ^15.3.1 bin: metro-inspector-proxy: src/cli.js - checksum: 3f85acc4b353c7936a900ddd64e0d0fec6e7c1c2d8985e9fb5e509879b5e3f25fb6138223869a225bf3a021500cb1c9564962638be97d7c912654dce4c673d46 + checksum: db75ae358bf061d7a19b84a8833b8f7d9fedfa559568c1010953d2c681ac549baa767a4665f11e0a1994e8c964197538ceafe19d0fc5e97f855a23c778edaaeb languageName: node linkType: hard -"metro-minify-uglify@npm:0.66.2": - version: 0.66.2 - resolution: "metro-minify-uglify@npm:0.66.2" +"metro-minify-uglify@npm:0.67.0": + version: 0.67.0 + resolution: "metro-minify-uglify@npm:0.67.0" dependencies: uglify-es: ^3.1.9 - checksum: 15ceb1b21cb06f2f369091e631f08b5f9e13c1001cab03ccda0610fe0845254627dbaade45f1c09dffbc5306736f97c42b593db33d4b909d4776b84127cfcf17 + checksum: e0d4c7bbcaedf210d4b7379cf158818a1311c65b2518599d34d374e6fd090f47e3c55bf31a018380685db8a4570e272fb57627dd0961915ab71fb08fd13dfd29 languageName: node linkType: hard -"metro-react-native-babel-preset@npm:0.66.2": - version: 0.66.2 - resolution: "metro-react-native-babel-preset@npm:0.66.2" +"metro-react-native-babel-preset@npm:0.67.0": + version: 0.67.0 + resolution: "metro-react-native-babel-preset@npm:0.67.0" dependencies: "@babel/core": ^7.14.0 "@babel/plugin-proposal-class-properties": ^7.0.0 @@ -15181,112 +15224,112 @@ __metadata: react-refresh: ^0.4.0 peerDependencies: "@babel/core": "*" - checksum: c490c73d3ae6674686253db110cc4ee4487a0d2a7b07acd09815abf6087b9358faaa69f8a6361b84024354c60b9f60afa44b57d4cf930f49a1b3cfed2a7ffb59 + checksum: 931105e7c76e1e69663bcf75ed8979161c6d486767ccc48c9c6ca80276adbeae7c2aaec0b5c9829f0a44fbf456e97908f81486bdb04cfe68fde375413acc654f languageName: node linkType: hard -"metro-react-native-babel-transformer@npm:0.66.2, metro-react-native-babel-transformer@npm:^0.66.1": - version: 0.66.2 - resolution: "metro-react-native-babel-transformer@npm:0.66.2" +"metro-react-native-babel-transformer@npm:0.67.0, metro-react-native-babel-transformer@npm:^0.67.0": + version: 0.67.0 + resolution: "metro-react-native-babel-transformer@npm:0.67.0" dependencies: "@babel/core": ^7.14.0 babel-preset-fbjs: ^3.4.0 - hermes-parser: 0.4.7 - metro-babel-transformer: 0.66.2 - metro-react-native-babel-preset: 0.66.2 - metro-source-map: 0.66.2 + hermes-parser: 0.5.0 + metro-babel-transformer: 0.67.0 + metro-react-native-babel-preset: 0.67.0 + metro-source-map: 0.67.0 nullthrows: ^1.1.1 peerDependencies: "@babel/core": "*" - checksum: b849306f06c1dabdc0fedc35e10646d4c0cdc752601e2f75cc20a2b341057861c661a62443a00cfa9eda220fe1705c0f8eb8f074716590d1acc6ed329f2b39ce + checksum: ff08b2f187a17bfed46170909d106ec042db52ad75e5facfbec8a7d8068c95b8e53c9ec28b6704f0809f9a338550d017e3e3596ef3f1373e8e7fcf1b3cd5233f languageName: node linkType: hard -"metro-resolver@npm:0.66.2, metro-resolver@npm:^0.66.1": - version: 0.66.2 - resolution: "metro-resolver@npm:0.66.2" +"metro-resolver@npm:0.67.0, metro-resolver@npm:^0.67.0": + version: 0.67.0 + resolution: "metro-resolver@npm:0.67.0" dependencies: absolute-path: ^0.0.0 - checksum: c0e80230b698cbe38f748197d66c3ae6448a4965f464ed216dba4e3eaaaa71719a803548b372c53caed8fb88b1784c79af2057c1e678d356dcff8b96644d5e81 + checksum: 967896f26c58071720effbf310352f8c89a3279c822c8303e2bdcc07ad7fb7e39e19afcb9ae8ec47f39573b47c4217fb9afbc14636d5345528b6d410b08c0f2f languageName: node linkType: hard -"metro-runtime@npm:0.66.2, metro-runtime@npm:^0.66.1": - version: 0.66.2 - resolution: "metro-runtime@npm:0.66.2" - checksum: 7b51abc53a04b7991ee0bbf5517d95b6f1305a4e8854c19afeed1087f8b15df25e67ecbd38fb5606909927d55757302089edbbf1e508b60accc5677aa671728b +"metro-runtime@npm:0.67.0, metro-runtime@npm:^0.67.0": + version: 0.67.0 + resolution: "metro-runtime@npm:0.67.0" + checksum: 06be8635277d594b17009d9b35bbd9cb65dd44980a0a87739e49801a6b6dae73109825ddd94e1a8195520b3fa41507d151b7b7f8a484cf61164e155bfdbb091b languageName: node linkType: hard -"metro-source-map@npm:0.66.2": - version: 0.66.2 - resolution: "metro-source-map@npm:0.66.2" +"metro-source-map@npm:0.67.0": + version: 0.67.0 + resolution: "metro-source-map@npm:0.67.0" dependencies: "@babel/traverse": ^7.14.0 "@babel/types": ^7.0.0 invariant: ^2.2.4 - metro-symbolicate: 0.66.2 + metro-symbolicate: 0.67.0 nullthrows: ^1.1.1 - ob1: 0.66.2 + ob1: 0.67.0 source-map: ^0.5.6 vlq: ^1.0.0 - checksum: 67959828b023079747d60ed41cc2263cdf883218c477799b26159c42c593737768e589498ebee7a3333080a96b2f97e0c01fd7371d8e59b6c5f8f5a4b250bbb6 + checksum: 87ae604d292c1694966cb755579aa3a0185b9b657590a2996a4184fe3cd164eedf43491b3a3369a2bdf846124f821d96a87e4a8eab0a8d133d5f04d00ba354f6 languageName: node linkType: hard -"metro-symbolicate@npm:0.66.2": - version: 0.66.2 - resolution: "metro-symbolicate@npm:0.66.2" +"metro-symbolicate@npm:0.67.0": + version: 0.67.0 + resolution: "metro-symbolicate@npm:0.67.0" dependencies: invariant: ^2.2.4 - metro-source-map: 0.66.2 + metro-source-map: 0.67.0 nullthrows: ^1.1.1 source-map: ^0.5.6 through2: ^2.0.1 vlq: ^1.0.0 bin: metro-symbolicate: src/index.js - checksum: 7a2cfee2d9cd9db6864f6dac5587891facab576ac5aed152981875b8150555ceeb3fcaa4a2d9647e8a3ec941b30c4812383f08af0154b889077187b5234d9367 + checksum: 4a2bbbcf6a166473003151c2e62255a7a3e0ba0043134c303418b21fc9cf6cf362c2b5a249f533dceb94a88642805bd771c2062bc5ae8cb3a53cf11809041128 languageName: node linkType: hard -"metro-transform-plugins@npm:0.66.2": - version: 0.66.2 - resolution: "metro-transform-plugins@npm:0.66.2" +"metro-transform-plugins@npm:0.67.0": + version: 0.67.0 + resolution: "metro-transform-plugins@npm:0.67.0" dependencies: "@babel/core": ^7.14.0 "@babel/generator": ^7.14.0 "@babel/template": ^7.0.0 "@babel/traverse": ^7.14.0 nullthrows: ^1.1.1 - checksum: 0d0f510e28579947092c83423239e27b652db01249f23f0a99a4978bb7b46a01c32161c0390b6caa59a0e5e5850293318b35c50b38a5773316dd12357aff7a08 + checksum: 79e468e5ba0965181f56777d998ebdfcc2792c33d8b25d5a180022e62fc3e3585050bfc82bb3b238bc778baef8ad37d1083da620b68f02240597ce73ec4efff5 languageName: node linkType: hard -"metro-transform-worker@npm:0.66.2": - version: 0.66.2 - resolution: "metro-transform-worker@npm:0.66.2" +"metro-transform-worker@npm:0.67.0": + version: 0.67.0 + resolution: "metro-transform-worker@npm:0.67.0" dependencies: "@babel/core": ^7.14.0 "@babel/generator": ^7.14.0 "@babel/parser": ^7.14.0 "@babel/types": ^7.0.0 babel-preset-fbjs: ^3.4.0 - metro: 0.66.2 - metro-babel-transformer: 0.66.2 - metro-cache: 0.66.2 - metro-cache-key: 0.66.2 - metro-hermes-compiler: 0.66.2 - metro-source-map: 0.66.2 - metro-transform-plugins: 0.66.2 + metro: 0.67.0 + metro-babel-transformer: 0.67.0 + metro-cache: 0.67.0 + metro-cache-key: 0.67.0 + metro-hermes-compiler: 0.67.0 + metro-source-map: 0.67.0 + metro-transform-plugins: 0.67.0 nullthrows: ^1.1.1 - checksum: 5d1ab3f9cb3b674c4f3d6148b8b08abf0cb93f30c3afe0e4f74b2149a272728ccbf515a582b5078a87ec1ea77840ca395974e06e082178f21d195858c5667aa1 + checksum: 114ecd11b9945c3bf0171c2dc725bc3676a14604740d15ee8e862cd903706743407b0592ffe1b3fd53946947bcf8d00f015f823343ee1eeb843ce63e514466c6 languageName: node linkType: hard -"metro@npm:0.66.2, metro@npm:^0.66.1": - version: 0.66.2 - resolution: "metro@npm:0.66.2" +"metro@npm:0.67.0, metro@npm:^0.67.0": + version: 0.67.0 + resolution: "metro@npm:0.67.0" dependencies: "@babel/code-frame": ^7.0.0 "@babel/core": ^7.14.0 @@ -15306,28 +15349,27 @@ __metadata: error-stack-parser: ^2.0.6 fs-extra: ^1.0.0 graceful-fs: ^4.1.3 - hermes-parser: 0.4.7 + hermes-parser: 0.5.0 image-size: ^0.6.0 invariant: ^2.2.4 - jest-haste-map: ^26.5.2 + jest-haste-map: ^27.3.1 jest-worker: ^26.0.0 lodash.throttle: ^4.1.1 - metro-babel-register: 0.66.2 - metro-babel-transformer: 0.66.2 - metro-cache: 0.66.2 - metro-cache-key: 0.66.2 - metro-config: 0.66.2 - metro-core: 0.66.2 - metro-hermes-compiler: 0.66.2 - metro-inspector-proxy: 0.66.2 - metro-minify-uglify: 0.66.2 - metro-react-native-babel-preset: 0.66.2 - metro-resolver: 0.66.2 - metro-runtime: 0.66.2 - metro-source-map: 0.66.2 - metro-symbolicate: 0.66.2 - metro-transform-plugins: 0.66.2 - metro-transform-worker: 0.66.2 + metro-babel-transformer: 0.67.0 + metro-cache: 0.67.0 + metro-cache-key: 0.67.0 + metro-config: 0.67.0 + metro-core: 0.67.0 + metro-hermes-compiler: 0.67.0 + metro-inspector-proxy: 0.67.0 + metro-minify-uglify: 0.67.0 + metro-react-native-babel-preset: 0.67.0 + metro-resolver: 0.67.0 + metro-runtime: 0.67.0 + metro-source-map: 0.67.0 + metro-symbolicate: 0.67.0 + metro-transform-plugins: 0.67.0 + metro-transform-worker: 0.67.0 mime-types: ^2.1.27 mkdirp: ^0.5.1 node-fetch: ^2.2.0 @@ -15338,11 +15380,11 @@ __metadata: strip-ansi: ^6.0.0 temp: 0.8.3 throat: ^5.0.0 - ws: ^1.1.5 + ws: ^7.5.1 yargs: ^15.3.1 bin: metro: src/cli.js - checksum: 0c677fe63105c341b2d3ceec169e5cb88d8fd5340679d717574297d1ea75638c751a0ed602020aff506150c35d73ad4057031397caddd95d24f48bb087e24c82 + checksum: f106dd7f56380f734ae0d71afcee068b18774196889a6909963fd82b4c0db5508915735bc5be8027150ccea3b5bed5d286fdda41d0458ba3d156d8db29841fce languageName: node linkType: hard @@ -15593,7 +15635,7 @@ __metadata: languageName: node linkType: hard -"micromatch@npm:^3.1.10, micromatch@npm:^3.1.4": +"micromatch@npm:^3.1.10": version: 3.1.10 resolution: "micromatch@npm:3.1.10" dependencies: @@ -15762,10 +15804,10 @@ __metadata: languageName: node linkType: hard -"minimist@npm:^1.1.1, minimist@npm:^1.2.0, minimist@npm:^1.2.5": - version: 1.2.6 - resolution: "minimist@npm:1.2.6" - checksum: d15428cd1e11eb14e1233bcfb88ae07ed7a147de251441d61158619dfb32c4d7e9061d09cab4825fdee18ecd6fce323228c8c47b5ba7cd20af378ca4048fb3fb +"minimist@npm:^1.2.0, minimist@npm:^1.2.5": + version: 1.2.5 + resolution: "minimist@npm:1.2.5" + checksum: 86706ce5b36c16bfc35c5fe3dbb01d5acdc9a22f2b6cc810b6680656a1d2c0e44a0159c9a3ba51fb072bb5c203e49e10b51dcd0eec39c481f4c42086719bae52 languageName: node linkType: hard @@ -16373,15 +16415,6 @@ __metadata: languageName: node linkType: hard -"normalize-path@npm:^2.1.1": - version: 2.1.1 - resolution: "normalize-path@npm:2.1.1" - dependencies: - remove-trailing-separator: ^1.0.1 - checksum: 7e9cbdcf7f5b8da7aa191fbfe33daf290cdcd8c038f422faf1b8a83c972bf7a6d94c5be34c4326cb00fb63bc0fd97d9fbcfaf2e5d6142332c2cd36d2e1b86cea - languageName: node - linkType: hard - "normalize-path@npm:^3.0.0, normalize-path@npm:~3.0.0": version: 3.0.0 resolution: "normalize-path@npm:3.0.0" @@ -16620,10 +16653,10 @@ __metadata: languageName: node linkType: hard -"ob1@npm:0.66.2": - version: 0.66.2 - resolution: "ob1@npm:0.66.2" - checksum: 18f4ddecd7631aef0cbbd1c11134cca26305e13e75324c51d0fcfb949aefbd3f18df33cdeb7e68b02e1d68a59163f3c7af3a08ff070ccfec6c91d3b67be2f8bb +"ob1@npm:0.67.0": + version: 0.67.0 + resolution: "ob1@npm:0.67.0" + checksum: 02910732e1094dd164d6dfa674250bc404503c8a85fa60b15399f9059006329d7b1bad2cb0bca1841bcf4c2c1759d91297485361523d21066984a9130f3f3b65 languageName: node linkType: hard @@ -16850,13 +16883,6 @@ __metadata: languageName: node linkType: hard -"options@npm:>=0.0.5": - version: 0.0.6 - resolution: "options@npm:0.0.6" - checksum: 8601fdc0a3e14987b7f2509676e5e5d8afe601c64600d9bad3a0aad7e8ed8631ad47e2fa155c63e4043832122d6f6e3251d276307a032d0bb50cc252980e3712 - languageName: node - linkType: hard - "ora@npm:^3.4.0": version: 3.4.0 resolution: "ora@npm:3.4.0" @@ -16871,6 +16897,23 @@ __metadata: languageName: node linkType: hard +"ora@npm:^5.4.1": + version: 5.4.1 + resolution: "ora@npm:5.4.1" + dependencies: + bl: ^4.1.0 + chalk: ^4.1.0 + cli-cursor: ^3.1.0 + cli-spinners: ^2.5.0 + is-interactive: ^1.0.0 + is-unicode-supported: ^0.1.0 + log-symbols: ^4.1.0 + strip-ansi: ^6.0.0 + wcwidth: ^1.0.1 + checksum: 28d476ee6c1049d68368c0dc922e7225e3b5600c3ede88fade8052837f9ed342625fdaa84a6209302587c8ddd9b664f71f0759833cbdb3a4cf81344057e63c63 + languageName: node + linkType: hard + "os-homedir@npm:^1.0.0": version: 1.0.2 resolution: "os-homedir@npm:1.0.2" @@ -18106,7 +18149,7 @@ __metadata: languageName: node linkType: hard -"prop-types@npm:^15.0.0, prop-types@npm:^15.6.2, prop-types@npm:^15.7.2": +"prop-types@npm:*, prop-types@npm:^15.0.0, prop-types@npm:^15.6.2, prop-types@npm:^15.7.2": version: 15.8.1 resolution: "prop-types@npm:15.8.1" dependencies: @@ -18402,13 +18445,13 @@ __metadata: languageName: node linkType: hard -"react-devtools-core@npm:4.19.1": - version: 4.19.1 - resolution: "react-devtools-core@npm:4.19.1" +"react-devtools-core@npm:^4.23.0": + version: 4.24.3 + resolution: "react-devtools-core@npm:4.24.3" dependencies: shell-quote: ^1.6.1 ws: ^7 - checksum: 20471dde740e25a6f51b7b2b719fb1e1a9213cfb2a14d6defb44eced93646f73c9c5e376fcfdc78827c4fb587bc030ca99a14a0154a94acf7a1e1496d2b59ef6 + checksum: 69b322aefb172e7dd25eab64d074d86f2d1de20b8c09ebd3ba857f782c3ff7d1e000eaccfd9b1ac320ebb1734991a3331d0a5ef174f6a01cb8956a0cc0464387 languageName: node linkType: hard @@ -18552,45 +18595,69 @@ __metadata: languageName: node linkType: hard -"react-native-codegen@npm:^0.0.8": - version: 0.0.8 - resolution: "react-native-codegen@npm:0.0.8" +"react-native-codegen@npm:*": + version: 0.0.14 + resolution: "react-native-codegen@npm:0.0.14" + dependencies: + "@babel/parser": ^7.14.0 + flow-parser: ^0.121.0 + jscodeshift: ^0.13.1 + nullthrows: ^1.1.1 + checksum: 2e22f472e504b035a032fcb4c13412ecd60971cb2f11a161c674219f379afcc8098103503dc5f394ac92e8f6cbd2dce68ad3d8b7eb5cb1cd01a4e548063cf97c + languageName: node + linkType: hard + +"react-native-codegen@npm:^0.0.13": + version: 0.0.13 + resolution: "react-native-codegen@npm:0.0.13" dependencies: + "@babel/parser": ^7.14.0 flow-parser: ^0.121.0 - jscodeshift: ^0.11.0 + jscodeshift: ^0.13.1 nullthrows: ^1.1.1 - checksum: c5ccdcb2a2f249756aca8e729cf96737368c8d33673b08d4c928a469bcb58ff37fbf3c7a070398f33b19846c4261948e2c5107c561934a41ac034620f7207bbd + checksum: bfe645fea6de985922d6d060b2ad0c9194f25b436b5b31c11fcc76358fa527f541c044d0818f32cba853bec3debfa12d2a48b4c9282f19d575ee2a7d3599571f languageName: node linkType: hard -"react-native@npm:0.67.2": - version: 0.67.2 - resolution: "react-native@npm:0.67.2" +"react-native-gradle-plugin@npm:^0.0.5": + version: 0.0.5 + resolution: "react-native-gradle-plugin@npm:0.0.5" + dependencies: + react-native-codegen: "*" + checksum: ee14e5abc692fadb66527334e00ce57bfb7371fae82711f3a1c658c8896e93daee17019e533b1eb0323606f812fa5c645e67348f4169ecc0cb9fa3de3706b5e6 + languageName: node + linkType: hard + +"react-native@npm:0.68.0": + version: 0.68.0 + resolution: "react-native@npm:0.68.0" dependencies: "@jest/create-cache-key-function": ^27.0.1 - "@react-native-community/cli": ^6.0.0 - "@react-native-community/cli-platform-android": ^6.0.0 - "@react-native-community/cli-platform-ios": ^6.0.0 + "@react-native-community/cli": ^7.0.3 + "@react-native-community/cli-platform-android": ^7.0.1 + "@react-native-community/cli-platform-ios": ^7.0.1 "@react-native/assets": 1.0.0 "@react-native/normalize-color": 2.0.0 "@react-native/polyfills": 2.0.0 abort-controller: ^3.0.0 anser: ^1.4.9 base64-js: ^1.1.2 + deprecated-react-native-prop-types: ^2.3.0 event-target-shim: ^5.0.1 - hermes-engine: ~0.9.0 + hermes-engine: ~0.11.0 invariant: ^2.2.4 jsc-android: ^250230.2.1 - metro-react-native-babel-transformer: 0.66.2 - metro-runtime: 0.66.2 - metro-source-map: 0.66.2 + metro-react-native-babel-transformer: 0.67.0 + metro-runtime: 0.67.0 + metro-source-map: 0.67.0 nullthrows: ^1.1.1 pretty-format: ^26.5.2 promise: ^8.0.3 - prop-types: ^15.7.2 - react-devtools-core: 4.19.1 - react-native-codegen: ^0.0.8 + react-devtools-core: ^4.23.0 + react-native-codegen: ^0.0.13 + react-native-gradle-plugin: ^0.0.5 react-refresh: ^0.4.0 + react-shallow-renderer: 16.14.1 regenerator-runtime: ^0.13.2 scheduler: ^0.20.2 stacktrace-parser: ^0.1.3 @@ -18601,38 +18668,40 @@ __metadata: react: 17.0.2 bin: react-native: cli.js - checksum: 6e8bd1a8ab1c8fad2928fd1aa921363fd2d49d4622c6edea38c3f80e67cf43253347661a545b69637f149fbc3a762f0a0e26a3bcf0003ac3c46dd83adb63b2b2 + checksum: 2232376ac65e63c8b2895b6fcb84299dd42ef6502b0d2d26a64758f4de871c64f261e116b6a0930a0e6b3320a68d46cbbe4daa5eb50fd517d90aa0eb451b189c languageName: node linkType: hard -"react-native@patch:react-native@0.67.2#./patches/react-native.patch::locator=%40jest%2Fmonorepo%40workspace%3A.": - version: 0.67.2 - resolution: "react-native@patch:react-native@npm%3A0.67.2#./patches/react-native.patch::version=0.67.2&hash=5ca1dc&locator=%40jest%2Fmonorepo%40workspace%3A." +"react-native@patch:react-native@0.68.0#./patches/react-native.patch::locator=%40jest%2Fmonorepo%40workspace%3A.": + version: 0.68.0 + resolution: "react-native@patch:react-native@npm%3A0.68.0#./patches/react-native.patch::version=0.68.0&hash=5ca1dc&locator=%40jest%2Fmonorepo%40workspace%3A." dependencies: "@jest/create-cache-key-function": ^27.0.1 - "@react-native-community/cli": ^6.0.0 - "@react-native-community/cli-platform-android": ^6.0.0 - "@react-native-community/cli-platform-ios": ^6.0.0 + "@react-native-community/cli": ^7.0.3 + "@react-native-community/cli-platform-android": ^7.0.1 + "@react-native-community/cli-platform-ios": ^7.0.1 "@react-native/assets": 1.0.0 "@react-native/normalize-color": 2.0.0 "@react-native/polyfills": 2.0.0 abort-controller: ^3.0.0 anser: ^1.4.9 base64-js: ^1.1.2 + deprecated-react-native-prop-types: ^2.3.0 event-target-shim: ^5.0.1 - hermes-engine: ~0.9.0 + hermes-engine: ~0.11.0 invariant: ^2.2.4 jsc-android: ^250230.2.1 - metro-react-native-babel-transformer: 0.66.2 - metro-runtime: 0.66.2 - metro-source-map: 0.66.2 + metro-react-native-babel-transformer: 0.67.0 + metro-runtime: 0.67.0 + metro-source-map: 0.67.0 nullthrows: ^1.1.1 pretty-format: ^26.5.2 promise: ^8.0.3 - prop-types: ^15.7.2 - react-devtools-core: 4.19.1 - react-native-codegen: ^0.0.8 + react-devtools-core: ^4.23.0 + react-native-codegen: ^0.0.13 + react-native-gradle-plugin: ^0.0.5 react-refresh: ^0.4.0 + react-shallow-renderer: 16.14.1 regenerator-runtime: ^0.13.2 scheduler: ^0.20.2 stacktrace-parser: ^0.1.3 @@ -18643,7 +18712,7 @@ __metadata: react: 17.0.2 bin: react-native: cli.js - checksum: 3af73858b5e41a7e47fceb0177d948ce9a8e09146270ff95183ed3527bff0960227b820fbfd1d9308c0e5eb1579b371a37279bc7edc8fc114436f9cf09edeb83 + checksum: f953ba6590354181e1331466c54b3d90d2d0a4b60c077808cd23b9c88b6008f332078e5541ad69a7ca5c66123cdda4ec8ea085bcfa9d61e28535d2233059cf96 languageName: node linkType: hard @@ -18703,7 +18772,7 @@ __metadata: languageName: node linkType: hard -"react-shallow-renderer@npm:^16.13.1": +"react-shallow-renderer@npm:16.14.1, react-shallow-renderer@npm:^16.13.1": version: 16.14.1 resolution: "react-shallow-renderer@npm:16.14.1" dependencies: @@ -18955,7 +19024,7 @@ __metadata: languageName: node linkType: hard -"recast@npm:^0.20.3": +"recast@npm:^0.20.4": version: 0.20.5 resolution: "recast@npm:0.20.5" dependencies: @@ -19230,13 +19299,6 @@ __metadata: languageName: node linkType: hard -"remove-trailing-separator@npm:^1.0.1": - version: 1.1.0 - resolution: "remove-trailing-separator@npm:1.1.0" - checksum: d3c20b5a2d987db13e1cca9385d56ecfa1641bae143b620835ac02a6b70ab88f68f117a0021838db826c57b31373d609d52e4f31aca75fc490c862732d595419 - languageName: node - linkType: hard - "renderkid@npm:^3.0.0": version: 3.0.0 resolution: "renderkid@npm:3.0.0" @@ -19586,13 +19648,6 @@ __metadata: languageName: node linkType: hard -"rsvp@npm:^4.8.4": - version: 4.8.5 - resolution: "rsvp@npm:4.8.5" - checksum: 2d8ef30d8febdf05bdf856ccca38001ae3647e41835ca196bc1225333f79b94ae44def733121ca549ccc36209c9b689f6586905e2a043873262609744da8efc1 - languageName: node - linkType: hard - "rtl-detect@npm:^1.0.4": version: 1.0.4 resolution: "rtl-detect@npm:1.0.4" @@ -19687,25 +19742,6 @@ __metadata: languageName: node linkType: hard -"sane@npm:^4.0.3": - version: 4.1.0 - resolution: "sane@npm:4.1.0" - dependencies: - "@cnakazawa/watch": ^1.0.3 - anymatch: ^2.0.0 - capture-exit: ^2.0.0 - exec-sh: ^0.3.2 - execa: ^1.0.0 - fb-watchman: ^2.0.0 - micromatch: ^3.1.4 - minimist: ^1.1.1 - walker: ~1.0.5 - bin: - sane: ./src/cli.js - checksum: 97716502d456c0d38670a902a4ea943d196dcdf998d1e40532d8f3e24e25d7eddfd4c3579025a1eee8eac09a48dfd05fba61a2156c56704e7feaa450eb249f7c - languageName: node - linkType: hard - "saslprep@npm:^1.0.3": version: 1.0.3 resolution: "saslprep@npm:1.0.3" @@ -20113,7 +20149,7 @@ __metadata: languageName: node linkType: hard -"simple-plist@npm:^1.0.0": +"simple-plist@npm:^1.1.0": version: 1.3.1 resolution: "simple-plist@npm:1.3.1" dependencies: @@ -21068,7 +21104,7 @@ __metadata: languageName: node linkType: hard -"temp@npm:^0.8.1": +"temp@npm:^0.8.4": version: 0.8.4 resolution: "temp@npm:0.8.4" dependencies: @@ -21712,13 +21748,6 @@ __metadata: languageName: node linkType: hard -"ultron@npm:1.0.x": - version: 1.0.2 - resolution: "ultron@npm:1.0.2" - checksum: f98993b128c774b4769aeeb86030158efb9c2440d3ad91d722af05e7418ddbee6d6fd974c257702b997e5e8fe417ca349c40d16c8cebc8de4b4a2fd40e872309 - languageName: node - linkType: hard - "umask@npm:^1.1.0": version: 1.1.0 resolution: "umask@npm:1.1.0" @@ -22234,6 +22263,15 @@ __metadata: languageName: node linkType: hard +"uuid@npm:^7.0.3": + version: 7.0.3 + resolution: "uuid@npm:7.0.3" + bin: + uuid: dist/bin/uuid + checksum: f5b7b5cc28accac68d5c083fd51cca64896639ebd4cca88c6cfb363801aaa83aa439c86dfc8446ea250a7a98d17afd2ad9e88d9d4958c79a412eccb93bae29de + languageName: node + linkType: hard + "uuid@npm:^8.3.1, uuid@npm:^8.3.2": version: 8.3.2 resolution: "uuid@npm:8.3.2" @@ -22424,7 +22462,7 @@ __metadata: languageName: node linkType: hard -"walker@npm:^1.0.7, walker@npm:~1.0.5": +"walker@npm:^1.0.7": version: 1.0.8 resolution: "walker@npm:1.0.8" dependencies: @@ -23159,16 +23197,6 @@ __metadata: languageName: node linkType: hard -"ws@npm:^1.1.0, ws@npm:^1.1.5": - version: 1.1.5 - resolution: "ws@npm:1.1.5" - dependencies: - options: ">=0.0.5" - ultron: 1.0.x - checksum: d2dfb74fe4f9bfa3f6e9e1d583210ce3d0b29fe376cfd93491e80844494842527ca3e68209205c1d6bc85849a7f379f9cc34150dc9e4b08a82cb031f4fbabc7b - languageName: node - linkType: hard - "ws@npm:^6.1.4": version: 6.2.2 resolution: "ws@npm:6.2.2" @@ -23178,7 +23206,7 @@ __metadata: languageName: node linkType: hard -"ws@npm:^7, ws@npm:^7.3.1": +"ws@npm:^7, ws@npm:^7.3.1, ws@npm:^7.5.1": version: 7.5.7 resolution: "ws@npm:7.5.7" peerDependencies: @@ -23208,13 +23236,13 @@ __metadata: languageName: node linkType: hard -"xcode@npm:^2.0.0": - version: 2.1.0 - resolution: "xcode@npm:2.1.0" +"xcode@npm:^3.0.0": + version: 3.0.1 + resolution: "xcode@npm:3.0.1" dependencies: - simple-plist: ^1.0.0 - uuid: ^3.3.2 - checksum: aaa4569f96411f3a024abfa9fb27f2b1dfcf0544b91d2a8b63a36214042b4560dc455942abd9b95836cdd24386d4a6731faf339e32b496b46b4ca810a1dea0e1 + simple-plist: ^1.1.0 + uuid: ^7.0.3 + checksum: 908ff85851f81aec6e36ca24427db092e1cc068f052716e14de5e762196858039efabbe053a1abe8920184622501049e74a93618e8692b982f7604a9847db108 languageName: node linkType: hard From 2e092b01235625c39a57c9b1e20f87eec97bf305 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Wed, 6 Apr 2022 13:59:43 +0300 Subject: [PATCH 021/128] feat(@jest/transform)!: require `process()` and `processAsync()` methods to always return structured data (#12638) --- .../react-native-npm-0.68.0-9eb3ecb60a.patch | 22 ++++- CHANGELOG.md | 1 + docs/CodeTransformation.md | 46 ++++++++--- docs/Configuration.md | 25 +++--- docs/Webpack.md | 25 +++--- e2e/__tests__/dependencyClash.test.ts | 10 ++- e2e/__tests__/multiProjectRunner.test.ts | 4 +- .../typescriptPreprocessor.js | 2 +- .../no-sourcemap/cssTransform.js | 2 +- .../typescriptPreprocessor.js | 2 +- .../transformer.js | 4 +- e2e/snapshot-serializers/transformer.js | 4 +- .../preprocessor.js | 23 +++--- e2e/stack-trace-source-maps/preprocessor.js | 23 +++--- e2e/transform-linked-modules/preprocessor.js | 2 +- .../async-transformer/my-transform.cjs | 12 +-- e2e/transform/cache/transformer.js | 4 +- .../preprocessor.js | 6 +- .../esm-transformer/my-transform.mjs | 4 +- .../multiple-transformers/cssPreprocessor.js | 18 +++-- .../multiple-transformers/filePreprocessor.js | 8 +- .../typescriptPreprocessor.js | 19 ++--- package.json | 2 +- packages/babel-jest/src/index.ts | 4 +- .../test_root/test_json_preprocessor.js | 2 +- .../__tests__/test_root/test_preprocessor.js | 4 +- .../jest-transform/src/ScriptTransformer.ts | 6 +- .../src/__tests__/ScriptTransformer.test.ts | 70 +++++++++------- .../ScriptTransformer.test.ts.snap | 80 +++++++++++++++++++ .../src/runtimeErrorsAndWarnings.ts | 6 +- packages/jest-transform/src/types.ts | 8 +- yarn.lock | 6 +- 32 files changed, 301 insertions(+), 153 deletions(-) rename patches/react-native.patch => .yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch (50%) diff --git a/patches/react-native.patch b/.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch similarity index 50% rename from patches/react-native.patch rename to .yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch index 0720ad2a58f4..bb6b711f1e52 100644 --- a/patches/react-native.patch +++ b/.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch @@ -1,8 +1,17 @@ diff --git a/jest/preprocessor.js b/jest/preprocessor.js -index 5920c0a6f23c056f27366fabf32dd13c6f86465b..2658e52f9127ac58849e7f830f6342d8b683672c 100644 +index f5e34763d840193e243a974e448b619f8f635095..cc6e05ab4c9c25a3d257379a1bf19c21fb9ef5ca 100644 --- a/jest/preprocessor.js +++ b/jest/preprocessor.js -@@ -64,8 +64,6 @@ module.exports = { +@@ -38,7 +38,7 @@ module.exports = { + sourceType: 'script', + ...nodeOptions, + ast: false, +- }).code; ++ }); + } + + const {ast} = transformer.transform({ +@@ -66,8 +66,6 @@ module.exports = { [require('@babel/plugin-transform-flow-strip-types')], [ require('@babel/plugin-proposal-class-properties'), @@ -11,3 +20,12 @@ index 5920c0a6f23c056f27366fabf32dd13c6f86465b..2658e52f9127ac58849e7f830f6342d8 ], [require('@babel/plugin-transform-computed-properties')], [require('@babel/plugin-transform-destructuring')], +@@ -112,7 +110,7 @@ module.exports = { + sourceMaps: true, + }, + src, +- ).code; ++ ); + }, + + getCacheKey: (createCacheKeyFunction([ diff --git a/CHANGELOG.md b/CHANGELOG.md index ce5503c5fcf3..96b32db89ccc 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -43,6 +43,7 @@ - `[jest-runtime]` [**BREAKING**] `Runtime.createHasteMap` now returns a promise ([#12008](https://github.com/facebook/jest/pull/12008)) - `[jest-runtime]` Calling `jest.resetModules` function will clear FS and transform cache ([#12531](https://github.com/facebook/jest/pull/12531)) - `[@jest/schemas]` New module for JSON schemas for Jest's config ([#12384](https://github.com/facebook/jest/pull/12384)) +- `[jest-transform]` [**BREAKING**] Make it required for `process()` and `processAsync()` methods to always return structured data ([#12638](https://github.com/facebook/jest/pull/12638)) - `[jest-test-result]` Add duration property to JSON test output ([#12518](https://github.com/facebook/jest/pull/12518)) - `[jest-watcher]` [**BREAKING**] Make `PatternPrompt` class to take `entityName` as third constructor parameter instead of `this._entityName` ([#12591](https://github.com/facebook/jest/pull/12591)) - `[jest-worker]` [**BREAKING**] Allow only absolute `workerPath` ([#12343](https://github.com/facebook/jest/pull/12343)) diff --git a/docs/CodeTransformation.md b/docs/CodeTransformation.md index 2393fac9928e..b94873c7eb0f 100644 --- a/docs/CodeTransformation.md +++ b/docs/CodeTransformation.md @@ -3,29 +3,36 @@ id: code-transformation title: Code Transformation --- -Jest runs the code in your project as JavaScript, but if you use some syntax not supported by Node.js out of the box (such as JSX, types from TypeScript, Vue templates etc.) then you'll need to transform that code into plain JavaScript, similar to what you would do when building for browsers. +Jest runs the code in your project as JavaScript, but if you use some syntax not supported by Node out of the box (such as JSX, TypeScript, Vue templates) then you'll need to transform that code into plain JavaScript, similar to what you would do when building for browsers. -Jest supports this via the [`transform` configuration option](Configuration.md#transform-objectstring-pathtotransformer--pathtotransformer-object). +Jest supports this via the [`transform`](Configuration.md#transform-objectstring-pathtotransformer--pathtotransformer-object) configuration option. -A transformer is a module that provides a synchronous function for transforming source files. For example, if you wanted to be able to use a new language feature in your modules or tests that aren't yet supported by Node, you might plug in one of many compilers that compile a future version of JavaScript to a current one. +A transformer is a module that provides a method for transforming source files. For example, if you wanted to be able to use a new language feature in your modules or tests that aren't yet supported by Node, you might plug in a code preprocessor that would transpile a future version of JavaScript to a current one. Jest will cache the result of a transformation and attempt to invalidate that result based on a number of factors, such as the source of the file being transformed and changing configuration. ## Defaults -Jest ships with one transformer out of the box - `babel-jest`. It will automatically load your project's Babel configuration and transform any file matching the following RegEx: `/\.[jt]sx?$/` meaning any `.js`, `.jsx`, `.ts` and `.tsx` file. In addition, `babel-jest` will inject the Babel plugin necessary for mock hoisting talked about in [ES Module mocking](ManualMocks.md#using-with-es-module-imports). +Jest ships with one transformer out of the box – [`babel-jest`](https://github.com/facebook/jest/tree/main/packages/babel-jest#setup). It will load your project's Babel configuration and transform any file matching the `/\.[jt]sx?$/` RegExp (in other words, any `.js`, `.jsx`, `.ts` or `.tsx` file). In addition, `babel-jest` will inject the Babel plugin necessary for mock hoisting talked about in [ES Module mocking](ManualMocks.md#using-with-es-module-imports). -If you override the `transform` configuration option `babel-jest` will no longer be active, and you'll need to add it manually if you wish to use Babel. +:::tip + +Remember to include the default `babel-jest` transformer explicitly, if you wish to use it alongside with additional code preprocessors: + +```json +"transform": { + "\\.[jt]sx?$": "babel-jest", + "\\.css$": "some-css-transformer", +} +``` + +::: ## Writing custom transformers You can write your own transformer. The API of a transformer is as follows: ```ts -// This version of the interface you are seeing on the website has been trimmed down for brevity -// For the full definition, see `packages/jest-transform/src/types.ts` in https://github.com/facebook/jest -// (taking care in choosing the right tag/commit for your version of Jest) - interface TransformOptions { supportsDynamicImport: boolean; supportsExportNamespaceFrom: boolean; @@ -41,6 +48,11 @@ interface TransformOptions { transformerConfig: OptionType; } +type TransformedSource = { + code: string; + map?: RawSourceMap | string | null; +}; + interface SyncTransformer { canInstrument?: boolean; @@ -111,6 +123,12 @@ type TransformerFactory = { }; ``` +:::note + +The definitions above were trimmed down for brevity. Full code can be found in [Jest repo on GitHub](https://github.com/facebook/jest/blob/main/packages/jest-transform/src/types.ts) (remember to choose the right tag/commit for your version of Jest). + +::: + There are a couple of ways you can import code into Jest - using Common JS (`require`) or ECMAScript Modules (`import` - which exists in static and dynamic versions). Jest passes files through code transformation on demand (for instance when a `require` or `import` is evaluated). This process, also known as "transpilation", might happen _synchronously_ (in the case of `require`), or _asynchronously_ (in the case of `import` or `import()`, the latter of which also works from Common JS modules). For this reason, the interface exposes both pairs of methods for asynchronous and synchronous processes: `process{Async}` and `getCacheKey{Async}`. The latter is called to figure out if we need to call `process{Async}` at all. Since async transformation can happen synchronously without issue, it's possible for the async case to "fall back" to the sync variant, but not vice versa. So if your code base is ESM only implementing the async variants is sufficient. Otherwise, if any code is loaded through `require` (including `createRequire` from within ESM), then you need to implement the synchronous variant. Be aware that `node_modules` is not transpiled with default config. @@ -125,7 +143,9 @@ Note that [ECMAScript module](ECMAScriptModules.md) support is indicated by the :::tip -Make sure `TransformedSource` contains a source map, so it is possible to report line information accurately in code coverage and test errors. Inline source maps also work but are slower. +Make sure `process{Async}` method returns source map alongside with transformed code, so it is possible to report line information accurately in code coverage and test errors. Inline source maps also work but are slower. + +During the development of a transformer it can be useful to run Jest with `--no-cache` to frequently [delete cache](Troubleshooting.md#caching-issues). ::: @@ -143,8 +163,10 @@ Importing images is a way to include them in your browser bundle, but they are n const path = require('path'); module.exports = { - process(src, filename, config, options) { - return `module.exports = ${JSON.stringify(path.basename(filename))};`; + process(sourceText, sourcePath, options) { + return { + code: `module.exports = ${JSON.stringify(path.basename(sourcePath))};`, + }; }, }; ``` diff --git a/docs/Configuration.md b/docs/Configuration.md index 277cf0b8f990..ab5dc416f632 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -1564,27 +1564,26 @@ Default timeout of a test in milliseconds. Default: `{"\\.[jt]sx?$": "babel-jest"}` -A map from regular expressions to paths to transformers. A transformer is a module that provides a synchronous function for transforming source files. For example, if you wanted to be able to use a new language feature in your modules or tests that aren't yet supported by node, you might plug in one of many compilers that compile a future version of JavaScript to a current one. Example: see the [examples/typescript](https://github.com/facebook/jest/blob/main/examples/typescript/package.json#L16) example or the [webpack tutorial](Webpack.md). +A map from regular expressions to paths to transformers. Optionally, a tuple with configuration options can be passed as second argument: `{filePattern: ['path-to-transformer', {options}]}`. For example, here is how you can configure `babel-jest` for non-default behavior: `{'\\.js$': ['babel-jest', {rootMode: 'upward'}]}`. -Examples of such compilers include: +Jest runs the code of your project as JavaScript, hence a transformer is needed if you use some syntax not supported by Node out of the box (such as JSX, TypeScript, Vue templates). By default, Jest will use [`babel-jest`](https://github.com/facebook/jest/tree/main/packages/babel-jest#setup) transformer, which will load your project's Babel configuration and transform any file matching the `/\.[jt]sx?$/` RegExp (in other words, any `.js`, `.jsx`, `.ts` or `.tsx` file). In addition, `babel-jest` will inject the Babel plugin necessary for mock hoisting talked about in [ES Module mocking](ManualMocks.md#using-with-es-module-imports). -- [Babel](https://babeljs.io/) -- [TypeScript](http://www.typescriptlang.org/) -- To build your own please visit the [Custom Transformer](CodeTransformation.md#writing-custom-transformers) section - -You can pass configuration to a transformer like `{filePattern: ['path-to-transformer', {options}]}` For example, to configure babel-jest for non-default behavior, `{"\\.js$": ['babel-jest', {rootMode: "upward"}]}` +See the [Code Transformation](CodeTransformation.md) section for more details and instructions on building your own transformer. :::tip -A transformer is only run once per file unless the file has changed. During the development of a transformer it can be useful to run Jest with `--no-cache` to frequently [delete Jest's cache](Troubleshooting.md#caching-issues). - -When adding additional code transformers, this will overwrite the default config and `babel-jest` is no longer automatically loaded. If you want to use it to compile JavaScript or TypeScript, it has to be explicitly defined by adding `{"\\.[jt]sx?$": "babel-jest"}` to the transform property. See [babel-jest plugin](https://github.com/facebook/jest/tree/main/packages/babel-jest#setup). +Keep in mind that a transformer only runs once per file unless the file has changed. -::: +Remember to include the default `babel-jest` transformer explicitly, if you wish to use it alongside with additional code preprocessors: -A transformer must be an object with at least a `process` function, and it's also recommended to include a `getCacheKey` function. If your transformer is written in ESM you should have a default export with that object. +```json +"transform": { + "\\.[jt]sx?$": "babel-jest", + "\\.css$": "some-css-transformer", +} +``` -If the tests are written using [native ESM](ECMAScriptModules.md) the transformer can export `processAsync` and `getCacheKeyAsync` instead or in addition to the synchronous variants. +::: ### `transformIgnorePatterns` \[array<string>] diff --git a/docs/Webpack.md b/docs/Webpack.md index e02c1d323db5..533e5b653ac1 100644 --- a/docs/Webpack.md +++ b/docs/Webpack.md @@ -83,16 +83,16 @@ Then all your className lookups on the styles object will be returned as-is (e.g } ``` -> Notice that Proxy is enabled in Node 6 by default. If you are not on Node 6 yet, make sure you invoke Jest using `node --harmony_proxies node_modules/.bin/jest`. - If `moduleNameMapper` cannot fulfill your requirements, you can use Jest's [`transform`](Configuration.md#transform-objectstring-pathtotransformer--pathtotransformer-object) config option to specify how assets are transformed. For example, a transformer that returns the basename of a file (such that `require('logo.jpg');` returns `'logo'`) can be written as: ```js title="fileTransformer.js" const path = require('path'); module.exports = { - process(src, filename, config, options) { - return `module.exports = ${JSON.stringify(path.basename(filename))};`; + process(sourceText, sourcePath, options) { + return { + code: `module.exports = ${JSON.stringify(path.basename(sourcePath))};`, + }; }, }; ``` @@ -112,16 +112,19 @@ module.exports = { We've told Jest to ignore files matching a stylesheet or image extension, and instead, require our mock files. You can adjust the regular expression to match the file types your webpack config handles. -_Note: if you are using babel-jest with additional code preprocessors, you have to explicitly define babel-jest as a transformer for your JavaScript code to map `.js` files to the babel-jest module._ +:::tip + +Remember to include the default `babel-jest` transformer explicitly, if you wish to use it alongside with additional code preprocessors: ```json "transform": { - "\\.js$": "babel-jest", - "\\.css$": "custom-transformer", - ... + "\\.[jt]sx?$": "babel-jest", + "\\.css$": "some-css-transformer", } ``` +::: + ### Configuring Jest to find our files Now that Jest knows how to process our files, we need to tell it how to _find_ them. For webpack's `modulesDirectories`, and `extensions` options there are direct analogs in Jest's `moduleDirectories` and `moduleFileExtensions` options. @@ -186,8 +189,7 @@ That's it! webpack is a complex and flexible tool, so you may have to make some webpack 2 offers native support for ES modules. However, Jest runs in Node, and thus requires ES modules to be transpiled to CommonJS modules. As such, if you are using webpack 2, you most likely will want to configure Babel to transpile ES modules to CommonJS modules only in the `test` environment. -```json -// .babelrc +```json title=".babelrc" { "presets": [["env", {"modules": false}]], @@ -203,8 +205,7 @@ webpack 2 offers native support for ES modules. However, Jest runs in Node, and If you use dynamic imports (`import('some-file.js').then(module => ...)`), you need to enable the `dynamic-import-node` plugin. -```json -// .babelrc +```json title=".babelrc" { "presets": [["env", {"modules": false}]], diff --git a/e2e/__tests__/dependencyClash.test.ts b/e2e/__tests__/dependencyClash.test.ts index d6ea667631a1..98fc1267e453 100644 --- a/e2e/__tests__/dependencyClash.test.ts +++ b/e2e/__tests__/dependencyClash.test.ts @@ -64,10 +64,12 @@ test('does not require project modules from inside node_modules', () => { if (!threw) { throw new Error('It used the wrong invariant module!'); } - return script.replace( - 'INVALID CODE FRAGMENT THAT WILL BE REMOVED BY THE TRANSFORMER', - '' - ); + return { + code: script.replace( + 'INVALID CODE FRAGMENT THAT WILL BE REMOVED BY THE TRANSFORMER', + '', + ), + }; }, }; `, diff --git a/e2e/__tests__/multiProjectRunner.test.ts b/e2e/__tests__/multiProjectRunner.test.ts index b4b42588ccf8..fc17f55e931c 100644 --- a/e2e/__tests__/multiProjectRunner.test.ts +++ b/e2e/__tests__/multiProjectRunner.test.ts @@ -450,7 +450,7 @@ test('Does transform files with the corresponding project transformer', () => { };`, 'project1/transformer.js': ` module.exports = { - process: () => 'module.exports = "PROJECT1";', + process: () => ({code: 'module.exports = "PROJECT1";'}), getCacheKey: () => 'PROJECT1_CACHE_KEY', } `, @@ -465,7 +465,7 @@ test('Does transform files with the corresponding project transformer', () => { };`, 'project2/transformer.js': ` module.exports = { - process: () => 'module.exports = "PROJECT2";', + process: () => ({code: 'module.exports = "PROJECT2";'}), getCacheKey: () => 'PROJECT2_CACHE_KEY', } `, diff --git a/e2e/coverage-provider-v8/esm-with-custom-transformer/typescriptPreprocessor.js b/e2e/coverage-provider-v8/esm-with-custom-transformer/typescriptPreprocessor.js index 3fec16a6891b..1fdcb803c166 100644 --- a/e2e/coverage-provider-v8/esm-with-custom-transformer/typescriptPreprocessor.js +++ b/e2e/coverage-provider-v8/esm-with-custom-transformer/typescriptPreprocessor.js @@ -21,6 +21,6 @@ export default { return {code: outputText, map: sourceMapText}; } - return sourceText; + return {code: sourceText}; }, }; diff --git a/e2e/coverage-provider-v8/no-sourcemap/cssTransform.js b/e2e/coverage-provider-v8/no-sourcemap/cssTransform.js index c973ad34fe44..4772932d79dd 100644 --- a/e2e/coverage-provider-v8/no-sourcemap/cssTransform.js +++ b/e2e/coverage-provider-v8/no-sourcemap/cssTransform.js @@ -7,5 +7,5 @@ module.exports = { getCacheKey: () => 'cssTransform', - process: () => 'module.exports = {};', + process: () => ({code: 'module.exports = {};'}), }; diff --git a/e2e/coverage-remapping/typescriptPreprocessor.js b/e2e/coverage-remapping/typescriptPreprocessor.js index dd8575ce8cba..25b9a60dab28 100644 --- a/e2e/coverage-remapping/typescriptPreprocessor.js +++ b/e2e/coverage-remapping/typescriptPreprocessor.js @@ -22,6 +22,6 @@ module.exports = { map: JSON.parse(result.sourceMapText), }; } - return src; + return {code: src}; }, }; diff --git a/e2e/global-setup-custom-transform/transformer.js b/e2e/global-setup-custom-transform/transformer.js index 178565a491e2..77db60a2742d 100644 --- a/e2e/global-setup-custom-transform/transformer.js +++ b/e2e/global-setup-custom-transform/transformer.js @@ -12,9 +12,9 @@ const fileToTransform = require.resolve('./index.js'); module.exports = { process(src, filename) { if (filename === fileToTransform) { - return src.replace('hello', 'hello, world'); + return {code: src.replace('hello', 'hello, world')}; } - return src; + return {code: src}; }, }; diff --git a/e2e/snapshot-serializers/transformer.js b/e2e/snapshot-serializers/transformer.js index 5606ac36381f..44d68384a734 100644 --- a/e2e/snapshot-serializers/transformer.js +++ b/e2e/snapshot-serializers/transformer.js @@ -10,8 +10,8 @@ module.exports = { process(src, filename) { if (/bar.js$/.test(filename)) { - return `${src};\nmodule.exports = createPlugin('bar');`; + return {code: `${src};\nmodule.exports = createPlugin('bar');`}; } - return src; + return {code: src}; }, }; diff --git a/e2e/stack-trace-source-maps-with-coverage/preprocessor.js b/e2e/stack-trace-source-maps-with-coverage/preprocessor.js index 133d42ec44a2..ded4db6d8929 100644 --- a/e2e/stack-trace-source-maps-with-coverage/preprocessor.js +++ b/e2e/stack-trace-source-maps-with-coverage/preprocessor.js @@ -8,14 +8,19 @@ const tsc = require('typescript'); module.exports = { - process(src, path) { - return tsc.transpileModule(src, { - compilerOptions: { - inlineSourceMap: true, - module: tsc.ModuleKind.CommonJS, - target: 'es5', - }, - fileName: path, - }).outputText; + process(sourceText, fileName) { + if (fileName.endsWith('.ts') || fileName.endsWith('.tsx')) { + const {outputText, sourceMapText} = tsc.transpileModule(sourceText, { + compilerOptions: { + inlineSourceMap: true, + module: tsc.ModuleKind.CommonJS, + target: 'es5', + }, + fileName, + }); + + return {code: outputText, map: sourceMapText}; + } + return {code: sourceText}; }, }; diff --git a/e2e/stack-trace-source-maps/preprocessor.js b/e2e/stack-trace-source-maps/preprocessor.js index 133d42ec44a2..ded4db6d8929 100644 --- a/e2e/stack-trace-source-maps/preprocessor.js +++ b/e2e/stack-trace-source-maps/preprocessor.js @@ -8,14 +8,19 @@ const tsc = require('typescript'); module.exports = { - process(src, path) { - return tsc.transpileModule(src, { - compilerOptions: { - inlineSourceMap: true, - module: tsc.ModuleKind.CommonJS, - target: 'es5', - }, - fileName: path, - }).outputText; + process(sourceText, fileName) { + if (fileName.endsWith('.ts') || fileName.endsWith('.tsx')) { + const {outputText, sourceMapText} = tsc.transpileModule(sourceText, { + compilerOptions: { + inlineSourceMap: true, + module: tsc.ModuleKind.CommonJS, + target: 'es5', + }, + fileName, + }); + + return {code: outputText, map: sourceMapText}; + } + return {code: sourceText}; }, }; diff --git a/e2e/transform-linked-modules/preprocessor.js b/e2e/transform-linked-modules/preprocessor.js index acf4723313d1..67c48b478bc3 100644 --- a/e2e/transform-linked-modules/preprocessor.js +++ b/e2e/transform-linked-modules/preprocessor.js @@ -7,6 +7,6 @@ module.exports = { process() { - return 'module.exports = "transformed"'; + return {code: 'module.exports = "transformed"'}; }, }; diff --git a/e2e/transform/async-transformer/my-transform.cjs b/e2e/transform/async-transformer/my-transform.cjs index 9f9b4a91398f..e1c13f1171a3 100644 --- a/e2e/transform/async-transformer/my-transform.cjs +++ b/e2e/transform/async-transformer/my-transform.cjs @@ -24,12 +24,14 @@ module.exports = { // we want to wait to ensure the module cache is populated with the correct module await wait(100); - return src; + return {code: src}; } - return src.replace( - "export default 'It was not transformed!!'", - 'export default 42', - ); + return { + code: src.replace( + "export default 'It was not transformed!!'", + 'export default 42', + ), + }; }, }; diff --git a/e2e/transform/cache/transformer.js b/e2e/transform/cache/transformer.js index 10d02e637f80..84b368ab9b57 100644 --- a/e2e/transform/cache/transformer.js +++ b/e2e/transform/cache/transformer.js @@ -6,11 +6,11 @@ */ module.exports = { - process(src, path) { + process(code, path) { if (path.includes('common')) { console.log(path); } - return src; + return {code}; }, }; diff --git a/e2e/transform/custom-instrumenting-preprocessor/preprocessor.js b/e2e/transform/custom-instrumenting-preprocessor/preprocessor.js index 99e12ff008e4..bb1dbf38c648 100644 --- a/e2e/transform/custom-instrumenting-preprocessor/preprocessor.js +++ b/e2e/transform/custom-instrumenting-preprocessor/preprocessor.js @@ -8,12 +8,12 @@ module.exports = { canInstrument: true, process(src, filename, options) { - src = `${src};\nglobalThis.__PREPROCESSED__ = true;`; + let code = `${src};\nglobalThis.__PREPROCESSED__ = true;`; if (options.instrument) { - src = `${src};\nglobalThis.__INSTRUMENTED__ = true;`; + code = `${src};\nglobalThis.__INSTRUMENTED__ = true;`; } - return src; + return {code}; }, }; diff --git a/e2e/transform/esm-transformer/my-transform.mjs b/e2e/transform/esm-transformer/my-transform.mjs index 241e27ee29db..96d8c23058f3 100644 --- a/e2e/transform/esm-transformer/my-transform.mjs +++ b/e2e/transform/esm-transformer/my-transform.mjs @@ -14,9 +14,9 @@ const fileToTransform = require.resolve('./module'); export default { process(src, filepath) { if (filepath === fileToTransform) { - return 'module.exports = 42;'; + return {code: 'module.exports = 42;'}; } - return src; + return {code: src}; }, }; diff --git a/e2e/transform/multiple-transformers/cssPreprocessor.js b/e2e/transform/multiple-transformers/cssPreprocessor.js index 5ca52dd30e54..6e5da5fce882 100644 --- a/e2e/transform/multiple-transformers/cssPreprocessor.js +++ b/e2e/transform/multiple-transformers/cssPreprocessor.js @@ -7,13 +7,15 @@ module.exports = { process() { - return ` - module.exports = { - root: 'App-root', - header: 'App-header', - logo: 'App-logo', - intro: 'App-intro', - }; - `; + const code = ` + module.exports = { + root: 'App-root', + header: 'App-header', + logo: 'App-logo', + intro: 'App-intro', + }; + `; + + return {code}; }, }; diff --git a/e2e/transform/multiple-transformers/filePreprocessor.js b/e2e/transform/multiple-transformers/filePreprocessor.js index c49b641e62d2..b419a52779c8 100644 --- a/e2e/transform/multiple-transformers/filePreprocessor.js +++ b/e2e/transform/multiple-transformers/filePreprocessor.js @@ -9,8 +9,10 @@ const path = require('path'); module.exports = { process(src, filename) { - return ` - module.exports = '${path.basename(filename)}'; - `; + const code = ` + module.exports = '${path.basename(filename)}'; + `; + + return {code}; }, }; diff --git a/e2e/typescript-coverage/typescriptPreprocessor.js b/e2e/typescript-coverage/typescriptPreprocessor.js index 8633bdab5a95..251c68f5e38f 100644 --- a/e2e/typescript-coverage/typescriptPreprocessor.js +++ b/e2e/typescript-coverage/typescriptPreprocessor.js @@ -8,18 +8,19 @@ const tsc = require('typescript'); module.exports = { - process(src, path) { - if (path.endsWith('.ts') || path.endsWith('.tsx')) { - return tsc.transpile( - src, - { + process(sourceText, fileName) { + if (fileName.endsWith('.ts') || fileName.endsWith('.tsx')) { + const {outputText, sourceMapText} = tsc.transpileModule(sourceText, { + compilerOptions: { jsx: tsc.JsxEmit.React, module: tsc.ModuleKind.CommonJS, + sourceMap: true, // if code is transformed, source map is necessary for coverage }, - path, - [], - ); + fileName, + }); + + return {code: outputText, map: sourceMapText}; } - return src; + return {code: sourceText}; }, }; diff --git a/package.json b/package.json index 3dd98afc3ab7..64974a50de2b 100644 --- a/package.json +++ b/package.json @@ -168,7 +168,7 @@ "babel-jest": "workspace:*", "jest": "workspace:*", "jest-environment-node": "workspace:*", - "react-native": "patch:react-native@0.68.0#./patches/react-native.patch" + "react-native": "patch:react-native@npm:0.68.0#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch" }, "packageManager": "yarn@3.2.0" } diff --git a/packages/babel-jest/src/index.ts b/packages/babel-jest/src/index.ts index ff5fc8b85ce6..b48ebe71a40c 100644 --- a/packages/babel-jest/src/index.ts +++ b/packages/babel-jest/src/index.ts @@ -244,7 +244,7 @@ export const createTransformer: TransformerCreator< } } - return sourceText; + return {code: sourceText}; }, async processAsync(sourceText, sourcePath, transformOptions) { const babelOptions = await loadBabelOptionsAsync( @@ -266,7 +266,7 @@ export const createTransformer: TransformerCreator< } } - return sourceText; + return {code: sourceText}; }, }; }; diff --git a/packages/jest-runtime/src/__tests__/test_root/test_json_preprocessor.js b/packages/jest-runtime/src/__tests__/test_root/test_json_preprocessor.js index ec9b48f69cc2..7597efa50e3f 100644 --- a/packages/jest-runtime/src/__tests__/test_root/test_json_preprocessor.js +++ b/packages/jest-runtime/src/__tests__/test_root/test_json_preprocessor.js @@ -10,5 +10,5 @@ module.exports.process = source => { const json = JSON.parse(source); Object.keys(json).forEach(k => (json[k] = k)); - return JSON.stringify(json); + return {code: JSON.stringify(json)}; }; diff --git a/packages/jest-runtime/src/__tests__/test_root/test_preprocessor.js b/packages/jest-runtime/src/__tests__/test_root/test_preprocessor.js index cf5e591fe05b..f5ce630fc144 100644 --- a/packages/jest-runtime/src/__tests__/test_root/test_preprocessor.js +++ b/packages/jest-runtime/src/__tests__/test_root/test_preprocessor.js @@ -7,4 +7,6 @@ 'use strict'; -module.exports.process = () => "throw new Error('preprocessor must not run.');"; +module.exports.process = () => ({ + code: "throw new Error('preprocessor must not run.');", +}); diff --git a/packages/jest-transform/src/ScriptTransformer.ts b/packages/jest-transform/src/ScriptTransformer.ts index 4959c200d5cc..3472042669b4 100644 --- a/packages/jest-transform/src/ScriptTransformer.ts +++ b/packages/jest-transform/src/ScriptTransformer.ts @@ -379,9 +379,7 @@ class ScriptTransformer { }; if (transformer && shouldCallTransform) { - if (typeof processed === 'string') { - transformed.code = processed; - } else if (processed != null && typeof processed.code === 'string') { + if (processed != null && typeof processed.code === 'string') { transformed = processed; } else { throw new Error(makeInvalidReturnValueError()); @@ -483,7 +481,7 @@ class ScriptTransformer { }; } - let processed = null; + let processed: TransformedSource | null = null; let shouldCallTransform = false; diff --git a/packages/jest-transform/src/__tests__/ScriptTransformer.test.ts b/packages/jest-transform/src/__tests__/ScriptTransformer.test.ts index 3e3533f781ce..7ca030ca726b 100644 --- a/packages/jest-transform/src/__tests__/ScriptTransformer.test.ts +++ b/packages/jest-transform/src/__tests__/ScriptTransformer.test.ts @@ -12,7 +12,7 @@ import type {Options, ShouldInstrumentOptions, Transformer} from '../types'; jest .mock('graceful-fs', () => ({ - ...jest.requireActual('graceful-fs'), + ...jest.requireActual('graceful-fs'), /* eslint-disable sort-keys */ readFileSync: jest.fn((path, options) => { mockInvariant(typeof path === 'string'); @@ -55,7 +55,7 @@ jest }, })) .mock('jest-util', () => ({ - ...jest.requireActual('jest-util'), + ...jest.requireActual('jest-util'), createDirectory: jest.fn(), })) .mock('path', () => jest.requireActual('path').posix); @@ -67,13 +67,15 @@ jest.mock( const transformer: Transformer = { getCacheKey: jest.fn(() => 'ab'), - process: (content, filename, config) => require('dedent')` + process: (content, filename, config) => ({ + code: require('dedent')` const TRANSFORMED = { filename: '${escapeStrings(filename)}', script: '${escapeStrings(content)}', config: '${escapeStrings(JSON.stringify(config))}', }; `, + }), }; return transformer; @@ -88,14 +90,15 @@ jest.mock( const transformer: Transformer = { getCacheKeyAsync: jest.fn().mockResolvedValue('ab'), - processAsync: async (content, filename, config) => - require('dedent')` + processAsync: async (content, filename, config) => ({ + code: require('dedent')` const TRANSFORMED = { filename: '${escapeStrings(filename)}', script: '${escapeStrings(content)}', config: '${escapeStrings(JSON.stringify(config))}', }; `, + }), }; return transformer; @@ -107,7 +110,7 @@ jest.mock( 'configureable-preprocessor', () => ({ createTransformer: jest.fn(() => ({ - process: jest.fn(() => 'processedCode'), + process: jest.fn().mockReturnValue({code: 'processedCode'}), })), }), {virtual: true}, @@ -117,7 +120,7 @@ jest.mock( 'cache_fs_preprocessor', () => ({ getCacheKey: jest.fn(() => 'ab'), - process: jest.fn(() => 'processedCode'), + process: jest.fn().mockReturnValue({code: 'processedCode'}), }), {virtual: true}, ); @@ -126,7 +129,7 @@ jest.mock( 'cache_fs_async_preprocessor', () => ({ getCacheKeyAsync: jest.fn().mockResolvedValue('ab'), - processAsync: jest.fn().mockResolvedValue('processedCode'), + processAsync: jest.fn().mockResolvedValue({code: 'processedCode'}), }), {virtual: true}, ); @@ -154,12 +157,14 @@ jest.mock( () => { const transformer: Transformer = { getCacheKey: jest.fn(() => 'cd'), - process: (content, filename) => jest.requireActual('dedent')` + process: (content, filename) => ({ + code: require('dedent')` module.exports = { filename: ${filename}, rawFirstLine: ${content.split('\n')[0]}, }; `, + }), }; return transformer; @@ -177,14 +182,14 @@ jest.mock('skipped-required-props-preprocessor', () => ({}), {virtual: true}); // Bad preprocessor jest.mock( 'skipped-required-props-preprocessor-only-sync', - () => ({process: () => ''}), + () => ({process: () => ({code: ''})}), {virtual: true}, ); // Bad preprocessor jest.mock( 'skipped-required-props-preprocessor-only-async', - () => ({processAsync: async () => ''}), + () => ({processAsync: async () => ({code: ''})}), {virtual: true}, ); @@ -203,7 +208,7 @@ jest.mock( 'skipped-process-method-preprocessor', () => ({ createTransformer() { - return {process: jest.fn(() => 'code')}; + return {process: jest.fn().mockReturnValue({code: 'code'})}; }, }), {virtual: true}, @@ -213,7 +218,7 @@ jest.mock( 'factory-for-async-preprocessor', () => ({ createTransformer() { - return {processAsync: jest.fn().mockResolvedValue('code')}; + return {processAsync: jest.fn().mockResolvedValue({code: 'code'})}; }, }), {virtual: true}, @@ -376,7 +381,7 @@ describe('ScriptTransformer', () => { ); }); - it("throws an error if `process` doesn't return a string or an object containing `code` key with processed string", async () => { + it("throws an error if `process` doesn't return an object containing `code` key with processed string", async () => { config = { ...config, transform: [['\\.js$', 'passthrough-preprocessor', {}]], @@ -385,6 +390,7 @@ describe('ScriptTransformer', () => { const incorrectReturnValues = [ [undefined, '/fruits/banana.js'], + ['code', '/fruits/banana.js'], [{a: 'a'}, '/fruits/kiwi.js'], [[], '/fruits/grapefruit.js'], ]; @@ -394,13 +400,10 @@ describe('ScriptTransformer', () => { require('passthrough-preprocessor').process.mockReturnValue(returnValue); expect(() => scriptTransformer.transform(filePath, getCoverageOptions()), - ).toThrow('must return a string'); + ).toThrowErrorMatchingSnapshot(); }); - const correctReturnValues = [ - ['code', '/fruits/banana.js'], - [{code: 'code'}, '/fruits/kiwi.js'], - ]; + const correctReturnValues = [[{code: 'code'}, '/fruits/kiwi.js']]; correctReturnValues.forEach(([returnValue, filePath]) => { mockInvariant(typeof filePath === 'string'); @@ -411,15 +414,15 @@ describe('ScriptTransformer', () => { }); }); - it("throws an error if `processAsync` doesn't return a promise of string or object containing `code` key with processed string", async () => { + it("throws an error if `processAsync` doesn't return a promise of object containing `code` key with processed string", async () => { const incorrectReturnValues: Array<[any, string]> = [ [undefined, '/fruits/banana.js'], + ['code', '/fruits/avocado.js'], [{a: 'a'}, '/fruits/kiwi.js'], [[], '/fruits/grapefruit.js'], ]; const correctReturnValues: Array<[any, string]> = [ - ['code', '/fruits/avocado.js'], [{code: 'code'}, '/fruits/mango.js'], ]; @@ -453,10 +456,7 @@ describe('ScriptTransformer', () => { const promisesToReject = incorrectReturnValues .map(buildPromise) - .map(promise => - // Jest must throw error - expect(promise).rejects.toThrow(), - ); + .map(promise => expect(promise).rejects.toThrowErrorMatchingSnapshot()); const promisesToResolve = correctReturnValues .map(buildPromise) @@ -790,7 +790,9 @@ describe('ScriptTransformer', () => { sourceMap, ).toString('base64')}`; - require('preprocessor-with-sourcemaps').process.mockReturnValue(content); + require('preprocessor-with-sourcemaps').process.mockReturnValue({ + code: content, + }); const result = scriptTransformer.transform( '/fruits/banana.js', @@ -823,7 +825,9 @@ describe('ScriptTransformer', () => { sourceMap, ).toString('base64')}`; - require('preprocessor-with-sourcemaps').process.mockReturnValue(content); + require('preprocessor-with-sourcemaps').process.mockReturnValue({ + code: content, + }); const result = await scriptTransformer.transformAsync( '/fruits/banana.js', @@ -857,7 +861,7 @@ describe('ScriptTransformer', () => { ).toString('base64')}`; require('async-preprocessor-with-sourcemaps').processAsync.mockResolvedValue( - content, + {code: content}, ); const result = await scriptTransformer.transformAsync( @@ -897,7 +901,9 @@ describe('ScriptTransformer', () => { .toString('base64') .slice(0, 16)}`; - require('preprocessor-with-sourcemaps').process.mockReturnValue(content); + require('preprocessor-with-sourcemaps').process.mockReturnValue({ + code: content, + }); const result = scriptTransformer.transform( '/fruits/banana.js', @@ -935,7 +941,9 @@ describe('ScriptTransformer', () => { .toString('base64') .slice(0, 16)}`; - require('preprocessor-with-sourcemaps').process.mockReturnValue(content); + require('preprocessor-with-sourcemaps').process.mockReturnValue({ + code: content, + }); const result = await scriptTransformer.transformAsync( '/fruits/banana.js', @@ -974,7 +982,7 @@ describe('ScriptTransformer', () => { .slice(0, 16)}`; require('async-preprocessor-with-sourcemaps').processAsync.mockResolvedValue( - content, + {code: content}, ); const result = await scriptTransformer.transformAsync( diff --git a/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap b/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap index 582da17801e8..1749735a183f 100644 --- a/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap +++ b/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap @@ -356,6 +356,86 @@ exports[`ScriptTransformer passes expected transform options to getCacheKeyAsync } `; +exports[`ScriptTransformer throws an error if \`process\` doesn't return an object containing \`code\` key with processed string 1`] = ` +"● Invalid return value: + Code transformer's \`process\` method must return an object containing \`code\` key + with processed string. If \`processAsync\` method is implemented it must return + a Promise resolving to an object containing \`code\` key with processed string. + Code Transformation Documentation: + https://jestjs.io/docs/code-transformation +" +`; + +exports[`ScriptTransformer throws an error if \`process\` doesn't return an object containing \`code\` key with processed string 2`] = ` +"● Invalid return value: + Code transformer's \`process\` method must return an object containing \`code\` key + with processed string. If \`processAsync\` method is implemented it must return + a Promise resolving to an object containing \`code\` key with processed string. + Code Transformation Documentation: + https://jestjs.io/docs/code-transformation +" +`; + +exports[`ScriptTransformer throws an error if \`process\` doesn't return an object containing \`code\` key with processed string 3`] = ` +"● Invalid return value: + Code transformer's \`process\` method must return an object containing \`code\` key + with processed string. If \`processAsync\` method is implemented it must return + a Promise resolving to an object containing \`code\` key with processed string. + Code Transformation Documentation: + https://jestjs.io/docs/code-transformation +" +`; + +exports[`ScriptTransformer throws an error if \`process\` doesn't return an object containing \`code\` key with processed string 4`] = ` +"● Invalid return value: + Code transformer's \`process\` method must return an object containing \`code\` key + with processed string. If \`processAsync\` method is implemented it must return + a Promise resolving to an object containing \`code\` key with processed string. + Code Transformation Documentation: + https://jestjs.io/docs/code-transformation +" +`; + +exports[`ScriptTransformer throws an error if \`processAsync\` doesn't return a promise of object containing \`code\` key with processed string 1`] = ` +"● Invalid return value: + Code transformer's \`process\` method must return an object containing \`code\` key + with processed string. If \`processAsync\` method is implemented it must return + a Promise resolving to an object containing \`code\` key with processed string. + Code Transformation Documentation: + https://jestjs.io/docs/code-transformation +" +`; + +exports[`ScriptTransformer throws an error if \`processAsync\` doesn't return a promise of object containing \`code\` key with processed string 2`] = ` +"● Invalid return value: + Code transformer's \`process\` method must return an object containing \`code\` key + with processed string. If \`processAsync\` method is implemented it must return + a Promise resolving to an object containing \`code\` key with processed string. + Code Transformation Documentation: + https://jestjs.io/docs/code-transformation +" +`; + +exports[`ScriptTransformer throws an error if \`processAsync\` doesn't return a promise of object containing \`code\` key with processed string 3`] = ` +"● Invalid return value: + Code transformer's \`process\` method must return an object containing \`code\` key + with processed string. If \`processAsync\` method is implemented it must return + a Promise resolving to an object containing \`code\` key with processed string. + Code Transformation Documentation: + https://jestjs.io/docs/code-transformation +" +`; + +exports[`ScriptTransformer throws an error if \`processAsync\` doesn't return a promise of object containing \`code\` key with processed string 4`] = ` +"● Invalid return value: + Code transformer's \`process\` method must return an object containing \`code\` key + with processed string. If \`processAsync\` method is implemented it must return + a Promise resolving to an object containing \`code\` key with processed string. + Code Transformation Documentation: + https://jestjs.io/docs/code-transformation +" +`; + exports[`ScriptTransformer throws an error if createTransformer returns object without \`process\` method 1`] = ` "● Invalid transformer module: "skipped-required-create-transformer-props-preprocessor" specified in the "transform" object of Jest configuration diff --git a/packages/jest-transform/src/runtimeErrorsAndWarnings.ts b/packages/jest-transform/src/runtimeErrorsAndWarnings.ts index 1b31299130ef..c57292ac5b14 100644 --- a/packages/jest-transform/src/runtimeErrorsAndWarnings.ts +++ b/packages/jest-transform/src/runtimeErrorsAndWarnings.ts @@ -19,9 +19,9 @@ export const makeInvalidReturnValueError = (): string => chalk.red( [ chalk.bold(`${BULLET}Invalid return value:`), - " Code transformer's `process` function must return a string or an object", - ' with `code` key containing a string. If `processAsync` function is implemented,', - ' it must return a Promise resolving to one of these values.', + " Code transformer's `process` method must return an object containing `code` key ", + ' with processed string. If `processAsync` method is implemented it must return ', + ' a Promise resolving to an object containing `code` key with processed string.', '', ].join('\n') + DOCUMENTATION_NOTE, ); diff --git a/packages/jest-transform/src/types.ts b/packages/jest-transform/src/types.ts index 85bb4a31ba54..543583477a6a 100644 --- a/packages/jest-transform/src/types.ts +++ b/packages/jest-transform/src/types.ts @@ -31,10 +31,10 @@ interface FixedRawSourceMap extends Omit { version: number; } -// TODO: For Jest 26 normalize this (always structured data, never a string) -export type TransformedSource = - | {code: string; map?: FixedRawSourceMap | string | null} - | string; +export type TransformedSource = { + code: string; + map?: FixedRawSourceMap | string | null; +}; export type TransformResult = TransformTypes.TransformResult; diff --git a/yarn.lock b/yarn.lock index 9cdc0bab46f4..a26e933d6633 100644 --- a/yarn.lock +++ b/yarn.lock @@ -18672,9 +18672,9 @@ __metadata: languageName: node linkType: hard -"react-native@patch:react-native@0.68.0#./patches/react-native.patch::locator=%40jest%2Fmonorepo%40workspace%3A.": +"react-native@patch:react-native@npm:0.68.0#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch::locator=%40jest%2Fmonorepo%40workspace%3A.": version: 0.68.0 - resolution: "react-native@patch:react-native@npm%3A0.68.0#./patches/react-native.patch::version=0.68.0&hash=5ca1dc&locator=%40jest%2Fmonorepo%40workspace%3A." + resolution: "react-native@patch:react-native@npm%3A0.68.0#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch::version=0.68.0&hash=c5a757&locator=%40jest%2Fmonorepo%40workspace%3A." dependencies: "@jest/create-cache-key-function": ^27.0.1 "@react-native-community/cli": ^7.0.3 @@ -18712,7 +18712,7 @@ __metadata: react: 17.0.2 bin: react-native: cli.js - checksum: f953ba6590354181e1331466c54b3d90d2d0a4b60c077808cd23b9c88b6008f332078e5541ad69a7ca5c66123cdda4ec8ea085bcfa9d61e28535d2233059cf96 + checksum: 14f503f007e6372c9c31c397df1cc6ecc581a597a8752009721402c132905aa9381d1bb5459da8862dde498348eb0c18a9e93ce1ee911a4947ff01cc5df9928d languageName: node linkType: hard From 777e32687775b9287650c85ade4f9fdda1405fe1 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 6 Apr 2022 13:28:27 +0200 Subject: [PATCH 022/128] chore: add missing `#` --- CHANGELOG.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 96b32db89ccc..9ea5a9255d3e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -57,7 +57,7 @@ - `[jest-circus, @jest/types]` Disallow undefined value in `TestContext` type ([#12507](https://github.com/facebook/jest/pull/12507)) - `[jest-config]` Correctly detect CI environment and update snapshots accordingly ([#12378](https://github.com/facebook/jest/pull/12378)) - `[jest-config]` Pass `moduleTypes` to `ts-node` to enforce CJS when transpiling ([#12397](https://github.com/facebook/jest/pull/12397)) -- `[jest-config]` [**BREAKING**] Add `mjs` and `cjs` to default `moduleFileExtensions` config ([12578](https://github.com/facebook/jest/pull/12578)) +- `[jest-config]` [**BREAKING**] Add `mjs` and `cjs` to default `moduleFileExtensions` config ([#12578](https://github.com/facebook/jest/pull/12578)) - `[jest-config, jest-haste-map]` Allow searching for tests in `node_modules` by exposing `retainAllFiles` ([#11084](https://github.com/facebook/jest/pull/11084)) - `[jest-core]` [**BREAKING**] Exit with status `1` if no tests are found with `--findRelatedTests` flag ([#12487](https://github.com/facebook/jest/pull/12487)) - `[jest-each]` `%#` is not replaced with index of the test case ([#12517](https://github.com/facebook/jest/pull/12517)) @@ -72,7 +72,7 @@ - `[jest-matcher-utils]` Pass maxWidth to `pretty-format` to avoid printing every element in arrays by default ([#12402](https://github.com/facebook/jest/pull/12402)) - `[jest-mock]` Fix function overloads for `spyOn` to allow more correct type inference in complex object ([#12442](https://github.com/facebook/jest/pull/12442)) - `[jest-reporters]` Notifications generated by the `--notify` flag are no longer persistent in GNOME Shell. ([#11733](https://github.com/facebook/jest/pull/11733)) -- `[@jest-reporters]` Move missing icon file which is needed for `NotifyReporter` class. ([#12593](https://github.com/facebook/jest/pull/12593)) +- `[@jest/reporters]` Move missing icon file which is needed for `NotifyReporter` class. ([#12593](https://github.com/facebook/jest/pull/12593)) - `[jest-worker]` Fix `Farm` execution results memory leak ([#12497](https://github.com/facebook/jest/pull/12497)) ### Chore & Maintenance From 0134332cfba330647702408cb5a5d6a4771ff192 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Thu, 7 Apr 2022 09:51:28 +0200 Subject: [PATCH 023/128] fix: `TestRunnerContext` is not optional (#12640) --- CHANGELOG.md | 1 + packages/jest-core/src/TestScheduler.ts | 4 +- .../src/__tests__/TestScheduler.test.js | 44 ++++++++++++------- .../src/__tests__/testRunner.test.ts | 13 +++--- packages/jest-runner/src/index.ts | 4 +- packages/jest-runner/src/runTest.ts | 8 ++-- packages/jest-runner/src/testWorker.ts | 4 +- 7 files changed, 46 insertions(+), 32 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9ea5a9255d3e..84c64111ae89 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -100,6 +100,7 @@ - `[jest-phabricator]` [**BREAKING**] Migrate to ESM ([#12341](https://github.com/facebook/jest/pull/12341)) - `[jest-resolve]` [**BREAKING**] Make `requireResolveFunction` argument mandatory ([#12353](https://github.com/facebook/jest/pull/12353)) - `[jest-runner]` [**BREAKING**] Remove some type exports from `@jest/test-result` ([#12353](https://github.com/facebook/jest/pull/12353)) +- `[jest-runner]` [**BREAKING**] Second argument to constructor (`Context`) is not optional ([#12640](https://github.com/facebook/jest/pull/12640)) - `[jest-serializer]` [**BREAKING**] Deprecate package in favour of using `v8` APIs directly ([#12391](https://github.com/facebook/jest/pull/12391)) - `[jest-snapshot]` [**BREAKING**] Migrate to ESM ([#12342](https://github.com/facebook/jest/pull/12342)) - `[jest-transform]` Update `write-file-atomic` to v4 ([#12357](https://github.com/facebook/jest/pull/12357)) diff --git a/packages/jest-core/src/TestScheduler.ts b/packages/jest-core/src/TestScheduler.ts index 54955ed39623..4a3d6f8485ea 100644 --- a/packages/jest-core/src/TestScheduler.ts +++ b/packages/jest-core/src/TestScheduler.ts @@ -216,9 +216,9 @@ class TestScheduler { const Runner: typeof TestRunner = await transformer.requireAndTranspileModule(config.runner); const runner = new Runner(this._globalConfig, { - changedFiles: this._context?.changedFiles, + changedFiles: this._context.changedFiles, sourcesRelatedToTestsInChangedFiles: - this._context?.sourcesRelatedToTestsInChangedFiles, + this._context.sourcesRelatedToTestsInChangedFiles, }); testRunners[config.runner] = runner; contextsByTestRunner.set(runner, context); diff --git a/packages/jest-core/src/__tests__/TestScheduler.test.js b/packages/jest-core/src/__tests__/TestScheduler.test.js index b707ef3289c9..98b0d705ad7e 100644 --- a/packages/jest-core/src/__tests__/TestScheduler.test.js +++ b/packages/jest-core/src/__tests__/TestScheduler.test.js @@ -7,7 +7,7 @@ */ import {SummaryReporter} from '@jest/reporters'; -import {makeProjectConfig} from '@jest/test-utils'; +import {makeGlobalConfig, makeProjectConfig} from '@jest/test-utils'; import {createTestScheduler} from '../TestScheduler'; import * as testSchedulerHelper from '../testSchedulerHelper'; @@ -37,18 +37,20 @@ beforeEach(() => { test('config for reporters supports `default`', async () => { const undefinedReportersScheduler = await createTestScheduler( - { + makeGlobalConfig({ reporters: undefined, - }, + }), + {}, {}, ); const numberOfReporters = undefinedReportersScheduler._dispatcher._reporters.length; const stringDefaultReportersScheduler = await createTestScheduler( - { + makeGlobalConfig({ reporters: ['default'], - }, + }), + {}, {}, ); expect(stringDefaultReportersScheduler._dispatcher._reporters.length).toBe( @@ -56,9 +58,10 @@ test('config for reporters supports `default`', async () => { ); const defaultReportersScheduler = await createTestScheduler( - { + makeGlobalConfig({ reporters: [['default', {}]], - }, + }), + {}, {}, ); expect(defaultReportersScheduler._dispatcher._reporters.length).toBe( @@ -66,16 +69,17 @@ test('config for reporters supports `default`', async () => { ); const emptyReportersScheduler = await createTestScheduler( - { + makeGlobalConfig({ reporters: [], - }, + }), + {}, {}, ); expect(emptyReportersScheduler._dispatcher._reporters.length).toBe(0); }); test('.addReporter() .removeReporter()', async () => { - const scheduler = await createTestScheduler({}, {}); + const scheduler = await createTestScheduler(makeGlobalConfig(), {}, {}); const reporter = new SummaryReporter(); scheduler.addReporter(reporter); expect(scheduler._dispatcher._reporters).toContain(reporter); @@ -84,7 +88,7 @@ test('.addReporter() .removeReporter()', async () => { }); test('schedule tests run in parallel per default', async () => { - const scheduler = await createTestScheduler({}, {}); + const scheduler = await createTestScheduler(makeGlobalConfig(), {}, {}); const test = { context: { config: makeProjectConfig({ @@ -107,7 +111,7 @@ test('schedule tests run in parallel per default', async () => { }); test('schedule tests run in serial if the runner flags them', async () => { - const scheduler = await createTestScheduler({}, {}); + const scheduler = await createTestScheduler(makeGlobalConfig(), {}, {}); const test = { context: { config: makeProjectConfig({ @@ -130,7 +134,11 @@ test('schedule tests run in serial if the runner flags them', async () => { }); test('should bail after `n` failures', async () => { - const scheduler = await createTestScheduler({bail: 2}, {}); + const scheduler = await createTestScheduler( + makeGlobalConfig({bail: 2}), + {}, + {}, + ); const test = { context: { config: makeProjectConfig({ @@ -162,7 +170,11 @@ test('should bail after `n` failures', async () => { }); test('should not bail if less than `n` failures', async () => { - const scheduler = await createTestScheduler({bail: 2}, {}); + const scheduler = await createTestScheduler( + makeGlobalConfig({bail: 2}), + {}, + {}, + ); const test = { context: { config: makeProjectConfig({ @@ -194,7 +206,7 @@ test('should not bail if less than `n` failures', async () => { }); test('should set runInBand to run in serial', async () => { - const scheduler = await createTestScheduler({}, {}); + const scheduler = await createTestScheduler(makeGlobalConfig(), {}, {}); const test = { context: { config: makeProjectConfig({ @@ -220,7 +232,7 @@ test('should set runInBand to run in serial', async () => { }); test('should set runInBand to not run in serial', async () => { - const scheduler = await createTestScheduler({}, {}); + const scheduler = await createTestScheduler(makeGlobalConfig(), {}, {}); const test = { context: { config: makeProjectConfig({ diff --git a/packages/jest-runner/src/__tests__/testRunner.test.ts b/packages/jest-runner/src/__tests__/testRunner.test.ts index 16fd75e183ad..b86345a44f71 100644 --- a/packages/jest-runner/src/__tests__/testRunner.test.ts +++ b/packages/jest-runner/src/__tests__/testRunner.test.ts @@ -7,6 +7,7 @@ */ import {TestWatcher} from '@jest/core'; +import {makeGlobalConfig, makeProjectConfig} from '@jest/test-utils'; import TestRunner from '../index'; let mockWorkerFarm; @@ -26,8 +27,8 @@ jest.mock('jest-worker', () => ({ jest.mock('../testWorker', () => {}); test('injects the serializable module map into each worker in watch mode', async () => { - const globalConfig = {maxWorkers: 2, watch: true}; - const config = {rootDir: '/path/'}; + const globalConfig = makeGlobalConfig({maxWorkers: 2, watch: true}); + const config = makeProjectConfig({rootDir: '/path/'}); const serializableModuleMap = jest.fn(); const runContext = {}; const context = { @@ -35,7 +36,7 @@ test('injects the serializable module map into each worker in watch mode', async moduleMap: {toJSON: () => serializableModuleMap}, }; - await new TestRunner(globalConfig).runTests( + await new TestRunner(globalConfig, {}).runTests( [ {context, path: './file.test.js'}, {context, path: './file2.test.js'}, @@ -68,11 +69,11 @@ test('injects the serializable module map into each worker in watch mode', async }); test('assign process.env.JEST_WORKER_ID = 1 when in runInBand mode', async () => { - const globalConfig = {maxWorkers: 1, watch: false}; - const config = {rootDir: '/path/'}; + const globalConfig = makeGlobalConfig({maxWorkers: 1, watch: false}); + const config = makeProjectConfig({rootDir: '/path/'}); const context = {config}; - await new TestRunner(globalConfig).runTests( + await new TestRunner(globalConfig, {}).runTests( [{context, path: './file.test.js'}], new TestWatcher({isWatchMode: globalConfig.watch}), undefined, diff --git a/packages/jest-runner/src/index.ts b/packages/jest-runner/src/index.ts index 88785a096342..a684d1e94660 100644 --- a/packages/jest-runner/src/index.ts +++ b/packages/jest-runner/src/index.ts @@ -51,9 +51,9 @@ export default class TestRunner { readonly isSerial?: boolean; - constructor(globalConfig: Config.GlobalConfig, context?: TestRunnerContext) { + constructor(globalConfig: Config.GlobalConfig, context: TestRunnerContext) { this._globalConfig = globalConfig; - this._context = context || {}; + this._context = context; } async runTests( diff --git a/packages/jest-runner/src/runTest.ts b/packages/jest-runner/src/runTest.ts index dfa50645bf46..ecf25812b269 100644 --- a/packages/jest-runner/src/runTest.ts +++ b/packages/jest-runner/src/runTest.ts @@ -79,7 +79,7 @@ async function runTestInternal( globalConfig: Config.GlobalConfig, projectConfig: Config.ProjectConfig, resolver: Resolver, - context?: TestRunnerContext, + context: TestRunnerContext, sendMessageToJest?: TestFileEvent, ): Promise { const testSource = fs.readFileSync(path, 'utf8'); @@ -188,13 +188,13 @@ async function runTestInternal( transformer, cacheFS, { - changedFiles: context?.changedFiles, + changedFiles: context.changedFiles, collectCoverage: globalConfig.collectCoverage, collectCoverageFrom: globalConfig.collectCoverageFrom, collectCoverageOnlyFrom: globalConfig.collectCoverageOnlyFrom, coverageProvider: globalConfig.coverageProvider, sourcesRelatedToTestsInChangedFiles: - context?.sourcesRelatedToTestsInChangedFiles, + context.sourcesRelatedToTestsInChangedFiles, }, path, ); @@ -363,7 +363,7 @@ export default async function runTest( globalConfig: Config.GlobalConfig, config: Config.ProjectConfig, resolver: Resolver, - context?: TestRunnerContext, + context: TestRunnerContext, sendMessageToJest?: TestFileEvent, ): Promise { const {leakDetector, result} = await runTestInternal( diff --git a/packages/jest-runner/src/testWorker.ts b/packages/jest-runner/src/testWorker.ts index 687cbfdcdc55..4962bffc8701 100644 --- a/packages/jest-runner/src/testWorker.ts +++ b/packages/jest-runner/src/testWorker.ts @@ -30,7 +30,7 @@ type WorkerData = { config: Config.ProjectConfig; globalConfig: Config.GlobalConfig; path: string; - context?: TestRunnerSerializedContext; + context: TestRunnerSerializedContext; }; // Make sure uncaught errors are logged before we exit. @@ -97,7 +97,7 @@ export async function worker({ globalConfig, config, getResolver(config), - context && { + { ...context, changedFiles: context.changedFiles && new Set(context.changedFiles), sourcesRelatedToTestsInChangedFiles: From 550c92f4289a0c726f2e2aaa5b86714145f5fbe0 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Thu, 7 Apr 2022 12:26:20 +0200 Subject: [PATCH 024/128] chore: stabilize event emitter runners (#12641) --- CHANGELOG.md | 3 +- packages/jest-core/src/TestScheduler.ts | 6 +- packages/jest-runner/src/index.ts | 104 ++++++------------------ 3 files changed, 26 insertions(+), 87 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 84c64111ae89..d9a05f43407a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,8 +14,9 @@ - `[jest-config]` [**BREAKING**] Rename `moduleLoader` to `runtime` ([#10817](https://github.com/facebook/jest/pull/10817)) - `[jest-config]` [**BREAKING**] Rename `extraGlobals` to `sandboxInjectedGlobals` ([#10817](https://github.com/facebook/jest/pull/10817)) - `[jest-config]` [**BREAKING**] Throw an error instead of showing a warning if multiple configs are used ([#12510](https://github.com/facebook/jest/pull/12510)) -- `[jest-core]` Pass project config to `globalSetup`/`globalTeardown` function as second argument ([#12440](https://github.com/facebook/jest/pull/12440)) - `[jest-cli, jest-core]` Add `--ignoreProjects` CLI argument to ignore test suites by project name ([#12620](https://github.com/facebook/jest/pull/12620)) +- `[jest-core]` Pass project config to `globalSetup`/`globalTeardown` function as second argument ([#12440](https://github.com/facebook/jest/pull/12440)) +- `[jest-core]` Stabilize test runners with event emitters ([#12641](https://github.com/facebook/jest/pull/12641)) - `[jest-environment-jsdom]` [**BREAKING**] Upgrade jsdom to 19.0.0 ([#12290](https://github.com/facebook/jest/pull/12290)) - `[jest-environment-jsdom]` [**BREAKING**] Add default `browser` condition to `exportConditions` for `jsdom` environment ([#11924](https://github.com/facebook/jest/pull/11924)) - `[jest-environment-jsdom]` [**BREAKING**] Pass global config to Jest environment constructor for `jsdom` environment ([#12461](https://github.com/facebook/jest/pull/12461)) diff --git a/packages/jest-core/src/TestScheduler.ts b/packages/jest-core/src/TestScheduler.ts index 4a3d6f8485ea..4e5101cf4041 100644 --- a/packages/jest-core/src/TestScheduler.ts +++ b/packages/jest-core/src/TestScheduler.ts @@ -242,11 +242,7 @@ class TestScheduler { serial: runInBand || Boolean(testRunner.isSerial), }; - /** - * Test runners with event emitters are still not supported - * for third party test runners. - */ - if (testRunner.__PRIVATE_UNSTABLE_API_supportsEventEmitters__) { + if (testRunner.supportsEventEmitters) { const unsubscribes = [ testRunner.on('test-file-start', ([test]) => onTestFileStart(test), diff --git a/packages/jest-runner/src/index.ts b/packages/jest-runner/src/index.ts index a684d1e94660..a753d16a8b91 100644 --- a/packages/jest-runner/src/index.ts +++ b/packages/jest-runner/src/index.ts @@ -47,7 +47,7 @@ export default class TestRunner { private readonly _globalConfig: Config.GlobalConfig; private readonly _context: TestRunnerContext; private readonly eventEmitter = new Emittery(); - readonly __PRIVATE_UNSTABLE_API_supportsEventEmitters__: boolean = true; + readonly supportsEventEmitters: boolean = true; readonly isSerial?: boolean; @@ -59,29 +59,19 @@ export default class TestRunner { async runTests( tests: Array, watcher: TestWatcher, - onStart: OnTestStart | undefined, - onResult: OnTestSuccess | undefined, - onFailure: OnTestFailure | undefined, + // keep these three as they're still passed and should be in the types, + // even if this particular runner doesn't use them + _onStart: OnTestStart | undefined, + _onResult: OnTestSuccess | undefined, + _onFailure: OnTestFailure | undefined, options: TestRunnerOptions, ): Promise { return await (options.serial - ? this._createInBandTestRun(tests, watcher, onStart, onResult, onFailure) - : this._createParallelTestRun( - tests, - watcher, - onStart, - onResult, - onFailure, - )); + ? this._createInBandTestRun(tests, watcher) + : this._createParallelTestRun(tests, watcher)); } - private async _createInBandTestRun( - tests: Array, - watcher: TestWatcher, - onStart?: OnTestStart, - onResult?: OnTestSuccess, - onFailure?: OnTestFailure, - ) { + private async _createInBandTestRun(tests: Array, watcher: TestWatcher) { process.env.JEST_WORKER_ID = '1'; const mutex = throat(1); return tests.reduce( @@ -92,19 +82,6 @@ export default class TestRunner { if (watcher.isInterrupted()) { throw new CancelRun(); } - // Remove `if(onStart)` in Jest 27 - if (onStart) { - await onStart(test); - - return runTest( - test.path, - this._globalConfig, - test.context.config, - test.context.resolver, - this._context, - undefined, - ); - } // `deepCyclicCopy` used here to avoid mem-leak const sendMessageToJest: TestFileEvent = (eventName, args) => @@ -124,23 +101,11 @@ export default class TestRunner { sendMessageToJest, ); }) - .then(result => { - if (onResult) { - return onResult(test, result); - } - - return this.eventEmitter.emit('test-file-success', [ - test, - result, - ]); - }) - .catch(err => { - if (onFailure) { - return onFailure(test, err); - } - - return this.eventEmitter.emit('test-file-failure', [test, err]); - }), + .then( + result => + this.eventEmitter.emit('test-file-success', [test, result]), + err => this.eventEmitter.emit('test-file-failure', [test, err]), + ), ), Promise.resolve(), ); @@ -149,9 +114,6 @@ export default class TestRunner { private async _createParallelTestRun( tests: Array, watcher: TestWatcher, - onStart?: OnTestStart, - onResult?: OnTestSuccess, - onFailure?: OnTestFailure, ) { const resolvers: Map = new Map(); for (const test of tests) { @@ -168,11 +130,7 @@ export default class TestRunner { forkOptions: {stdio: 'pipe'}, maxRetries: 3, numWorkers: this._globalConfig.maxWorkers, - setupArgs: [ - { - serializableResolvers: Array.from(resolvers.values()), - }, - ], + setupArgs: [{serializableResolvers: Array.from(resolvers.values())}], }) as WorkerInterface; if (worker.getStdout()) worker.getStdout().pipe(process.stdout); @@ -188,12 +146,7 @@ export default class TestRunner { return Promise.reject(); } - // Remove `if(onStart)` in Jest 27 - if (onStart) { - await onStart(test); - } else { - await this.eventEmitter.emit('test-file-start', [test]); - } + await this.eventEmitter.emit('test-file-start', [test]); const promise = worker.worker({ config: test.context.config, @@ -212,9 +165,9 @@ export default class TestRunner { if (promise.UNSTABLE_onCustomMessage) { // TODO: Get appropriate type for `onCustomMessage` - promise.UNSTABLE_onCustomMessage(([event, payload]: any) => { - this.eventEmitter.emit(event, payload); - }); + promise.UNSTABLE_onCustomMessage(([event, payload]: any) => + this.eventEmitter.emit(event, payload), + ); } return promise; @@ -230,21 +183,10 @@ export default class TestRunner { const runAllTests = Promise.all( tests.map(test => - runTestInWorker(test) - .then(result => { - if (onResult) { - return onResult(test, result); - } - - return this.eventEmitter.emit('test-file-success', [test, result]); - }) - .catch(error => { - if (onFailure) { - return onFailure(test, error); - } - - return this.eventEmitter.emit('test-file-failure', [test, error]); - }), + runTestInWorker(test).then( + result => this.eventEmitter.emit('test-file-success', [test, result]), + error => this.eventEmitter.emit('test-file-failure', [test, error]), + ), ), ); From c12d4448cf5dfc273804d8210358066cfbee1169 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Thu, 7 Apr 2022 12:33:27 +0200 Subject: [PATCH 025/128] chore(website): use lite embed instead of iframe for YouTube videos (#12643) --- docs/Architecture.md | 20 +-- website/docusaurus.config.js | 3 + website/package.json | 1 + website/src/pages/index.js | 19 +-- website/src/pages/videos.js | 127 ------------------ website/static/css/custom.css | 2 +- .../version-25.x/Architecture.md | 20 +-- .../version-26.x/Architecture.md | 20 +-- .../version-27.0/Architecture.md | 20 +-- .../version-27.1/Architecture.md | 20 +-- .../version-27.2/Architecture.md | 20 +-- .../version-27.4/Architecture.md | 20 +-- .../version-27.5/Architecture.md | 20 +-- yarn.lock | 11 ++ 14 files changed, 51 insertions(+), 272 deletions(-) delete mode 100644 website/src/pages/videos.js diff --git a/docs/Architecture.md b/docs/Architecture.md index 300abd75d9f0..8d9a7c1d5eba 100644 --- a/docs/Architecture.md +++ b/docs/Architecture.md @@ -3,26 +3,14 @@ id: architecture title: Architecture --- +import LiteYouTubeEmbed from 'react-lite-youtube-embed'; + If you are interested in learning more about how Jest works, understand its architecture, and how Jest is split up into individual reusable packages, check out this video: - + If you'd like to learn how to build a testing framework like Jest from scratch, check out this video: - + There is also a [written guide you can follow](https://cpojer.net/posts/building-a-javascript-testing-framework). It teaches the fundamental concepts of Jest and explains how various parts of Jest can be used to compose a custom testing framework. diff --git a/website/docusaurus.config.js b/website/docusaurus.config.js index 00cf5cc76d72..8d57541950c8 100644 --- a/website/docusaurus.config.js +++ b/website/docusaurus.config.js @@ -69,6 +69,9 @@ module.exports = { path.resolve('src/components/v1/legacyCSS.css'), path.resolve('static/css/custom.css'), path.resolve('static/css/jest.css'), + require.resolve( + 'react-lite-youtube-embed/dist/LiteYouTubeEmbed.css' + ), ], }, gtag: { diff --git a/website/package.json b/website/package.json index 0021728e996f..6a4bab45207b 100644 --- a/website/package.json +++ b/website/package.json @@ -39,6 +39,7 @@ "react": "^17.0.1", "react-dom": "^17.0.1", "react-github-btn": "^1.2.0", + "react-lite-youtube-embed": "^2.2.1-a", "react-markdown": "^8.0.0" }, "devDependencies": { diff --git a/website/src/pages/index.js b/website/src/pages/index.js index 0ab8788f28fb..ac555ee4b141 100755 --- a/website/src/pages/index.js +++ b/website/src/pages/index.js @@ -11,6 +11,7 @@ import Head from '@docusaurus/Head'; import Link from '@docusaurus/Link'; import backers from '@site/backers.json'; import Translate from '@docusaurus/Translate'; +import LiteYouTubeEmbed from 'react-lite-youtube-embed'; import {setupLandingAnimation} from '@site/src/pages/animations/_landingAnimation'; @@ -512,14 +513,7 @@ class Index extends React.Component {
- + If you'd like to learn how to build a testing framework like Jest from scratch, check out this video: - + There is also a [written guide you can follow](https://cpojer.net/posts/building-a-javascript-testing-framework). It teaches the fundamental concepts of Jest and explains how various parts of Jest can be used to compose a custom testing framework. diff --git a/website/versioned_docs/version-26.x/Architecture.md b/website/versioned_docs/version-26.x/Architecture.md index 300abd75d9f0..8d9a7c1d5eba 100644 --- a/website/versioned_docs/version-26.x/Architecture.md +++ b/website/versioned_docs/version-26.x/Architecture.md @@ -3,26 +3,14 @@ id: architecture title: Architecture --- +import LiteYouTubeEmbed from 'react-lite-youtube-embed'; + If you are interested in learning more about how Jest works, understand its architecture, and how Jest is split up into individual reusable packages, check out this video: - + If you'd like to learn how to build a testing framework like Jest from scratch, check out this video: - + There is also a [written guide you can follow](https://cpojer.net/posts/building-a-javascript-testing-framework). It teaches the fundamental concepts of Jest and explains how various parts of Jest can be used to compose a custom testing framework. diff --git a/website/versioned_docs/version-27.0/Architecture.md b/website/versioned_docs/version-27.0/Architecture.md index 300abd75d9f0..8d9a7c1d5eba 100644 --- a/website/versioned_docs/version-27.0/Architecture.md +++ b/website/versioned_docs/version-27.0/Architecture.md @@ -3,26 +3,14 @@ id: architecture title: Architecture --- +import LiteYouTubeEmbed from 'react-lite-youtube-embed'; + If you are interested in learning more about how Jest works, understand its architecture, and how Jest is split up into individual reusable packages, check out this video: - + If you'd like to learn how to build a testing framework like Jest from scratch, check out this video: - + There is also a [written guide you can follow](https://cpojer.net/posts/building-a-javascript-testing-framework). It teaches the fundamental concepts of Jest and explains how various parts of Jest can be used to compose a custom testing framework. diff --git a/website/versioned_docs/version-27.1/Architecture.md b/website/versioned_docs/version-27.1/Architecture.md index 300abd75d9f0..8d9a7c1d5eba 100644 --- a/website/versioned_docs/version-27.1/Architecture.md +++ b/website/versioned_docs/version-27.1/Architecture.md @@ -3,26 +3,14 @@ id: architecture title: Architecture --- +import LiteYouTubeEmbed from 'react-lite-youtube-embed'; + If you are interested in learning more about how Jest works, understand its architecture, and how Jest is split up into individual reusable packages, check out this video: - + If you'd like to learn how to build a testing framework like Jest from scratch, check out this video: - + There is also a [written guide you can follow](https://cpojer.net/posts/building-a-javascript-testing-framework). It teaches the fundamental concepts of Jest and explains how various parts of Jest can be used to compose a custom testing framework. diff --git a/website/versioned_docs/version-27.2/Architecture.md b/website/versioned_docs/version-27.2/Architecture.md index 300abd75d9f0..8d9a7c1d5eba 100644 --- a/website/versioned_docs/version-27.2/Architecture.md +++ b/website/versioned_docs/version-27.2/Architecture.md @@ -3,26 +3,14 @@ id: architecture title: Architecture --- +import LiteYouTubeEmbed from 'react-lite-youtube-embed'; + If you are interested in learning more about how Jest works, understand its architecture, and how Jest is split up into individual reusable packages, check out this video: - + If you'd like to learn how to build a testing framework like Jest from scratch, check out this video: - + There is also a [written guide you can follow](https://cpojer.net/posts/building-a-javascript-testing-framework). It teaches the fundamental concepts of Jest and explains how various parts of Jest can be used to compose a custom testing framework. diff --git a/website/versioned_docs/version-27.4/Architecture.md b/website/versioned_docs/version-27.4/Architecture.md index 300abd75d9f0..8d9a7c1d5eba 100644 --- a/website/versioned_docs/version-27.4/Architecture.md +++ b/website/versioned_docs/version-27.4/Architecture.md @@ -3,26 +3,14 @@ id: architecture title: Architecture --- +import LiteYouTubeEmbed from 'react-lite-youtube-embed'; + If you are interested in learning more about how Jest works, understand its architecture, and how Jest is split up into individual reusable packages, check out this video: - + If you'd like to learn how to build a testing framework like Jest from scratch, check out this video: - + There is also a [written guide you can follow](https://cpojer.net/posts/building-a-javascript-testing-framework). It teaches the fundamental concepts of Jest and explains how various parts of Jest can be used to compose a custom testing framework. diff --git a/website/versioned_docs/version-27.5/Architecture.md b/website/versioned_docs/version-27.5/Architecture.md index 300abd75d9f0..8d9a7c1d5eba 100644 --- a/website/versioned_docs/version-27.5/Architecture.md +++ b/website/versioned_docs/version-27.5/Architecture.md @@ -3,26 +3,14 @@ id: architecture title: Architecture --- +import LiteYouTubeEmbed from 'react-lite-youtube-embed'; + If you are interested in learning more about how Jest works, understand its architecture, and how Jest is split up into individual reusable packages, check out this video: - + If you'd like to learn how to build a testing framework like Jest from scratch, check out this video: - + There is also a [written guide you can follow](https://cpojer.net/posts/building-a-javascript-testing-framework). It teaches the fundamental concepts of Jest and explains how various parts of Jest can be used to compose a custom testing framework. diff --git a/yarn.lock b/yarn.lock index a26e933d6633..7e1c7a58f9a2 100644 --- a/yarn.lock +++ b/yarn.lock @@ -13804,6 +13804,7 @@ __metadata: react: ^17.0.1 react-dom: ^17.0.1 react-github-btn: ^1.2.0 + react-lite-youtube-embed: ^2.2.1-a react-markdown: ^8.0.0 languageName: unknown linkType: soft @@ -18557,6 +18558,16 @@ __metadata: languageName: node linkType: hard +"react-lite-youtube-embed@npm:^2.2.1-a": + version: 2.2.1 + resolution: "react-lite-youtube-embed@npm:2.2.1" + peerDependencies: + react: ">=16.0.8" + react-dom: ">=16.0.8" + checksum: f3be7bcaa6ec5ca5a7e35a941a7e6d555ac465486807240992ef3389d29631bcc7f85e37a3199ee1dd7ce47ac21440987f113694dcb73ad9be0b3d1e02cfabf9 + languageName: node + linkType: hard + "react-loadable-ssr-addon-v5-slorber@npm:^1.0.1": version: 1.0.1 resolution: "react-loadable-ssr-addon-v5-slorber@npm:1.0.1" From 5247e1ff6bb13a88f95597979d938fd74c33b655 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Thu, 7 Apr 2022 12:42:19 +0200 Subject: [PATCH 026/128] feat: add all available globals to test globals, not just explicit ones (#12642) --- CHANGELOG.md | 1 + packages/jest-environment-jsdom/src/index.ts | 10 +-- packages/jest-environment-node/src/index.ts | 91 +++++++------------- 3 files changed, 34 insertions(+), 68 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index d9a05f43407a..7aaa13347453 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -24,6 +24,7 @@ - `[jest-environment-node]` [**BREAKING**] Add default `node` and `node-addon` conditions to `exportConditions` for `node` environment ([#11924](https://github.com/facebook/jest/pull/11924)) - `[jest-environment-node]` [**BREAKING**] Pass global config to Jest environment constructor for `node` environment ([#12461](https://github.com/facebook/jest/pull/12461)) - `[jest-environment-node]` [**BREAKING**] Second argument `context` to constructor is mandatory ([#12469](https://github.com/facebook/jest/pull/12469)) +- `[jest-environment-node]` Add all available globals to test globals, not just explicit ones ([#12642](https://github.com/facebook/jest/pull/12642)) - `[@jest/expect]` New module which extends `expect` with `jest-snapshot` matchers ([#12404](https://github.com/facebook/jest/pull/12404), [#12410](https://github.com/facebook/jest/pull/12410), [#12418](https://github.com/facebook/jest/pull/12418)) - `[@jest/expect-utils]` New module exporting utils for `expect` ([#12323](https://github.com/facebook/jest/pull/12323)) - `[@jest/fake-timers]` [**BREAKING**] Rename `timers` configuration option to `fakeTimers` ([#12572](https://github.com/facebook/jest/pull/12572)) diff --git a/packages/jest-environment-jsdom/src/index.ts b/packages/jest-environment-jsdom/src/index.ts index 30a01b4b3d58..f16e876ecefe 100644 --- a/packages/jest-environment-jsdom/src/index.ts +++ b/packages/jest-environment-jsdom/src/index.ts @@ -111,16 +111,14 @@ export default class JSDOMEnvironment implements JestEnvironment { this.moduleMocker = new ModuleMocker(global as any); - const timerConfig = { - idToRef: (id: number) => id, - refToId: (ref: number) => ref, - }; - this.fakeTimers = new LegacyFakeTimers({ config: projectConfig, global: global as unknown as typeof globalThis, moduleMocker: this.moduleMocker, - timerConfig, + timerConfig: { + idToRef: (id: number) => id, + refToId: (ref: number) => ref, + }, }); this.fakeTimersModern = new ModernFakeTimers({ diff --git a/packages/jest-environment-node/src/index.ts b/packages/jest-environment-node/src/index.ts index f6f8576bd6e6..b6bdd65d895e 100644 --- a/packages/jest-environment-node/src/index.ts +++ b/packages/jest-environment-node/src/index.ts @@ -22,6 +22,22 @@ type Timer = { unref: () => Timer; }; +// some globals we do not want, either because deprecated or we set it ourselves +const denyList = new Set([ + 'GLOBAL', + 'root', + 'global', + 'Buffer', + 'ArrayBuffer', + 'Uint8Array', +]); + +const nodeGlobals = new Set( + Object.getOwnPropertyNames(globalThis).filter( + global => !denyList.has(global), + ), +); + export default class NodeEnvironment implements JestEnvironment { context: Context | null; fakeTimers: LegacyFakeTimers | null; @@ -37,70 +53,23 @@ export default class NodeEnvironment implements JestEnvironment { 'this', Object.assign(this.context, projectConfig.testEnvironmentOptions), )); + + const contextGlobals = new Set(Object.getOwnPropertyNames(global)); + for (const nodeGlobalsKey of nodeGlobals) { + if (!contextGlobals.has(nodeGlobalsKey)) { + // @ts-expect-error + global[nodeGlobalsKey] = globalThis[nodeGlobalsKey]; + } + } + global.global = global; - global.clearInterval = clearInterval; - global.clearTimeout = clearTimeout; - global.setInterval = setInterval; - global.setTimeout = setTimeout; global.Buffer = Buffer; - global.setImmediate = setImmediate; - global.clearImmediate = clearImmediate; global.ArrayBuffer = ArrayBuffer; // TextEncoder (global or via 'util') references a Uint8Array constructor // different than the global one used by users in tests. This makes sure the // same constructor is referenced by both. global.Uint8Array = Uint8Array; - // URL and URLSearchParams are global in Node >= 10 - global.URL = URL; - global.URLSearchParams = URLSearchParams; - - // TextDecoder and TextDecoder are global in Node >= 11 - global.TextEncoder = TextEncoder; - global.TextDecoder = TextDecoder; - - // queueMicrotask is global in Node >= 11 - global.queueMicrotask = queueMicrotask; - - // AbortController is global in Node >= 15 - if (typeof AbortController !== 'undefined') { - global.AbortController = AbortController; - } - // AbortSignal is global in Node >= 15 - if (typeof AbortSignal !== 'undefined') { - global.AbortSignal = AbortSignal; - } - // Event is global in Node >= 15.4 - if (typeof Event !== 'undefined') { - global.Event = Event; - } - // EventTarget is global in Node >= 15.4 - if (typeof EventTarget !== 'undefined') { - global.EventTarget = EventTarget; - } - // MessageChannel is global in Node >= 15 - if (typeof MessageChannel !== 'undefined') { - global.MessageChannel = MessageChannel; - } - // MessageEvent is global in Node >= 15 - if (typeof MessageEvent !== 'undefined') { - global.MessageEvent = MessageEvent; - } - // performance is global in Node >= 16 - if (typeof performance !== 'undefined') { - global.performance = performance; - } - // atob and btoa are global in Node >= 16 - if (typeof atob !== 'undefined' && typeof btoa !== 'undefined') { - global.atob = atob; - global.btoa = btoa; - } - // structuredClone is global in Node >= 17 - // @ts-expect-error type definition for structuredClone is missing - if (typeof structuredClone !== 'undefined') { - // @ts-expect-error type definition for structuredClone is missing - global.structuredClone = structuredClone; - } installCommonGlobals(global, projectConfig.globals); this.moduleMocker = new ModuleMocker(global); @@ -118,16 +87,14 @@ export default class NodeEnvironment implements JestEnvironment { const timerRefToId = (timer: Timer): number | undefined => (timer && timer.id) || undefined; - const timerConfig = { - idToRef: timerIdToRef, - refToId: timerRefToId, - }; - this.fakeTimers = new LegacyFakeTimers({ config: projectConfig, global, moduleMocker: this.moduleMocker, - timerConfig, + timerConfig: { + idToRef: timerIdToRef, + refToId: timerRefToId, + }, }); this.fakeTimersModern = new ModernFakeTimers({ From c6902a061946b45791d07ef91c37c4681f43d793 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Thu, 7 Apr 2022 13:02:25 +0200 Subject: [PATCH 027/128] chore: fix v8 coverage test (#12644) --- e2e/__tests__/coverageProviderV8.test.ts | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/e2e/__tests__/coverageProviderV8.test.ts b/e2e/__tests__/coverageProviderV8.test.ts index e0aed23d0d10..6071485cc61e 100644 --- a/e2e/__tests__/coverageProviderV8.test.ts +++ b/e2e/__tests__/coverageProviderV8.test.ts @@ -11,13 +11,17 @@ import runJest from '../runJest'; const DIR = path.resolve(__dirname, '../coverage-provider-v8'); +// https://github.com/nodejs/node/issues/42638 +const nodeOptions = + typeof fetch === 'undefined' ? '' : '--no-experimental-fetch'; + test('prints coverage with missing sourcemaps', () => { const sourcemapDir = path.join(DIR, 'no-sourcemap'); const {stdout, exitCode} = runJest( sourcemapDir, ['--coverage', '--coverage-provider', 'v8'], - {stripAnsi: true}, + {nodeOptions, stripAnsi: true}, ); expect(exitCode).toBe(0); @@ -30,7 +34,7 @@ test('prints coverage with empty sourcemaps', () => { const {stdout, exitCode} = runJest( sourcemapDir, ['--coverage', '--coverage-provider', 'v8'], - {stripAnsi: true}, + {nodeOptions, stripAnsi: true}, ); expect(exitCode).toBe(0); @@ -43,7 +47,7 @@ test('prints correct coverage report, if a CJS module is put under test without const {stdout, exitCode} = runJest( sourcemapDir, ['--coverage', '--coverage-provider', 'v8', '--no-cache'], - {stripAnsi: true}, + {nodeOptions, stripAnsi: true}, ); expect(exitCode).toBe(0); @@ -56,7 +60,7 @@ test('prints correct coverage report, if a TS module is transpiled by Babel to C const {stdout, exitCode} = runJest( sourcemapDir, ['--coverage', '--coverage-provider', 'v8', '--no-cache'], - {stripAnsi: true}, + {nodeOptions, stripAnsi: true}, ); expect(exitCode).toBe(0); @@ -72,7 +76,7 @@ onNodeVersions('>=12.16.0', () => { sourcemapDir, ['--coverage', '--coverage-provider', 'v8', '--no-cache'], { - nodeOptions: '--experimental-vm-modules --no-warnings', + nodeOptions: `${nodeOptions} --experimental-vm-modules --no-warnings`, stripAnsi: true, }, ); @@ -88,7 +92,7 @@ onNodeVersions('>=12.16.0', () => { sourcemapDir, ['--coverage', '--coverage-provider', 'v8', '--no-cache'], { - nodeOptions: '--experimental-vm-modules --no-warnings', + nodeOptions: `${nodeOptions} --experimental-vm-modules --no-warnings`, stripAnsi: true, }, ); From a93def0e5bc938f056ada7774368f6923000d0ec Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Thu, 7 Apr 2022 20:20:17 +0800 Subject: [PATCH 028/128] Use native ESM for dev scripts (#12636) --- .eslintrc.js => .eslintrc.cjs | 26 ++++++++--- .github/workflows/nodejs.yml | 2 +- e2e/watch-plugins/cjs/my-watch-plugin.cjs | 6 +-- e2e/watch-plugins/mjs/my-watch-plugin.mjs | 6 +-- package.json | 20 ++++----- scripts/{build.js => build.mjs} | 44 +++++++++++-------- scripts/{buildTs.js => buildTs.mjs} | 22 +++++----- scripts/{buildUtils.js => buildUtils.mjs} | 41 ++++++++--------- scripts/{bundleTs.js => bundleTs.mjs} | 30 +++++++------ ...htHeaders.js => checkCopyrightHeaders.mjs} | 10 ++--- scripts/{cleanE2e.js => cleanE2e.mjs} | 18 ++++---- scripts/{mapCoverage.js => mapCoverage.mjs} | 8 ++-- scripts/remove-examples.js | 22 ---------- scripts/remove-examples.mjs | 23 ++++++++++ scripts/{verifyOldTs.js => verifyOldTs.mjs} | 26 ++++++----- scripts/{verifyPnP.js => verifyPnP.mjs} | 24 +++++----- scripts/{watch.js => watch.mjs} | 18 +++++--- 17 files changed, 187 insertions(+), 159 deletions(-) rename .eslintrc.js => .eslintrc.cjs (96%) rename scripts/{build.js => build.mjs} (83%) rename scripts/{buildTs.js => buildTs.mjs} (93%) rename scripts/{buildUtils.js => buildUtils.mjs} (83%) rename scripts/{bundleTs.js => bundleTs.mjs} (89%) rename scripts/{checkCopyrightHeaders.js => checkCopyrightHeaders.mjs} (95%) rename scripts/{cleanE2e.js => cleanE2e.mjs} (65%) rename scripts/{mapCoverage.js => mapCoverage.mjs} (87%) delete mode 100644 scripts/remove-examples.js create mode 100644 scripts/remove-examples.mjs rename scripts/{verifyOldTs.js => verifyOldTs.mjs} (90%) rename scripts/{verifyPnP.js => verifyPnP.mjs} (80%) rename scripts/{watch.js => watch.mjs} (83%) diff --git a/.eslintrc.js b/.eslintrc.cjs similarity index 96% rename from .eslintrc.js rename to .eslintrc.cjs index 8e4aec244a31..8ee5a68dfe67 100644 --- a/.eslintrc.js +++ b/.eslintrc.cjs @@ -5,11 +5,21 @@ * LICENSE file in the root directory of this source tree. */ -const {getPackages} = require('./scripts/buildUtils'); +const fs = require('fs'); +const path = require('path'); +const {sync: readPkg} = require('read-pkg'); -const internalPackages = getPackages() - .map(({pkg}) => pkg.name) - .sort(); +function getPackages() { + const PACKAGES_DIR = path.resolve(__dirname, 'packages'); + const packages = fs + .readdirSync(PACKAGES_DIR) + .map(file => path.resolve(PACKAGES_DIR, file)) + .filter(f => fs.lstatSync(path.resolve(f)).isDirectory()); + return packages.map(packageDir => { + const pkg = readPkg({cwd: packageDir}); + return pkg.name; + }); +} module.exports = { env: { @@ -254,7 +264,7 @@ module.exports = { }, { env: {node: true}, - files: ['*.js', '*.jsx'], + files: ['*.js', '*.jsx', '*.mjs', '*.cjs'], }, { files: [ @@ -325,7 +335,7 @@ module.exports = { 'scripts/**', 'babel.config.js', 'testSetupFile.js', - '.eslintrc.js', + '.eslintrc.cjs', ], }, ], @@ -507,7 +517,9 @@ module.exports = { 'import/ignore': ['react-native'], // using `new RegExp` makes sure to escape `/` 'import/internal-regex': new RegExp( - internalPackages.map(pkg => `^${pkg}$`).join('|'), + getPackages() + .map(pkg => `^${pkg}$`) + .join('|'), ).source, 'import/resolver': { typescript: {}, diff --git a/.github/workflows/nodejs.yml b/.github/workflows/nodejs.yml index fef63f5fa0c1..16f831fb611f 100644 --- a/.github/workflows/nodejs.yml +++ b/.github/workflows/nodejs.yml @@ -177,7 +177,7 @@ jobs: yarn jest-coverage --color --config jest.config.ci.js --max-workers ${{ steps.cpu-cores.outputs.count }} --shard=${{ matrix.shard }} yarn test-leak - name: map coverage - run: node ./scripts/mapCoverage.js + run: node ./scripts/mapCoverage.mjs if: always() - uses: codecov/codecov-action@v3 if: always() diff --git a/e2e/watch-plugins/cjs/my-watch-plugin.cjs b/e2e/watch-plugins/cjs/my-watch-plugin.cjs index 6fa3d51d68d4..b68701c9893c 100644 --- a/e2e/watch-plugins/cjs/my-watch-plugin.cjs +++ b/e2e/watch-plugins/cjs/my-watch-plugin.cjs @@ -6,8 +6,7 @@ */ class MyWatchPlugin { // Add hooks to Jest lifecycle events - apply(jestHooks) { - } + apply(jestHooks) {} // Get the prompt information for interactive plugins getUsageInfo(globalConfig) { @@ -15,8 +14,7 @@ class MyWatchPlugin { } // Executed when the key from `getUsageInfo` is input - run(globalConfig, updateConfigAndRun) { - } + run(globalConfig, updateConfigAndRun) {} } module.exports = MyWatchPlugin; diff --git a/e2e/watch-plugins/mjs/my-watch-plugin.mjs b/e2e/watch-plugins/mjs/my-watch-plugin.mjs index 873aaed19d58..f313583a7bb4 100644 --- a/e2e/watch-plugins/mjs/my-watch-plugin.mjs +++ b/e2e/watch-plugins/mjs/my-watch-plugin.mjs @@ -6,8 +6,7 @@ */ class MyWatchPlugin { // Add hooks to Jest lifecycle events - apply(jestHooks) { - } + apply(jestHooks) {} // Get the prompt information for interactive plugins getUsageInfo(globalConfig) { @@ -15,8 +14,7 @@ class MyWatchPlugin { } // Executed when the key from `getUsageInfo` is input - run(globalConfig, updateConfigAndRun) { - } + run(globalConfig, updateConfigAndRun) {} } export default MyWatchPlugin; diff --git a/package.json b/package.json index 64974a50de2b..5009fceaebca 100644 --- a/package.json +++ b/package.json @@ -87,31 +87,31 @@ "scripts": { "build-clean": "rimraf './packages/*/build' './packages/*/dist' './packages/*/tsconfig.tsbuildinfo' './packages/*/api-extractor.json' './api-extractor.json'", "build": "yarn build:js && yarn build:ts && yarn bundle:ts", - "build:js": "node ./scripts/build.js", - "build:ts": "node ./scripts/buildTs.js", - "bundle:ts": "node ./scripts/bundleTs.js", - "check-copyright-headers": "node ./scripts/checkCopyrightHeaders.js", + "build:js": "node ./scripts/build.mjs", + "build:ts": "node ./scripts/buildTs.mjs", + "bundle:ts": "node ./scripts/bundleTs.mjs", + "check-copyright-headers": "node ./scripts/checkCopyrightHeaders.mjs", "clean-all": "yarn clean-e2e && yarn build-clean && rimraf './packages/*/node_modules' && rimraf './node_modules'", - "clean-e2e": "node ./scripts/cleanE2e.js", + "clean-e2e": "node ./scripts/cleanE2e.mjs", "crowdin:upload": "echo 'Uploading sources to Crowdin' && crowdin upload sources --config ./crowdin.yaml", "crowdin:download": "echo 'Downloading translations from Crowdin' && crowdin download --config ./crowdin.yaml", "jest": "node ./packages/jest-cli/bin/jest.js", "jest-jasmine": "JEST_JASMINE=1 yarn jest", "jest-jasmine-ci": "yarn jest-jasmine --color --config jest.config.ci.js", "jest-coverage": "yarn jest --coverage", - "lint": "eslint . --cache --ext js,jsx,ts,tsx,md", + "lint": "eslint . --cache --ext js,jsx,cjs,mjs,ts,tsx,md", "lint:prettier": "prettier '**/*.{json,md,yml,yaml}' 'website/**/*.{css,js}' --write", "lint:prettier:ci": "prettier '**/*.{json,md,yml,yaml}' 'website/**/*.{css,js}' --check", - "remove-examples": "node ./scripts/remove-examples.js", + "remove-examples": "node ./scripts/remove-examples.mjs", "test-types": "yarn jest --config jest.config.tsd.js", "test-ci-partial": "yarn test-ci-partial:parallel -i", "test-ci-partial:parallel": "yarn jest --color --config jest.config.ci.js", "test-pretty-format-perf": "node packages/pretty-format/perf/test.js", "test-leak": "yarn jest -i --detectLeaks --color jest-mock jest-diff jest-repl pretty-format", "test": "yarn lint && yarn jest", - "verify-old-ts": "node ./scripts/verifyOldTs.js", - "verify-pnp": "node ./scripts/verifyPnP.js", - "watch": "yarn build:js && node ./scripts/watch.js", + "verify-old-ts": "node ./scripts/verifyOldTs.mjs", + "verify-pnp": "node ./scripts/verifyPnP.mjs", + "watch": "yarn build:js && node ./scripts/watch.mjs", "watch:ts": "yarn build:ts --watch" }, "workspaces": [ diff --git a/scripts/build.js b/scripts/build.mjs similarity index 83% rename from scripts/build.js rename to scripts/build.mjs index fa6c025ea2cf..4fa3eb2662d1 100644 --- a/scripts/build.js +++ b/scripts/build.mjs @@ -12,36 +12,39 @@ * Non-js files not matching IGNORE_PATTERN will be copied without transpiling. * * Example: - * node ./scripts/build.js - * node ./scripts/build.js /users/123/jest/packages/jest-111/src/111.js - * - * NOTE: this script is node@6 compatible + * node ./scripts/build.mjs + * node ./scripts/build.mjs /users/123/jest/packages/jest-111/src/111.js */ -'use strict'; - -const assert = require('assert'); -const fs = require('fs'); -const path = require('path'); -const babel = require('@babel/core'); -const chalk = require('chalk'); -const glob = require('glob'); -const micromatch = require('micromatch'); -const prettier = require('prettier'); -const transformOptions = require('../babel.config.js'); -const {getPackages, adjustToTerminalWidth, OK} = require('./buildUtils'); +import assert from 'assert'; +import path from 'path'; +import {fileURLToPath} from 'url'; +import babel from '@babel/core'; +import chalk from 'chalk'; +import glob from 'glob'; +import fs from 'graceful-fs'; +import micromatch from 'micromatch'; +import prettier from 'prettier'; +import transformOptions from '../babel.config.js'; +import { + OK, + PACKAGES_DIR, + adjustToTerminalWidth, + getPackages, +} from './buildUtils.mjs'; const SRC_DIR = 'src'; const BUILD_DIR = 'build'; const JS_FILES_PATTERN = '**/*.js'; const TS_FILES_PATTERN = '**/*.ts'; const IGNORE_PATTERN = '**/__{tests,mocks}__/**'; -const PACKAGES_DIR = path.resolve(__dirname, '../packages'); const INLINE_REQUIRE_EXCLUDE_LIST = /packages\/expect|(jest-(circus|diff|get-type|jasmine2|matcher-utils|message-util|regex-util|snapshot))|pretty-format\//; -const prettierConfig = prettier.resolveConfig.sync(__filename); +const prettierConfig = prettier.resolveConfig.sync( + fileURLToPath(import.meta.url), +); prettierConfig.trailingComma = 'none'; prettierConfig.parser = 'babel'; @@ -110,7 +113,10 @@ function buildFile(file, silent) { // The excluded modules are injected into the user's sandbox // We need to guard some globals there. options.plugins.push( - require.resolve('./babel-plugin-jest-native-globals'), + path.resolve( + path.dirname(fileURLToPath(import.meta.url)), + 'babel-plugin-jest-native-globals.js', + ), ); } else { options.plugins = options.plugins.map(plugin => { diff --git a/scripts/buildTs.js b/scripts/buildTs.mjs similarity index 93% rename from scripts/buildTs.js rename to scripts/buildTs.mjs index 5faf8bd38bd0..6ab57279aced 100644 --- a/scripts/buildTs.js +++ b/scripts/buildTs.mjs @@ -5,18 +5,16 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; - -const assert = require('assert'); -const fs = require('fs'); -const os = require('os'); -const path = require('path'); -const chalk = require('chalk'); -const execa = require('execa'); -const globby = require('globby'); -const stripJsonComments = require('strip-json-comments'); -const throat = require('throat'); -const {getPackages} = require('./buildUtils'); +import assert from 'assert'; +import os from 'os'; +import path from 'path'; +import chalk from 'chalk'; +import execa from 'execa'; +import globby from 'globby'; +import fs from 'graceful-fs'; +import stripJsonComments from 'strip-json-comments'; +import throat from 'throat'; +import {getPackages} from './buildUtils.mjs'; (async () => { const packages = getPackages(); diff --git a/scripts/buildUtils.js b/scripts/buildUtils.mjs similarity index 83% rename from scripts/buildUtils.js rename to scripts/buildUtils.mjs index 1136a369308d..67a721d1eb3b 100644 --- a/scripts/buildUtils.js +++ b/scripts/buildUtils.mjs @@ -5,26 +5,30 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; - -const assert = require('assert'); -const fs = require('fs'); -const path = require('path'); -const chalk = require('chalk'); -const {sync: readPkg} = require('read-pkg'); -const stringLength = require('string-length'); -const rootPackage = require('../package.json'); - -const PACKAGES_DIR = path.resolve(__dirname, '../packages'); - -const OK = chalk.reset.inverse.bold.green(' DONE '); +import assert from 'assert'; +import {createRequire} from 'module'; +import path from 'path'; +import {fileURLToPath} from 'url'; +import chalk from 'chalk'; +import fs from 'graceful-fs'; +import {sync as readPkg} from 'read-pkg'; +import stringLength from 'string-length'; + +export const PACKAGES_DIR = path.resolve( + path.dirname(fileURLToPath(import.meta.url)), + '../packages', +); + +export const OK = chalk.reset.inverse.bold.green(' DONE '); // Get absolute paths of all directories under packages/* -module.exports.getPackages = function getPackages() { +export function getPackages() { const packages = fs .readdirSync(PACKAGES_DIR) .map(file => path.resolve(PACKAGES_DIR, file)) .filter(f => fs.lstatSync(path.resolve(f)).isDirectory()); + const require = createRequire(import.meta.url); + const rootPackage = require('../package.json'); const nodeEngineRequirement = rootPackage.engines.node; @@ -104,9 +108,9 @@ module.exports.getPackages = function getPackages() { return {packageDir, pkg}; }); -}; +} -module.exports.adjustToTerminalWidth = function adjustToTerminalWidth(str) { +export function adjustToTerminalWidth(str) { const columns = process.stdout.columns || 80; const WIDTH = columns - stringLength(OK) + 1; const strs = str.match(new RegExp(`(.{1,${WIDTH}})`, 'g')); @@ -115,7 +119,4 @@ module.exports.adjustToTerminalWidth = function adjustToTerminalWidth(str) { lastString += Array(WIDTH - lastString.length).join(chalk.dim('.')); } return strs.slice(0, -1).concat(lastString).join('\n'); -}; - -module.exports.OK = OK; -module.exports.PACKAGES_DIR = PACKAGES_DIR; +} diff --git a/scripts/bundleTs.js b/scripts/bundleTs.mjs similarity index 89% rename from scripts/bundleTs.js rename to scripts/bundleTs.mjs index bdf20f05cc56..4cac2d4a4b08 100644 --- a/scripts/bundleTs.js +++ b/scripts/bundleTs.mjs @@ -5,25 +5,26 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; - -const fs = require('fs'); -const path = require('path'); -const { +import {createRequire} from 'module'; +import path from 'path'; +import {fileURLToPath} from 'url'; +import { CompilerState, Extractor, ExtractorConfig, -} = require('@microsoft/api-extractor'); -const chalk = require('chalk'); -const {sync: pkgDir} = require('pkg-dir'); -const prettier = require('prettier'); -const rimraf = require('rimraf'); -const {getPackages} = require('./buildUtils'); +} from '@microsoft/api-extractor'; +import chalk from 'chalk'; +import fs from 'graceful-fs'; +import {sync as pkgDir} from 'pkg-dir'; +import prettier from 'prettier'; +import rimraf from 'rimraf'; +import {getPackages} from './buildUtils.mjs'; const prettierConfig = prettier.resolveConfig.sync( - __filename.replace(/\.js$/, '.d.ts'), + fileURLToPath(import.meta.url).replace(/\.js$/, '.d.ts'), ); +const require = createRequire(import.meta.url); const typescriptCompilerFolder = pkgDir(require.resolve('typescript')); const copyrightSnippet = ` @@ -104,7 +105,10 @@ const copyrightSnippet = ` }; await fs.promises.writeFile( - path.resolve(__dirname, '../api-extractor.json'), + path.resolve( + path.dirname(fileURLToPath(import.meta.url)), + '../api-extractor.json', + ), JSON.stringify(sharedExtractorConfig, null, 2), ); diff --git a/scripts/checkCopyrightHeaders.js b/scripts/checkCopyrightHeaders.mjs similarity index 95% rename from scripts/checkCopyrightHeaders.js rename to scripts/checkCopyrightHeaders.mjs index 8d490d570f6c..78467692b227 100755 --- a/scripts/checkCopyrightHeaders.js +++ b/scripts/checkCopyrightHeaders.mjs @@ -5,11 +5,9 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; - -const {execSync} = require('child_process'); -const fs = require('fs'); -const {isBinaryFileSync} = require('isbinaryfile'); +import {execSync} from 'child_process'; +import fs from 'graceful-fs'; +import {isBinaryFileSync} from 'isbinaryfile'; const getFileContents = path => fs.readFileSync(path, {encoding: 'utf-8'}); const isDirectory = path => fs.lstatSync(path).isDirectory(); @@ -149,7 +147,7 @@ function check() { ${invalidFiles.join('\n ')} -Please include the header or exclude the files in \`scripts/checkCopyrightHeaders.js\``); +Please include the header or exclude the files in \`scripts/checkCopyrightHeaders.mjs\``); process.exit(1); } } diff --git a/scripts/cleanE2e.js b/scripts/cleanE2e.mjs similarity index 65% rename from scripts/cleanE2e.js rename to scripts/cleanE2e.mjs index 6292e749343d..09ee9d620f1d 100644 --- a/scripts/cleanE2e.js +++ b/scripts/cleanE2e.mjs @@ -5,11 +5,10 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; - -const {normalize, resolve} = require('path'); -const {sync: glob} = require('glob'); -const {sync: rimraf} = require('rimraf'); +import {dirname, normalize, resolve} from 'path'; +import {fileURLToPath} from 'url'; +import glob from 'glob'; +import rimraf from 'rimraf'; const excludedModules = [ 'e2e/global-setup-node-modules/node_modules/', @@ -22,12 +21,13 @@ const excludedModules = [ 'e2e/retain-all-files/node_modules/', ].map(dir => normalize(dir)); -const e2eNodeModules = glob('e2e/*/node_modules/') - .concat(glob('e2e/*/*/node_modules/')) +const e2eNodeModules = glob + .sync('e2e/*/node_modules/') + .concat(glob.sync('e2e/*/*/node_modules/')) .filter(dir => !excludedModules.includes(dir)) - .map(dir => resolve(__dirname, '..', dir)) + .map(dir => resolve(dirname(fileURLToPath(import.meta.url)), '..', dir)) .sort(); e2eNodeModules.forEach(dir => { - rimraf(dir, {glob: false}); + rimraf.sync(dir, {glob: false}); }); diff --git a/scripts/mapCoverage.js b/scripts/mapCoverage.mjs similarity index 87% rename from scripts/mapCoverage.js rename to scripts/mapCoverage.mjs index cf0a5e47f028..b78fe3da6418 100644 --- a/scripts/mapCoverage.js +++ b/scripts/mapCoverage.mjs @@ -25,9 +25,11 @@ * produce a full coverage report. */ -const istanbulCoverage = require('istanbul-lib-coverage'); -const istanbulReport = require('istanbul-lib-report'); -const istanbulReports = require('istanbul-reports'); +import {createRequire} from 'module'; +import istanbulCoverage from 'istanbul-lib-coverage'; +import istanbulReport from 'istanbul-lib-report'; +import istanbulReports from 'istanbul-reports'; +const require = createRequire(import.meta.url); const coverage = require('../coverage/coverage-final.json'); const map = istanbulCoverage.createCoverageMap(); diff --git a/scripts/remove-examples.js b/scripts/remove-examples.js deleted file mode 100644 index d77654f6fdc9..000000000000 --- a/scripts/remove-examples.js +++ /dev/null @@ -1,22 +0,0 @@ -/** - * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -'use strict'; - -const {writeFileSync} = require('fs'); -const {resolve} = require('path'); -const rimraf = require('rimraf'); - -const configFile = require.resolve('../jest.config'); - -const config = require(configFile); - -delete config.projects; - -writeFileSync(configFile, `module.exports = ${JSON.stringify(config)};\n`); - -rimraf.sync(resolve(__dirname, '../examples/')); diff --git a/scripts/remove-examples.mjs b/scripts/remove-examples.mjs new file mode 100644 index 000000000000..d1a22e519c57 --- /dev/null +++ b/scripts/remove-examples.mjs @@ -0,0 +1,23 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +import {createRequire} from 'module'; +import {dirname, resolve} from 'path'; +import {fileURLToPath} from 'url'; +import fs from 'graceful-fs'; +import rimraf from 'rimraf'; +const require = createRequire(import.meta.url); + +const configFile = require.resolve('../jest.config'); + +const config = require(configFile); + +delete config.projects; + +fs.writeFileSync(configFile, `module.exports = ${JSON.stringify(config)};\n`); + +rimraf.sync(resolve(dirname(fileURLToPath(import.meta.url)), '../examples/')); diff --git a/scripts/verifyOldTs.js b/scripts/verifyOldTs.mjs similarity index 90% rename from scripts/verifyOldTs.js rename to scripts/verifyOldTs.mjs index 113febee9909..481c500ad49e 100644 --- a/scripts/verifyOldTs.js +++ b/scripts/verifyOldTs.mjs @@ -5,15 +5,16 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; - -const fs = require('fs'); -const path = require('path'); -const chalk = require('chalk'); -const execa = require('execa'); -const rimraf = require('rimraf'); -const stripJsonComments = require('strip-json-comments'); -const tempy = require('tempy'); +import {createRequire} from 'module'; +import path from 'path'; +import {fileURLToPath} from 'url'; +import chalk from 'chalk'; +import execa from 'execa'; +import fs from 'graceful-fs'; +import rimraf from 'rimraf'; +import stripJsonComments from 'strip-json-comments'; +import tempy from 'tempy'; +const require = createRequire(import.meta.url); const baseTsConfig = JSON.parse( stripJsonComments( @@ -35,7 +36,10 @@ const tsConfig = { const tsVersion = '4.2'; function smoketest() { - const jestDirectory = path.resolve(__dirname, '../packages/jest'); + const jestDirectory = path.resolve( + path.dirname(fileURLToPath(import.meta.url)), + '../packages/jest', + ); const cwd = tempy.directory(); @@ -71,7 +75,7 @@ function smoketest() { } function typeTests() { - const cwd = path.resolve(__dirname, '../'); + const cwd = path.resolve(path.dirname(fileURLToPath(import.meta.url)), '../'); const rootPackageJson = require('../package.json'); const currentTsdTypescriptVersion = diff --git a/scripts/verifyPnP.js b/scripts/verifyPnP.mjs similarity index 80% rename from scripts/verifyPnP.js rename to scripts/verifyPnP.mjs index cd49c4aae500..294ca451544c 100644 --- a/scripts/verifyPnP.js +++ b/scripts/verifyPnP.mjs @@ -5,18 +5,20 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; +import path from 'path'; +import {fileURLToPath} from 'url'; +import chalk from 'chalk'; +import dedent from 'dedent'; +import execa from 'execa'; +import fs from 'graceful-fs'; +import yaml from 'js-yaml'; +import rimraf from 'rimraf'; +import tempy from 'tempy'; -const fs = require('fs'); -const path = require('path'); -const chalk = require('chalk'); -const dedent = require('dedent'); -const execa = require('execa'); -const yaml = require('js-yaml'); -const rimraf = require('rimraf'); -const tempy = require('tempy'); - -const rootDirectory = path.resolve(__dirname, '..'); +const rootDirectory = path.resolve( + path.dirname(fileURLToPath(import.meta.url)), + '..', +); const cwd = tempy.directory(); diff --git a/scripts/watch.js b/scripts/watch.mjs similarity index 83% rename from scripts/watch.js rename to scripts/watch.mjs index 8c93185108fd..a4734d14ea3d 100644 --- a/scripts/watch.js +++ b/scripts/watch.mjs @@ -9,14 +9,18 @@ * Watch files for changes and rebuild (copy from 'src/' to `build/`) if changed */ -const {execSync} = require('child_process'); -const fs = require('fs'); -const path = require('path'); -const chalk = require('chalk'); -const chokidar = require('chokidar'); -const {PACKAGES_DIR, getPackages} = require('./buildUtils'); +import {execSync} from 'child_process'; +import path from 'path'; +import {fileURLToPath} from 'url'; +import chalk from 'chalk'; +import chokidar from 'chokidar'; +import fs from 'graceful-fs'; +import {PACKAGES_DIR, getPackages} from './buildUtils.mjs'; -const BUILD_CMD = `node ${path.resolve(__dirname, './build.js')}`; +const BUILD_CMD = `node ${path.resolve( + path.dirname(fileURLToPath(import.meta.url)), + 'build.mjs', +)}`; let filesToBuild = new Map(); From 420ba4535b4563909d8b3a51fd97a3619c5f10d1 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Fri, 8 Apr 2022 11:38:49 +0300 Subject: [PATCH 029/128] feat(jest-runner): improve typings by exposing `TestRunner` abstract classes (#12646) --- CHANGELOG.md | 1 + packages/jest-core/src/TestScheduler.ts | 24 +++--- .../__typetests__/jest-runner.test.ts | 73 +++++++++++++++++++ .../jest-runner/__typetests__/tsconfig.json | 11 +++ packages/jest-runner/package.json | 4 +- .../src/__tests__/testRunner.test.ts | 55 ++++++-------- packages/jest-runner/src/index.ts | 64 ++++++---------- packages/jest-runner/src/types.ts | 45 ++++++++++++ packages/jest-test-result/src/index.ts | 1 + packages/jest-test-result/src/types.ts | 4 +- yarn.lock | 2 + 11 files changed, 196 insertions(+), 88 deletions(-) create mode 100644 packages/jest-runner/__typetests__/jest-runner.test.ts create mode 100644 packages/jest-runner/__typetests__/tsconfig.json diff --git a/CHANGELOG.md b/CHANGELOG.md index 7aaa13347453..79a416b988a1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -42,6 +42,7 @@ - `[jest-resolve, jest-runtime]` Add support for async resolver ([#11540](https://github.com/facebook/jest/pull/11540)) - `[jest-runner]` Allow `setupFiles` module to export an async function ([#12042](https://github.com/facebook/jest/pull/12042)) - `[jest-runner]` Allow passing `testEnvironmentOptions` via docblocks ([#12470](https://github.com/facebook/jest/pull/12470)) +- `[jest-runner]` Exposing `CallbackTestRunner`, `EmittingTestRunner` abstract classes to help typing third party runners ([#12646](https://github.com/facebook/jest/pull/12646)) - `[jest-runtime]` [**BREAKING**] `Runtime.createHasteMap` now returns a promise ([#12008](https://github.com/facebook/jest/pull/12008)) - `[jest-runtime]` Calling `jest.resetModules` function will clear FS and transform cache ([#12531](https://github.com/facebook/jest/pull/12531)) - `[@jest/schemas]` New module for JSON schemas for Jest's config ([#12384](https://github.com/facebook/jest/pull/12384)) diff --git a/packages/jest-core/src/TestScheduler.ts b/packages/jest-core/src/TestScheduler.ts index 4e5101cf4041..2a8872edd507 100644 --- a/packages/jest-core/src/TestScheduler.ts +++ b/packages/jest-core/src/TestScheduler.ts @@ -29,7 +29,7 @@ import { import {createScriptTransformer} from '@jest/transform'; import type {Config} from '@jest/types'; import {formatExecError} from 'jest-message-util'; -import type TestRunner from 'jest-runner'; +import type {JestTestRunner, TestRunnerContext} from 'jest-runner'; import type {Context} from 'jest-runtime'; import { buildSnapshotResolver, @@ -40,6 +40,11 @@ import ReporterDispatcher from './ReporterDispatcher'; import type TestWatcher from './TestWatcher'; import {shouldRunInBand} from './testSchedulerHelper'; +type TestRunnerConstructor = new ( + globalConfig: Config.GlobalConfig, + context: TestRunnerContext, +) => JestTestRunner; + export type TestSchedulerOptions = { startRun: (globalConfig: Config.GlobalConfig) => void; }; @@ -206,14 +211,14 @@ class TestScheduler { showStatus: !runInBand, }); - const testRunners: {[key: string]: TestRunner} = Object.create(null); - const contextsByTestRunner = new WeakMap(); + const testRunners: Record = Object.create(null); + const contextsByTestRunner = new WeakMap(); await Promise.all( Array.from(contexts).map(async context => { const {config} = context; if (!testRunners[config.runner]) { const transformer = await createScriptTransformer(config); - const Runner: typeof TestRunner = + const Runner: TestRunnerConstructor = await transformer.requireAndTranspileModule(config.runner); const runner = new Runner(this._globalConfig, { changedFiles: this._context.changedFiles, @@ -262,14 +267,7 @@ class TestScheduler { ), ]; - await testRunner.runTests( - tests, - watcher, - undefined, - undefined, - undefined, - testRunnerOptions, - ); + await testRunner.runTests(tests, watcher, testRunnerOptions); unsubscribes.forEach(sub => sub()); } else { @@ -310,7 +308,7 @@ class TestScheduler { } private _partitionTests( - testRunners: Record, + testRunners: Record, tests: Array, ): Record> | null { if (Object.keys(testRunners).length > 1) { diff --git a/packages/jest-runner/__typetests__/jest-runner.test.ts b/packages/jest-runner/__typetests__/jest-runner.test.ts new file mode 100644 index 000000000000..95ec032693b5 --- /dev/null +++ b/packages/jest-runner/__typetests__/jest-runner.test.ts @@ -0,0 +1,73 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +import {expectType} from 'tsd-lite'; +import type {Test, TestEvents} from '@jest/test-result'; +import type {Config} from '@jest/types'; +import {CallbackTestRunner, EmittingTestRunner} from 'jest-runner'; +import type { + OnTestFailure, + OnTestStart, + OnTestSuccess, + TestRunnerContext, + TestRunnerOptions, + TestWatcher, + UnsubscribeFn, +} from 'jest-runner'; + +const globalConfig = {} as Config.GlobalConfig; +const runnerContext = {} as TestRunnerContext; + +// CallbackRunner + +class CallbackRunner extends CallbackTestRunner { + async runTests( + tests: Array, + watcher: TestWatcher, + onStart: OnTestStart, + onResult: OnTestSuccess, + onFailure: OnTestFailure, + options: TestRunnerOptions, + ): Promise { + expectType(this._globalConfig); + expectType(this._context); + + return; + } +} + +const callbackRunner = new CallbackRunner(globalConfig, runnerContext); + +expectType(callbackRunner.isSerial); +expectType(callbackRunner.supportsEventEmitters); + +// EmittingRunner + +class EmittingRunner extends EmittingTestRunner { + async runTests( + tests: Array, + watcher: TestWatcher, + options: TestRunnerOptions, + ): Promise { + expectType(this._globalConfig); + expectType(this._context); + + return; + } + + on( + eventName: string, + listener: (eventData: TestEvents[Name]) => void | Promise, + ): UnsubscribeFn { + return () => {}; + } +} + +const emittingRunner = new EmittingRunner(globalConfig, runnerContext); + +expectType(emittingRunner.isSerial); +expectType(emittingRunner.supportsEventEmitters); diff --git a/packages/jest-runner/__typetests__/tsconfig.json b/packages/jest-runner/__typetests__/tsconfig.json new file mode 100644 index 000000000000..fe8eab794254 --- /dev/null +++ b/packages/jest-runner/__typetests__/tsconfig.json @@ -0,0 +1,11 @@ +{ + "extends": "../../../tsconfig.json", + "compilerOptions": { + "noUnusedLocals": false, + "noUnusedParameters": false, + "skipLibCheck": true, + + "types": [] + }, + "include": ["./**/*"] +} diff --git a/packages/jest-runner/package.json b/packages/jest-runner/package.json index 6a9d5137755d..7a5756434c36 100644 --- a/packages/jest-runner/package.json +++ b/packages/jest-runner/package.json @@ -39,10 +39,12 @@ "throat": "^6.0.1" }, "devDependencies": { + "@tsd/typescript": "~4.6.2", "@types/exit": "^0.1.30", "@types/graceful-fs": "^4.1.2", "@types/source-map-support": "^0.5.0", - "jest-jasmine2": "^28.0.0-alpha.8" + "jest-jasmine2": "^28.0.0-alpha.8", + "tsd-lite": "^0.5.1" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-runner/src/__tests__/testRunner.test.ts b/packages/jest-runner/src/__tests__/testRunner.test.ts index b86345a44f71..b71f179afa3d 100644 --- a/packages/jest-runner/src/__tests__/testRunner.test.ts +++ b/packages/jest-runner/src/__tests__/testRunner.test.ts @@ -7,6 +7,7 @@ */ import {TestWatcher} from '@jest/core'; +import type {TestContext} from '@jest/test-result'; import {makeGlobalConfig, makeProjectConfig} from '@jest/test-utils'; import TestRunner from '../index'; @@ -29,56 +30,46 @@ jest.mock('../testWorker', () => {}); test('injects the serializable module map into each worker in watch mode', async () => { const globalConfig = makeGlobalConfig({maxWorkers: 2, watch: true}); const config = makeProjectConfig({rootDir: '/path/'}); - const serializableModuleMap = jest.fn(); const runContext = {}; - const context = { + const mockTestContext = { config, - moduleMap: {toJSON: () => serializableModuleMap}, - }; + moduleMap: {toJSON: jest.fn()}, + } as unknown as TestContext; - await new TestRunner(globalConfig, {}).runTests( + await new TestRunner(globalConfig, runContext).runTests( [ - {context, path: './file.test.js'}, - {context, path: './file2.test.js'}, + {context: mockTestContext, path: './file.test.js'}, + {context: mockTestContext, path: './file2.test.js'}, ], new TestWatcher({isWatchMode: globalConfig.watch}), - undefined, - undefined, - undefined, {serial: false}, ); - expect(mockWorkerFarm.worker.mock.calls).toEqual([ - [ - { - config, - context: runContext, - globalConfig, - path: './file.test.js', - }, - ], - [ - { - config, - context: runContext, - globalConfig, - path: './file2.test.js', - }, - ], - ]); + expect(mockWorkerFarm.worker).toBeCalledTimes(2); + + expect(mockWorkerFarm.worker).nthCalledWith(1, { + config, + context: runContext, + globalConfig, + path: './file.test.js', + }); + + expect(mockWorkerFarm.worker).nthCalledWith(2, { + config, + context: runContext, + globalConfig, + path: './file2.test.js', + }); }); test('assign process.env.JEST_WORKER_ID = 1 when in runInBand mode', async () => { const globalConfig = makeGlobalConfig({maxWorkers: 1, watch: false}); const config = makeProjectConfig({rootDir: '/path/'}); - const context = {config}; + const context = {config} as TestContext; await new TestRunner(globalConfig, {}).runTests( [{context, path: './file.test.js'}], new TestWatcher({isWatchMode: globalConfig.watch}), - undefined, - undefined, - undefined, {serial: true}, ); diff --git a/packages/jest-runner/src/index.ts b/packages/jest-runner/src/index.ts index a753d16a8b91..c5b7dcfc0584 100644 --- a/packages/jest-runner/src/index.ts +++ b/packages/jest-runner/src/index.ts @@ -14,18 +14,15 @@ import type { TestFileEvent, TestResult, } from '@jest/test-result'; -import type {Config} from '@jest/types'; import {deepCyclicCopy} from 'jest-util'; import {PromiseWithCustomMessage, Worker} from 'jest-worker'; import runTest from './runTest'; import type {SerializableResolver, worker} from './testWorker'; -import type { - OnTestFailure, - OnTestStart, - OnTestSuccess, - TestRunnerContext, +import { + EmittingTestRunner, TestRunnerOptions, TestWatcher, + UnsubscribeFn, } from './types'; const TEST_WORKER_PATH = require.resolve('./testWorker'); @@ -34,6 +31,7 @@ interface WorkerInterface extends Worker { worker: typeof worker; } +export {CallbackTestRunner, EmittingTestRunner} from './types'; export type { OnTestFailure, OnTestStart, @@ -41,37 +39,24 @@ export type { TestWatcher, TestRunnerContext, TestRunnerOptions, + JestTestRunner, + UnsubscribeFn, } from './types'; -export default class TestRunner { - private readonly _globalConfig: Config.GlobalConfig; - private readonly _context: TestRunnerContext; - private readonly eventEmitter = new Emittery(); - readonly supportsEventEmitters: boolean = true; - - readonly isSerial?: boolean; - - constructor(globalConfig: Config.GlobalConfig, context: TestRunnerContext) { - this._globalConfig = globalConfig; - this._context = context; - } +export default class TestRunner extends EmittingTestRunner { + readonly #eventEmitter = new Emittery(); async runTests( tests: Array, watcher: TestWatcher, - // keep these three as they're still passed and should be in the types, - // even if this particular runner doesn't use them - _onStart: OnTestStart | undefined, - _onResult: OnTestSuccess | undefined, - _onFailure: OnTestFailure | undefined, options: TestRunnerOptions, ): Promise { return await (options.serial - ? this._createInBandTestRun(tests, watcher) - : this._createParallelTestRun(tests, watcher)); + ? this.#createInBandTestRun(tests, watcher) + : this.#createParallelTestRun(tests, watcher)); } - private async _createInBandTestRun(tests: Array, watcher: TestWatcher) { + async #createInBandTestRun(tests: Array, watcher: TestWatcher) { process.env.JEST_WORKER_ID = '1'; const mutex = throat(1); return tests.reduce( @@ -85,12 +70,12 @@ export default class TestRunner { // `deepCyclicCopy` used here to avoid mem-leak const sendMessageToJest: TestFileEvent = (eventName, args) => - this.eventEmitter.emit( + this.#eventEmitter.emit( eventName, deepCyclicCopy(args, {keepPrototype: false}), ); - await this.eventEmitter.emit('test-file-start', [test]); + await this.#eventEmitter.emit('test-file-start', [test]); return runTest( test.path, @@ -103,18 +88,16 @@ export default class TestRunner { }) .then( result => - this.eventEmitter.emit('test-file-success', [test, result]), - err => this.eventEmitter.emit('test-file-failure', [test, err]), + this.#eventEmitter.emit('test-file-success', [test, result]), + error => + this.#eventEmitter.emit('test-file-failure', [test, error]), ), ), Promise.resolve(), ); } - private async _createParallelTestRun( - tests: Array, - watcher: TestWatcher, - ) { + async #createParallelTestRun(tests: Array, watcher: TestWatcher) { const resolvers: Map = new Map(); for (const test of tests) { if (!resolvers.has(test.context.config.name)) { @@ -146,7 +129,7 @@ export default class TestRunner { return Promise.reject(); } - await this.eventEmitter.emit('test-file-start', [test]); + await this.#eventEmitter.emit('test-file-start', [test]); const promise = worker.worker({ config: test.context.config, @@ -166,7 +149,7 @@ export default class TestRunner { if (promise.UNSTABLE_onCustomMessage) { // TODO: Get appropriate type for `onCustomMessage` promise.UNSTABLE_onCustomMessage(([event, payload]: any) => - this.eventEmitter.emit(event, payload), + this.#eventEmitter.emit(event, payload), ); } @@ -184,8 +167,9 @@ export default class TestRunner { const runAllTests = Promise.all( tests.map(test => runTestInWorker(test).then( - result => this.eventEmitter.emit('test-file-success', [test, result]), - error => this.eventEmitter.emit('test-file-failure', [test, error]), + result => + this.#eventEmitter.emit('test-file-success', [test, result]), + error => this.#eventEmitter.emit('test-file-failure', [test, error]), ), ), ); @@ -210,8 +194,8 @@ export default class TestRunner { on( eventName: Name, listener: (eventData: TestEvents[Name]) => void | Promise, - ): Emittery.UnsubscribeFn { - return this.eventEmitter.on(eventName, listener); + ): UnsubscribeFn { + return this.#eventEmitter.on(eventName, listener); } } diff --git a/packages/jest-runner/src/types.ts b/packages/jest-runner/src/types.ts index 4bb5f2c58879..71da90742fab 100644 --- a/packages/jest-runner/src/types.ts +++ b/packages/jest-runner/src/types.ts @@ -10,6 +10,7 @@ import type {JestEnvironment} from '@jest/environment'; import type { SerializableError, Test, + TestEvents, TestFileEvent, TestResult, } from '@jest/test-result'; @@ -19,10 +20,12 @@ import type RuntimeType from 'jest-runtime'; export type ErrorWithCode = Error & {code?: string}; export type OnTestStart = (test: Test) => Promise; + export type OnTestFailure = ( test: Test, serializableError: SerializableError, ) => Promise; + export type OnTestSuccess = ( test: Test, testResult: TestResult, @@ -52,6 +55,48 @@ export type TestRunnerSerializedContext = { sourcesRelatedToTestsInChangedFiles?: Array; }; +export type UnsubscribeFn = () => void; + +abstract class BaseTestRunner { + readonly isSerial?: boolean; + abstract readonly supportsEventEmitters: boolean; + + constructor( + protected readonly _globalConfig: Config.GlobalConfig, + protected readonly _context: TestRunnerContext, + ) {} +} + +export abstract class CallbackTestRunner extends BaseTestRunner { + readonly supportsEventEmitters = false; + + abstract runTests( + tests: Array, + watcher: TestWatcher, + onStart: OnTestStart, + onResult: OnTestSuccess, + onFailure: OnTestFailure, + options: TestRunnerOptions, + ): Promise; +} + +export abstract class EmittingTestRunner extends BaseTestRunner { + readonly supportsEventEmitters = true; + + abstract runTests( + tests: Array, + watcher: TestWatcher, + options: TestRunnerOptions, + ): Promise; + + abstract on( + eventName: Name, + listener: (eventData: TestEvents[Name]) => void | Promise, + ): UnsubscribeFn; +} + +export type JestTestRunner = CallbackTestRunner | EmittingTestRunner; + // TODO: Should live in `@jest/core` or `jest-watcher` type WatcherState = {interrupted: boolean}; export interface TestWatcher extends Emittery<{change: WatcherState}> { diff --git a/packages/jest-test-result/src/index.ts b/packages/jest-test-result/src/index.ts index 26edbc397fa6..0ffa340c2c03 100644 --- a/packages/jest-test-result/src/index.ts +++ b/packages/jest-test-result/src/index.ts @@ -25,6 +25,7 @@ export type { Status, Suite, Test, + TestContext, TestEvents, TestFileEvent, TestResult, diff --git a/packages/jest-test-result/src/types.ts b/packages/jest-test-result/src/types.ts index 40abef5f541a..2494a47f7c65 100644 --- a/packages/jest-test-result/src/types.ts +++ b/packages/jest-test-result/src/types.ts @@ -183,12 +183,12 @@ export type SnapshotSummary = { }; export type Test = { - context: Context; + context: TestContext; duration?: number; path: string; }; -type Context = { +export type TestContext = { config: Config.ProjectConfig; hasteFS: HasteFS; moduleMap: ModuleMap; diff --git a/yarn.lock b/yarn.lock index 7e1c7a58f9a2..238c2a73760f 100644 --- a/yarn.lock +++ b/yarn.lock @@ -13542,6 +13542,7 @@ __metadata: "@jest/test-result": ^28.0.0-alpha.8 "@jest/transform": ^28.0.0-alpha.8 "@jest/types": ^28.0.0-alpha.8 + "@tsd/typescript": ~4.6.2 "@types/exit": ^0.1.30 "@types/graceful-fs": ^4.1.2 "@types/node": "*" @@ -13561,6 +13562,7 @@ __metadata: jest-worker: ^28.0.0-alpha.8 source-map-support: ^0.5.6 throat: ^6.0.1 + tsd-lite: ^0.5.1 languageName: unknown linkType: soft From 40ac384940524ae77853cfee2182c9f07bdd1e2a Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Fri, 8 Apr 2022 12:05:27 +0300 Subject: [PATCH 030/128] chore: add `noImplicitOverride` check (#12648) --- .github/workflows/nodejs.yml | 2 +- CHANGELOG.md | 2 +- packages/expect/src/asymmetricMatchers.ts | 16 ++++----- packages/expect/src/jestMatchersObject.ts | 4 +-- packages/jest-console/src/BufferedConsole.ts | 34 +++++++++---------- packages/jest-console/src/CustomConsole.ts | 34 +++++++++---------- packages/jest-console/src/NullConsole.ts | 28 +++++++-------- .../jest-core/src/TestNamePatternPrompt.ts | 2 +- .../jest-core/src/TestPathPatternPrompt.ts | 2 +- .../src/plugins/FailedTestsInteractive.ts | 8 ++--- packages/jest-core/src/plugins/Quit.ts | 4 +-- .../jest-core/src/plugins/TestNamePattern.ts | 6 ++-- .../jest-core/src/plugins/TestPathPattern.ts | 6 ++-- .../jest-core/src/plugins/UpdateSnapshots.ts | 6 ++-- .../src/plugins/UpdateSnapshotsInteractive.ts | 8 ++--- .../jest-reporters/src/CoverageReporter.ts | 4 +-- .../jest-reporters/src/DefaultReporter.ts | 10 +++--- .../src/GitHubActionsReporter.ts | 2 +- packages/jest-reporters/src/NotifyReporter.ts | 5 ++- .../jest-reporters/src/SummaryReporter.ts | 4 +-- .../jest-reporters/src/VerboseReporter.ts | 8 ++--- packages/jest-validate/src/utils.ts | 4 +-- packages/jest-worker/src/WorkerPool.ts | 2 +- scripts/verifyOldTs.mjs | 2 +- tsconfig.json | 1 + 25 files changed, 104 insertions(+), 100 deletions(-) diff --git a/.github/workflows/nodejs.yml b/.github/workflows/nodejs.yml index 16f831fb611f..eae01938f0d3 100644 --- a/.github/workflows/nodejs.yml +++ b/.github/workflows/nodejs.yml @@ -55,7 +55,7 @@ jobs: run: yarn build - name: test typings run: yarn test-types - - name: verify TypeScript@4.2 compatibility + - name: verify TypeScript@4.3 compatibility run: yarn verify-old-ts lint: diff --git a/CHANGELOG.md b/CHANGELOG.md index 79a416b988a1..55e39de6c6ea 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -81,7 +81,7 @@ ### Chore & Maintenance - `[*]` [**BREAKING**] Drop support for Node v10 and v15 and target first LTS `16.13.0` ([#12220](https://github.com/facebook/jest/pull/12220)) -- `[*]` [**BREAKING**] Drop support for `typescript@3.8`, minimum version is now `4.2` ([#11142](https://github.com/facebook/jest/pull/11142)) +- `[*]` [**BREAKING**] Drop support for `typescript@3.8`, minimum version is now `4.3` ([#11142](https://github.com/facebook/jest/pull/11142), [#12648](https://github.com/facebook/jest/pull/12648)) - `[*]` Bundle all `.d.ts` files into a single `index.d.ts` per module ([#12345](https://github.com/facebook/jest/pull/12345)) - `[*]` Use `globalThis` instead of `global` ([#12447](https://github.com/facebook/jest/pull/12447)) - `[babel-jest]` [**BREAKING**] Only export `createTransformer` ([#12407](https://github.com/facebook/jest/pull/12407)) diff --git a/packages/expect/src/asymmetricMatchers.ts b/packages/expect/src/asymmetricMatchers.ts index 9af6ce60c2a7..58390fc11421 100644 --- a/packages/expect/src/asymmetricMatchers.ts +++ b/packages/expect/src/asymmetricMatchers.ts @@ -131,7 +131,7 @@ class Any extends AsymmetricMatcher { return 'Any'; } - getExpectedType() { + override getExpectedType() { if (this.sample == String) { return 'string'; } @@ -155,7 +155,7 @@ class Any extends AsymmetricMatcher { return fnNameFor(this.sample); } - toAsymmetricMatcher() { + override toAsymmetricMatcher() { return `Any<${fnNameFor(this.sample)}>`; } } @@ -171,7 +171,7 @@ class Anything extends AsymmetricMatcher { // No getExpectedType method, because it matches either null or undefined. - toAsymmetricMatcher() { + override toAsymmetricMatcher() { return 'Anything'; } } @@ -203,7 +203,7 @@ class ArrayContaining extends AsymmetricMatcher> { return `Array${this.inverse ? 'Not' : ''}Containing`; } - getExpectedType() { + override getExpectedType() { return 'array'; } } @@ -240,7 +240,7 @@ class ObjectContaining extends AsymmetricMatcher> { return `Object${this.inverse ? 'Not' : ''}Containing`; } - getExpectedType() { + override getExpectedType() { return 'object'; } } @@ -263,7 +263,7 @@ class StringContaining extends AsymmetricMatcher { return `String${this.inverse ? 'Not' : ''}Containing`; } - getExpectedType() { + override getExpectedType() { return 'string'; } } @@ -286,7 +286,7 @@ class StringMatching extends AsymmetricMatcher { return `String${this.inverse ? 'Not' : ''}Matching`; } - getExpectedType() { + override getExpectedType() { return 'string'; } } @@ -326,7 +326,7 @@ class CloseTo extends AsymmetricMatcher { return `Number${this.inverse ? 'Not' : ''}CloseTo`; } - getExpectedType() { + override getExpectedType() { return 'number'; } } diff --git a/packages/expect/src/jestMatchersObject.ts b/packages/expect/src/jestMatchersObject.ts index 121a3116f26d..090434d66f60 100644 --- a/packages/expect/src/jestMatchersObject.ts +++ b/packages/expect/src/jestMatchersObject.ts @@ -94,11 +94,11 @@ export const setMatchers = ( return `${this.inverse ? 'not.' : ''}${key}`; } - getExpectedType() { + override getExpectedType() { return 'any'; } - toAsymmetricMatcher() { + override toAsymmetricMatcher() { return `${this.toString()}<${this.sample.map(String).join(', ')}>`; } } diff --git a/packages/jest-console/src/BufferedConsole.ts b/packages/jest-console/src/BufferedConsole.ts index f65874209f8c..f30f5829a623 100644 --- a/packages/jest-console/src/BufferedConsole.ts +++ b/packages/jest-console/src/BufferedConsole.ts @@ -24,7 +24,7 @@ export default class BufferedConsole extends Console { private _timers: LogTimers = {}; private _groupDepth = 0; - Console: typeof Console = Console; + override Console: typeof Console = Console; constructor() { super({ @@ -71,7 +71,7 @@ export default class BufferedConsole extends Console { ); } - assert(value: unknown, message?: string | Error): void { + override assert(value: unknown, message?: string | Error): void { try { assert(value, message); } catch (error: any) { @@ -79,7 +79,7 @@ export default class BufferedConsole extends Console { } } - count(label: string = 'default'): void { + override count(label: string = 'default'): void { if (!this._counters[label]) { this._counters[label] = 0; } @@ -87,28 +87,28 @@ export default class BufferedConsole extends Console { this._log('count', format(`${label}: ${++this._counters[label]}`)); } - countReset(label: string = 'default'): void { + override countReset(label: string = 'default'): void { this._counters[label] = 0; } - debug(firstArg: unknown, ...rest: Array): void { + override debug(firstArg: unknown, ...rest: Array): void { this._log('debug', format(firstArg, ...rest)); } - dir(firstArg: unknown, options: InspectOptions = {}): void { + override dir(firstArg: unknown, options: InspectOptions = {}): void { const representation = inspect(firstArg, options); this._log('dir', formatWithOptions(options, representation)); } - dirxml(firstArg: unknown, ...rest: Array): void { + override dirxml(firstArg: unknown, ...rest: Array): void { this._log('dirxml', format(firstArg, ...rest)); } - error(firstArg: unknown, ...rest: Array): void { + override error(firstArg: unknown, ...rest: Array): void { this._log('error', format(firstArg, ...rest)); } - group(title?: string, ...rest: Array): void { + override group(title?: string, ...rest: Array): void { this._groupDepth++; if (title || rest.length > 0) { @@ -116,7 +116,7 @@ export default class BufferedConsole extends Console { } } - groupCollapsed(title?: string, ...rest: Array): void { + override groupCollapsed(title?: string, ...rest: Array): void { this._groupDepth++; if (title || rest.length > 0) { @@ -124,21 +124,21 @@ export default class BufferedConsole extends Console { } } - groupEnd(): void { + override groupEnd(): void { if (this._groupDepth > 0) { this._groupDepth--; } } - info(firstArg: unknown, ...rest: Array): void { + override info(firstArg: unknown, ...rest: Array): void { this._log('info', format(firstArg, ...rest)); } - log(firstArg: unknown, ...rest: Array): void { + override log(firstArg: unknown, ...rest: Array): void { this._log('log', format(firstArg, ...rest)); } - time(label: string = 'default'): void { + override time(label: string = 'default'): void { if (this._timers[label]) { return; } @@ -146,7 +146,7 @@ export default class BufferedConsole extends Console { this._timers[label] = new Date(); } - timeEnd(label: string = 'default'): void { + override timeEnd(label: string = 'default'): void { const startTime = this._timers[label]; if (startTime) { @@ -157,7 +157,7 @@ export default class BufferedConsole extends Console { } } - timeLog(label = 'default', ...data: Array): void { + override timeLog(label = 'default', ...data: Array): void { const startTime = this._timers[label]; if (startTime) { @@ -167,7 +167,7 @@ export default class BufferedConsole extends Console { } } - warn(firstArg: unknown, ...rest: Array): void { + override warn(firstArg: unknown, ...rest: Array): void { this._log('warn', format(firstArg, ...rest)); } diff --git a/packages/jest-console/src/CustomConsole.ts b/packages/jest-console/src/CustomConsole.ts index a02850252d31..a363ad939c3b 100644 --- a/packages/jest-console/src/CustomConsole.ts +++ b/packages/jest-console/src/CustomConsole.ts @@ -22,7 +22,7 @@ export default class CustomConsole extends Console { private _timers: LogTimers = {}; private _groupDepth = 0; - Console: typeof Console = Console; + override Console: typeof Console = Console; constructor( stdout: NodeJS.WriteStream, @@ -49,7 +49,7 @@ export default class CustomConsole extends Console { ); } - assert(value: unknown, message?: string | Error): asserts value { + override assert(value: unknown, message?: string | Error): asserts value { try { assert(value, message); } catch (error: any) { @@ -57,7 +57,7 @@ export default class CustomConsole extends Console { } } - count(label: string = 'default'): void { + override count(label: string = 'default'): void { if (!this._counters[label]) { this._counters[label] = 0; } @@ -65,28 +65,28 @@ export default class CustomConsole extends Console { this._log('count', format(`${label}: ${++this._counters[label]}`)); } - countReset(label: string = 'default'): void { + override countReset(label: string = 'default'): void { this._counters[label] = 0; } - debug(firstArg: unknown, ...args: Array): void { + override debug(firstArg: unknown, ...args: Array): void { this._log('debug', format(firstArg, ...args)); } - dir(firstArg: unknown, options: InspectOptions = {}): void { + override dir(firstArg: unknown, options: InspectOptions = {}): void { const representation = inspect(firstArg, options); this._log('dir', formatWithOptions(options, representation)); } - dirxml(firstArg: unknown, ...args: Array): void { + override dirxml(firstArg: unknown, ...args: Array): void { this._log('dirxml', format(firstArg, ...args)); } - error(firstArg: unknown, ...args: Array): void { + override error(firstArg: unknown, ...args: Array): void { this._logError('error', format(firstArg, ...args)); } - group(title?: string, ...args: Array): void { + override group(title?: string, ...args: Array): void { this._groupDepth++; if (title || args.length > 0) { @@ -94,7 +94,7 @@ export default class CustomConsole extends Console { } } - groupCollapsed(title?: string, ...args: Array): void { + override groupCollapsed(title?: string, ...args: Array): void { this._groupDepth++; if (title || args.length > 0) { @@ -102,21 +102,21 @@ export default class CustomConsole extends Console { } } - groupEnd(): void { + override groupEnd(): void { if (this._groupDepth > 0) { this._groupDepth--; } } - info(firstArg: unknown, ...args: Array): void { + override info(firstArg: unknown, ...args: Array): void { this._log('info', format(firstArg, ...args)); } - log(firstArg: unknown, ...args: Array): void { + override log(firstArg: unknown, ...args: Array): void { this._log('log', format(firstArg, ...args)); } - time(label: string = 'default'): void { + override time(label: string = 'default'): void { if (this._timers[label]) { return; } @@ -124,7 +124,7 @@ export default class CustomConsole extends Console { this._timers[label] = new Date(); } - timeEnd(label: string = 'default'): void { + override timeEnd(label: string = 'default'): void { const startTime = this._timers[label]; if (startTime) { @@ -135,7 +135,7 @@ export default class CustomConsole extends Console { } } - timeLog(label = 'default', ...data: Array): void { + override timeLog(label = 'default', ...data: Array): void { const startTime = this._timers[label]; if (startTime) { @@ -145,7 +145,7 @@ export default class CustomConsole extends Console { } } - warn(firstArg: unknown, ...args: Array): void { + override warn(firstArg: unknown, ...args: Array): void { this._logError('warn', format(firstArg, ...args)); } diff --git a/packages/jest-console/src/NullConsole.ts b/packages/jest-console/src/NullConsole.ts index 002e3a9738ff..de8d3e2ba5e2 100644 --- a/packages/jest-console/src/NullConsole.ts +++ b/packages/jest-console/src/NullConsole.ts @@ -8,18 +8,18 @@ import CustomConsole from './CustomConsole'; export default class NullConsole extends CustomConsole { - assert(): void {} - debug(): void {} - dir(): void {} - error(): void {} - info(): void {} - log(): void {} - time(): void {} - timeEnd(): void {} - timeLog(): void {} - trace(): void {} - warn(): void {} - group(): void {} - groupCollapsed(): void {} - groupEnd(): void {} + override assert(): void {} + override debug(): void {} + override dir(): void {} + override error(): void {} + override info(): void {} + override log(): void {} + override time(): void {} + override timeEnd(): void {} + override timeLog(): void {} + override trace(): void {} + override warn(): void {} + override group(): void {} + override groupCollapsed(): void {} + override groupEnd(): void {} } diff --git a/packages/jest-core/src/TestNamePatternPrompt.ts b/packages/jest-core/src/TestNamePatternPrompt.ts index 426a8bc45956..0449eaa8a653 100644 --- a/packages/jest-core/src/TestNamePatternPrompt.ts +++ b/packages/jest-core/src/TestNamePatternPrompt.ts @@ -18,7 +18,7 @@ export default class TestNamePatternPrompt extends PatternPrompt { super(pipe, prompt, 'tests'); } - protected _onChange(pattern: string, options: ScrollOptions): void { + protected override _onChange(pattern: string, options: ScrollOptions): void { super._onChange(pattern, options); this._printPrompt(pattern); } diff --git a/packages/jest-core/src/TestPathPatternPrompt.ts b/packages/jest-core/src/TestPathPatternPrompt.ts index 6c9d948da346..86875cc1b3d4 100644 --- a/packages/jest-core/src/TestPathPatternPrompt.ts +++ b/packages/jest-core/src/TestPathPatternPrompt.ts @@ -18,7 +18,7 @@ export default class TestPathPatternPrompt extends PatternPrompt { super(pipe, prompt, 'filenames'); } - protected _onChange(pattern: string, options: ScrollOptions): void { + protected override _onChange(pattern: string, options: ScrollOptions): void { super._onChange(pattern, options); this._printPrompt(pattern); } diff --git a/packages/jest-core/src/plugins/FailedTestsInteractive.ts b/packages/jest-core/src/plugins/FailedTestsInteractive.ts index 8fcb9b3f9c88..fa0853be55ff 100644 --- a/packages/jest-core/src/plugins/FailedTestsInteractive.ts +++ b/packages/jest-core/src/plugins/FailedTestsInteractive.ts @@ -19,7 +19,7 @@ export default class FailedTestsInteractivePlugin extends BaseWatchPlugin { private _failedTestAssertions?: Array; private readonly _manager = new FailedTestsInteractiveMode(this._stdout); - apply(hooks: JestHookSubscriber): void { + override apply(hooks: JestHookSubscriber): void { hooks.onTestRunComplete(results => { this._failedTestAssertions = this.getFailedTestAssertions(results); @@ -27,7 +27,7 @@ export default class FailedTestsInteractivePlugin extends BaseWatchPlugin { }); } - getUsageInfo(): UsageData | null { + override getUsageInfo(): UsageData | null { if (this._failedTestAssertions?.length) { return {key: 'i', prompt: 'run failing tests interactively'}; } @@ -35,13 +35,13 @@ export default class FailedTestsInteractivePlugin extends BaseWatchPlugin { return null; } - onKey(key: string): void { + override onKey(key: string): void { if (this._manager.isActive()) { this._manager.put(key); } } - run( + override run( _: Config.GlobalConfig, updateConfigAndRun: UpdateConfigCallback, ): Promise { diff --git a/packages/jest-core/src/plugins/Quit.ts b/packages/jest-core/src/plugins/Quit.ts index ac4c0646351e..c35e654565d5 100644 --- a/packages/jest-core/src/plugins/Quit.ts +++ b/packages/jest-core/src/plugins/Quit.ts @@ -15,7 +15,7 @@ class QuitPlugin extends BaseWatchPlugin { this.isInternal = true; } - async run(): Promise { + override async run(): Promise { if (typeof this._stdin.setRawMode === 'function') { this._stdin.setRawMode(false); } @@ -23,7 +23,7 @@ class QuitPlugin extends BaseWatchPlugin { process.exit(0); } - getUsageInfo(): UsageData { + override getUsageInfo(): UsageData { return { key: 'q', prompt: 'quit watch mode', diff --git a/packages/jest-core/src/plugins/TestNamePattern.ts b/packages/jest-core/src/plugins/TestNamePattern.ts index 34e61f3c30c3..ea3ff104ac88 100644 --- a/packages/jest-core/src/plugins/TestNamePattern.ts +++ b/packages/jest-core/src/plugins/TestNamePattern.ts @@ -25,18 +25,18 @@ class TestNamePatternPlugin extends BaseWatchPlugin { this.isInternal = true; } - getUsageInfo(): UsageData { + override getUsageInfo(): UsageData { return { key: 't', prompt: 'filter by a test name regex pattern', }; } - onKey(key: string): void { + override onKey(key: string): void { this._prompt.put(key); } - run( + override run( globalConfig: Config.GlobalConfig, updateConfigAndRun: UpdateConfigCallback, ): Promise { diff --git a/packages/jest-core/src/plugins/TestPathPattern.ts b/packages/jest-core/src/plugins/TestPathPattern.ts index b02b74b62443..d0866db9b27f 100644 --- a/packages/jest-core/src/plugins/TestPathPattern.ts +++ b/packages/jest-core/src/plugins/TestPathPattern.ts @@ -25,18 +25,18 @@ class TestPathPatternPlugin extends BaseWatchPlugin { this.isInternal = true; } - getUsageInfo(): UsageData { + override getUsageInfo(): UsageData { return { key: 'p', prompt: 'filter by a filename regex pattern', }; } - onKey(key: string): void { + override onKey(key: string): void { this._prompt.put(key); } - run( + override run( globalConfig: Config.GlobalConfig, updateConfigAndRun: UpdateConfigCallback, ): Promise { diff --git a/packages/jest-core/src/plugins/UpdateSnapshots.ts b/packages/jest-core/src/plugins/UpdateSnapshots.ts index 1a637895d500..d783a091bd99 100644 --- a/packages/jest-core/src/plugins/UpdateSnapshots.ts +++ b/packages/jest-core/src/plugins/UpdateSnapshots.ts @@ -23,7 +23,7 @@ class UpdateSnapshotsPlugin extends BaseWatchPlugin { this._hasSnapshotFailure = false; } - run( + override run( _globalConfig: Config.GlobalConfig, updateConfigAndRun: UpdateConfigCallback, ): Promise { @@ -31,13 +31,13 @@ class UpdateSnapshotsPlugin extends BaseWatchPlugin { return Promise.resolve(false); } - apply(hooks: JestHookSubscriber): void { + override apply(hooks: JestHookSubscriber): void { hooks.onTestRunComplete(results => { this._hasSnapshotFailure = results.snapshot.failure; }); } - getUsageInfo(): UsageData | null { + override getUsageInfo(): UsageData | null { if (this._hasSnapshotFailure) { return { key: 'u', diff --git a/packages/jest-core/src/plugins/UpdateSnapshotsInteractive.ts b/packages/jest-core/src/plugins/UpdateSnapshotsInteractive.ts index 63f52ff5cfcd..1961a13611cc 100644 --- a/packages/jest-core/src/plugins/UpdateSnapshotsInteractive.ts +++ b/packages/jest-core/src/plugins/UpdateSnapshotsInteractive.ts @@ -42,7 +42,7 @@ class UpdateSnapshotInteractivePlugin extends BaseWatchPlugin { return failedTestPaths; } - apply(hooks: JestHookSubscriber): void { + override apply(hooks: JestHookSubscriber): void { hooks.onTestRunComplete(results => { this._failedSnapshotTestAssertions = this.getFailedSnapshotTestAssertions(results); @@ -52,13 +52,13 @@ class UpdateSnapshotInteractivePlugin extends BaseWatchPlugin { }); } - onKey(key: string): void { + override onKey(key: string): void { if (this._snapshotInteractiveMode.isActive()) { this._snapshotInteractiveMode.put(key); } } - run( + override run( _globalConfig: Config.GlobalConfig, updateConfigAndRun: Function, ): Promise { @@ -85,7 +85,7 @@ class UpdateSnapshotInteractivePlugin extends BaseWatchPlugin { } } - getUsageInfo(): UsageData | null { + override getUsageInfo(): UsageData | null { if (this._failedSnapshotTestAssertions?.length > 0) { return { key: 'i', diff --git a/packages/jest-reporters/src/CoverageReporter.ts b/packages/jest-reporters/src/CoverageReporter.ts index 63da91389719..2390029f90b6 100644 --- a/packages/jest-reporters/src/CoverageReporter.ts +++ b/packages/jest-reporters/src/CoverageReporter.ts @@ -64,7 +64,7 @@ export default class CoverageReporter extends BaseReporter { this._options = options || {}; } - onTestResult(_test: Test, testResult: TestResult): void { + override onTestResult(_test: Test, testResult: TestResult): void { if (testResult.v8Coverage) { this._v8CoverageResults.push(testResult.v8Coverage); return; @@ -75,7 +75,7 @@ export default class CoverageReporter extends BaseReporter { } } - async onRunComplete( + override async onRunComplete( contexts: Set, aggregatedResults: AggregatedResult, ): Promise { diff --git a/packages/jest-reporters/src/DefaultReporter.ts b/packages/jest-reporters/src/DefaultReporter.ts index 19a46dac5ab0..3af42784283e 100644 --- a/packages/jest-reporters/src/DefaultReporter.ts +++ b/packages/jest-reporters/src/DefaultReporter.ts @@ -127,22 +127,22 @@ export default class DefaultReporter extends BaseReporter { } } - onRunStart( + override onRunStart( aggregatedResults: AggregatedResult, options: ReporterOnStartOptions, ): void { this._status.runStarted(aggregatedResults, options); } - onTestStart(test: Test): void { + override onTestStart(test: Test): void { this._status.testStarted(test.path, test.context.config); } - onTestCaseResult(test: Test, testCaseResult: TestCaseResult): void { + override onTestCaseResult(test: Test, testCaseResult: TestCaseResult): void { this._status.addTestCaseResult(test, testCaseResult); } - onRunComplete(): void { + override onRunComplete(): void { this.forceFlushBufferedOutput(); this._status.runFinished(); process.stdout.write = this._out; @@ -150,7 +150,7 @@ export default class DefaultReporter extends BaseReporter { clearLine(process.stderr); } - onTestResult( + override onTestResult( test: Test, testResult: TestResult, aggregatedResults: AggregatedResult, diff --git a/packages/jest-reporters/src/GitHubActionsReporter.ts b/packages/jest-reporters/src/GitHubActionsReporter.ts index dd63977df91d..b9188e701b7b 100644 --- a/packages/jest-reporters/src/GitHubActionsReporter.ts +++ b/packages/jest-reporters/src/GitHubActionsReporter.ts @@ -23,7 +23,7 @@ function replaceEntities(s: string): string { } export default class GitHubActionsReporter extends BaseReporter { - onRunComplete( + override onRunComplete( _contexts?: Set, aggregatedResults?: AggregatedResult, ): void { diff --git a/packages/jest-reporters/src/NotifyReporter.ts b/packages/jest-reporters/src/NotifyReporter.ts index 4bc77ac48999..63d8a218ea2b 100644 --- a/packages/jest-reporters/src/NotifyReporter.ts +++ b/packages/jest-reporters/src/NotifyReporter.ts @@ -37,7 +37,10 @@ export default class NotifyReporter extends BaseReporter { this._context = context; } - onRunComplete(contexts: Set, result: AggregatedResult): void { + override onRunComplete( + contexts: Set, + result: AggregatedResult, + ): void { const success = result.numFailedTests === 0 && result.numRuntimeErrorTestSuites === 0; diff --git a/packages/jest-reporters/src/SummaryReporter.ts b/packages/jest-reporters/src/SummaryReporter.ts index c46854a4b83f..36e59aae3bb3 100644 --- a/packages/jest-reporters/src/SummaryReporter.ts +++ b/packages/jest-reporters/src/SummaryReporter.ts @@ -70,7 +70,7 @@ export default class SummaryReporter extends BaseReporter { } } - onRunStart( + override onRunStart( aggregatedResults: AggregatedResult, options: ReporterOnStartOptions, ): void { @@ -78,7 +78,7 @@ export default class SummaryReporter extends BaseReporter { this._estimatedTime = options.estimatedTime; } - onRunComplete( + override onRunComplete( contexts: Set, aggregatedResults: AggregatedResult, ): void { diff --git a/packages/jest-reporters/src/VerboseReporter.ts b/packages/jest-reporters/src/VerboseReporter.ts index 4476e895d98d..919767dbdf9b 100644 --- a/packages/jest-reporters/src/VerboseReporter.ts +++ b/packages/jest-reporters/src/VerboseReporter.ts @@ -20,9 +20,9 @@ import type {Test} from './types'; const {ICONS} = specialChars; export default class VerboseReporter extends DefaultReporter { - protected _globalConfig: Config.GlobalConfig; + protected override _globalConfig: Config.GlobalConfig; - static readonly filename = __filename; + static override readonly filename = __filename; constructor(globalConfig: Config.GlobalConfig) { super(globalConfig); @@ -31,7 +31,7 @@ export default class VerboseReporter extends DefaultReporter { // Verbose mode is for debugging. Buffering of output is undesirable. // See https://github.com/facebook/jest/issues/8208 - protected __wrapStdio( + protected override __wrapStdio( stream: NodeJS.WritableStream | NodeJS.WriteStream, ): void { const write = stream.write.bind(stream); @@ -71,7 +71,7 @@ export default class VerboseReporter extends DefaultReporter { return root; } - onTestResult( + override onTestResult( test: Test, result: TestResult, aggregatedResults: AggregatedResult, diff --git a/packages/jest-validate/src/utils.ts b/packages/jest-validate/src/utils.ts index e327bce87f7e..d6890f7914cd 100644 --- a/packages/jest-validate/src/utils.ts +++ b/packages/jest-validate/src/utils.ts @@ -25,8 +25,8 @@ export const formatPrettyObject = (value: unknown): string => : JSON.stringify(value, null, 2).split('\n').join('\n '); export class ValidationError extends Error { - name: string; - message: string; + override name: string; + override message: string; constructor(name: string, message: string, comment?: string | null) { super(); diff --git a/packages/jest-worker/src/WorkerPool.ts b/packages/jest-worker/src/WorkerPool.ts index 0bf2a72c3ed1..694858b9a863 100644 --- a/packages/jest-worker/src/WorkerPool.ts +++ b/packages/jest-worker/src/WorkerPool.ts @@ -27,7 +27,7 @@ class WorkerPool extends BaseWorkerPool implements WorkerPoolInterface { this.getWorkerById(workerId).send(request, onStart, onEnd, onCustomMessage); } - createWorker(workerOptions: WorkerOptions): WorkerInterface { + override createWorker(workerOptions: WorkerOptions): WorkerInterface { let Worker; if (this._options.enableWorkerThreads) { Worker = require('./workers/NodeThreadsWorker').default; diff --git a/scripts/verifyOldTs.mjs b/scripts/verifyOldTs.mjs index 481c500ad49e..9ad40b74fe6a 100644 --- a/scripts/verifyOldTs.mjs +++ b/scripts/verifyOldTs.mjs @@ -33,7 +33,7 @@ const tsConfig = { }; /* eslint-enable */ -const tsVersion = '4.2'; +const tsVersion = '4.3'; function smoketest() { const jestDirectory = path.resolve( diff --git a/tsconfig.json b/tsconfig.json index cff2131d1fb2..574e1e6ec482 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -12,6 +12,7 @@ /* Additional Checks */ "noUnusedLocals": true, "noUnusedParameters": true, + "noImplicitOverride": true, "noImplicitReturns": true, "noFallthroughCasesInSwitch": true, From a5f1ef43981b7426d61bcd7cbc59a79f548c075a Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Fri, 8 Apr 2022 11:05:43 +0200 Subject: [PATCH 031/128] chore: refresh lockfile (#12651) --- package.json | 1 - packages/jest-core/package.json | 2 +- packages/jest-core/src/TestWatcher.ts | 4 +- .../jest-core/src/__tests__/watch.test.js | 16 +- packages/jest-runner/package.json | 2 +- packages/pretty-format/package.json | 2 +- yarn.lock | 1124 ++++++++--------- 7 files changed, 560 insertions(+), 591 deletions(-) diff --git a/package.json b/package.json index 5009fceaebca..5125d1a77316 100644 --- a/package.json +++ b/package.json @@ -164,7 +164,6 @@ "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" }, "resolutions": { - "@testing-library/dom/pretty-format": "26.6.1", "babel-jest": "workspace:*", "jest": "workspace:*", "jest-environment-node": "workspace:*", diff --git a/packages/jest-core/package.json b/packages/jest-core/package.json index cd2bb18539dc..37a50b158f73 100644 --- a/packages/jest-core/package.json +++ b/packages/jest-core/package.json @@ -20,7 +20,7 @@ "@types/node": "*", "ansi-escapes": "^4.2.1", "chalk": "^4.0.0", - "emittery": "^0.8.1", + "emittery": "^0.10.2", "exit": "^0.1.2", "graceful-fs": "^4.2.9", "jest-changed-files": "^28.0.0-alpha.3", diff --git a/packages/jest-core/src/TestWatcher.ts b/packages/jest-core/src/TestWatcher.ts index 03f19b1f840b..af91597dddc1 100644 --- a/packages/jest-core/src/TestWatcher.ts +++ b/packages/jest-core/src/TestWatcher.ts @@ -5,13 +5,13 @@ * LICENSE file in the root directory of this source tree. */ -import emittery = require('emittery'); +import Emittery = require('emittery'); type State = { interrupted: boolean; }; -export default class TestWatcher extends emittery<{change: State}> { +export default class TestWatcher extends Emittery<{change: State}> { state: State; private _isWatchMode: boolean; diff --git a/packages/jest-core/src/__tests__/watch.test.js b/packages/jest-core/src/__tests__/watch.test.js index dc46da7f1ec7..d38508a2a64b 100644 --- a/packages/jest-core/src/__tests__/watch.test.js +++ b/packages/jest-core/src/__tests__/watch.test.js @@ -142,7 +142,9 @@ describe('Watch mode flows', () => { globalConfig, onComplete: expect.any(Function), outputStream: pipe, - testWatcher: new TestWatcher({isWatchMode: true}), + testWatcher: JSON.parse( + JSON.stringify(new TestWatcher({isWatchMode: true})), + ), }); }); @@ -156,7 +158,9 @@ describe('Watch mode flows', () => { globalConfig, onComplete: expect.any(Function), outputStream: pipe, - testWatcher: new TestWatcher({isWatchMode: true}), + testWatcher: JSON.parse( + JSON.stringify(new TestWatcher({isWatchMode: true})), + ), }); }); @@ -167,7 +171,9 @@ describe('Watch mode flows', () => { globalConfig, onComplete: expect.any(Function), outputStream: pipe, - testWatcher: new TestWatcher({isWatchMode: true}), + testWatcher: JSON.parse( + JSON.stringify(new TestWatcher({isWatchMode: true})), + ), }); expect(pipe.write.mock.calls.reverse()[0]).toMatchSnapshot(); }); @@ -183,7 +189,9 @@ describe('Watch mode flows', () => { globalConfig, onComplete: expect.any(Function), outputStream: pipe, - testWatcher: new TestWatcher({isWatchMode: true}), + testWatcher: JSON.parse( + JSON.stringify(new TestWatcher({isWatchMode: true})), + ), }); expect(pipe.write.mock.calls.reverse()[0]).toMatchSnapshot(); }); diff --git a/packages/jest-runner/package.json b/packages/jest-runner/package.json index 7a5756434c36..7103c9861d3c 100644 --- a/packages/jest-runner/package.json +++ b/packages/jest-runner/package.json @@ -24,7 +24,7 @@ "@jest/types": "^28.0.0-alpha.8", "@types/node": "*", "chalk": "^4.0.0", - "emittery": "^0.8.1", + "emittery": "^0.10.2", "graceful-fs": "^4.2.9", "jest-docblock": "^28.0.0-alpha.6", "jest-environment-node": "^28.0.0-alpha.8", diff --git a/packages/pretty-format/package.json b/packages/pretty-format/package.json index 2d40b5cf389a..689422ef07bc 100644 --- a/packages/pretty-format/package.json +++ b/packages/pretty-format/package.json @@ -23,7 +23,7 @@ "@jest/schemas": "^28.0.0-alpha.3", "ansi-regex": "^5.0.1", "ansi-styles": "^5.0.0", - "react-is": "^17.0.1" + "react-is": "^18.0.0" }, "devDependencies": { "@types/react": "*", diff --git a/yarn.lock b/yarn.lock index 238c2a73760f..674344c1f98d 100644 --- a/yarn.lock +++ b/yarn.lock @@ -288,25 +288,25 @@ __metadata: linkType: hard "@babel/core@npm:*, @babel/core@npm:^7.0.0, @babel/core@npm:^7.1.0, @babel/core@npm:^7.11.1, @babel/core@npm:^7.11.6, @babel/core@npm:^7.12.3, @babel/core@npm:^7.13.16, @babel/core@npm:^7.14.0, @babel/core@npm:^7.15.5, @babel/core@npm:^7.17.8, @babel/core@npm:^7.3.4, @babel/core@npm:^7.7.2, @babel/core@npm:^7.8.0": - version: 7.17.8 - resolution: "@babel/core@npm:7.17.8" + version: 7.17.9 + resolution: "@babel/core@npm:7.17.9" dependencies: "@ampproject/remapping": ^2.1.0 "@babel/code-frame": ^7.16.7 - "@babel/generator": ^7.17.7 + "@babel/generator": ^7.17.9 "@babel/helper-compilation-targets": ^7.17.7 "@babel/helper-module-transforms": ^7.17.7 - "@babel/helpers": ^7.17.8 - "@babel/parser": ^7.17.8 + "@babel/helpers": ^7.17.9 + "@babel/parser": ^7.17.9 "@babel/template": ^7.16.7 - "@babel/traverse": ^7.17.3 + "@babel/traverse": ^7.17.9 "@babel/types": ^7.17.0 convert-source-map: ^1.7.0 debug: ^4.1.0 gensync: ^1.0.0-beta.2 - json5: ^2.1.2 + json5: ^2.2.1 semver: ^6.3.0 - checksum: 0e686b1be444d25494424065238931f2b3df908bf072b72bab973acfd6d27a481fc280c9cd8a3c6fe2c46beee50e0d2307468d8b15b64dc4036f025e75f6609d + checksum: 2d301e4561a170bb584a735ec412de8fdc40b2052e12380d4a5e36781be5af1fd2a60552e7f0764b0a491a242f20105265bd2a10ff57b30c2842684f02dbb5a2 languageName: node linkType: hard @@ -334,14 +334,14 @@ __metadata: languageName: node linkType: hard -"@babel/generator@npm:^7.12.5, @babel/generator@npm:^7.14.0, @babel/generator@npm:^7.17.3, @babel/generator@npm:^7.17.7, @babel/generator@npm:^7.7.2": - version: 7.17.7 - resolution: "@babel/generator@npm:7.17.7" +"@babel/generator@npm:^7.12.5, @babel/generator@npm:^7.14.0, @babel/generator@npm:^7.17.7, @babel/generator@npm:^7.17.9, @babel/generator@npm:^7.7.2": + version: 7.17.9 + resolution: "@babel/generator@npm:7.17.9" dependencies: "@babel/types": ^7.17.0 jsesc: ^2.5.1 source-map: ^0.5.0 - checksum: e7344b9b4559115f2754ecc2ae9508412ea6a8f617544cd3d3f17cabc727bd30630765f96c8a4ebc8901ded1492a3a6c23d695a4f1e8f3042f860b30c891985c + checksum: afbdd4afbf731ba0a17e7e2d9a2291e6461259af887f88f1178f63514a86e9c18cec462ae8f9cd6df9ba15a18296f47b0e151202bb4f834f7338ac0c07ec8dc8 languageName: node linkType: hard @@ -378,20 +378,20 @@ __metadata: languageName: node linkType: hard -"@babel/helper-create-class-features-plugin@npm:^7.16.10, @babel/helper-create-class-features-plugin@npm:^7.16.7, @babel/helper-create-class-features-plugin@npm:^7.17.6": - version: 7.17.6 - resolution: "@babel/helper-create-class-features-plugin@npm:7.17.6" +"@babel/helper-create-class-features-plugin@npm:^7.16.10, @babel/helper-create-class-features-plugin@npm:^7.16.7, @babel/helper-create-class-features-plugin@npm:^7.17.6, @babel/helper-create-class-features-plugin@npm:^7.17.9": + version: 7.17.9 + resolution: "@babel/helper-create-class-features-plugin@npm:7.17.9" dependencies: "@babel/helper-annotate-as-pure": ^7.16.7 "@babel/helper-environment-visitor": ^7.16.7 - "@babel/helper-function-name": ^7.16.7 - "@babel/helper-member-expression-to-functions": ^7.16.7 + "@babel/helper-function-name": ^7.17.9 + "@babel/helper-member-expression-to-functions": ^7.17.7 "@babel/helper-optimise-call-expression": ^7.16.7 "@babel/helper-replace-supers": ^7.16.7 "@babel/helper-split-export-declaration": ^7.16.7 peerDependencies: "@babel/core": ^7.0.0 - checksum: d85a5b3f9a18a661372d77462e6ea2a6a03f1083f8b3055ed165284214af9ea6ad677f6bcc4b5ce215da27f95fa93064580d4b6723b578c480ecf17dd31a4307 + checksum: db7be8852096084883dbbd096f925976695e5b34919a888fded9fd359d75d9994960e459f4eeb51ff6700109f83be6c1359e57809deb3fe36fc589b2a208b6d7 languageName: node linkType: hard @@ -443,23 +443,13 @@ __metadata: languageName: node linkType: hard -"@babel/helper-function-name@npm:^7.16.7": - version: 7.16.7 - resolution: "@babel/helper-function-name@npm:7.16.7" +"@babel/helper-function-name@npm:^7.16.7, @babel/helper-function-name@npm:^7.17.9": + version: 7.17.9 + resolution: "@babel/helper-function-name@npm:7.17.9" dependencies: - "@babel/helper-get-function-arity": ^7.16.7 "@babel/template": ^7.16.7 - "@babel/types": ^7.16.7 - checksum: fc77cbe7b10cfa2a262d7a37dca575c037f20419dfe0c5d9317f589599ca24beb5f5c1057748011159149eaec47fe32338c6c6412376fcded68200df470161e1 - languageName: node - linkType: hard - -"@babel/helper-get-function-arity@npm:^7.16.7": - version: 7.16.7 - resolution: "@babel/helper-get-function-arity@npm:7.16.7" - dependencies: - "@babel/types": ^7.16.7 - checksum: 25d969fb207ff2ad5f57a90d118f6c42d56a0171022e200aaa919ba7dc95ae7f92ec71cdea6c63ef3629a0dc962ab4c78e09ca2b437185ab44539193f796e0c3 + "@babel/types": ^7.17.0 + checksum: a59b2e5af56d8f43b9b0019939a43774754beb7cb01a211809ca8031c71890999d07739e955343135ec566c4d8ff725435f1f60fb0af3bb546837c1f9f84f496 languageName: node linkType: hard @@ -472,7 +462,7 @@ __metadata: languageName: node linkType: hard -"@babel/helper-member-expression-to-functions@npm:^7.16.7": +"@babel/helper-member-expression-to-functions@npm:^7.16.7, @babel/helper-member-expression-to-functions@npm:^7.17.7": version: 7.17.7 resolution: "@babel/helper-member-expression-to-functions@npm:7.17.7" dependencies: @@ -606,34 +596,34 @@ __metadata: languageName: node linkType: hard -"@babel/helpers@npm:^7.12.5, @babel/helpers@npm:^7.17.8": - version: 7.17.8 - resolution: "@babel/helpers@npm:7.17.8" +"@babel/helpers@npm:^7.12.5, @babel/helpers@npm:^7.17.9": + version: 7.17.9 + resolution: "@babel/helpers@npm:7.17.9" dependencies: "@babel/template": ^7.16.7 - "@babel/traverse": ^7.17.3 + "@babel/traverse": ^7.17.9 "@babel/types": ^7.17.0 - checksum: 463dad58119fefebf2d0201bfa53ec9607aa00356908895640fc07589747fb3c2e0dfee4019f3e8c9781e57c9aa5dff4c72ec8d1b031c4ed8349f90b6aefe99d + checksum: 3c6db861e4c82fff2de3efb4ad12e32658c50c29920597cd0979390659b202e5849acd9542e0e2453167a52ccc30156ee4455d64d0e330f020d991d7551566f8 languageName: node linkType: hard "@babel/highlight@npm:^7.16.7": - version: 7.16.10 - resolution: "@babel/highlight@npm:7.16.10" + version: 7.17.9 + resolution: "@babel/highlight@npm:7.17.9" dependencies: "@babel/helper-validator-identifier": ^7.16.7 chalk: ^2.0.0 js-tokens: ^4.0.0 - checksum: 1f1bdd752a90844f4efc22166a46303fb651ba0fd75a06daba3ebae2575ab3edc1da9827c279872a3aaf305f50a18473c5fa1966752726a2b253065fd4c0745e + checksum: 7bdf10228f2e4d18f48f114411ed584380d356e7c168d7582c14abd8df9909b2fc09e0a7cd334f47c3eb0bc17e639e0c8d9688c6afd5d09a2bdbf0ac193b11fd languageName: node linkType: hard -"@babel/parser@npm:^7.1.0, @babel/parser@npm:^7.12.7, @babel/parser@npm:^7.13.16, @babel/parser@npm:^7.14.0, @babel/parser@npm:^7.14.7, @babel/parser@npm:^7.16.7, @babel/parser@npm:^7.17.3, @babel/parser@npm:^7.17.8": - version: 7.17.8 - resolution: "@babel/parser@npm:7.17.8" +"@babel/parser@npm:^7.1.0, @babel/parser@npm:^7.12.7, @babel/parser@npm:^7.13.16, @babel/parser@npm:^7.14.0, @babel/parser@npm:^7.14.7, @babel/parser@npm:^7.16.7, @babel/parser@npm:^7.17.8, @babel/parser@npm:^7.17.9": + version: 7.17.9 + resolution: "@babel/parser@npm:7.17.9" bin: parser: ./bin/babel-parser.js - checksum: 1771808491982cc47baa888a997aef6b58308e3844c8c00f730f8fd97defe57d32cdbf46075cd49aaee310fa31f3d2c80a0d41b41a4ee0ff336ee09e2ff6c222 + checksum: ea59c985ebfae7c0299c8ea63ed34903202f51665db8d59c55b4366e20270b74d7367a2c211fdd2db20f25750df89adcc85ab6c8692061c6459a88efb79f43e6 languageName: node linkType: hard @@ -700,17 +690,18 @@ __metadata: linkType: hard "@babel/plugin-proposal-decorators@npm:*": - version: 7.17.8 - resolution: "@babel/plugin-proposal-decorators@npm:7.17.8" + version: 7.17.9 + resolution: "@babel/plugin-proposal-decorators@npm:7.17.9" dependencies: - "@babel/helper-create-class-features-plugin": ^7.17.6 + "@babel/helper-create-class-features-plugin": ^7.17.9 "@babel/helper-plugin-utils": ^7.16.7 "@babel/helper-replace-supers": ^7.16.7 + "@babel/helper-split-export-declaration": ^7.16.7 "@babel/plugin-syntax-decorators": ^7.17.0 charcodes: ^0.2.0 peerDependencies: "@babel/core": ^7.0.0-0 - checksum: 8687de0ef0d671bc0c7e2ae0a7970055f8f6a0c8a50dcf81fe54bad85ffb59447ad7d75169f891244ef4a5a7bc2d146d753b7077635597fd998a44db632481ae + checksum: a3d177b88843bf73d798e4b21c1b8146bd33fd19ab56e5ab379d6670db84e172570e73bcf5a4e5a83193cfea49fed3db0015454e78f30f46d25d256c6e65a7b3 languageName: node linkType: hard @@ -1324,8 +1315,8 @@ __metadata: linkType: hard "@babel/plugin-transform-modules-commonjs@npm:^7.0.0, @babel/plugin-transform-modules-commonjs@npm:^7.1.0, @babel/plugin-transform-modules-commonjs@npm:^7.13.8, @babel/plugin-transform-modules-commonjs@npm:^7.16.8": - version: 7.17.7 - resolution: "@babel/plugin-transform-modules-commonjs@npm:7.17.7" + version: 7.17.9 + resolution: "@babel/plugin-transform-modules-commonjs@npm:7.17.9" dependencies: "@babel/helper-module-transforms": ^7.17.7 "@babel/helper-plugin-utils": ^7.16.7 @@ -1333,7 +1324,7 @@ __metadata: babel-plugin-dynamic-import-node: ^2.3.3 peerDependencies: "@babel/core": ^7.0.0-0 - checksum: d84385d89465f8241cbeed8069dc54fb15ee0465119a3326c65ee93ce93019b7a9953b23e22a67203aa2ebf81ac444eadf6d37912d453ec7ba2dce9872bb6490 + checksum: 23f248a28b43978c7ee187a91392510f665db32f2cc869007da4922e5a83da47f27ecd5da37c8f66fe6b89e4b324f1a978a4493ae59edf2b3129387d844fde1b languageName: node linkType: hard @@ -1514,13 +1505,13 @@ __metadata: linkType: hard "@babel/plugin-transform-regenerator@npm:^7.0.0, @babel/plugin-transform-regenerator@npm:^7.16.7": - version: 7.16.7 - resolution: "@babel/plugin-transform-regenerator@npm:7.16.7" + version: 7.17.9 + resolution: "@babel/plugin-transform-regenerator@npm:7.17.9" dependencies: - regenerator-transform: ^0.14.2 + regenerator-transform: ^0.15.0 peerDependencies: "@babel/core": ^7.0.0-0 - checksum: 12b1f9a4f324027af69f49522fbe7feea2ac53285ca5c7e27a70de09f56c74938bfda8b09ac06e57fa1207e441f00efb7adbc462afc9be5e8abd0c2a07715e01 + checksum: bf92f7228397615f12fa62d1decbe854ee9065d44e55036f99bf312783d51b082981bab38ba61de9858f7e20513484a043bfa958c0ce4a0d4d1710710df029a9 languageName: node linkType: hard @@ -1800,21 +1791,21 @@ __metadata: linkType: hard "@babel/runtime-corejs3@npm:^7.17.8": - version: 7.17.8 - resolution: "@babel/runtime-corejs3@npm:7.17.8" + version: 7.17.9 + resolution: "@babel/runtime-corejs3@npm:7.17.9" dependencies: core-js-pure: ^3.20.2 regenerator-runtime: ^0.13.4 - checksum: 91f96437393b48c51000d1bb9d7a219de9394c5cf5227f1d263b6653fac3ff78e9d5e445e7c4410e9e3b24497715098ea6ade6fcad6cf964b0cf3ff161a85bd9 + checksum: c0893eb1ba4fd8a5a0e43d0fd5c3ad61c020dc5953bb74a76e9e10a0adfde7a5d8fd7e78d59b08dce3a0774948c6c40c81df0fdd0a1130c414fd3535fae365cb languageName: node linkType: hard "@babel/runtime@npm:^7.1.2, @babel/runtime@npm:^7.10.2, @babel/runtime@npm:^7.10.3, @babel/runtime@npm:^7.11.2, @babel/runtime@npm:^7.12.1, @babel/runtime@npm:^7.12.13, @babel/runtime@npm:^7.12.5, @babel/runtime@npm:^7.17.8, @babel/runtime@npm:^7.8.4": - version: 7.17.8 - resolution: "@babel/runtime@npm:7.17.8" + version: 7.17.9 + resolution: "@babel/runtime@npm:7.17.9" dependencies: regenerator-runtime: ^0.13.4 - checksum: 68d195c1630bb91ac20e86635d292a17ebab7f361cfe79406b3f5a6cc2e59fa283ae5006568899abf869312c2b35b744bd407aea8ffdb650f1a68d07785d47e9 + checksum: 4d56bdb82890f386d5a57c40ef985a0ed7f0a78f789377a2d0c3e8826819e0f7f16ba0fe906d9b2241c5f7ca56630ef0653f5bb99f03771f7b87ff8af4bf5fe3 languageName: node linkType: hard @@ -1829,21 +1820,21 @@ __metadata: languageName: node linkType: hard -"@babel/traverse@npm:^7.12.9, @babel/traverse@npm:^7.13.0, @babel/traverse@npm:^7.14.0, @babel/traverse@npm:^7.16.7, @babel/traverse@npm:^7.16.8, @babel/traverse@npm:^7.17.3, @babel/traverse@npm:^7.7.2": - version: 7.17.3 - resolution: "@babel/traverse@npm:7.17.3" +"@babel/traverse@npm:^7.12.9, @babel/traverse@npm:^7.13.0, @babel/traverse@npm:^7.14.0, @babel/traverse@npm:^7.16.7, @babel/traverse@npm:^7.16.8, @babel/traverse@npm:^7.17.3, @babel/traverse@npm:^7.17.9, @babel/traverse@npm:^7.7.2": + version: 7.17.9 + resolution: "@babel/traverse@npm:7.17.9" dependencies: "@babel/code-frame": ^7.16.7 - "@babel/generator": ^7.17.3 + "@babel/generator": ^7.17.9 "@babel/helper-environment-visitor": ^7.16.7 - "@babel/helper-function-name": ^7.16.7 + "@babel/helper-function-name": ^7.17.9 "@babel/helper-hoist-variables": ^7.16.7 "@babel/helper-split-export-declaration": ^7.16.7 - "@babel/parser": ^7.17.3 + "@babel/parser": ^7.17.9 "@babel/types": ^7.17.0 debug: ^4.1.0 globals: ^11.1.0 - checksum: 780d7ecf711758174989794891af08d378f81febdb8932056c0d9979524bf0298e28f8e7708a872d7781151506c28f56c85c63ea3f1f654662c2fcb8a3eb9fdc + checksum: d907c71d1617589cc0cddc9837cb27bcb9b8f2117c379e13e72653745abe01da24e8c072bd0c91b9db33323ddb1086722756fbc50b487b2608733baf9dd6fd2c languageName: node linkType: hard @@ -1865,13 +1856,14 @@ __metadata: linkType: hard "@crowdin/cli@npm:^3.5.2": - version: 3.7.7 - resolution: "@crowdin/cli@npm:3.7.7" + version: 3.7.8 + resolution: "@crowdin/cli@npm:3.7.8" dependencies: + njre: ^0.2.0 shelljs: ^0.8.4 bin: crowdin: jdeploy-bundle/jdeploy.js - checksum: 8e47e0abe2483ccd471e55cf1a193d79ffc1f1359157956740c5ed4e124b8784d91e73482bbbf78da1a8689769232f951f98622f24f4f35bd6933452338a8770 + checksum: 4898403bc034d5058197f0e975a924aaa9c871ca77012add7a2819c597a81a0f9b89d365bab01b651bf978e775809b91eac5d161edc01e77fc08c8bd6efd89d2 languageName: node linkType: hard @@ -2434,20 +2426,20 @@ __metadata: languageName: node linkType: hard -"@eslint/eslintrc@npm:^1.1.0": - version: 1.1.0 - resolution: "@eslint/eslintrc@npm:1.1.0" +"@eslint/eslintrc@npm:^1.2.1": + version: 1.2.1 + resolution: "@eslint/eslintrc@npm:1.2.1" dependencies: ajv: ^6.12.4 debug: ^4.3.2 espree: ^9.3.1 globals: ^13.9.0 - ignore: ^4.0.6 + ignore: ^5.2.0 import-fresh: ^3.2.1 js-yaml: ^4.1.0 minimatch: ^3.0.4 strip-json-comments: ^3.1.1 - checksum: 784aa2157e2808b52bbbaf1d1cfca9a6ba0b2faaa3696eb7a1229d4b357400fbd8a6aa09a16e7ae0868ea075d3a8f365cf5928b6d05a1df47f40a1167423a4fa + checksum: 1f797b9f94d71b965992cf6c44e3bcb574643014fd1e3d4862d25056bd5568f59c488461a7e9a1c1758ca7f0def5d3cb69c3d8b38581bcf4a53af74371243797 languageName: node linkType: hard @@ -2475,13 +2467,13 @@ __metadata: linkType: hard "@humanwhocodes/config-array@npm:^0.9.2": - version: 0.9.3 - resolution: "@humanwhocodes/config-array@npm:0.9.3" + version: 0.9.5 + resolution: "@humanwhocodes/config-array@npm:0.9.5" dependencies: "@humanwhocodes/object-schema": ^1.2.1 debug: ^4.1.1 minimatch: ^3.0.4 - checksum: 6e5d7d274941c459bab0a14a87e372206d89fad3e4879d982edc942e8cc34da6510ea3644b8535a2a9edaa6527e91dccceabc6837ffa8ee506d66bca5d269ebc + checksum: 8ba6281bc0590f6c6eadeefc14244b5a3e3f5903445aadd1a32099ed80e753037674026ce1b3c945ab93561bea5eb29e3c5bff67060e230c295595ba517a3492 languageName: node linkType: hard @@ -2565,7 +2557,7 @@ __metadata: "@types/rimraf": ^3.0.0 ansi-escapes: ^4.2.1 chalk: ^4.0.0 - emittery: ^0.8.1 + emittery: ^0.10.2 exit: ^0.1.2 graceful-fs: ^4.2.9 jest-changed-files: ^28.0.0-alpha.3 @@ -2920,7 +2912,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/types@npm:^26.6.1, @jest/types@npm:^26.6.2": +"@jest/types@npm:^26.6.2": version: 26.6.2 resolution: "@jest/types@npm:26.6.2" dependencies: @@ -2970,6 +2962,13 @@ __metadata: languageName: node linkType: hard +"@leichtgewicht/ip-codec@npm:^2.0.1": + version: 2.0.3 + resolution: "@leichtgewicht/ip-codec@npm:2.0.3" + checksum: 5b6bee0481c82ac05c748322e34ac68aa01757451b4f49f1ab9cc91e420a1ea4cd0fc4678251e6fa41d566a3e3683cca3e179fb767c87845286863ac98b54f15 + languageName: node + linkType: hard + "@lerna/add@npm:4.0.0": version: 4.0.0 resolution: "@lerna/add@npm:4.0.0" @@ -3802,27 +3801,27 @@ __metadata: languageName: node linkType: hard -"@microsoft/api-extractor-model@npm:7.15.3": - version: 7.15.3 - resolution: "@microsoft/api-extractor-model@npm:7.15.3" +"@microsoft/api-extractor-model@npm:7.16.0": + version: 7.16.0 + resolution: "@microsoft/api-extractor-model@npm:7.16.0" dependencies: "@microsoft/tsdoc": 0.13.2 "@microsoft/tsdoc-config": ~0.15.2 - "@rushstack/node-core-library": 3.45.0 - checksum: dfa706b1b2acac93c68afe0c7e119e45a95ab40e75b0d70fdb687ce263e22fd1a491a4f4ee1151d0ef059dfb35daef909b27f3608c67f542666623af6e953127 + "@rushstack/node-core-library": 3.45.1 + checksum: ba1bf057f5eed213aea45887a93c0cdabd0d7c9da2644aeb7460748fa33a01f04b91507923e7ea511452a7dfb849498089a2c3a844986ffc4c2abf8ab6d831a6 languageName: node linkType: hard "@microsoft/api-extractor@npm:^7.19.4": - version: 7.19.4 - resolution: "@microsoft/api-extractor@npm:7.19.4" + version: 7.20.1 + resolution: "@microsoft/api-extractor@npm:7.20.1" dependencies: - "@microsoft/api-extractor-model": 7.15.3 + "@microsoft/api-extractor-model": 7.16.0 "@microsoft/tsdoc": 0.13.2 "@microsoft/tsdoc-config": ~0.15.2 - "@rushstack/node-core-library": 3.45.0 - "@rushstack/rig-package": 0.3.7 - "@rushstack/ts-command-line": 4.10.6 + "@rushstack/node-core-library": 3.45.1 + "@rushstack/rig-package": 0.3.8 + "@rushstack/ts-command-line": 4.10.7 colors: ~1.2.1 lodash: ~4.17.15 resolve: ~1.17.0 @@ -3831,7 +3830,7 @@ __metadata: typescript: ~4.5.2 bin: api-extractor: bin/api-extractor - checksum: 15d1749e02053a7d70b43b87067b31055995bbe80acc888016612b8d61b6788e9f2619774982f7271c9c5271b512d1340fea609e4b001ab9e2347411d3c63fa2 + checksum: c9fb01e3803b35f8ca2471fe67015bb74d4a997f4409737f5b3fc52ea633d8379689e4685f6502d81245649e5531cadd9bb37c50cc71068488ff0e67dea4af67 languageName: node linkType: hard @@ -3974,17 +3973,17 @@ __metadata: linkType: hard "@octokit/core@npm:^3.5.1": - version: 3.5.1 - resolution: "@octokit/core@npm:3.5.1" + version: 3.6.0 + resolution: "@octokit/core@npm:3.6.0" dependencies: "@octokit/auth-token": ^2.4.4 "@octokit/graphql": ^4.5.8 - "@octokit/request": ^5.6.0 + "@octokit/request": ^5.6.3 "@octokit/request-error": ^2.0.5 "@octokit/types": ^6.0.3 before-after-hook: ^2.2.0 universal-user-agent: ^6.0.0 - checksum: 67179739fc9712b201f2400f132287a2c56a18506e00900bc9d2a3f742b74f1ba69ad998e42f28f3964c0bd1d5478232c1ec7b485c97702b821fbe22b76afa90 + checksum: f81160129037bd8555d47db60cd5381637b7e3602ad70735a7bdf8f3d250c7b7114a666bb12ef7a8746a326a5d72ed30a1b8f8a5a170007f7285c8e217bef1f0 languageName: node linkType: hard @@ -4067,7 +4066,7 @@ __metadata: languageName: node linkType: hard -"@octokit/request@npm:^5.6.0": +"@octokit/request@npm:^5.6.0, @octokit/request@npm:^5.6.3": version: 5.6.3 resolution: "@octokit/request@npm:5.6.3" dependencies: @@ -4383,9 +4382,9 @@ __metadata: languageName: node linkType: hard -"@rushstack/node-core-library@npm:3.45.0": - version: 3.45.0 - resolution: "@rushstack/node-core-library@npm:3.45.0" +"@rushstack/node-core-library@npm:3.45.1": + version: 3.45.1 + resolution: "@rushstack/node-core-library@npm:3.45.1" dependencies: "@types/node": 12.20.24 colors: ~1.2.1 @@ -4396,38 +4395,38 @@ __metadata: semver: ~7.3.0 timsort: ~0.3.0 z-schema: ~5.0.2 - checksum: 1dc9dd7a042b33d891d4174369f8a63e70c76a2a502ef0a2d49993639d9722ff34eb149da7f06cd16ad069aa0d6045df8df9be27ab38fdad0fbc0349787d08b3 + checksum: 2001e1acda14e75dc3cc4aa988c2ec9609c2ed7a59ef27a5b97ce9a0380c534ad9eb96074821a52e52e34c06cc1f4a011c15f6e5d17bbf830430e739c6d185ce languageName: node linkType: hard -"@rushstack/rig-package@npm:0.3.7": - version: 0.3.7 - resolution: "@rushstack/rig-package@npm:0.3.7" +"@rushstack/rig-package@npm:0.3.8": + version: 0.3.8 + resolution: "@rushstack/rig-package@npm:0.3.8" dependencies: resolve: ~1.17.0 strip-json-comments: ~3.1.1 - checksum: 3dceb4dbed159a9c54f97d91a38a4f0ec3219d9e33c3f3cad903a56bc20385849749b460168687334611d3af7bf210da05d794af97c665dfbf5b95aba56dd3cc + checksum: 375788eae1c18fa4807bbe96541ebddc65bcc44113f186fae2cfbf0b355deb376e20fa8a014f40a6babdcde86d446234dcbaf5d3df4fdca5bf196ec5d4c41f0b languageName: node linkType: hard -"@rushstack/ts-command-line@npm:4.10.6": - version: 4.10.6 - resolution: "@rushstack/ts-command-line@npm:4.10.6" +"@rushstack/ts-command-line@npm:4.10.7": + version: 4.10.7 + resolution: "@rushstack/ts-command-line@npm:4.10.7" dependencies: "@types/argparse": 1.0.38 argparse: ~1.0.9 colors: ~1.2.1 string-argv: ~0.3.1 - checksum: a618104fa5076fa1d67163638d6741784dc298fc4768a126c9d0cc17801baca903ed712b42cd3f530ca25402d219bdfa1c880ed0e82d3b0a419c1cbd02589d9b + checksum: 0c57867e5ea14b9296db403c2979995fe4bdeae3787331fc2d8faa18ee612b5fbcf989afcf5e30bc7f01cfe62003d451b29fc65fdda0790b95f3aacd72d41918 languageName: node linkType: hard "@sideway/address@npm:^4.1.3": - version: 4.1.3 - resolution: "@sideway/address@npm:4.1.3" + version: 4.1.4 + resolution: "@sideway/address@npm:4.1.4" dependencies: "@hapi/hoek": ^9.0.0 - checksum: 3c1faf6ef37a0b59b62ce42b59c012c00ef1fc4194ad6776c65c2f9a6dd6c1710c6f6362b3ca3fa582fdb93984f0cb64ca44f9f5e02940634805f5e561279c22 + checksum: b9fca2a93ac2c975ba12e0a6d97853832fb1f4fb02393015e012b47fa916a75ca95102d77214b2a29a2784740df2407951af8c5dde054824c65577fd293c4cdb languageName: node linkType: hard @@ -4446,9 +4445,9 @@ __metadata: linkType: hard "@sinclair/typebox@npm:^0.23.3": - version: 0.23.3 - resolution: "@sinclair/typebox@npm:0.23.3" - checksum: c8d961c8af1b701e67641770376010634730076f0412dda34b01f1d6f54d98916414335b51929285ade43ab85bb14a372bbc287575ce4b1e0179d8af808ec4d7 + version: 0.23.4 + resolution: "@sinclair/typebox@npm:0.23.4" + checksum: 98af5b70bf23a36061886966038058c22238d68bcd1bb2528b4470506f8a08ec5190f5f4190de17ce5fa54ebcaf7e150efbe96db6acab2696911391e4358ab39 languageName: node linkType: hard @@ -4665,8 +4664,8 @@ __metadata: linkType: hard "@testing-library/dom@npm:^8.0.0": - version: 8.11.3 - resolution: "@testing-library/dom@npm:8.11.3" + version: 8.13.0 + resolution: "@testing-library/dom@npm:8.13.0" dependencies: "@babel/code-frame": ^7.10.4 "@babel/runtime": ^7.12.5 @@ -4676,7 +4675,7 @@ __metadata: dom-accessibility-api: ^0.5.9 lz-string: ^1.4.4 pretty-format: ^27.0.2 - checksum: 2245d254b6058590e25de86fb7b3c75e4a31096901a191f80d3efb9fa7e1e273043416f370c8770feb9f3ccc73a1550a877a3b003b593f1728ae828fcb52cd62 + checksum: 880f1872b9949800d4444e3bdbd03df86d6f41ec7c27136dff1da29e87d2df2d7ee904afcdf895ffce351c25bd12119117eae023354d50e707ad56d43b2ed3ed languageName: node linkType: hard @@ -4744,12 +4743,12 @@ __metadata: linkType: hard "@tsd/typescript@npm:~4.6.2": - version: 4.6.2 - resolution: "@tsd/typescript@npm:4.6.2" + version: 4.6.3 + resolution: "@tsd/typescript@npm:4.6.3" bin: tsc: typescript/bin/tsc tsserver: typescript/bin/tsserver - checksum: f464054292c903c402a2c885a4ada5f9bb5ba7cf3234bb797d9c77bd4be2682e59f747fddfb858b2ee4f39f32f565cb3a41b75ca959bf8bfd9438895e46c6497 + checksum: 8a8d570bd4cd392c8bf33bd5a9516a4bc06964d5e98754a346f2dfd051a7c8a44d33d1f449e17a696a7d6b5f81ceb36e8a7b473d9aee077bd7138f0ed252a7f6 languageName: node linkType: hard @@ -4792,15 +4791,15 @@ __metadata: linkType: hard "@types/babel__core@npm:*, @types/babel__core@npm:^7.0.0, @types/babel__core@npm:^7.1.0, @types/babel__core@npm:^7.1.14": - version: 7.1.18 - resolution: "@types/babel__core@npm:7.1.18" + version: 7.1.19 + resolution: "@types/babel__core@npm:7.1.19" dependencies: "@babel/parser": ^7.1.0 "@babel/types": ^7.0.0 "@types/babel__generator": "*" "@types/babel__template": "*" "@types/babel__traverse": "*" - checksum: 2e5b5d7c84f347d3789575486e58b0df5c91613abc3d27e716274aba3048518e07e1f068250ba829e2ed58532ccc88da595ce95ba2688e7bbcd7c25a3c6627ed + checksum: 8c9fa87a1c2224cbec251683a58bebb0d74c497118034166aaa0491a4e2627998a6621fc71f8a60ffd27d9c0c52097defedf7637adc6618d0331c15adb302338 languageName: node linkType: hard @@ -5284,9 +5283,9 @@ __metadata: linkType: hard "@types/prop-types@npm:*, @types/prop-types@npm:^15.0.0": - version: 15.7.4 - resolution: "@types/prop-types@npm:15.7.4" - checksum: ef6e1899e59b876c273811b1bd845022fc66d5a3d11cb38a25b6c566b30514ae38fe20a40f67622f362a4f4f7f9224e22d8da101cff3d6e97e11d7b4c307cfc1 + version: 15.7.5 + resolution: "@types/prop-types@npm:15.7.5" + checksum: 5b43b8b15415e1f298243165f1d44390403bb2bd42e662bca3b5b5633fdd39c938e91b7fce3a9483699db0f7a715d08cef220c121f723a634972fdf596aec980 languageName: node linkType: hard @@ -5305,11 +5304,11 @@ __metadata: linkType: hard "@types/react-dom@npm:*": - version: 17.0.11 - resolution: "@types/react-dom@npm:17.0.11" + version: 17.0.15 + resolution: "@types/react-dom@npm:17.0.15" dependencies: - "@types/react": "*" - checksum: 4d5730dffbef86c887cecad7e3cecda424ce6a64d0b5441c63b5b015d48219868660a2bb1aa15e897e565ad8867fa6b885d4358b04e1c4e589ba4c07c3fda55c + "@types/react": ^17 + checksum: 7b90372bd7207d3860e1043ebfe10fd21fbd9ec3417a29593ca14359774830c888ba4ebb25cf0510628607496f8d35b09d23d329ea709b9311f5866185c5fd67 languageName: node linkType: hard @@ -5363,14 +5362,14 @@ __metadata: languageName: node linkType: hard -"@types/react@npm:*, @types/react@npm:^17.0.3": - version: 17.0.43 - resolution: "@types/react@npm:17.0.43" +"@types/react@npm:*, @types/react@npm:^17, @types/react@npm:^17.0.3": + version: 17.0.44 + resolution: "@types/react@npm:17.0.44" dependencies: "@types/prop-types": "*" "@types/scheduler": "*" csstype: ^3.0.2 - checksum: 981b0993f5b3ea9d3488b8cc883201e8ae47ba7732929f788f450a79fd72829e658080d5084e67caa008e58d989b0abc1d5f36ff0a1cda09315ea3a3c0c9dc11 + checksum: ebee02778ca08f954c316dc907802264e0121c87b8fa2e7e0156ab0ef2a1b0a09d968c016a3600ec4c9a17dc09b4274f292d9b15a1a5369bb7e4072def82808f languageName: node linkType: hard @@ -5567,7 +5566,7 @@ __metadata: languageName: node linkType: hard -"@types/ws@npm:^8.2.2": +"@types/ws@npm:^8.5.1": version: 8.5.3 resolution: "@types/ws@npm:8.5.3" dependencies: @@ -5577,9 +5576,9 @@ __metadata: linkType: hard "@types/yargs-parser@npm:*": - version: 20.2.1 - resolution: "@types/yargs-parser@npm:20.2.1" - checksum: 1d039e64494a7a61ddd278349a3dc60b19f99ff0517425696e796f794e4252452b9d62178e69755ad03f439f9dc0c8c3d7b3a1201b3a24e134bac1a09fa11eaa + version: 21.0.0 + resolution: "@types/yargs-parser@npm:21.0.0" + checksum: b2f4c8d12ac18a567440379909127cf2cec393daffb73f246d0a25df36ea983b93b7e9e824251f959e9f928cbc7c1aab6728d0a0ff15d6145f66cec2be67d9a2 languageName: node linkType: hard @@ -5602,21 +5601,21 @@ __metadata: linkType: hard "@types/yargs@npm:^17.0.8": - version: 17.0.8 - resolution: "@types/yargs@npm:17.0.8" + version: 17.0.10 + resolution: "@types/yargs@npm:17.0.10" dependencies: "@types/yargs-parser": "*" - checksum: 63d06700ffbed745f00d7994eb92416649c8a3ead22f26446979d383f3af52fa9400bb185268f3a44a2348749098ffe33a8185ca676b77bc3206c63b8b73fd01 + checksum: f0673cbfc08e17239dc58952a88350d6c4db04a027a28a06fbad27d87b670e909f9cd9e66f9c64cebdd5071d1096261e33454a55868395f125297e5c50992ca8 languageName: node linkType: hard "@typescript-eslint/eslint-plugin@npm:^5.14.0": - version: 5.14.0 - resolution: "@typescript-eslint/eslint-plugin@npm:5.14.0" + version: 5.18.0 + resolution: "@typescript-eslint/eslint-plugin@npm:5.18.0" dependencies: - "@typescript-eslint/scope-manager": 5.14.0 - "@typescript-eslint/type-utils": 5.14.0 - "@typescript-eslint/utils": 5.14.0 + "@typescript-eslint/scope-manager": 5.18.0 + "@typescript-eslint/type-utils": 5.18.0 + "@typescript-eslint/utils": 5.18.0 debug: ^4.3.2 functional-red-black-tree: ^1.0.1 ignore: ^5.1.8 @@ -5629,42 +5628,42 @@ __metadata: peerDependenciesMeta: typescript: optional: true - checksum: 7176b30ebc2144292b38404b28aadc7a32d24d454deb8000e0e2ae71a199b9cff7c67ed6ff723b93278091f19948fdd4ef44029aade3ee6ec6f340acc9104ec6 + checksum: e8f0e7cfa0d102b1006a0f674fbba6cfc3d5a609d3ebb07306d744d3db91080659cd2b9935ccbde2ad9bbbe9543bc47540df1ffada0e7676dd38957cdffd7436 languageName: node linkType: hard "@typescript-eslint/parser@npm:^5.14.0": - version: 5.14.0 - resolution: "@typescript-eslint/parser@npm:5.14.0" + version: 5.18.0 + resolution: "@typescript-eslint/parser@npm:5.18.0" dependencies: - "@typescript-eslint/scope-manager": 5.14.0 - "@typescript-eslint/types": 5.14.0 - "@typescript-eslint/typescript-estree": 5.14.0 + "@typescript-eslint/scope-manager": 5.18.0 + "@typescript-eslint/types": 5.18.0 + "@typescript-eslint/typescript-estree": 5.18.0 debug: ^4.3.2 peerDependencies: eslint: ^6.0.0 || ^7.0.0 || ^8.0.0 peerDependenciesMeta: typescript: optional: true - checksum: 2ee433b070d4b46fe2c2e11596fa92f39e60459a75d0e3fafe4f7d2e2f9772847208ce208190a3af0ec6490cb46a517523ac92a82a17fe289cc03ed7e512638a + checksum: 8e007a4980eb8794621bf51404b6ecc923eeffc661d7da2fac9d5c79f6ea70735322953dd88ee4a9b06d916f43e4cc633d724a5cf70c0a10a8cd251d54e67ff4 languageName: node linkType: hard -"@typescript-eslint/scope-manager@npm:5.14.0": - version: 5.14.0 - resolution: "@typescript-eslint/scope-manager@npm:5.14.0" +"@typescript-eslint/scope-manager@npm:5.18.0": + version: 5.18.0 + resolution: "@typescript-eslint/scope-manager@npm:5.18.0" dependencies: - "@typescript-eslint/types": 5.14.0 - "@typescript-eslint/visitor-keys": 5.14.0 - checksum: 20f163877218fc1c880e014ef2f858f7f8280a5d9dfc09dce092df9b72f6c5ebf490ede8b8dcf51e55f4d62a248eb5ccd468d37756731f27c8695c2f199f2638 + "@typescript-eslint/types": 5.18.0 + "@typescript-eslint/visitor-keys": 5.18.0 + checksum: c82625ec8293afea6e3df035612e7a7ccf3b23476a9b20bf7eb1190a52bca1886a3ea479d6b6b92eaac77dbbb2a23112b03e97f894aac39c45f7442672338cb6 languageName: node linkType: hard -"@typescript-eslint/type-utils@npm:5.14.0": - version: 5.14.0 - resolution: "@typescript-eslint/type-utils@npm:5.14.0" +"@typescript-eslint/type-utils@npm:5.18.0": + version: 5.18.0 + resolution: "@typescript-eslint/type-utils@npm:5.18.0" dependencies: - "@typescript-eslint/utils": 5.14.0 + "@typescript-eslint/utils": 5.18.0 debug: ^4.3.2 tsutils: ^3.21.0 peerDependencies: @@ -5672,23 +5671,23 @@ __metadata: peerDependenciesMeta: typescript: optional: true - checksum: b5b71f397a87769558473b9283e65f92a1153d4de93cb9e5bf559ca6f7d8a898b4b565141bd2455c9fb6c2266aa5e39465a0337a7484a09a7fdf4bfbf191c7cf + checksum: a9722e18635d98ed7b468b1915d4bc9ef3de6dd85bfe734d932465977f9952655171cb5c886c7d42145ebb8ef1b5b7fcf50e9937a9370080246a7bae4cbd1047 languageName: node linkType: hard -"@typescript-eslint/types@npm:5.14.0": - version: 5.14.0 - resolution: "@typescript-eslint/types@npm:5.14.0" - checksum: 1113c0c785a449970c52459dd1c779a80ae7b34b0bae923eace43a5d27279ee47092703d2a6a120c4ee7a78f0157ce8d6e53f951696d7b6197e121aac08ccc07 +"@typescript-eslint/types@npm:5.18.0": + version: 5.18.0 + resolution: "@typescript-eslint/types@npm:5.18.0" + checksum: 25d8d6f2f70ac4e93f4759a4927290749f528bce2150a87cde08200d706a6147880ca2ceeb8c93e0f370aace096c878096cd45427a59538877ac2121df8aaa01 languageName: node linkType: hard -"@typescript-eslint/typescript-estree@npm:5.14.0": - version: 5.14.0 - resolution: "@typescript-eslint/typescript-estree@npm:5.14.0" +"@typescript-eslint/typescript-estree@npm:5.18.0": + version: 5.18.0 + resolution: "@typescript-eslint/typescript-estree@npm:5.18.0" dependencies: - "@typescript-eslint/types": 5.14.0 - "@typescript-eslint/visitor-keys": 5.14.0 + "@typescript-eslint/types": 5.18.0 + "@typescript-eslint/visitor-keys": 5.18.0 debug: ^4.3.2 globby: ^11.0.4 is-glob: ^4.0.3 @@ -5697,33 +5696,33 @@ __metadata: peerDependenciesMeta: typescript: optional: true - checksum: 41816c4cb37538a8206c1c590e9d0d0c30eca8a972001a102bf43002b8b6e53ec1ce451a156ce037ea978d34b297c5f677de7fe7baecd355687629e177dc6809 + checksum: 2fc564062180a0623966061ecd0c9ecf4dfaa2350cc9b7584444cdc71afa615c2bafe75f7ea684289e38b4fd73d33766f4a99f2c1999321ba3826ad7ccbf4ea9 languageName: node linkType: hard -"@typescript-eslint/utils@npm:5.14.0, @typescript-eslint/utils@npm:^5.10.0": - version: 5.14.0 - resolution: "@typescript-eslint/utils@npm:5.14.0" +"@typescript-eslint/utils@npm:5.18.0, @typescript-eslint/utils@npm:^5.10.0": + version: 5.18.0 + resolution: "@typescript-eslint/utils@npm:5.18.0" dependencies: "@types/json-schema": ^7.0.9 - "@typescript-eslint/scope-manager": 5.14.0 - "@typescript-eslint/types": 5.14.0 - "@typescript-eslint/typescript-estree": 5.14.0 + "@typescript-eslint/scope-manager": 5.18.0 + "@typescript-eslint/types": 5.18.0 + "@typescript-eslint/typescript-estree": 5.18.0 eslint-scope: ^5.1.1 eslint-utils: ^3.0.0 peerDependencies: eslint: ^6.0.0 || ^7.0.0 || ^8.0.0 - checksum: c44b415e61e83f89ae7314f30e9783d813b19cd65b40993cb6dc28696f42ba3e4fa2bb31006ec67fe5414e37a02386616c87aa35e5ff8659e65a06fb3e83c95d + checksum: f0b03a7fe557ce97480b3824043900e563c173d46a759c8272d92ecaf32ff96e98212df76dbd2d20dc91ce512e6219bb69c9036896b8d7e22eec22366f80381b languageName: node linkType: hard -"@typescript-eslint/visitor-keys@npm:5.14.0": - version: 5.14.0 - resolution: "@typescript-eslint/visitor-keys@npm:5.14.0" +"@typescript-eslint/visitor-keys@npm:5.18.0": + version: 5.18.0 + resolution: "@typescript-eslint/visitor-keys@npm:5.18.0" dependencies: - "@typescript-eslint/types": 5.14.0 + "@typescript-eslint/types": 5.18.0 eslint-visitor-keys: ^3.0.0 - checksum: 3fc6038b330602b0dd2ff4070b11057a19239caa6f5bd956ee75d66f37f1b936704a98c4b1eae5da19a34d72b836a93e675080608138e50eabf72c2c901f648e + checksum: c856e3cf2fde3008e1d9bea3c73bc60d9060c7cb6d6ea186c20db9d74eff84986365f518dd1b4e142dca179e9a5cd7a6ed4381173d6abfd0ebd4d16d5cf50b94 languageName: node linkType: hard @@ -6028,13 +6027,13 @@ __metadata: linkType: hard "agentkeepalive@npm:^4.1.3": - version: 4.2.0 - resolution: "agentkeepalive@npm:4.2.0" + version: 4.2.1 + resolution: "agentkeepalive@npm:4.2.1" dependencies: debug: ^4.1.0 depd: ^1.1.2 humanize-ms: ^1.2.1 - checksum: 89806f83ceebbcaabf6bd581a8dce4870910fd2a11f66df8f505b4cd4ce4ca5ab9e6eec8d11ce8531a6b60f6748b75b0775e0e2fa33871503ef00d535418a19a + checksum: 39cb49ed8cf217fd6da058a92828a0a84e0b74c35550f82ee0a10e1ee403c4b78ade7948be2279b188b7a7303f5d396ea2738b134731e464bf28de00a4f72a18 languageName: node linkType: hard @@ -6126,13 +6125,13 @@ __metadata: linkType: hard "algoliasearch-helper@npm:^3.7.4": - version: 3.7.4 - resolution: "algoliasearch-helper@npm:3.7.4" + version: 3.8.1 + resolution: "algoliasearch-helper@npm:3.8.1" dependencies: "@algolia/events": ^4.0.1 peerDependencies: algoliasearch: ">= 3.1 < 5" - checksum: ac6e19a778e439f0f0c86938da32e2a4d442792067e3706770b85a4f845473c9035ac2e108444368a34bd59234357fb29186d74c96c697806bd63015b0fe5d47 + checksum: e576265365ea9949205f803c8e8527b06e1970b1965ae23f85c34360f64d90dc3ae36463c9dd13945037a8e661baa212cae15b559bf4b7dc35da533634b28ff6 languageName: node linkType: hard @@ -6420,7 +6419,7 @@ __metadata: languageName: node linkType: hard -"array-flatten@npm:^2.1.0": +"array-flatten@npm:^2.1.2": version: 2.1.2 resolution: "array-flatten@npm:2.1.2" checksum: e8988aac1fbfcdaae343d08c9a06a6fddd2c6141721eeeea45c3cf523bf4431d29a46602929455ed548c7a3e0769928cdc630405427297e7081bd118fdec9262 @@ -7069,17 +7068,15 @@ __metadata: languageName: node linkType: hard -"bonjour@npm:^3.5.0": - version: 3.5.0 - resolution: "bonjour@npm:3.5.0" +"bonjour-service@npm:^1.0.11": + version: 1.0.11 + resolution: "bonjour-service@npm:1.0.11" dependencies: - array-flatten: ^2.1.0 - deep-equal: ^1.0.1 + array-flatten: ^2.1.2 dns-equal: ^1.0.0 - dns-txt: ^2.0.2 - multicast-dns: ^6.0.1 - multicast-dns-service-types: ^1.1.0 - checksum: 2cfbe9fa861f4507b5ff3853eeae3ef03a231ede2b7363efedd80880ea3c0576f64416f98056c96e429ed68ff38dc4a70c0583d1eb4dab72e491ca44a0f03444 + fast-deep-equal: ^3.1.3 + multicast-dns: ^7.2.4 + checksum: b6093a856de9bc303551f1639945318e93782d3c40f03e38def3e2f079f478afd5385cf46538ade86f07205ac4b5f059105832b01eb9ce142fc69d27c006982f languageName: node linkType: hard @@ -7208,12 +7205,12 @@ __metadata: languageName: node linkType: hard -"bson@npm:^4.6.1": - version: 4.6.1 - resolution: "bson@npm:4.6.1" +"bson@npm:^4.6.2": + version: 4.6.2 + resolution: "bson@npm:4.6.2" dependencies: buffer: ^5.6.0 - checksum: 32c38400b0c5f85cf22c28b9f9bbc63b3c090c23a749a8c159db975f225161a7fe776f8a18ed1da3f58a9e7496ce2b7935753e9471f17c614bf02ebab145e052 + checksum: f4072d059ad9a46dd92451da5efb278d98f7b23fe6de0ee8dd1f9f05e005189156509b11deeba655befdf9434cffd283bfc35bcf75d2123c1fdf9b723ce8a98d languageName: node linkType: hard @@ -7231,13 +7228,6 @@ __metadata: languageName: node linkType: hard -"buffer-indexof@npm:^1.0.0": - version: 1.1.1 - resolution: "buffer-indexof@npm:1.1.1" - checksum: 0967abc2981a8e7d776324c6b84811e4d84a7ead89b54a3bb8791437f0c4751afd060406b06db90a436f1cf771867331b5ecf5c4aca95b4ccb9f6cb146c22ebc - languageName: node - linkType: hard - "buffer@npm:^5.5.0, buffer@npm:^5.6.0": version: 5.7.1 resolution: "buffer@npm:5.7.1" @@ -7445,9 +7435,9 @@ __metadata: linkType: hard "caniuse-lite@npm:^1.0.0, caniuse-lite@npm:^1.0.30001317": - version: 1.0.30001320 - resolution: "caniuse-lite@npm:1.0.30001320" - checksum: d1f52e9d8e2316f2dba4c7adb4c5957e535b07a4a90ac5432bef3a83b4dab487f0efaa6eff3cda75a52bf044d09886ec583299595389fe0a92cf135f4f07692e + version: 1.0.30001327 + resolution: "caniuse-lite@npm:1.0.30001327" + checksum: 789076fb889bd03515c4a3e2bfa09cd5b28439645173445147eb6ddfd8105c755e46dfda3de4b75edd2b71490864188bbfe8a2efe920c7998960b4e98916f518 languageName: node linkType: hard @@ -7543,15 +7533,15 @@ __metadata: linkType: hard "cheerio-select@npm:^1.5.0": - version: 1.5.0 - resolution: "cheerio-select@npm:1.5.0" + version: 1.6.0 + resolution: "cheerio-select@npm:1.6.0" dependencies: - css-select: ^4.1.3 - css-what: ^5.0.1 + css-select: ^4.3.0 + css-what: ^6.0.1 domelementtype: ^2.2.0 - domhandler: ^4.2.0 - domutils: ^2.7.0 - checksum: d4506d8b9ad330a18f9de3a5a22138d0804063e92aac2fc020384cc52ab86d2194d2ae614fc87f0e2a62b6a6dd0c28ad23669cec64331172a9f99ad604863010 + domhandler: ^4.3.1 + domutils: ^2.8.0 + checksum: c64cccea5ba3af091cf876d07a8bbf81fbd616c821495d194b73829f026777a8edd17a0f760ddd5be4a213c4411c60b03d2b1f8da4a77a46c81ed596a9860b20 languageName: node linkType: hard @@ -7668,11 +7658,11 @@ __metadata: linkType: hard "clean-css@npm:^5.2.2, clean-css@npm:^5.2.4": - version: 5.2.4 - resolution: "clean-css@npm:5.2.4" + version: 5.3.0 + resolution: "clean-css@npm:5.3.0" dependencies: source-map: ~0.6.0 - checksum: 16f4e9de6368c7fdacee3c62f6a3bf96488620e0d5a9ad7c943c2acf8f194ea96d3b98d3cf5dbdb3fad1fdc713baa99d146722b5a48d0ba9f4ad3a7fe702d883 + checksum: 29e15ef4678e1eb571546128cb7a922c5301c1bd12ee30a6e8141c72789b8130739a9a5b335435a6ee108400336a561ebd9faabe1a7d8808eb48d39cff390cd7 languageName: node linkType: hard @@ -7877,7 +7867,7 @@ __metadata: languageName: node linkType: hard -"color-support@npm:^1.1.2": +"color-support@npm:^1.1.3": version: 1.1.3 resolution: "color-support@npm:1.1.3" bin: @@ -7961,6 +7951,13 @@ __metadata: languageName: node linkType: hard +"command-exists-promise@npm:^2.0.2": + version: 2.0.2 + resolution: "command-exists-promise@npm:2.0.2" + checksum: f6674abbc7d9cc704255999adb42e8b8fe165d941de207d1df8177e1ccea2afb9ff57aad7a70f9235056dd317e45b31f9726ecb2c39826f9a1f98a50f4de1b31 + languageName: node + linkType: hard + "command-exists@npm:^1.2.8": version: 1.2.9 resolution: "command-exists@npm:1.2.9" @@ -8459,14 +8456,12 @@ __metadata: languageName: node linkType: hard -"css-declaration-sorter@npm:^6.0.3": - version: 6.1.4 - resolution: "css-declaration-sorter@npm:6.1.4" - dependencies: - timsort: ^0.3.0 +"css-declaration-sorter@npm:^6.2.2": + version: 6.2.2 + resolution: "css-declaration-sorter@npm:6.2.2" peerDependencies: postcss: ^8.0.9 - checksum: 72800a234f0d4facf44a5b504170749b854cd3bd6bf16d0955b3e70a1b613cec0192f585a81e8db1f03c035b13ca9494698a7eaaf861150db51c2f8f643e8ffb + checksum: afd3aea1b763b7abb5a9d0e10e973e99520b528522be421d9ef13d4fa7ead2cd48acd85d48c0fd0e954f596da2181dafbafc176a080ab017ebd1909a8231c9b4 languageName: node linkType: hard @@ -8513,16 +8508,16 @@ __metadata: languageName: node linkType: hard -"css-select@npm:^4.1.3": - version: 4.2.1 - resolution: "css-select@npm:4.2.1" +"css-select@npm:^4.1.3, css-select@npm:^4.3.0": + version: 4.3.0 + resolution: "css-select@npm:4.3.0" dependencies: boolbase: ^1.0.0 - css-what: ^5.1.0 - domhandler: ^4.3.0 + css-what: ^6.0.1 + domhandler: ^4.3.1 domutils: ^2.8.0 nth-check: ^2.0.1 - checksum: 6617193ec7c332217204c4ea371d332c6845603fda415e36032e7e9e18206d7c368a14e3c57532082314d2689955b01122aa1097c1c52b6c1cab7ad90970d3c6 + checksum: d6202736839194dd7f910320032e7cfc40372f025e4bf21ca5bf6eb0a33264f322f50ba9c0adc35dadd342d3d6fae5ca244779a4873afbfa76561e343f2058e0 languageName: node linkType: hard @@ -8555,10 +8550,10 @@ __metadata: languageName: node linkType: hard -"css-what@npm:^5.0.1, css-what@npm:^5.1.0": - version: 5.1.0 - resolution: "css-what@npm:5.1.0" - checksum: 0b75d1bac95c885c168573c85744a6c6843d8c33345f54f717218b37ea6296b0e99bb12105930ea170fd4a921990392a7c790c16c585c1d8960c49e2b7ec39f7 +"css-what@npm:^6.0.1": + version: 6.1.0 + resolution: "css-what@npm:6.1.0" + checksum: b975e547e1e90b79625918f84e67db5d33d896e6de846c9b584094e529f0c63e2ab85ee33b9daffd05bff3a146a1916bec664e18bb76dd5f66cbff9fc13b2bbe languageName: node linkType: hard @@ -8572,26 +8567,26 @@ __metadata: linkType: hard "cssnano-preset-advanced@npm:^5.3.1": - version: 5.3.1 - resolution: "cssnano-preset-advanced@npm:5.3.1" + version: 5.3.3 + resolution: "cssnano-preset-advanced@npm:5.3.3" dependencies: autoprefixer: ^10.3.7 - cssnano-preset-default: ^5.2.5 + cssnano-preset-default: ^5.2.7 postcss-discard-unused: ^5.1.0 postcss-merge-idents: ^5.1.1 postcss-reduce-idents: ^5.2.0 postcss-zindex: ^5.1.0 peerDependencies: postcss: ^8.2.15 - checksum: 2594d725733b3fb6210dd1bcb39b9e9952be9c57a62aff040091ecfef93d66cdc68d2682babebe8cd5fbc5a5be0768bd3af15d0badadd31b59ac08aad6bf0193 + checksum: 01449ff538b55b772447fea5437e6be38245f5d19d985f36ee9e045753b944238f07c9f460351ecd7ee97901e807082aff78fba327b33ba18a8a3ba030dbddfc languageName: node linkType: hard -"cssnano-preset-default@npm:^5.2.5": - version: 5.2.5 - resolution: "cssnano-preset-default@npm:5.2.5" +"cssnano-preset-default@npm:^5.2.7": + version: 5.2.7 + resolution: "cssnano-preset-default@npm:5.2.7" dependencies: - css-declaration-sorter: ^6.0.3 + css-declaration-sorter: ^6.2.2 cssnano-utils: ^3.1.0 postcss-calc: ^8.2.3 postcss-colormin: ^5.3.0 @@ -8600,7 +8595,7 @@ __metadata: postcss-discard-duplicates: ^5.1.0 postcss-discard-empty: ^5.1.1 postcss-discard-overridden: ^5.1.0 - postcss-merge-longhand: ^5.1.3 + postcss-merge-longhand: ^5.1.4 postcss-merge-rules: ^5.1.1 postcss-minify-font-values: ^5.1.0 postcss-minify-gradients: ^5.1.1 @@ -8622,7 +8617,7 @@ __metadata: postcss-unique-selectors: ^5.1.1 peerDependencies: postcss: ^8.2.15 - checksum: cb743cf2c2a29edb019caeee7a3c9853fadafe54ebe66fb899665fb50d9fe2c79f918180cf39c218dda0195cf704e15bd3a8a5c2d639b2388cddf512d0795f6c + checksum: 1408ce86e29756a90dafcfff162ccfd983ab31fcfdb1549875bb4cca657b0c520424ea95f88b750ea06967d5a61201de207afe0a4c5514fac90d7265358b9d3a languageName: node linkType: hard @@ -8636,15 +8631,15 @@ __metadata: linkType: hard "cssnano@npm:^5.0.6, cssnano@npm:^5.1.5": - version: 5.1.5 - resolution: "cssnano@npm:5.1.5" + version: 5.1.7 + resolution: "cssnano@npm:5.1.7" dependencies: - cssnano-preset-default: ^5.2.5 + cssnano-preset-default: ^5.2.7 lilconfig: ^2.0.3 yaml: ^1.10.2 peerDependencies: postcss: ^8.2.15 - checksum: 7fec29799355f1ccefa370b249bb3b3fb498fb4c6ccd7c7a39e9c6af0632bfffd71b7c93baa19da67d04dcf56de71365b9f8bec9198daa29e8e5847a9f3ec881 + checksum: d69e7e0091b7e6e43f3d61e416a54afb7a55a2a065d96d859650fa34ab5e70b3162a340fb59a8714042762f8e388fbc3cb810d478d775bcd4695d0951b625000 languageName: node linkType: hard @@ -8681,9 +8676,9 @@ __metadata: linkType: hard "csstype@npm:^3.0.2": - version: 3.0.10 - resolution: "csstype@npm:3.0.10" - checksum: 20a8fa324f2b33ddf94aa7507d1b6ab3daa6f3cc308888dc50126585d7952f2471de69b2dbe0635d1fdc31223fef8e070842691877e725caf456e2378685a631 + version: 3.0.11 + resolution: "csstype@npm:3.0.11" + checksum: 95e56abfe9ca219ae065acb4e43f61771a03170eed919127f558dfa168240867aba7629c8d98a201a0dd06d9a5ce82686f0570031c928516c61816adbc7c877f languageName: node linkType: hard @@ -8737,15 +8732,15 @@ __metadata: languageName: node linkType: hard -"debug@npm:4, debug@npm:^4.0.0, debug@npm:^4.0.1, debug@npm:^4.1.0, debug@npm:^4.1.1, debug@npm:^4.3.1, debug@npm:^4.3.2, debug@npm:^4.3.3": - version: 4.3.3 - resolution: "debug@npm:4.3.3" +"debug@npm:4, debug@npm:^4.0.0, debug@npm:^4.0.1, debug@npm:^4.1.0, debug@npm:^4.1.1, debug@npm:^4.3.1, debug@npm:^4.3.2, debug@npm:^4.3.3, debug@npm:^4.3.4": + version: 4.3.4 + resolution: "debug@npm:4.3.4" dependencies: ms: 2.1.2 peerDependenciesMeta: supports-color: optional: true - checksum: 14472d56fe4a94dbcfaa6dbed2dd3849f1d72ba78104a1a328047bb564643ca49df0224c3a17fa63533fd11dd3d4c8636cd861191232a2c6735af00cc2d4de16 + checksum: 3dbad3f94ea64f34431a9cbf0bafb61853eda57bff2880036153438f50fb5a84f27683ba0d8e5426bf41a8c6ff03879488120cf5b3a761e77953169c0600a708 languageName: node linkType: hard @@ -8821,20 +8816,6 @@ __metadata: languageName: node linkType: hard -"deep-equal@npm:^1.0.1": - version: 1.1.1 - resolution: "deep-equal@npm:1.1.1" - dependencies: - is-arguments: ^1.0.4 - is-date-object: ^1.0.1 - is-regex: ^1.0.4 - object-is: ^1.0.1 - object-keys: ^1.1.1 - regexp.prototype.flags: ^1.2.0 - checksum: f92686f2c5bcdf714a75a5fa7a9e47cb374a8ec9307e717b8d1ce61f56a75aaebf5619c2a12b8087a705b5a2f60d0292c35f8b58cb1f72e3268a3a15cab9f78d - languageName: node - linkType: hard - "deep-extend@npm:^0.6.0": version: 0.6.0 resolution: "deep-extend@npm:0.6.0" @@ -9079,12 +9060,12 @@ __metadata: linkType: hard "dezalgo@npm:^1.0.0": - version: 1.0.3 - resolution: "dezalgo@npm:1.0.3" + version: 1.0.4 + resolution: "dezalgo@npm:1.0.4" dependencies: asap: ^2.0.0 wrappy: 1 - checksum: 8b26238db91423b2702a7a6d9629d0019c37c415e7b6e75d4b3e8d27e9464e21cac3618dd145f4d4ee96c70cc6ff034227b5b8a0e9c09015a8bdbe6dace3cfb9 + checksum: 895389c6aead740d2ab5da4d3466d20fa30f738010a4d3f4dcccc9fc645ca31c9d10b7e1804ae489b1eb02c7986f9f1f34ba132d409b043082a86d9a4e745624 languageName: node linkType: hard @@ -9142,22 +9123,12 @@ __metadata: languageName: node linkType: hard -"dns-packet@npm:^1.3.1": - version: 1.3.4 - resolution: "dns-packet@npm:1.3.4" - dependencies: - ip: ^1.1.0 - safe-buffer: ^5.0.1 - checksum: 7dd87f85cb4f9d1a99c03470730e3d9385e67dc94f6c13868c4034424a5378631e492f9f1fbc43d3c42f319fbbfe18b6488bb9527c32d34692c52bf1f5eedf69 - languageName: node - linkType: hard - -"dns-txt@npm:^2.0.2": - version: 2.0.2 - resolution: "dns-txt@npm:2.0.2" +"dns-packet@npm:^5.2.2": + version: 5.3.1 + resolution: "dns-packet@npm:5.3.1" dependencies: - buffer-indexof: ^1.0.0 - checksum: 80130b665379ecd991687ae079fbee25d091e03e4c4cef41e7643b977849ac48c2f56bfcb3727e53594d29029b833749811110d9f3fbee1b26a6e6f8096a5cef + "@leichtgewicht/ip-codec": ^2.0.1 + checksum: 196ff74a0669126cf5fc901a5849b72f625bd7a4cb163b3f4d41fbe19ed0b017cf7674daef5b0acbd448c094fcd795e501d7066f301be428e4acecfcf3c5f336 languageName: node linkType: hard @@ -9180,9 +9151,9 @@ __metadata: linkType: hard "dom-accessibility-api@npm:^0.5.9": - version: 0.5.11 - resolution: "dom-accessibility-api@npm:0.5.11" - checksum: 6928436f384e34f6c9279a887c7417fd0bf3c881b491f60a44b24eec37ce7318124f1440fcd4110b4cffc6dd0668548fde2837627eb76e3b75f840884c6bd7df + version: 0.5.13 + resolution: "dom-accessibility-api@npm:0.5.13" + checksum: a5a5f14c01e466d424750aaac9225f1dc43cf16d101a1c40e01a554abce63c48084707002c39b805f2ce212273c179dd6d2258175997cd06d5f79851bf52dd40 languageName: node linkType: hard @@ -9234,9 +9205,9 @@ __metadata: linkType: hard "domelementtype@npm:^2.0.1, domelementtype@npm:^2.2.0": - version: 2.2.0 - resolution: "domelementtype@npm:2.2.0" - checksum: 24cb386198640cd58aa36f8c987f2ea61859929106d06ffcc8f547e70cb2ed82a6dc56dcb8252b21fba1f1ea07df6e4356d60bfe57f77114ca1aed6828362629 + version: 2.3.0 + resolution: "domelementtype@npm:2.3.0" + checksum: ee837a318ff702622f383409d1f5b25dd1024b692ef64d3096ff702e26339f8e345820f29a68bcdcea8cfee3531776b3382651232fbeae95612d6f0a75efb4f6 languageName: node linkType: hard @@ -9258,12 +9229,12 @@ __metadata: languageName: node linkType: hard -"domhandler@npm:^4.0.0, domhandler@npm:^4.2.0, domhandler@npm:^4.3.0": - version: 4.3.0 - resolution: "domhandler@npm:4.3.0" +"domhandler@npm:^4.0.0, domhandler@npm:^4.2.0, domhandler@npm:^4.3.1": + version: 4.3.1 + resolution: "domhandler@npm:4.3.1" dependencies: domelementtype: ^2.2.0 - checksum: d2a2dbf40dd99abf936b65ad83c6b530afdb3605a87cad37a11b5d9220e68423ebef1b86c89e0f6d93ffaf315cc327cf1a988652e7a9a95cce539e3984f4c64d + checksum: 4c665ceed016e1911bf7d1dadc09dc888090b64dee7851cccd2fcf5442747ec39c647bb1cb8c8919f8bbdd0f0c625a6bafeeed4b2d656bbecdbae893f43ffaaa languageName: node linkType: hard @@ -9287,7 +9258,7 @@ __metadata: languageName: node linkType: hard -"domutils@npm:^2.5.2, domutils@npm:^2.7.0, domutils@npm:^2.8.0": +"domutils@npm:^2.5.2, domutils@npm:^2.8.0": version: 2.8.0 resolution: "domutils@npm:2.8.0" dependencies: @@ -9376,16 +9347,16 @@ __metadata: linkType: hard "electron-to-chromium@npm:^1.4.84": - version: 1.4.93 - resolution: "electron-to-chromium@npm:1.4.93" - checksum: 997411da3a4dba3e7f38f5eff98f099a44d76088293982e452e886af8c5717ddbd6c9677e0e0840e51610004decb170c6a529424ba067c84eb45e303d6640224 + version: 1.4.106 + resolution: "electron-to-chromium@npm:1.4.106" + checksum: 79eae050a775f6f674a24d4541d54cdb1c35e956d6e112ee9ec8d752fa9bcd94739e5f86c58d8e04f85199cf720146aee301b2e397932ad5c8d8e8cffe65a2ee languageName: node linkType: hard -"emittery@npm:^0.8.1": - version: 0.8.1 - resolution: "emittery@npm:0.8.1" - checksum: 2457e8c7b0688bb006126f2c025b2655abe682f66b184954122a8a065b5277f9813d49d627896a10b076b81c513ec5f491fd9c14fbd42c04b95ca3c9f3c365ee +"emittery@npm:^0.10.2": + version: 0.10.2 + resolution: "emittery@npm:0.10.2" + checksum: ee3e21788b043b90885b18ea756ec3105c1cedc50b29709c92b01e239c7e55345d4bb6d3aef4ddbaf528eef448a40b3bb831bad9ee0fc9c25cbf1367ab1ab5ac languageName: node linkType: hard @@ -9614,8 +9585,8 @@ __metadata: linkType: hard "es-abstract@npm:^1.19.0, es-abstract@npm:^1.19.1": - version: 1.19.1 - resolution: "es-abstract@npm:1.19.1" + version: 1.19.2 + resolution: "es-abstract@npm:1.19.2" dependencies: call-bind: ^1.0.2 es-to-primitive: ^1.2.1 @@ -9623,21 +9594,21 @@ __metadata: get-intrinsic: ^1.1.1 get-symbol-description: ^1.0.0 has: ^1.0.3 - has-symbols: ^1.0.2 + has-symbols: ^1.0.3 internal-slot: ^1.0.3 is-callable: ^1.2.4 - is-negative-zero: ^2.0.1 + is-negative-zero: ^2.0.2 is-regex: ^1.1.4 is-shared-array-buffer: ^1.0.1 is-string: ^1.0.7 - is-weakref: ^1.0.1 - object-inspect: ^1.11.0 + is-weakref: ^1.0.2 + object-inspect: ^1.12.0 object-keys: ^1.1.1 object.assign: ^4.1.2 string.prototype.trimend: ^1.0.4 string.prototype.trimstart: ^1.0.4 unbox-primitive: ^1.0.1 - checksum: b6be8410672c5364db3fb01eb786e30c7b4bb32b4af63d381c08840f4382c4a168e7855cd338bf59d4f1a1a1138f4d748d1fd40ec65aaa071876f9e9fbfed949 + checksum: 4724811fd54b2cea959a8b08e49cd41cc65c77363c37bf5b42dc64a7c730e16a0dca80edc73e46ebf90a8de311622009a5a8dbe47e9f4e129c35f52c5020fe4e languageName: node linkType: hard @@ -9728,13 +9699,13 @@ __metadata: linkType: hard "eslint-config-prettier@npm:^8.1.0": - version: 8.3.0 - resolution: "eslint-config-prettier@npm:8.3.0" + version: 8.5.0 + resolution: "eslint-config-prettier@npm:8.5.0" peerDependencies: eslint: ">=7.0.0" bin: eslint-config-prettier: bin/cli.js - checksum: df4cea3032671995bb5ab07e016169072f7fa59f44a53251664d9ca60951b66cdc872683b5c6a3729c91497c11490ca44a79654b395dd6756beb0c3903a37196 + checksum: 0d0f5c32e7a0ad91249467ce71ca92394ccd343178277d318baf32063b79ea90216f4c81d1065d60f96366fdc60f151d4d68ae7811a58bd37228b84c2083f893 languageName: node linkType: hard @@ -9749,22 +9720,22 @@ __metadata: linkType: hard "eslint-import-resolver-typescript@npm:^2.5.0": - version: 2.5.0 - resolution: "eslint-import-resolver-typescript@npm:2.5.0" + version: 2.7.1 + resolution: "eslint-import-resolver-typescript@npm:2.7.1" dependencies: - debug: ^4.3.1 - glob: ^7.1.7 - is-glob: ^4.0.1 - resolve: ^1.20.0 - tsconfig-paths: ^3.9.0 + debug: ^4.3.4 + glob: ^7.2.0 + is-glob: ^4.0.3 + resolve: ^1.22.0 + tsconfig-paths: ^3.14.1 peerDependencies: eslint: "*" eslint-plugin-import: "*" - checksum: e507a0cb46a05f136b1416664c7cbe1b1178001417421ce5621f147e88c8973b5c9ee1554dbf0b79ae93f760d69f2796e1a880d562356a080e9e4ac1058206a3 + checksum: 1d81b657b1f73bf95b8f0b745c0305574b91630c1db340318f3ca8918e206fce20a933b95e7c419338cc4452cb80bb2b2d92acaf01b6aa315c78a332d832545c languageName: node linkType: hard -"eslint-module-utils@npm:^2.7.2": +"eslint-module-utils@npm:^2.7.3": version: 2.7.3 resolution: "eslint-module-utils@npm:2.7.3" dependencies: @@ -9787,31 +9758,31 @@ __metadata: linkType: hard "eslint-plugin-import@npm:^2.6.0": - version: 2.25.4 - resolution: "eslint-plugin-import@npm:2.25.4" + version: 2.26.0 + resolution: "eslint-plugin-import@npm:2.26.0" dependencies: array-includes: ^3.1.4 array.prototype.flat: ^1.2.5 debug: ^2.6.9 doctrine: ^2.1.0 eslint-import-resolver-node: ^0.3.6 - eslint-module-utils: ^2.7.2 + eslint-module-utils: ^2.7.3 has: ^1.0.3 - is-core-module: ^2.8.0 + is-core-module: ^2.8.1 is-glob: ^4.0.3 - minimatch: ^3.0.4 + minimatch: ^3.1.2 object.values: ^1.1.5 - resolve: ^1.20.0 - tsconfig-paths: ^3.12.0 + resolve: ^1.22.0 + tsconfig-paths: ^3.14.1 peerDependencies: eslint: ^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8 - checksum: 0af24f5c7c6ca692f42e3947127f0ae7dfe44f1e02740f7cbe988b510a9c52bab0065d7df04e2d953dcc88a4595a00cbdcf14018acf8cd75cfd47b72efcbb734 + checksum: 0bf77ad80339554481eafa2b1967449e1f816b94c7a6f9614ce33fb4083c4e6c050f10d241dd50b4975d47922880a34de1e42ea9d8e6fd663ebb768baa67e655 languageName: node linkType: hard "eslint-plugin-jest@npm:^26.1.0": - version: 26.1.1 - resolution: "eslint-plugin-jest@npm:26.1.1" + version: 26.1.4 + resolution: "eslint-plugin-jest@npm:26.1.4" dependencies: "@typescript-eslint/utils": ^5.10.0 peerDependencies: @@ -9822,7 +9793,7 @@ __metadata: optional: true jest: optional: true - checksum: efed65bd6b83f15f38e3d8447d0dbbac18c10d6e4c4853c8d0539f5bc8e898cca8136b1e706899b756ea995ed189445b7f15d0fffeb983890608c33e752670d7 + checksum: f9989a853a165ad1afc077d7d75582391d511e8e14145bb67c76b0ad70a0966358311659da0e82162832bd23a327c2bd1d15dd5d3917f69bb8c14d256e8e1d77 languageName: node linkType: hard @@ -9905,10 +9876,10 @@ __metadata: linkType: hard "eslint@npm:^8.8.0": - version: 8.9.0 - resolution: "eslint@npm:8.9.0" + version: 8.12.0 + resolution: "eslint@npm:8.12.0" dependencies: - "@eslint/eslintrc": ^1.1.0 + "@eslint/eslintrc": ^1.2.1 "@humanwhocodes/config-array": ^0.9.2 ajv: ^6.10.0 chalk: ^4.0.0 @@ -9945,7 +9916,7 @@ __metadata: v8-compile-cache: ^2.0.3 bin: eslint: bin/eslint.js - checksum: 8efecdb9752ee6cb4d2787a14e00cbeab29562ed95dd71c6f3f8ac410426a067d5aa659416d2290e46ca44bc5607e6a6e6c62f814694d8639f80666f522022a7 + checksum: 111bf9046b7a463049788dd00d7f4cd91e024029982352dff4811ce5dfa8cb1136aa127cd8a7a91508234d3e1b4fb6f638a1f5ef9ea08b1af93a18703a4a8dc1 languageName: node linkType: hard @@ -10330,7 +10301,7 @@ __metadata: languageName: unknown linkType: soft -"express@npm:^4.17.1": +"express@npm:^4.17.3": version: 4.17.3 resolution: "express@npm:4.17.3" dependencies: @@ -10443,11 +10414,11 @@ __metadata: linkType: hard "fast-check@npm:^2.0.0": - version: 2.22.0 - resolution: "fast-check@npm:2.22.0" + version: 2.24.0 + resolution: "fast-check@npm:2.24.0" dependencies: - pure-rand: ^5.0.0 - checksum: a61172eef68c66fe6d47d10ebbc655cfebca61e9b2341af6f81d3a033bbcbbf1860e38a5bfa4a7f5938284d8112cefb0810e07128ef7c248a3b78d4b0da02fc9 + pure-rand: ^5.0.1 + checksum: 8f1e590768379c2831bfc70e38c3eb545f82c706eaa316664226bd46956a1e52b644d665d9b31ebeca1e86477b054232f1159841b41c065ec8e4c24295da1c05 languageName: node linkType: hard @@ -10807,8 +10778,8 @@ __metadata: linkType: hard "fork-ts-checker-webpack-plugin@npm:^6.5.0": - version: 6.5.0 - resolution: "fork-ts-checker-webpack-plugin@npm:6.5.0" + version: 6.5.1 + resolution: "fork-ts-checker-webpack-plugin@npm:6.5.1" dependencies: "@babel/code-frame": ^7.8.3 "@types/json-schema": ^7.0.5 @@ -10833,7 +10804,7 @@ __metadata: optional: true vue-template-compiler: optional: true - checksum: 95d145ab7936445f3a9bfa4116ef73537f97196cfaa3f5b24473dff36d034e839d3b0e034a23beefc9619eceb7a9866816bfd55afd1968e955eb3b3f8cfc35ed + checksum: b5a06f72fb2db5d182e026668446ef54a80eb8f2f01a4f3336dfa9770c80cda6b5657d1e8dc20f45e2aaa9b72b55be1f4425fb9cf78efc989e1b5107ccdb41a1 languageName: node linkType: hard @@ -11048,19 +11019,18 @@ __metadata: linkType: hard "gauge@npm:^4.0.0": - version: 4.0.1 - resolution: "gauge@npm:4.0.1" + version: 4.0.4 + resolution: "gauge@npm:4.0.4" dependencies: - ansi-regex: ^5.0.1 aproba: ^1.0.3 || ^2.0.0 - color-support: ^1.1.2 - console-control-strings: ^1.0.0 + color-support: ^1.1.3 + console-control-strings: ^1.1.0 has-unicode: ^2.0.1 - signal-exit: ^3.0.0 + signal-exit: ^3.0.7 string-width: ^4.2.3 strip-ansi: ^6.0.1 - wide-align: ^1.1.2 - checksum: 398540c761f2efbd8c35323b781a572db09a3ab2d62ea672fc440eb88e9249624ac8b64275731d9ef266cde6491880df5360d74d0829da077136ee614b08f85c + wide-align: ^1.1.5 + checksum: 788b6bfe52f1dd8e263cda800c26ac0ca2ff6de0b6eee2fe0d9e3abf15e149b651bd27bf5226be10e6e3edb5c4e5d5985a5a1a98137e7a892f75eff76467ad2d languageName: node linkType: hard @@ -11272,7 +11242,7 @@ __metadata: languageName: node linkType: hard -"github-buttons@npm:^2.8.0": +"github-buttons@npm:^2.21.1": version: 2.21.1 resolution: "github-buttons@npm:2.21.1" checksum: 5c90dc19a9301cfd5cedbb6adcd62725a7a013d5a564d15383c8cd92090beb3a5290fbdf0dd370b94e4a81e61a417b68f7b5df98da411b7df7453c2012d9a37a @@ -11311,7 +11281,7 @@ __metadata: languageName: node linkType: hard -"glob@npm:^7.0.0, glob@npm:^7.1.1, glob@npm:^7.1.2, glob@npm:^7.1.3, glob@npm:^7.1.4, glob@npm:^7.1.6, glob@npm:^7.1.7": +"glob@npm:^7.0.0, glob@npm:^7.1.1, glob@npm:^7.1.2, glob@npm:^7.1.3, glob@npm:^7.1.4, glob@npm:^7.1.6, glob@npm:^7.2.0": version: 7.2.0 resolution: "glob@npm:7.2.0" dependencies: @@ -11362,11 +11332,11 @@ __metadata: linkType: hard "globals@npm:^13.6.0, globals@npm:^13.9.0": - version: 13.12.1 - resolution: "globals@npm:13.12.1" + version: 13.13.0 + resolution: "globals@npm:13.13.0" dependencies: type-fest: ^0.20.2 - checksum: cf7877629c8f2a293b0a7d09d1dcce7f2d426ec2528600c481c5b3f3d070b0a120eb2499439ac0404990fb8a5742c0165b1bf1f52603364001ddc89bea3dda24 + checksum: c55ea8fd3afecb72567bac41605577e19e68476993dfb0ca4c49b86075af5f0ae3f0f5502525f69010f7c5ea5db6a1c540a80a4f80ebdfb2f686d87b0f05d7e9 languageName: node linkType: hard @@ -11844,9 +11814,9 @@ __metadata: linkType: hard "html-entities@npm:^2.3.2": - version: 2.3.2 - resolution: "html-entities@npm:2.3.2" - checksum: 522d8d202df301ff51b517a379e642023ed5c81ea9fb5674ffad88cff386165733d00b6089d5c2fcc644e44777d6072017b6216d8fa40f271d3610420d00a886 + version: 2.3.3 + resolution: "html-entities@npm:2.3.3" + checksum: 92521501da8aa5f66fee27f0f022d6e9ceae62667dae93aa6a2f636afa71ad530b7fb24a18d4d6c124c9885970cac5f8a52dbf1731741161002816ae43f98196 languageName: node linkType: hard @@ -11875,9 +11845,9 @@ __metadata: linkType: hard "html-tags@npm:^3.1.0": - version: 3.1.0 - resolution: "html-tags@npm:3.1.0" - checksum: 67587f2d4022390d7bc34b1313773ecb0b0e0c79fb331aa3e20023eb4c862c7188a1ff775d126fcd75f4e4f08f956666a1c57688c4d24d85a77f9d4b1a42f345 + version: 3.2.0 + resolution: "html-tags@npm:3.2.0" + checksum: a0c9e96ac26c84adad9cc66d15d6711a17f60acda8d987218f1d4cbaacd52864939b230e635cce5a1179f3ddab2a12b9231355617dfbae7945fcfec5e96d2041 languageName: node linkType: hard @@ -11997,7 +11967,7 @@ __metadata: languageName: node linkType: hard -"http-proxy-middleware@npm:^2.0.0": +"http-proxy-middleware@npm:^2.0.3": version: 2.0.4 resolution: "http-proxy-middleware@npm:2.0.4" dependencies: @@ -12113,13 +12083,6 @@ __metadata: languageName: node linkType: hard -"ignore@npm:^4.0.6": - version: 4.0.6 - resolution: "ignore@npm:4.0.6" - checksum: 248f82e50a430906f9ee7f35e1158e3ec4c3971451dd9f99c9bc1548261b4db2b99709f60ac6c6cac9333494384176cc4cc9b07acbe42d52ac6a09cad734d800 - languageName: node - linkType: hard - "ignore@npm:^5.0.5, ignore@npm:^5.1.8, ignore@npm:^5.1.9, ignore@npm:^5.2.0": version: 5.2.0 resolution: "ignore@npm:5.2.0" @@ -12343,7 +12306,7 @@ __metadata: languageName: node linkType: hard -"ip@npm:^1.1.0, ip@npm:^1.1.5": +"ip@npm:^1.1.5": version: 1.1.5 resolution: "ip@npm:1.1.5" checksum: 30133981f082a060a32644f6a7746e9ba7ac9e2bc07ecc8bbdda3ee8ca9bec1190724c390e45a1ee7695e7edfd2a8f7dda2c104ec5f7ac5068c00648504c7e5a @@ -12399,16 +12362,6 @@ __metadata: languageName: node linkType: hard -"is-arguments@npm:^1.0.4": - version: 1.1.1 - resolution: "is-arguments@npm:1.1.1" - dependencies: - call-bind: ^1.0.2 - has-tostringtag: ^1.0.0 - checksum: 7f02700ec2171b691ef3e4d0e3e6c0ba408e8434368504bb593d0d7c891c0dbfda6d19d30808b904a6cb1929bca648c061ba438c39f296c2a8ca083229c49f27 - languageName: node - linkType: hard - "is-arrayish@npm:^0.2.1": version: 0.2.1 resolution: "is-arrayish@npm:0.2.1" @@ -12476,7 +12429,7 @@ __metadata: languageName: node linkType: hard -"is-core-module@npm:^2.1.0, is-core-module@npm:^2.5.0, is-core-module@npm:^2.8.0, is-core-module@npm:^2.8.1": +"is-core-module@npm:^2.1.0, is-core-module@npm:^2.5.0, is-core-module@npm:^2.8.1": version: 2.8.1 resolution: "is-core-module@npm:2.8.1" dependencies: @@ -12657,7 +12610,7 @@ __metadata: languageName: node linkType: hard -"is-negative-zero@npm:^2.0.1": +"is-negative-zero@npm:^2.0.2": version: 2.0.2 resolution: "is-negative-zero@npm:2.0.2" checksum: f3232194c47a549da60c3d509c9a09be442507616b69454716692e37ae9f37c4dea264fb208ad0c9f3efd15a796a46b79df07c7e53c6227c32170608b809149a @@ -12672,11 +12625,11 @@ __metadata: linkType: hard "is-number-object@npm:^1.0.4": - version: 1.0.6 - resolution: "is-number-object@npm:1.0.6" + version: 1.0.7 + resolution: "is-number-object@npm:1.0.7" dependencies: has-tostringtag: ^1.0.0 - checksum: c697704e8fc2027fc41cb81d29805de4e8b6dc9c3efee93741dbf126a8ecc8443fef85adbc581415ae7e55d325e51d0a942324ae35c829131748cce39cba55f3 + checksum: d1e8d01bb0a7134c74649c4e62da0c6118a0bfc6771ea3c560914d52a627873e6920dd0fd0ebc0e12ad2ff4687eac4c308f7e80320b973b2c8a2c8f97a7524f7 languageName: node linkType: hard @@ -12775,7 +12728,7 @@ __metadata: languageName: node linkType: hard -"is-regex@npm:^1.0.4, is-regex@npm:^1.0.5, is-regex@npm:^1.1.0, is-regex@npm:^1.1.4": +"is-regex@npm:^1.0.5, is-regex@npm:^1.1.0, is-regex@npm:^1.1.4": version: 1.1.4 resolution: "is-regex@npm:1.1.4" dependencies: @@ -12800,9 +12753,11 @@ __metadata: linkType: hard "is-shared-array-buffer@npm:^1.0.1": - version: 1.0.1 - resolution: "is-shared-array-buffer@npm:1.0.1" - checksum: 2ffb92533e64e2876e6cfe6906871d28400b6f1a53130fe652ec8007bc0e5044d05e7af8e31bdc992fbba520bd92938cfbeedd0f286be92f250c7c76191c4d90 + version: 1.0.2 + resolution: "is-shared-array-buffer@npm:1.0.2" + dependencies: + call-bind: ^1.0.2 + checksum: 9508929cf14fdc1afc9d61d723c6e8d34f5e117f0bffda4d97e7a5d88c3a8681f633a74f8e3ad1fe92d5113f9b921dc5ca44356492079612f9a247efbce7032a languageName: node linkType: hard @@ -12877,7 +12832,7 @@ __metadata: languageName: node linkType: hard -"is-weakref@npm:^1.0.1": +"is-weakref@npm:^1.0.2": version: 1.0.2 resolution: "is-weakref@npm:1.0.2" dependencies: @@ -12945,9 +12900,9 @@ __metadata: linkType: hard "isbinaryfile@npm:^4.0.0": - version: 4.0.8 - resolution: "isbinaryfile@npm:4.0.8" - checksum: 606e3bb648d1a0dee23459d1d937bb2560e66a5281ec7c9ff50e585402d73321ac268d0f34cb7393125b3ebc4c7962d39e50a01cdb8904b52fce08b7ccd2bf9f + version: 4.0.10 + resolution: "isbinaryfile@npm:4.0.10" + checksum: a6b28db7e23ac7a77d3707567cac81356ea18bd602a4f21f424f862a31d0e7ab4f250759c98a559ece35ffe4d99f0d339f1ab884ffa9795172f632ab8f88e686 languageName: node linkType: hard @@ -13335,14 +13290,14 @@ __metadata: linkType: soft "jest-junit@npm:^13.0.0": - version: 13.0.0 - resolution: "jest-junit@npm:13.0.0" + version: 13.1.0 + resolution: "jest-junit@npm:13.1.0" dependencies: mkdirp: ^1.0.4 strip-ansi: ^6.0.1 uuid: ^8.3.2 xml: ^1.0.1 - checksum: d3a1bf6e98250837d1a9939cd54f29a7bd4fb835af30e92d0d544300fbe634eb86d2b018c79a7a35b123d933bf3e6c96ba13c0161cdefbf66fc3ab771707572e + checksum: a12ec522012cf9d0e97d4c665d8ca05b97dc3d25ef3cd0dbba2b095da4b68e1cabac9751a2718a9593b55c620a2b980e0b6c7dd7d33dfc4b73193bc67b9c9ae0 languageName: node linkType: hard @@ -13548,7 +13503,7 @@ __metadata: "@types/node": "*" "@types/source-map-support": ^0.5.0 chalk: ^4.0.0 - emittery: ^0.8.1 + emittery: ^0.10.2 graceful-fs: ^4.2.9 jest-docblock: ^28.0.0-alpha.6 jest-environment-node: ^28.0.0-alpha.8 @@ -14112,7 +14067,7 @@ __metadata: languageName: node linkType: hard -"json5@npm:^2.1.2, json5@npm:^2.2.0": +"json5@npm:^2.1.2, json5@npm:^2.2.0, json5@npm:^2.2.1": version: 2.2.1 resolution: "json5@npm:2.2.1" bin: @@ -14738,6 +14693,13 @@ __metadata: languageName: node linkType: hard +"lru-cache@npm:^7.4.0": + version: 7.8.0 + resolution: "lru-cache@npm:7.8.0" + checksum: 7cc046276b668e7b59c10f7f25049d89315cd22fb5205c0eb476583ba29b8542955189452dc8655a771e1a91f6056ddcb29daf4ac35197f77b3ce9a0041d54c9 + languageName: node + linkType: hard + "lz-string@npm:^1.4.4": version: 1.4.4 resolution: "lz-string@npm:1.4.4" @@ -15787,7 +15749,7 @@ __metadata: languageName: node linkType: hard -"minimatch@npm:^3.0.2, minimatch@npm:^3.0.4": +"minimatch@npm:^3.0.2, minimatch@npm:^3.0.4, minimatch@npm:^3.1.2": version: 3.1.2 resolution: "minimatch@npm:3.1.2" dependencies: @@ -15807,10 +15769,10 @@ __metadata: languageName: node linkType: hard -"minimist@npm:^1.2.0, minimist@npm:^1.2.5": - version: 1.2.5 - resolution: "minimist@npm:1.2.5" - checksum: 86706ce5b36c16bfc35c5fe3dbb01d5acdc9a22f2b6cc810b6680656a1d2c0e44a0159c9a3ba51fb072bb5c203e49e10b51dcd0eec39c481f4c42086719bae52 +"minimist@npm:^1.2.0, minimist@npm:^1.2.5, minimist@npm:^1.2.6": + version: 1.2.6 + resolution: "minimist@npm:1.2.6" + checksum: d15428cd1e11eb14e1233bcfb88ae07ed7a147de251441d61158619dfb32c4d7e9061d09cab4825fdee18ecd6fce323228c8c47b5ba7cd20af378ca4048fb3fb languageName: node linkType: hard @@ -15935,13 +15897,13 @@ __metadata: linkType: hard "mkdirp@npm:^0.5.1, mkdirp@npm:^0.5.5": - version: 0.5.5 - resolution: "mkdirp@npm:0.5.5" + version: 0.5.6 + resolution: "mkdirp@npm:0.5.6" dependencies: - minimist: ^1.2.5 + minimist: ^1.2.6 bin: mkdirp: bin/cmd.js - checksum: 3bce20ea525f9477befe458ab85284b0b66c8dc3812f94155af07c827175948cdd8114852ac6c6d82009b13c1048c37f6d98743eb019651ee25c39acc8aabe7d + checksum: 0c91b721bb12c3f9af4b77ebf73604baf350e64d80df91754dc509491ae93bf238581e59c7188360cec7cb62fc4100959245a42cfe01834efedc5e9d068376c2 languageName: node linkType: hard @@ -15968,19 +15930,19 @@ __metadata: languageName: node linkType: hard -"mongodb-connection-string-url@npm:^2.4.1": - version: 2.4.2 - resolution: "mongodb-connection-string-url@npm:2.4.2" +"mongodb-connection-string-url@npm:^2.5.2": + version: 2.5.2 + resolution: "mongodb-connection-string-url@npm:2.5.2" dependencies: "@types/whatwg-url": ^8.2.1 whatwg-url: ^11.0.0 - checksum: aed2718840c79f8d6be35309e308bf4466a009256da6b02e6212abeef39ae27bf6101273580696e246e51ee4f7471e2d938c44e8f8a5194982092f692b37c571 + checksum: bd13af7d62d33e2d6e5217692961e34b2dafbbba5f41d361417257592754df3e925efc00fa8a5e038624e284245dab39e913d5f06ff962feede86d5f58fc5827 languageName: node linkType: hard -"mongodb-memory-server-core@npm:8.3.0": - version: 8.3.0 - resolution: "mongodb-memory-server-core@npm:8.3.0" +"mongodb-memory-server-core@npm:8.4.2": + version: 8.4.2 + resolution: "mongodb-memory-server-core@npm:8.4.2" dependencies: "@types/tmp": ^0.2.3 async-mutex: ^0.3.2 @@ -15990,7 +15952,7 @@ __metadata: get-port: ^5.1.1 https-proxy-agent: ^5.0.0 md5-file: ^5.0.0 - mongodb: ^4.3.1 + mongodb: ^4.4.0 new-find-package-json: ^1.1.0 semver: ^7.3.5 tar-stream: ^2.1.4 @@ -15998,33 +15960,33 @@ __metadata: tslib: ^2.3.1 uuid: ^8.3.1 yauzl: ^2.10.0 - checksum: 94dd31b6860c44083dfd4875ba03784b832176d625ff22fd23b300405bc4153276f64ab4fa5bfb5ab2610189f8e8fc8a228e9b7791a2bd45d7f03f675dc0897c + checksum: e1e61f55c5ea10b41c01eff9956e2f6b527141673e8c70a6c3208770bb3aeedcee0c31f533b5d7b83fb181b80e593ae4751beac5c03b2de2b74f0b057daa2c59 languageName: node linkType: hard "mongodb-memory-server@npm:^8.3.0": - version: 8.3.0 - resolution: "mongodb-memory-server@npm:8.3.0" + version: 8.4.2 + resolution: "mongodb-memory-server@npm:8.4.2" dependencies: - mongodb-memory-server-core: 8.3.0 + mongodb-memory-server-core: 8.4.2 tslib: ^2.3.1 - checksum: 300e7e8d78032baf2d4c54b799e4cae0e77c6cdc58119f82581ab4a214acb6ff61a30f3d43a81da4b2e162ec8f2a8f196eb72f1724f20830ca5aa1ba0700e5ae + checksum: aea44c44a4f22c3513ea13626a63190325b4bbedd81cac2e5e0c919d16998d613ee782787c768d267b82863226e1891a27dc01bc13bc8a5f5259f79321fcacbf languageName: node linkType: hard -"mongodb@npm:^4.3.1": - version: 4.3.1 - resolution: "mongodb@npm:4.3.1" +"mongodb@npm:^4.3.1, mongodb@npm:^4.4.0": + version: 4.5.0 + resolution: "mongodb@npm:4.5.0" dependencies: - bson: ^4.6.1 + bson: ^4.6.2 denque: ^2.0.1 - mongodb-connection-string-url: ^2.4.1 + mongodb-connection-string-url: ^2.5.2 saslprep: ^1.0.3 - socks: ^2.6.1 + socks: ^2.6.2 dependenciesMeta: saslprep: optional: true - checksum: 5684b5481bfbf73e4628b8bad7018cd4436fdb23b9548fb38dece3e079b1716fe870d41070a505d13ae4d86c107315afaf34891ba2b64925eb4fa4cd5bb70300 + checksum: 423974a663c90e6673226a9ad691e8b445ecd43fc4e9e424343644b20c35188bd3d6692dcc2798022cc6b5c6f4391b54747c7543134b46f93cb3da428e5f9246 languageName: node linkType: hard @@ -16070,22 +16032,15 @@ __metadata: languageName: node linkType: hard -"multicast-dns-service-types@npm:^1.1.0": - version: 1.1.0 - resolution: "multicast-dns-service-types@npm:1.1.0" - checksum: 0979fca1cce85484d256e4db3af591d941b41a61f134da3607213d2624c12ed5b8a246565cb19a9b3cb542819e8fbc71a90b07e77023ee6a9515540fe1d371f7 - languageName: node - linkType: hard - -"multicast-dns@npm:^6.0.1": - version: 6.2.3 - resolution: "multicast-dns@npm:6.2.3" +"multicast-dns@npm:^7.2.4": + version: 7.2.4 + resolution: "multicast-dns@npm:7.2.4" dependencies: - dns-packet: ^1.3.1 + dns-packet: ^5.2.2 thunky: ^1.0.2 bin: multicast-dns: cli.js - checksum: f515b49ca964429ab48a4ac8041fcf969c927aeb49ab65288bd982e52c849a870fc3b03565780b0d194a1a02da8821f28b6425e48e95b8107bc9fcc92f571a6f + checksum: 45a78628a8f26479c4018122d689a8b22aff034699a1913dac0b9891e4111162b3222c85bba642d624270a90e51129607f1e41aa701e0108cc974246bc9fe828 languageName: node linkType: hard @@ -16110,11 +16065,11 @@ __metadata: linkType: hard "nanoid@npm:^3.3.1": - version: 3.3.1 - resolution: "nanoid@npm:3.3.1" + version: 3.3.2 + resolution: "nanoid@npm:3.3.2" bin: nanoid: bin/nanoid.cjs - checksum: 4ef0969e1bbe866fc223eb32276cbccb0961900bfe79104fa5abe34361979dead8d0e061410a5c03bc3d47455685adf32c09d6f27790f4a6898fb51f7df7ec86 + checksum: 376717f0685251fad77850bd84c6b8d57837c71eeb1c05be7c742140cc1835a5a2953562add05166d6dbc8fb65f3fdffa356213037b967a470e1691dc3e7b9cc languageName: node linkType: hard @@ -16199,6 +16154,18 @@ __metadata: languageName: node linkType: hard +"njre@npm:^0.2.0": + version: 0.2.0 + resolution: "njre@npm:0.2.0" + dependencies: + command-exists-promise: ^2.0.2 + node-fetch: ^2.5.0 + tar: ^4.4.8 + yauzl: ^2.10.0 + checksum: b5ec0e31237ff437956a4390c3bdf63ec3f911e83f6fc671d12448ae053a30546c2e82000d815636b118ff20b71395f97f45cc7c331ba15972b6d45ea678da1d + languageName: node + linkType: hard + "no-case@npm:^3.0.4": version: 3.0.4 resolution: "no-case@npm:3.0.4" @@ -16243,7 +16210,7 @@ __metadata: languageName: node linkType: hard -"node-fetch@npm:2.6.7, node-fetch@npm:^2.2.0, node-fetch@npm:^2.6.0, node-fetch@npm:^2.6.1, node-fetch@npm:^2.6.7": +"node-fetch@npm:2.6.7, node-fetch@npm:^2.2.0, node-fetch@npm:^2.5.0, node-fetch@npm:^2.6.0, node-fetch@npm:^2.6.1, node-fetch@npm:^2.6.7": version: 2.6.7 resolution: "node-fetch@npm:2.6.7" dependencies: @@ -16257,21 +16224,21 @@ __metadata: languageName: node linkType: hard -"node-forge@npm:^1.2.0": - version: 1.3.0 - resolution: "node-forge@npm:1.3.0" - checksum: 3d8124168dd82006fafbb079f40a529afa0de5bf4d77e6a5a471877e9d39bece31fdc8339e8aee30d5480dc79ffcd1059cfcb21983d350dd3f2a9f226db6ca85 +"node-forge@npm:^1": + version: 1.3.1 + resolution: "node-forge@npm:1.3.1" + checksum: 08fb072d3d670599c89a1704b3e9c649ff1b998256737f0e06fbd1a5bf41cae4457ccaee32d95052d80bbafd9ffe01284e078c8071f0267dc9744e51c5ed42a9 languageName: node linkType: hard "node-gyp-build@npm:^4.2.1": - version: 4.3.0 - resolution: "node-gyp-build@npm:4.3.0" + version: 4.4.0 + resolution: "node-gyp-build@npm:4.4.0" bin: node-gyp-build: bin.js node-gyp-build-optional: optional.js node-gyp-build-test: build-test.js - checksum: 1ecab16d9f275174d516e223f60f65ebe07540347d5c04a6a7d6921060b7f2e3af4f19463d9d1dcedc452e275c2ae71354a99405e55ebd5b655bb2f38025c728 + checksum: 972a059f960253d254e0b23ce10f54c8982236fc0edcab85166d0b7f87443b2ce98391c877cfb2f6eeafcf03c538c5f4dd3e0bfff03828eb48634f58f4c64343 languageName: node linkType: hard @@ -16681,14 +16648,14 @@ __metadata: languageName: node linkType: hard -"object-inspect@npm:^1.11.0, object-inspect@npm:^1.7.0, object-inspect@npm:^1.9.0": +"object-inspect@npm:^1.12.0, object-inspect@npm:^1.7.0, object-inspect@npm:^1.9.0": version: 1.12.0 resolution: "object-inspect@npm:1.12.0" checksum: 2b36d4001a9c921c6b342e2965734519c9c58c355822243c3207fbf0aac271f8d44d30d2d570d450b2cc6f0f00b72bcdba515c37827d2560e5f22b1899a31cf4 languageName: node linkType: hard -"object-is@npm:^1.0.1, object-is@npm:^1.0.2, object-is@npm:^1.1.2": +"object-is@npm:^1.0.2, object-is@npm:^1.1.2": version: 1.1.5 resolution: "object-is@npm:1.1.5" dependencies: @@ -17606,15 +17573,15 @@ __metadata: languageName: node linkType: hard -"postcss-merge-longhand@npm:^5.1.3": - version: 5.1.3 - resolution: "postcss-merge-longhand@npm:5.1.3" +"postcss-merge-longhand@npm:^5.1.4": + version: 5.1.4 + resolution: "postcss-merge-longhand@npm:5.1.4" dependencies: postcss-value-parser: ^4.2.0 stylehacks: ^5.1.0 peerDependencies: postcss: ^8.2.15 - checksum: fc5ed3510b281cf545c167913af8ca22c250c88c10f28dfb669acc09c6bccfba977f6855eb6e0dd5e3caee63ac45c53e3575d02a7f6d0079ca87c139852c95ff + checksum: 3245531aebcd0d2fe6982e142c088ae96ed5242885349e6160e68fc007cdc10d8b0f3e57d7987e3ba07fc9f7d0f6f278972fecaa517c0fa8594bdeaed82393f0 languageName: node linkType: hard @@ -17870,12 +17837,12 @@ __metadata: linkType: hard "postcss-selector-parser@npm:^6.0.2, postcss-selector-parser@npm:^6.0.4, postcss-selector-parser@npm:^6.0.5, postcss-selector-parser@npm:^6.0.9": - version: 6.0.9 - resolution: "postcss-selector-parser@npm:6.0.9" + version: 6.0.10 + resolution: "postcss-selector-parser@npm:6.0.10" dependencies: cssesc: ^3.0.0 util-deprecate: ^1.0.2 - checksum: f8161ab4d3e5c76b8467189c6d164ba0f6b6e74677435f29e34caa1df01e052b582b4ae4f7468b2243c4befdd8bdcdb7685542d1b2fca8deae21b3e849c78802 + checksum: 46afaa60e3d1998bd7adf6caa374baf857cc58d3ff944e29459c9a9e4680a7fe41597bd5b755fc81d7c388357e9bf67c0251d047c640a09f148e13606b8a8608 languageName: node linkType: hard @@ -17971,11 +17938,11 @@ __metadata: linkType: hard "prettier@npm:^2.0.0, prettier@npm:^2.0.1, prettier@npm:^2.1.1": - version: 2.5.1 - resolution: "prettier@npm:2.5.1" + version: 2.6.2 + resolution: "prettier@npm:2.6.2" bin: prettier: bin-prettier.js - checksum: 21b9408476ea1c544b0e45d51ceb94a84789ff92095abb710942d780c862d0daebdb29972d47f6b4d0f7ebbfb0ffbf56cc2cfa3e3e9d1cca54864af185b15b66 + checksum: 48d08dde8e9fb1f5bccdd205baa7f192e9fc8bc98f86e1b97d919de804e28c806b0e6cc685e4a88211aa7987fa9668f30baae19580d87ced3ed0f2ec6572106f languageName: node linkType: hard @@ -18010,23 +17977,11 @@ __metadata: jest-util: ^28.0.0-alpha.8 react: "*" react-dom: "*" - react-is: ^17.0.1 + react-is: ^18.0.0 react-test-renderer: "*" languageName: unknown linkType: soft -"pretty-format@npm:26.6.1": - version: 26.6.1 - resolution: "pretty-format@npm:26.6.1" - dependencies: - "@jest/types": ^26.6.1 - ansi-regex: ^5.0.0 - ansi-styles: ^4.0.0 - react-is: ^17.0.1 - checksum: d2e714b5dc54c23ffa64e5bdb5efa5a580d13bc78404cb30939207a53ac2ad0d289fb4086d89d237a863657f7d8528c7de0eeec273e4ad1612800aa1f41b3e0a - languageName: node - linkType: hard - "pretty-format@npm:^26.5.2, pretty-format@npm:^26.6.2": version: 26.6.2 resolution: "pretty-format@npm:26.6.2" @@ -18039,7 +17994,7 @@ __metadata: languageName: node linkType: hard -"pretty-format@npm:^27.0.0, pretty-format@npm:^27.5.1": +"pretty-format@npm:^27.0.0, pretty-format@npm:^27.0.2, pretty-format@npm:^27.5.1": version: 27.5.1 resolution: "pretty-format@npm:27.5.1" dependencies: @@ -18257,10 +18212,10 @@ __metadata: languageName: node linkType: hard -"pure-rand@npm:^5.0.0": - version: 5.0.0 - resolution: "pure-rand@npm:5.0.0" - checksum: f33a9021a8916ae1c2e3211ba0ecaa01ed5fae21e3979ce0ee67e562b7e0dabf0d35a9f4113f0c0ceffa799d2276da44d09eebe6b7f49ec3b8fe0dcfa59f8dec +"pure-rand@npm:^5.0.1": + version: 5.0.1 + resolution: "pure-rand@npm:5.0.1" + checksum: 2b05a6d80163308583a013fab8d7f7f2958a6f77895680c99d8c3ea1f3e49ac273716a59cb1777cfc370540df53e6dc017e46c70a869da81fe490b2e6703d77d languageName: node linkType: hard @@ -18500,11 +18455,11 @@ __metadata: linkType: hard "react-github-btn@npm:^1.2.0": - version: 1.2.1 - resolution: "react-github-btn@npm:1.2.1" + version: 1.2.2 + resolution: "react-github-btn@npm:1.2.2" dependencies: - github-buttons: ^2.8.0 - checksum: 12c1b3631deef214ced7386b35fd73bbeb2d78742f409356955f475f22256b3af80b99ffa5bb185b66c63b4c34d75ad7a4cf1e947ef5ad3207f29f2fc28d58fc + github-buttons: ^2.21.1 + checksum: 8e6a2e187d0c300657ed6da00b51b8b8de8f7635e203285a835551aaedde796edb2b101f8bcfd06c25f0f1f4bc555d53cff32dc783152f744ff0715f5619c22c languageName: node linkType: hard @@ -18524,7 +18479,7 @@ __metadata: languageName: node linkType: hard -"react-is@npm:^16.12.0 || ^17.0.0, react-is@npm:^17.0.0, react-is@npm:^17.0.1, react-is@npm:^17.0.2": +"react-is@npm:^16.12.0 || ^17.0.0, react-is@npm:^17.0.1, react-is@npm:^17.0.2": version: 17.0.2 resolution: "react-is@npm:17.0.2" checksum: 9d6d111d8990dc98bc5402c1266a808b0459b5d54830bbea24c12d908b536df7883f268a7868cfaedde3dd9d4e0d574db456f84d2e6df9c4526f99bb4b5344d8 @@ -18538,6 +18493,13 @@ __metadata: languageName: node linkType: hard +"react-is@npm:^18.0.0": + version: 18.0.0 + resolution: "react-is@npm:18.0.0" + checksum: d38f6afee4d8d791cdd69c715841c01a503c9b06da6158e0893447cea6ba50cd262dca9bde84127720cf44fd05c58185eafc32accace4bb2deb03b3cdbeb6b6b + languageName: node + linkType: hard + "react-json-view@npm:^1.21.3": version: 1.21.3 resolution: "react-json-view@npm:1.21.3" @@ -18583,8 +18545,8 @@ __metadata: linkType: hard "react-markdown@npm:^8.0.0": - version: 8.0.1 - resolution: "react-markdown@npm:8.0.1" + version: 8.0.2 + resolution: "react-markdown@npm:8.0.2" dependencies: "@types/hast": ^2.0.0 "@types/prop-types": ^15.0.0 @@ -18593,7 +18555,7 @@ __metadata: hast-util-whitespace: ^2.0.0 prop-types: ^15.0.0 property-information: ^6.0.0 - react-is: ^17.0.0 + react-is: ^18.0.0 remark-parse: ^10.0.0 remark-rehype: ^10.0.0 space-separated-tokens: ^2.0.0 @@ -18604,7 +18566,7 @@ __metadata: peerDependencies: "@types/react": ">=16" react: ">=16" - checksum: 22a4bce581d43e3b5556166b1d00b646591955c7c1da0e0ec3d7acc5024d7c31256fd20d1ef814da0c1cdde4caf75023b8dddbe151b7b3405d7069b0fe5e9cbc + checksum: 9c7f4751bca31e1d2f5aa3dc2d1b564152999a8442857f1e9191b4d6fbbff9bee761511f05d52c30cf7dfbbb9fde51e8d9de9034cc3ca3929bc619ac4a825261 languageName: node linkType: hard @@ -18901,14 +18863,14 @@ __metadata: linkType: hard "read-package-json@npm:^4.1.1": - version: 4.1.1 - resolution: "read-package-json@npm:4.1.1" + version: 4.1.2 + resolution: "read-package-json@npm:4.1.2" dependencies: glob: ^7.1.1 json-parse-even-better-errors: ^2.3.0 normalize-package-data: ^3.0.0 npm-normalize-package-bin: ^1.0.0 - checksum: d95f6e9747bcce9bdbfae8442a86c41cde3a73691a8a8cdc46e0711e7768718e1f0955a38cbde01a6e571f490bbdc9d6a83713a89eca85646a816e659a78f6f4 + checksum: 729acda12fdbff6cee8cee7b6023a16e85c02406e2427b3cd091948d945940cfb6a6ebe7a8b4df967d483f360d0ec12fb83ab80de3e7bbb2ba2c426d07fd774e languageName: node linkType: hard @@ -19107,12 +19069,12 @@ __metadata: languageName: node linkType: hard -"regenerator-transform@npm:^0.14.2": - version: 0.14.5 - resolution: "regenerator-transform@npm:0.14.5" +"regenerator-transform@npm:^0.15.0": + version: 0.15.0 + resolution: "regenerator-transform@npm:0.15.0" dependencies: "@babel/runtime": ^7.8.4 - checksum: a467a3b652b4ec26ff964e9c5f1817523a73fc44cb928b8d21ff11aebeac5d10a84d297fe02cea9f282bcec81a0b0d562237da69ef0f40a0160b30a4fa98bc94 + checksum: 86e54849ab1167618d28bb56d214c52a983daf29b0d115c976d79840511420049b6b42c9ebdf187defa8e7129bdd74b6dd266420d0d3868c9fa7f793b5d15d49 languageName: node linkType: hard @@ -19126,7 +19088,7 @@ __metadata: languageName: node linkType: hard -"regexp.prototype.flags@npm:^1.2.0, regexp.prototype.flags@npm:^1.4.1": +"regexp.prototype.flags@npm:^1.4.1": version: 1.4.1 resolution: "regexp.prototype.flags@npm:1.4.1" dependencies: @@ -19460,7 +19422,7 @@ __metadata: languageName: node linkType: hard -"resolve@npm:^1.1.6, resolve@npm:^1.10.0, resolve@npm:^1.14.2, resolve@npm:^1.15.0, resolve@npm:^1.19.0, resolve@npm:^1.20.0, resolve@npm:^1.3.2": +"resolve@npm:^1.1.6, resolve@npm:^1.10.0, resolve@npm:^1.14.2, resolve@npm:^1.15.0, resolve@npm:^1.19.0, resolve@npm:^1.20.0, resolve@npm:^1.22.0, resolve@npm:^1.3.2": version: 1.22.0 resolution: "resolve@npm:1.22.0" dependencies: @@ -19492,7 +19454,7 @@ __metadata: languageName: node linkType: hard -"resolve@patch:resolve@^1.1.6#~builtin, resolve@patch:resolve@^1.10.0#~builtin, resolve@patch:resolve@^1.14.2#~builtin, resolve@patch:resolve@^1.15.0#~builtin, resolve@patch:resolve@^1.19.0#~builtin, resolve@patch:resolve@^1.20.0#~builtin, resolve@patch:resolve@^1.3.2#~builtin": +"resolve@patch:resolve@^1.1.6#~builtin, resolve@patch:resolve@^1.10.0#~builtin, resolve@patch:resolve@^1.14.2#~builtin, resolve@patch:resolve@^1.15.0#~builtin, resolve@patch:resolve@^1.19.0#~builtin, resolve@patch:resolve@^1.20.0#~builtin, resolve@patch:resolve@^1.22.0#~builtin, resolve@patch:resolve@^1.3.2#~builtin": version: 1.22.0 resolution: "resolve@patch:resolve@npm%3A1.22.0#~builtin::version=1.22.0&hash=07638b" dependencies: @@ -19862,12 +19824,12 @@ __metadata: languageName: node linkType: hard -"selfsigned@npm:^2.0.0": - version: 2.0.0 - resolution: "selfsigned@npm:2.0.0" +"selfsigned@npm:^2.0.1": + version: 2.0.1 + resolution: "selfsigned@npm:2.0.1" dependencies: - node-forge: ^1.2.0 - checksum: 43fca39a5aded2a8e97c1756af74c049a9dde12d47d302820f7d507d25c2ad7da4b04bc439a36620d63b4c0149bcf34ae7a729f978bf3b1bf48859c36ae34cee + node-forge: ^1 + checksum: 864e65c2f31ca877bce3ccdaa3bdef5e1e992b63b2a03641e00c24cd305bf2acce093431d1fed2e5ae9f526558db4be5e90baa2b3474c0428fcf7e25cc86ac93 languageName: node linkType: hard @@ -19908,13 +19870,13 @@ __metadata: linkType: hard "semver@npm:^7.1.1, semver@npm:^7.1.3, semver@npm:^7.3.2, semver@npm:^7.3.4, semver@npm:^7.3.5, semver@npm:~7.3.0": - version: 7.3.5 - resolution: "semver@npm:7.3.5" + version: 7.3.6 + resolution: "semver@npm:7.3.6" dependencies: - lru-cache: ^6.0.0 + lru-cache: ^7.4.0 bin: semver: bin/semver.js - checksum: 5eafe6102bea2a7439897c1856362e31cc348ccf96efd455c8b5bc2c61e6f7e7b8250dc26b8828c1d76a56f818a7ee907a36ae9fb37a599d3d24609207001d60 + checksum: 9845f96b22268190b30025e02feca391451f2bd49b2c51920c27cc56744f64cbe397df089018fdb347d4b4fd800eabbd85661870eb63eb28055d2b72e457f759 languageName: node linkType: hard @@ -20313,7 +20275,7 @@ __metadata: languageName: node linkType: hard -"socks@npm:^2.3.3, socks@npm:^2.6.1": +"socks@npm:^2.3.3, socks@npm:^2.6.1, socks@npm:^2.6.2": version: 2.6.2 resolution: "socks@npm:2.6.2" dependencies: @@ -20834,7 +20796,7 @@ __metadata: languageName: node linkType: hard -"strip-ansi@npm:^7.0.0, strip-ansi@npm:^7.0.1": +"strip-ansi@npm:^7.0.1": version: 7.0.1 resolution: "strip-ansi@npm:7.0.1" dependencies: @@ -21051,7 +21013,7 @@ __metadata: languageName: node linkType: hard -"tar@npm:^4.4.12": +"tar@npm:^4.4.12, tar@npm:^4.4.8": version: 4.4.19 resolution: "tar@npm:4.4.19" dependencies: @@ -21269,7 +21231,7 @@ __metadata: languageName: node linkType: hard -"timsort@npm:^0.3.0, timsort@npm:~0.3.0": +"timsort@npm:~0.3.0": version: 0.3.0 resolution: "timsort@npm:0.3.0" checksum: 1a66cb897dacabd7dd7c91b7e2301498ca9e224de2edb9e42d19f5b17c4b6dc62a8d4cbc64f28be82aaf1541cb5a78ab49aa818f42a2989ebe049a64af731e2a @@ -21474,8 +21436,8 @@ __metadata: linkType: hard "ts-node@npm:^10.5.0": - version: 10.5.0 - resolution: "ts-node@npm:10.5.0" + version: 10.7.0 + resolution: "ts-node@npm:10.7.0" dependencies: "@cspotcode/source-map-support": 0.7.0 "@tsconfig/node10": ^1.0.7 @@ -21503,22 +21465,23 @@ __metadata: bin: ts-node: dist/bin.js ts-node-cwd: dist/bin-cwd.js + ts-node-esm: dist/bin-esm.js ts-node-script: dist/bin-script.js ts-node-transpile-only: dist/bin-transpile.js ts-script: dist/bin-script-deprecated.js - checksum: d51ac8a9b3582ce3705cef8d35f3372e40caa277dbd7c7baeb651961538f13d2f11f22402614348f78d9b10501bd1cb5f05ec4f2ec9a74bd0e288de769c32335 + checksum: 2a379e43f7478d0b79e1e63af91fe222d83857727957df4bd3bdf3c0a884de5097b12feb9bbf530074526b8874c0338b0e6328cf334f3a5e2c49c71e837273f7 languageName: node linkType: hard -"tsconfig-paths@npm:^3.12.0, tsconfig-paths@npm:^3.9.0": - version: 3.12.0 - resolution: "tsconfig-paths@npm:3.12.0" +"tsconfig-paths@npm:^3.14.1": + version: 3.14.1 + resolution: "tsconfig-paths@npm:3.14.1" dependencies: "@types/json5": ^0.0.29 json5: ^1.0.1 - minimist: ^1.2.0 + minimist: ^1.2.6 strip-bom: ^3.0.0 - checksum: 4999ec6cd1c7cc06750a460dbc0d39fe3595a4308cb5f1d0d0a8283009cf9c0a30d5a156508c28fe3a47760508af5263ab288fc23d71e9762779674257a95d3b + checksum: 8afa01c673ebb4782ba53d3a12df97fa837ce524f8ad38ee4e2b2fd57f5ac79abc21c574e9e9eb014d93efe7fe8214001b96233b5c6ea75bd1ea82afe17a4c6d languageName: node linkType: hard @@ -21654,9 +21617,9 @@ __metadata: linkType: hard "type-fest@npm:^2.11.2, type-fest@npm:^2.5.0": - version: 2.12.1 - resolution: "type-fest@npm:2.12.1" - checksum: faac07668190b7709c16ba4696e42b6cc83b702fa11e8936ce94d9ed1415eb9034b157ae25bba23e222d755e031787f7b92552710704d55e39aadcc27f0ee1da + version: 2.12.2 + resolution: "type-fest@npm:2.12.2" + checksum: ee69676da1f69d2b14bbec28c7b95220a3221ab14093f54bde179c59e185a80470859553eada535ec35d8637a245c2f0efe9d7c99cc46a43f3b4c7ef64db7957 languageName: node linkType: hard @@ -21687,12 +21650,12 @@ __metadata: linkType: hard "typescript@npm:*, typescript@npm:^4.2.4": - version: 4.6.2 - resolution: "typescript@npm:4.6.2" + version: 4.6.3 + resolution: "typescript@npm:4.6.3" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: 8a44ed7e6f6c4cb1ebe8cf236ecda2fb119d84dcf0fbd77e707b2dfea1bbcfc4e366493a143513ce7f57203c75da9d4e20af6fe46de89749366351046be7577c + checksum: 255bb26c8cb846ca689dd1c3a56587af4f69055907aa2c154796ea28ee0dea871535b1c78f85a6212c77f2657843a269c3a742d09d81495b97b914bf7920415b languageName: node linkType: hard @@ -21707,12 +21670,12 @@ __metadata: linkType: hard "typescript@patch:typescript@*#~builtin, typescript@patch:typescript@^4.2.4#~builtin": - version: 4.6.2 - resolution: "typescript@patch:typescript@npm%3A4.6.2#~builtin::version=4.6.2&hash=bda367" + version: 4.6.3 + resolution: "typescript@patch:typescript@npm%3A4.6.3#~builtin::version=4.6.3&hash=bda367" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: 40b493a71747fb89fa70df104e2c4a5e284b43750af5bea024090a5261cefa387f7a9372411b13030f7bf5555cee4275443d08805642ae5c74ef76740854a4c7 + checksum: 6bf45caf847062420592e711bc9c28bf5f9a9a7fa8245343b81493e4ededae33f1774009d1234d911422d1646a2c839f44e1a23ecb111b40a60ac2ea4c1482a8 languageName: node linkType: hard @@ -21746,11 +21709,11 @@ __metadata: linkType: hard "uglify-js@npm:^3.1.4": - version: 3.15.1 - resolution: "uglify-js@npm:3.15.1" + version: 3.15.3 + resolution: "uglify-js@npm:3.15.3" bin: uglifyjs: bin/uglifyjs - checksum: cf88574ec8af4d69368142a3f9fb83ac11b1344a117dff08890fcf99ed12c782c810f02e71a0c2a7e8666ea6225894f1c171cbd90e1a1fe4b2c4a198f8ad61a3 + checksum: 5d2f5a8591b84d81317783205ba26c7a94c435476c19df8612024d28986acbe1f5dbd65bc604134a8557a3f64e8a5ed2660d11e2ba74b59af1fe531fd5506b16 languageName: node linkType: hard @@ -21954,11 +21917,11 @@ __metadata: linkType: hard "unist-util-position@npm:^4.0.0": - version: 4.0.2 - resolution: "unist-util-position@npm:4.0.2" + version: 4.0.3 + resolution: "unist-util-position@npm:4.0.3" dependencies: "@types/unist": ^2.0.0 - checksum: 6da7320689c387c6c4740c8d27edc42c4582ee19736143604005ccad51b1239d65fed29b7bf966a778935985d5a6036e27dc35108d050a94a9757dbf76bf2d10 + checksum: 0d89973628d40f19345cbcc50008f7f56d411afa54434bbe6c224b22d26aaf9d4500da2de363f1f01945acab1f1c31920c514253149eb546ff9b8bbc1ea94209 languageName: node linkType: hard @@ -22187,14 +22150,14 @@ __metadata: linkType: hard "use-isomorphic-layout-effect@npm:^1.0.0": - version: 1.1.1 - resolution: "use-isomorphic-layout-effect@npm:1.1.1" + version: 1.1.2 + resolution: "use-isomorphic-layout-effect@npm:1.1.2" peerDependencies: - react: ^16.8.0 || ^17.0.0 + react: ^16.8.0 || ^17.0.0 || ^18.0.0 peerDependenciesMeta: "@types/react": optional: true - checksum: fd9061817d4945af37fd79866b1fe96a09cafe873169a66ec699140b609c64db6c60512d94ec3ca90967837026ea6e6d003901c557693708aeee11d392418a9e + checksum: a6532f7fc9ae222c3725ff0308aaf1f1ddbd3c00d685ef9eee6714fd0684de5cb9741b432fbf51e61a784e2955424864f7ea9f99734a02f237b17ad3e18ea5cb languageName: node linkType: hard @@ -22594,37 +22557,36 @@ __metadata: linkType: hard "webpack-dev-server@npm:^4.7.4": - version: 4.7.4 - resolution: "webpack-dev-server@npm:4.7.4" + version: 4.8.1 + resolution: "webpack-dev-server@npm:4.8.1" dependencies: "@types/bonjour": ^3.5.9 "@types/connect-history-api-fallback": ^1.3.5 "@types/express": ^4.17.13 "@types/serve-index": ^1.9.1 "@types/sockjs": ^0.3.33 - "@types/ws": ^8.2.2 + "@types/ws": ^8.5.1 ansi-html-community: ^0.0.8 - bonjour: ^3.5.0 + bonjour-service: ^1.0.11 chokidar: ^3.5.3 colorette: ^2.0.10 compression: ^1.7.4 connect-history-api-fallback: ^1.6.0 default-gateway: ^6.0.3 - del: ^6.0.0 - express: ^4.17.1 + express: ^4.17.3 graceful-fs: ^4.2.6 html-entities: ^2.3.2 - http-proxy-middleware: ^2.0.0 + http-proxy-middleware: ^2.0.3 ipaddr.js: ^2.0.1 open: ^8.0.9 p-retry: ^4.5.0 portfinder: ^1.0.28 + rimraf: ^3.0.2 schema-utils: ^4.0.0 - selfsigned: ^2.0.0 + selfsigned: ^2.0.1 serve-index: ^1.9.1 sockjs: ^0.3.21 spdy: ^4.0.2 - strip-ansi: ^7.0.0 webpack-dev-middleware: ^5.3.1 ws: ^8.4.2 peerDependencies: @@ -22634,7 +22596,7 @@ __metadata: optional: true bin: webpack-dev-server: bin/webpack-dev-server.js - checksum: 58a7664e32144bdc4a720a044e685d6b4c030290875a06440d3f2471163d636a2be02b8b85168d554ecf3b0a41e7ba9fa3cd16f3bbdfee87b02fbb5329a8efa3 + checksum: 6f827068353cb024f04edd275ae2828b6d47a3316c1a8677066d1500b1d1038b516399777792bb464ec40bc6f963abe9b24a5fd93b9b39487a3574b38ae45fd6 languageName: node linkType: hard @@ -22666,8 +22628,8 @@ __metadata: linkType: hard "webpack@npm:^5.70.0": - version: 5.70.0 - resolution: "webpack@npm:5.70.0" + version: 5.72.0 + resolution: "webpack@npm:5.72.0" dependencies: "@types/eslint-scope": ^3.7.3 "@types/estree": ^0.0.51 @@ -22698,7 +22660,7 @@ __metadata: optional: true bin: webpack: bin/webpack.js - checksum: 00439884a9cdd5305aed3ce93735635785a15c5464a6d2cfce87e17727a07585de02420913e82aa85ddd2ae7322175d2cfda6ac0878a17f061cb605e6a7db57a + checksum: 8365f1466d0f7adbf80ebc9b780f263a28eeeabcd5fb515249bfd9a56ab7fe8d29ea53df3d9364d0732ab39ae774445eb28abce694ed375b13882a6b2fe93ffc languageName: node linkType: hard @@ -22851,7 +22813,7 @@ __metadata: languageName: node linkType: hard -"wide-align@npm:^1.1.0, wide-align@npm:^1.1.2": +"wide-align@npm:^1.1.0, wide-align@npm:^1.1.5": version: 1.1.5 resolution: "wide-align@npm:1.1.5" dependencies: @@ -23381,9 +23343,9 @@ __metadata: linkType: hard "yargs-parser@npm:^21.0.0": - version: 21.0.0 - resolution: "yargs-parser@npm:21.0.0" - checksum: 1e205fca1cb7a36a1585e2b94a64e641c12741b53627d338e12747f4dca3c3610cdd9bb235040621120548dd74c3ef03a8168d52a1eabfedccbe4a62462b6731 + version: 21.0.1 + resolution: "yargs-parser@npm:21.0.1" + checksum: c3ea2ed12cad0377ce3096b3f138df8267edf7b1aa7d710cd502fe16af417bafe4443dd71b28158c22fcd1be5dfd0e86319597e47badf42ff83815485887323a languageName: node linkType: hard @@ -23422,8 +23384,8 @@ __metadata: linkType: hard "yargs@npm:^17.3.1": - version: 17.3.1 - resolution: "yargs@npm:17.3.1" + version: 17.4.0 + resolution: "yargs@npm:17.4.0" dependencies: cliui: ^7.0.2 escalade: ^3.1.1 @@ -23432,7 +23394,7 @@ __metadata: string-width: ^4.2.3 y18n: ^5.0.5 yargs-parser: ^21.0.0 - checksum: 64fc2e32c56739f1d14d2d24acd17a6944c3c8e3e3558f09fc1953ac112e868cc16013d282886b9d5be22187f8b9ed4f60741a6b1011f595ce2718805a656852 + checksum: 63985bddddf1fb6b9c98744591e8b70f99839591521cb84eea60903d52ec0da35ab46c42c325d151f3ab5c41935f976c10da096b5a7067c217714a91c0bd4be3 languageName: node linkType: hard @@ -23478,11 +23440,11 @@ __metadata: linkType: hard "zone.js@npm:~0.11.3": - version: 0.11.4 - resolution: "zone.js@npm:0.11.4" + version: 0.11.5 + resolution: "zone.js@npm:0.11.5" dependencies: - tslib: ^2.0.0 - checksum: 20c3e39898019de4747a434a29ed528e5d730a674570c3e72775a57f9d57dba812e70d67c3932ff54e95db9b778f06a9b18119c5184dfd9552d3622544a6729f + tslib: ^2.3.0 + checksum: 7dba3af83cc68e881e8a5cc549e4a7bab5f32c5289838f14eb251871816210a39ed8bcd89030593b56d469b4aa8271d644e71ad408fcadd4ccd61b8c7203f2ef languageName: node linkType: hard From 051af02d0dd9922702caffcad7223cd5aec9f062 Mon Sep 17 00:00:00 2001 From: Udit Takkar <53316345+Udit-takkar@users.noreply.github.com> Date: Fri, 8 Apr 2022 15:28:30 +0530 Subject: [PATCH 032/128] fix: rename config option name to id (#11981) --- CHANGELOG.md | 1 + .../__snapshots__/showConfig.test.ts.snap | 2 +- e2e/__tests__/multiProjectRunner.test.ts | 28 ++++++------- e2e/__tests__/showConfig.test.ts | 2 +- e2e/custom-haste-map/hasteMap.js | 6 +-- packages/jest-config/src/ValidConfig.ts | 2 +- .../src/__tests__/normalize.test.ts | 18 ++++---- packages/jest-config/src/index.ts | 2 +- packages/jest-config/src/normalize.ts | 6 +-- .../src/__tests__/SearchSource.test.ts | 42 +++++++++---------- .../logDebugMessages.test.ts.snap | 2 +- .../src/__tests__/index.test.js | 6 +-- packages/jest-haste-map/src/index.ts | 17 ++++---- packages/jest-runner/src/index.ts | 4 +- packages/jest-runner/src/testWorker.ts | 6 +-- .../src/__mocks__/createRuntime.js | 2 +- packages/jest-runtime/src/index.ts | 2 +- .../src/__tests__/test_sequencer.test.ts | 4 +- packages/jest-test-sequencer/src/index.ts | 2 +- .../jest-transform/src/ScriptTransformer.ts | 2 +- .../src/__tests__/ScriptTransformer.test.ts | 2 +- .../ScriptTransformer.test.ts.snap | 22 +++++----- packages/jest-types/src/Config.ts | 4 +- .../src/__tests__/fixtures/jestConfig.ts | 2 +- packages/test-utils/src/config.ts | 2 +- 25 files changed, 93 insertions(+), 95 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 55e39de6c6ea..b443c26b5344 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -94,6 +94,7 @@ - `[expect]` [**BREAKING**] Snapshot matcher types are moved to `@jest/expect` ([#12404](https://github.com/facebook/jest/pull/12404)) - `[jest-cli]` Update `yargs` to v17 ([#12357](https://github.com/facebook/jest/pull/12357)) - `[jest-config]` [**BREAKING**] Remove `getTestEnvironment` export ([#12353](https://github.com/facebook/jest/pull/12353)) +- `[jest-config]` [**BREAKING**] Rename config option `name` to `id` ([#11981](https://github.com/facebook/jest/pull/11981)) - `[jest-create-cache-key-function]` Added README.md file with basic usage instructions ([#12492](https://github.com/facebook/jest/pull/12492)) - `[@jest/core]` Use `index.ts` instead of `jest.ts` as main export ([#12329](https://github.com/facebook/jest/pull/12329)) - `[jest-environment-jsdom]` [**BREAKING**] Migrate to ESM ([#12340](https://github.com/facebook/jest/pull/12340)) diff --git a/e2e/__tests__/__snapshots__/showConfig.test.ts.snap b/e2e/__tests__/__snapshots__/showConfig.test.ts.snap index dd05871f8ae6..82e8281b2cad 100644 --- a/e2e/__tests__/__snapshots__/showConfig.test.ts.snap +++ b/e2e/__tests__/__snapshots__/showConfig.test.ts.snap @@ -27,6 +27,7 @@ exports[`--showConfig outputs config info and exits 1`] = ` "forceNodeFilesystemAPI": true, "throwOnModuleCollision": false }, + "id": "[md5 hash]", "injectGlobals": true, "moduleDirectories": [ "node_modules" @@ -43,7 +44,6 @@ exports[`--showConfig outputs config info and exits 1`] = ` ], "moduleNameMapper": [], "modulePathIgnorePatterns": [], - "name": "[md5 hash]", "prettierPath": "prettier", "resetMocks": false, "resetModules": false, diff --git a/e2e/__tests__/multiProjectRunner.test.ts b/e2e/__tests__/multiProjectRunner.test.ts index fc17f55e931c..c9ad5b0bf811 100644 --- a/e2e/__tests__/multiProjectRunner.test.ts +++ b/e2e/__tests__/multiProjectRunner.test.ts @@ -346,7 +346,7 @@ test('resolves projects and their properly', () => { }, }), 'project1.conf.json': JSON.stringify({ - name: 'project1', + id: 'project1', rootDir: './project1', // root dir should be this project's directory setupFiles: ['/project1_setup.js'], @@ -358,7 +358,7 @@ test('resolves projects and their properly', () => { 'project2/__tests__/test.test.js': "test('project2', () => expect(globalThis.project2).toBe(true))", 'project2/project2.conf.json': JSON.stringify({ - name: 'project2', + id: 'project2', rootDir: '../', // root dir is set to the top level setupFiles: ['/project2/project2_setup.js'], // rootDir shold be of the testEnvironment: 'node', @@ -514,13 +514,13 @@ describe("doesn't bleed module file extensions resolution with multiple workers" expect(configs).toHaveLength(2); - const [{name: name1}, {name: name2}] = configs; + const [{id: id1}, {id: id2}] = configs; - expect(name1).toEqual(expect.any(String)); - expect(name2).toEqual(expect.any(String)); - expect(name1).toHaveLength(32); - expect(name2).toHaveLength(32); - expect(name1).not.toEqual(name2); + expect(id1).toEqual(expect.any(String)); + expect(id2).toEqual(expect.any(String)); + expect(id1).toHaveLength(32); + expect(id2).toHaveLength(32); + expect(id1).not.toEqual(id2); const {stderr} = runJest(DIR, [ '--no-watchman', @@ -557,13 +557,13 @@ describe("doesn't bleed module file extensions resolution with multiple workers" expect(configs).toHaveLength(2); - const [{name: name1}, {name: name2}] = configs; + const [{id: id1}, {id: id2}] = configs; - expect(name1).toEqual(expect.any(String)); - expect(name2).toEqual(expect.any(String)); - expect(name1).toHaveLength(32); - expect(name2).toHaveLength(32); - expect(name1).not.toEqual(name2); + expect(id1).toEqual(expect.any(String)); + expect(id2).toEqual(expect.any(String)); + expect(id1).toHaveLength(32); + expect(id2).toHaveLength(32); + expect(id1).not.toEqual(id2); const {stderr} = runJest(DIR, ['--no-watchman', '-w=2']); diff --git a/e2e/__tests__/showConfig.test.ts b/e2e/__tests__/showConfig.test.ts index f0c545d28c19..41570e07e1da 100644 --- a/e2e/__tests__/showConfig.test.ts +++ b/e2e/__tests__/showConfig.test.ts @@ -33,7 +33,7 @@ test('--showConfig outputs config info and exits', () => { .replace(/\\\\\.pnp\\\\\.\[\^[/\\]+\]\+\$/g, '<>') .replace(/\\\\(?:([^.]+?)|$)/g, '/$1') .replace(/"cacheDirectory": "(.+)"/g, '"cacheDirectory": "/tmp/jest"') - .replace(/"name": "(.+)"/g, '"name": "[md5 hash]"') + .replace(/"id": "(.+)"/g, '"id": "[md5 hash]"') .replace(/"version": "(.+)"/g, '"version": "[version]"') .replace(/"maxWorkers": (\d+)/g, '"maxWorkers": "[maxWorkers]"') .replace(/"\S*show-config-test/gm, '"<>') diff --git a/e2e/custom-haste-map/hasteMap.js b/e2e/custom-haste-map/hasteMap.js index a7a5bcfb99e4..d132db0ea181 100644 --- a/e2e/custom-haste-map/hasteMap.js +++ b/e2e/custom-haste-map/hasteMap.js @@ -109,7 +109,7 @@ class HasteMap { constructor(options) { this._cachePath = HasteMap.getCacheFilePath( options.cacheDirectory, - options.name, + options.id, ); } @@ -120,8 +120,8 @@ class HasteMap { }; } - static getCacheFilePath(tmpdir, name) { - return path.join(tmpdir, name); + static getCacheFilePath(tmpdir, id) { + return path.join(tmpdir, id); } getCacheFilePath() { diff --git a/packages/jest-config/src/ValidConfig.ts b/packages/jest-config/src/ValidConfig.ts index 4cac317e0971..18b083bbb8bf 100644 --- a/packages/jest-config/src/ValidConfig.ts +++ b/packages/jest-config/src/ValidConfig.ts @@ -90,6 +90,7 @@ const initialOptions: Config.InitialOptions = { retainAllFiles: false, throwOnModuleCollision: false, }, + id: 'string', injectGlobals: true, json: false, lastCommit: false, @@ -113,7 +114,6 @@ const initialOptions: Config.InitialOptions = { }, modulePathIgnorePatterns: ['/build/'], modulePaths: ['/shared/vendor/modules'], - name: 'string', noStackTrace: false, notify: false, notifyMode: 'failure-change', diff --git a/packages/jest-config/src/__tests__/normalize.test.ts b/packages/jest-config/src/__tests__/normalize.test.ts index 077b3be65d02..d4e264ccebae 100644 --- a/packages/jest-config/src/__tests__/normalize.test.ts +++ b/packages/jest-config/src/__tests__/normalize.test.ts @@ -66,7 +66,7 @@ afterEach(() => { (console.warn as unknown as jest.SpyInstance).mockRestore(); }); -it('picks a name based on the rootDir', async () => { +it('picks an id based on the rootDir', async () => { const rootDir = '/root/path/foo'; const expected = createHash('md5') .update('/root/path/foo') @@ -78,32 +78,32 @@ it('picks a name based on the rootDir', async () => { }, {} as Config.Argv, ); - expect(options.name).toBe(expected); + expect(options.id).toBe(expected); }); -it('keeps custom project name based on the projects rootDir', async () => { - const name = 'test'; +it('keeps custom project id based on the projects rootDir', async () => { + const id = 'test'; const {options} = await normalize( { - projects: [{name, rootDir: '/path/to/foo'}], + projects: [{id, rootDir: '/path/to/foo'}], rootDir: '/root/path/baz', }, {} as Config.Argv, ); - expect(options.projects[0].name).toBe(name); + expect(options.projects[0].id).toBe(id); }); -it('keeps custom names based on the rootDir', async () => { +it('keeps custom ids based on the rootDir', async () => { const {options} = await normalize( { - name: 'custom-name', + id: 'custom-id', rootDir: '/root/path/foo', }, {} as Config.Argv, ); - expect(options.name).toBe('custom-name'); + expect(options.id).toBe('custom-id'); }); it('minimal config is stable across runs', async () => { diff --git a/packages/jest-config/src/index.ts b/packages/jest-config/src/index.ts index e44d23bc5f23..5728f473e5cc 100644 --- a/packages/jest-config/src/index.ts +++ b/packages/jest-config/src/index.ts @@ -192,13 +192,13 @@ const groupOptions = ( globalTeardown: options.globalTeardown, globals: options.globals, haste: options.haste, + id: options.id, injectGlobals: options.injectGlobals, moduleDirectories: options.moduleDirectories, moduleFileExtensions: options.moduleFileExtensions, moduleNameMapper: options.moduleNameMapper, modulePathIgnorePatterns: options.modulePathIgnorePatterns, modulePaths: options.modulePaths, - name: options.name, prettierPath: options.prettierPath, resetMocks: options.resetMocks, resetModules: options.resetModules, diff --git a/packages/jest-config/src/normalize.ts b/packages/jest-config/src/normalize.ts index a07ec04a372a..7f22cb5e72e7 100644 --- a/packages/jest-config/src/normalize.ts +++ b/packages/jest-config/src/normalize.ts @@ -370,8 +370,8 @@ const normalizeMissingOptions = ( configPath: string | null | undefined, projectIndex: number, ): Config.InitialOptionsWithRootDir => { - if (!options.name) { - options.name = createHash('md5') + if (!options.id) { + options.id = createHash('md5') .update(options.rootDir) // In case we load config from some path that has the same root dir .update(configPath || '') @@ -989,7 +989,7 @@ export default async function normalize( case 'listTests': case 'logHeapUsage': case 'maxConcurrency': - case 'name': + case 'id': case 'noStackTrace': case 'notify': case 'notifyMode': diff --git a/packages/jest-core/src/__tests__/SearchSource.test.ts b/packages/jest-core/src/__tests__/SearchSource.test.ts index 25e53955a382..7e4af257a870 100644 --- a/packages/jest-core/src/__tests__/SearchSource.test.ts +++ b/packages/jest-core/src/__tests__/SearchSource.test.ts @@ -57,13 +57,13 @@ const initSearchSource = async ( }; describe('SearchSource', () => { - const name = 'SearchSource'; + const id = 'SearchSource'; let searchSource: SearchSource; describe('isTestFilePath', () => { beforeEach(async () => { searchSource = await initSearchSource({ - name, + id, rootDir: '.', roots: [], }); @@ -76,7 +76,7 @@ describe('SearchSource', () => { return; } const searchSource = await initSearchSource({ - name, + id, rootDir: '.', roots: [], testMatch: undefined, @@ -113,8 +113,8 @@ describe('SearchSource', () => { it('finds tests matching a pattern via testRegex', async () => { const paths = await getTestPaths({ + id, moduleFileExtensions: ['js', 'jsx', 'txt'], - name, rootDir, testMatch: undefined, testRegex: 'not-really-a-test', @@ -127,8 +127,8 @@ describe('SearchSource', () => { it('finds tests matching a pattern via testMatch', async () => { const paths = await getTestPaths({ + id, moduleFileExtensions: ['js', 'jsx', 'txt'], - name, rootDir, testMatch: ['**/not-really-a-test.txt', '!**/do-not-match-me.txt'], testRegex: '', @@ -141,8 +141,8 @@ describe('SearchSource', () => { it('finds tests matching a JS regex pattern', async () => { const paths = await getTestPaths({ + id, moduleFileExtensions: ['js', 'jsx'], - name, rootDir, testMatch: undefined, testRegex: 'test.jsx?', @@ -155,8 +155,8 @@ describe('SearchSource', () => { it('finds tests matching a JS glob pattern', async () => { const paths = await getTestPaths({ + id, moduleFileExtensions: ['js', 'jsx'], - name, rootDir, testMatch: ['**/test.js?(x)'], testRegex: '', @@ -169,8 +169,8 @@ describe('SearchSource', () => { it('finds tests matching a JS with overriding glob patterns', async () => { const paths = await getTestPaths({ + id, moduleFileExtensions: ['js', 'jsx'], - name, rootDir, testMatch: [ '**/*.js?(x)', @@ -188,7 +188,7 @@ describe('SearchSource', () => { it('finds tests with default file extensions using testRegex', async () => { const paths = await getTestPaths({ - name, + id, rootDir, testMatch: undefined, testRegex, @@ -201,7 +201,7 @@ describe('SearchSource', () => { it('finds tests with default file extensions using testMatch', async () => { const paths = await getTestPaths({ - name, + id, rootDir, testMatch, testRegex: '', @@ -214,7 +214,7 @@ describe('SearchSource', () => { it('finds tests with parentheses in their rootDir when using testMatch', async () => { const paths = await getTestPaths({ - name, + id, rootDir: path.resolve(__dirname, 'test_root_with_(parentheses)'), testMatch: ['**/__testtests__/**/*'], testRegex: undefined, @@ -226,8 +226,8 @@ describe('SearchSource', () => { it('finds tests with similar but custom file extensions', async () => { const paths = await getTestPaths({ + id, moduleFileExtensions: ['js', 'jsx'], - name, rootDir, testMatch, }); @@ -239,8 +239,8 @@ describe('SearchSource', () => { it('finds tests with totally custom foobar file extensions', async () => { const paths = await getTestPaths({ + id, moduleFileExtensions: ['js', 'foobar'], - name, rootDir, testMatch, }); @@ -252,8 +252,8 @@ describe('SearchSource', () => { it('finds tests with many kinds of file extensions', async () => { const paths = await getTestPaths({ + id, moduleFileExtensions: ['js', 'jsx'], - name, rootDir, testMatch, }); @@ -265,7 +265,7 @@ describe('SearchSource', () => { it('finds tests using a regex only', async () => { const paths = await getTestPaths({ - name, + id, rootDir, testMatch: undefined, testRegex, @@ -278,7 +278,7 @@ describe('SearchSource', () => { it('finds tests using a glob only', async () => { const paths = await getTestPaths({ - name, + id, rootDir, testMatch, testRegex: '', @@ -294,7 +294,7 @@ describe('SearchSource', () => { beforeEach(async () => { searchSource = await initSearchSource( { - name, + id, rootDir: '.', roots: [], }, @@ -385,7 +385,7 @@ describe('SearchSource', () => { 'haste_impl.js', ), }, - name: 'SearchSource-findRelatedTests-tests', + id: 'SearchSource-findRelatedTests-tests', rootDir, }); }); @@ -432,8 +432,8 @@ describe('SearchSource', () => { describe('findRelatedTestsFromPattern', () => { beforeEach(async () => { searchSource = await initSearchSource({ + id, moduleFileExtensions: ['js', 'jsx', 'foobar'], - name, rootDir, testMatch, }); @@ -484,7 +484,7 @@ describe('SearchSource', () => { return; } searchSource = await initSearchSource({ - name, + id, rootDir: '.', roots: ['/foo/bar/prefix'], }); @@ -509,7 +509,7 @@ describe('SearchSource', () => { '../../../jest-haste-map/src/__tests__/haste_impl.js', ), }, - name: 'SearchSource-findRelatedSourcesFromTestsInChangedFiles-tests', + id: 'SearchSource-findRelatedSourcesFromTestsInChangedFiles-tests', rootDir, }); }); diff --git a/packages/jest-core/src/lib/__tests__/__snapshots__/logDebugMessages.test.ts.snap b/packages/jest-core/src/lib/__tests__/__snapshots__/logDebugMessages.test.ts.snap index fb42e183f896..b27bc6754017 100644 --- a/packages/jest-core/src/lib/__tests__/__snapshots__/logDebugMessages.test.ts.snap +++ b/packages/jest-core/src/lib/__tests__/__snapshots__/logDebugMessages.test.ts.snap @@ -19,6 +19,7 @@ exports[`prints the config object 1`] = ` "forceCoverageMatch": [], "globals": {}, "haste": {}, + "id": "test_name", "injectGlobals": true, "moduleDirectories": [], "moduleFileExtensions": [ @@ -27,7 +28,6 @@ exports[`prints the config object 1`] = ` "moduleNameMapper": [], "modulePathIgnorePatterns": [], "modulePaths": [], - "name": "test_name", "prettierPath": "prettier", "resetMocks": false, "resetModules": false, diff --git a/packages/jest-haste-map/src/__tests__/index.test.js b/packages/jest-haste-map/src/__tests__/index.test.js index 454995640051..7aeb7fec76f4 100644 --- a/packages/jest-haste-map/src/__tests__/index.test.js +++ b/packages/jest-haste-map/src/__tests__/index.test.js @@ -206,8 +206,8 @@ describe('HasteMap', () => { defaultConfig = { extensions: ['js', 'json'], hasteImplModulePath: require.resolve('./haste_impl.js'), + id: 'haste-map-test', maxWorkers: 1, - name: 'haste-map-test', platforms: ['ios', 'android'], resetCache: false, rootDir: path.join('/', 'project'), @@ -300,11 +300,11 @@ describe('HasteMap', () => { const HasteMap = require('../').default; const hasteMap1 = await HasteMap.create({ ...defaultConfig, - name: '@scoped/package', + id: '@scoped/package', }); const hasteMap2 = await HasteMap.create({ ...defaultConfig, - name: '-scoped-package', + id: '-scoped-package', }); expect(hasteMap1.getCacheFilePath()).not.toBe(hasteMap2.getCacheFilePath()); }); diff --git a/packages/jest-haste-map/src/index.ts b/packages/jest-haste-map/src/index.ts index 84d2eb2f0f5a..76d16bcfde5e 100644 --- a/packages/jest-haste-map/src/index.ts +++ b/packages/jest-haste-map/src/index.ts @@ -65,10 +65,10 @@ type Options = { forceNodeFilesystemAPI?: boolean; hasteImplModulePath?: string; hasteMapModulePath?: string; + id: string; ignorePattern?: HasteRegExp; maxWorkers: number; mocksPattern?: string; - name: string; platforms: Array; resetCache?: boolean; retainAllFiles: boolean; @@ -89,10 +89,10 @@ type InternalOptions = { extensions: Array; forceNodeFilesystemAPI: boolean; hasteImplModulePath?: string; + id: string; ignorePattern?: HasteRegExp; maxWorkers: number; mocksPattern: RegExp | null; - name: string; platforms: Array; resetCache?: boolean; retainAllFiles: boolean; @@ -258,11 +258,11 @@ export default class HasteMap extends EventEmitter { extensions: options.extensions, forceNodeFilesystemAPI: !!options.forceNodeFilesystemAPI, hasteImplModulePath: options.hasteImplModulePath, + id: options.id, maxWorkers: options.maxWorkers, mocksPattern: options.mocksPattern ? new RegExp(options.mocksPattern) : null, - name: options.name, platforms: options.platforms, resetCache: options.resetCache, retainAllFiles: options.retainAllFiles, @@ -329,9 +329,9 @@ export default class HasteMap extends EventEmitter { this._cachePath = HasteMap.getCacheFilePath( this._options.cacheDirectory, - `haste-map-${this._options.name}-${rootDirHash}`, + `haste-map-${this._options.id}-${rootDirHash}`, VERSION, - this._options.name, + this._options.id, this._options.roots .map(root => fastPath.relative(options.rootDir, root)) .join(':'), @@ -348,14 +348,11 @@ export default class HasteMap extends EventEmitter { static getCacheFilePath( tmpdir: string, - name: string, + id: string, ...extra: Array ): string { const hash = createHash('md5').update(extra.join('')); - return path.join( - tmpdir, - `${name.replace(/\W/g, '-')}-${hash.digest('hex')}`, - ); + return path.join(tmpdir, `${id.replace(/\W/g, '-')}-${hash.digest('hex')}`); } static getModuleMapFromJSON(json: SerializableModuleMap): HasteModuleMap { diff --git a/packages/jest-runner/src/index.ts b/packages/jest-runner/src/index.ts index c5b7dcfc0584..7a1f0a5a94b1 100644 --- a/packages/jest-runner/src/index.ts +++ b/packages/jest-runner/src/index.ts @@ -100,8 +100,8 @@ export default class TestRunner extends EmittingTestRunner { async #createParallelTestRun(tests: Array, watcher: TestWatcher) { const resolvers: Map = new Map(); for (const test of tests) { - if (!resolvers.has(test.context.config.name)) { - resolvers.set(test.context.config.name, { + if (!resolvers.has(test.context.config.id)) { + resolvers.set(test.context.config.id, { config: test.context.config, serializableModuleMap: test.context.moduleMap.toJSON(), }); diff --git a/packages/jest-runner/src/testWorker.ts b/packages/jest-runner/src/testWorker.ts index 4962bffc8701..f18c92ce9f05 100644 --- a/packages/jest-runner/src/testWorker.ts +++ b/packages/jest-runner/src/testWorker.ts @@ -59,9 +59,9 @@ const formatError = (error: string | ErrorWithCode): SerializableError => { const resolvers = new Map(); const getResolver = (config: Config.ProjectConfig) => { - const resolver = resolvers.get(config.name); + const resolver = resolvers.get(config.id); if (!resolver) { - throw new Error(`Cannot find resolver for: ${config.name}`); + throw new Error(`Cannot find resolver for: ${config.id}`); } return resolver; }; @@ -77,7 +77,7 @@ export function setup(setupData: { const moduleMap = HasteMap.getStatic(config).getModuleMapFromJSON( serializableModuleMap, ); - resolvers.set(config.name, Runtime.createResolver(config, moduleMap)); + resolvers.set(config.id, Runtime.createResolver(config, moduleMap)); } } diff --git a/packages/jest-runtime/src/__mocks__/createRuntime.js b/packages/jest-runtime/src/__mocks__/createRuntime.js index 67f9e2be9c1c..c562ee7a74fe 100644 --- a/packages/jest-runtime/src/__mocks__/createRuntime.js +++ b/packages/jest-runtime/src/__mocks__/createRuntime.js @@ -69,9 +69,9 @@ module.exports = async function createRuntime(filename, projectConfig) { 'haste_impl.js', ), }, + id: `Runtime-${filename.replace(/\W/, '-')}.tests`, moduleDirectories: ['node_modules'], moduleFileExtensions: ['js', 'jsx', 'ts', 'tsx', 'json', 'node'], - name: `Runtime-${filename.replace(/\W/, '-')}.tests`, rootDir, ...projectConfig, moduleNameMapper, diff --git a/packages/jest-runtime/src/index.ts b/packages/jest-runtime/src/index.ts index abc76358872b..17f69ced6dc3 100644 --- a/packages/jest-runtime/src/index.ts +++ b/packages/jest-runtime/src/index.ts @@ -376,10 +376,10 @@ export default class Runtime { forceNodeFilesystemAPI: config.haste.forceNodeFilesystemAPI, hasteImplModulePath: config.haste.hasteImplModulePath, hasteMapModulePath: config.haste.hasteMapModulePath, + id: config.id, ignorePattern, maxWorkers: options?.maxWorkers || 1, mocksPattern: escapePathForRegex(`${path.sep}__mocks__${path.sep}`), - name: config.name, platforms: config.haste.platforms || ['ios', 'android'], resetCache: options?.resetCache, retainAllFiles: config.haste.retainAllFiles || false, diff --git a/packages/jest-test-sequencer/src/__tests__/test_sequencer.test.ts b/packages/jest-test-sequencer/src/__tests__/test_sequencer.test.ts index 7d7a937ab5a9..4830a53d1040 100644 --- a/packages/jest-test-sequencer/src/__tests__/test_sequencer.test.ts +++ b/packages/jest-test-sequencer/src/__tests__/test_sequencer.test.ts @@ -29,7 +29,7 @@ const context: Context = { cache: true, cacheDirectory: '/cache', haste: {}, - name: 'test', + id: 'test', }), hasteFS: { getSize: path => path.length, @@ -41,7 +41,7 @@ const secondContext: Context = { cache: true, cacheDirectory: '/cache2', haste: {}, - name: 'test2', + id: 'test2', }), hasteFS: { getSize: path => path.length, diff --git a/packages/jest-test-sequencer/src/index.ts b/packages/jest-test-sequencer/src/index.ts index 4b103f8a7725..711765dd2cd8 100644 --- a/packages/jest-test-sequencer/src/index.ts +++ b/packages/jest-test-sequencer/src/index.ts @@ -46,7 +46,7 @@ export default class TestSequencer { const HasteMapClass = HasteMap.getStatic(config); return HasteMapClass.getCacheFilePath( config.cacheDirectory, - `perf-cache-${config.name}`, + `perf-cache-${config.id}`, ); } diff --git a/packages/jest-transform/src/ScriptTransformer.ts b/packages/jest-transform/src/ScriptTransformer.ts index 3472042669b4..1c78f616f4bc 100644 --- a/packages/jest-transform/src/ScriptTransformer.ts +++ b/packages/jest-transform/src/ScriptTransformer.ts @@ -211,7 +211,7 @@ class ScriptTransformer { const HasteMapClass = HasteMap.getStatic(this._config); const baseCacheDir = HasteMapClass.getCacheFilePath( this._config.cacheDirectory, - `jest-transform-cache-${this._config.name}`, + `jest-transform-cache-${this._config.id}`, VERSION, ); // Create sub folders based on the cacheKey to avoid creating one diff --git a/packages/jest-transform/src/__tests__/ScriptTransformer.test.ts b/packages/jest-transform/src/__tests__/ScriptTransformer.test.ts index 7ca030ca726b..5cb141be586e 100644 --- a/packages/jest-transform/src/__tests__/ScriptTransformer.test.ts +++ b/packages/jest-transform/src/__tests__/ScriptTransformer.test.ts @@ -278,7 +278,7 @@ describe('ScriptTransformer', () => { config = makeProjectConfig({ cache: true, cacheDirectory: '/cache/', - name: 'test', + id: 'test', rootDir: '/', transformIgnorePatterns: ['/node_modules/'], }); diff --git a/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap b/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap index 1749735a183f..d79e6c7ee43f 100644 --- a/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap +++ b/packages/jest-transform/src/__tests__/__snapshots__/ScriptTransformer.test.ts.snap @@ -43,6 +43,7 @@ exports[`ScriptTransformer in async mode, passes expected transform options to g "globalTeardown": undefined, "globals": Object {}, "haste": Object {}, + "id": "test", "injectGlobals": true, "moduleDirectories": Array [], "moduleFileExtensions": Array [ @@ -51,7 +52,6 @@ exports[`ScriptTransformer in async mode, passes expected transform options to g "moduleNameMapper": Array [], "modulePathIgnorePatterns": Array [], "modulePaths": Array [], - "name": "test", "prettierPath": "prettier", "resetMocks": false, "resetModules": false, @@ -94,7 +94,7 @@ exports[`ScriptTransformer in async mode, passes expected transform options to g "unmockedModulePathPatterns": undefined, "watchPathIgnorePatterns": Array [], }, - "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", + "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"id":"test","injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", "coverageProvider": "babel", "instrument": true, "supportsDynamicImport": false, @@ -120,7 +120,7 @@ exports[`ScriptTransformer in async mode, uses the supplied async preprocessor 1 "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_async_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_async_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"id":"test","injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_async_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"id\\":\\"test\\",\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_async_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; @@ -130,7 +130,7 @@ exports[`ScriptTransformer in async mode, uses the supplied preprocessor 1`] = ` "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"id":"test","injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"id\\":\\"test\\",\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; @@ -176,6 +176,7 @@ exports[`ScriptTransformer passes expected transform options to getCacheKey 1`] "globalTeardown": undefined, "globals": Object {}, "haste": Object {}, + "id": "test", "injectGlobals": true, "moduleDirectories": Array [], "moduleFileExtensions": Array [ @@ -184,7 +185,6 @@ exports[`ScriptTransformer passes expected transform options to getCacheKey 1`] "moduleNameMapper": Array [], "modulePathIgnorePatterns": Array [], "modulePaths": Array [], - "name": "test", "prettierPath": "prettier", "resetMocks": false, "resetModules": false, @@ -227,7 +227,7 @@ exports[`ScriptTransformer passes expected transform options to getCacheKey 1`] "unmockedModulePathPatterns": undefined, "watchPathIgnorePatterns": Array [], }, - "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", + "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"id":"test","injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", "coverageProvider": "babel", "instrument": true, "supportsDynamicImport": false, @@ -283,6 +283,7 @@ exports[`ScriptTransformer passes expected transform options to getCacheKeyAsync "globalTeardown": undefined, "globals": Object {}, "haste": Object {}, + "id": "test", "injectGlobals": true, "moduleDirectories": Array [], "moduleFileExtensions": Array [ @@ -291,7 +292,6 @@ exports[`ScriptTransformer passes expected transform options to getCacheKeyAsync "moduleNameMapper": Array [], "modulePathIgnorePatterns": Array [], "modulePaths": Array [], - "name": "test", "prettierPath": "prettier", "resetMocks": false, "resetModules": false, @@ -334,7 +334,7 @@ exports[`ScriptTransformer passes expected transform options to getCacheKeyAsync "unmockedModulePathPatterns": undefined, "watchPathIgnorePatterns": Array [], }, - "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_async_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", + "configString": "{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"id":"test","injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_async_preprocessor",{"configKey":"configValue"}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]}", "coverageProvider": "babel", "instrument": true, "supportsDynamicImport": false, @@ -762,7 +762,7 @@ exports[`ScriptTransformer uses mixture of sync/async preprocessors 1`] = ` "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_async_preprocessor",{}],["\\\\.css$","css-preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_async_preprocessor\\",{}],[\\"\\\\\\\\.css$\\",\\"css-preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"id":"test","injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_async_preprocessor",{}],["\\\\.css$","css-preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"id\\":\\"test\\",\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_async_preprocessor\\",{}],[\\"\\\\\\\\.css$\\",\\"css-preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; @@ -779,7 +779,7 @@ exports[`ScriptTransformer uses multiple preprocessors 1`] = ` "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{}],["\\\\.css$","css-preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}],[\\"\\\\\\\\.css$\\",\\"css-preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"id":"test","injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{}],["\\\\.css$","css-preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"id\\":\\"test\\",\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}],[\\"\\\\\\\\.css$\\",\\"css-preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; @@ -796,7 +796,7 @@ exports[`ScriptTransformer uses the supplied preprocessor 1`] = ` "const TRANSFORMED = { filename: '/fruits/banana.js', script: 'module.exports = "banana";', - config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"name":"test","prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"name\\":\\"test\\",\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', + config: '{"collectCoverage":false,"collectCoverageFrom":[],"coverageProvider":"babel","supportsDynamicImport":false,"supportsExportNamespaceFrom":false,"supportsStaticESM":false,"supportsTopLevelAwait":false,"instrument":false,"cacheFS":{},"config":{"automock":false,"cache":true,"cacheDirectory":"/cache/","clearMocks":false,"coveragePathIgnorePatterns":[],"cwd":"/test_root_dir/","detectLeaks":false,"detectOpenHandles":false,"errorOnDeprecated":false,"extensionsToTreatAsEsm":[],"fakeTimers":{"enableGlobally":false},"forceCoverageMatch":[],"globals":{},"haste":{},"id":"test","injectGlobals":true,"moduleDirectories":[],"moduleFileExtensions":["js"],"moduleNameMapper":[],"modulePathIgnorePatterns":[],"modulePaths":[],"prettierPath":"prettier","resetMocks":false,"resetModules":false,"restoreMocks":false,"rootDir":"/","roots":[],"runner":"jest-runner","runtime":"/test_module_loader_path","sandboxInjectedGlobals":[],"setupFiles":[],"setupFilesAfterEnv":[],"skipFilter":false,"skipNodeResolution":false,"slowTestThreshold":5,"snapshotFormat":{},"snapshotSerializers":[],"testEnvironment":"node","testEnvironmentOptions":{},"testLocationInResults":false,"testMatch":[],"testPathIgnorePatterns":[],"testRegex":["\\\\.test\\\\.js$"],"testRunner":"jest-circus/runner","transform":[["\\\\.js$","test_preprocessor",{}]],"transformIgnorePatterns":["/node_modules/"],"watchPathIgnorePatterns":[]},"configString":"{\\"automock\\":false,\\"cache\\":true,\\"cacheDirectory\\":\\"/cache/\\",\\"clearMocks\\":false,\\"coveragePathIgnorePatterns\\":[],\\"cwd\\":\\"/test_root_dir/\\",\\"detectLeaks\\":false,\\"detectOpenHandles\\":false,\\"errorOnDeprecated\\":false,\\"extensionsToTreatAsEsm\\":[],\\"fakeTimers\\":{\\"enableGlobally\\":false},\\"forceCoverageMatch\\":[],\\"globals\\":{},\\"haste\\":{},\\"id\\":\\"test\\",\\"injectGlobals\\":true,\\"moduleDirectories\\":[],\\"moduleFileExtensions\\":[\\"js\\"],\\"moduleNameMapper\\":[],\\"modulePathIgnorePatterns\\":[],\\"modulePaths\\":[],\\"prettierPath\\":\\"prettier\\",\\"resetMocks\\":false,\\"resetModules\\":false,\\"restoreMocks\\":false,\\"rootDir\\":\\"/\\",\\"roots\\":[],\\"runner\\":\\"jest-runner\\",\\"runtime\\":\\"/test_module_loader_path\\",\\"sandboxInjectedGlobals\\":[],\\"setupFiles\\":[],\\"setupFilesAfterEnv\\":[],\\"skipFilter\\":false,\\"skipNodeResolution\\":false,\\"slowTestThreshold\\":5,\\"snapshotFormat\\":{},\\"snapshotSerializers\\":[],\\"testEnvironment\\":\\"node\\",\\"testEnvironmentOptions\\":{},\\"testLocationInResults\\":false,\\"testMatch\\":[],\\"testPathIgnorePatterns\\":[],\\"testRegex\\":[\\"\\\\\\\\.test\\\\\\\\.js$\\"],\\"testRunner\\":\\"jest-circus/runner\\",\\"transform\\":[[\\"\\\\\\\\.js$\\",\\"test_preprocessor\\",{}]],\\"transformIgnorePatterns\\":[\\"/node_modules/\\"],\\"watchPathIgnorePatterns\\":[]}","transformerConfig":{}}', };" `; diff --git a/packages/jest-types/src/Config.ts b/packages/jest-types/src/Config.ts index 3b9d14cf76ab..02dcf2d8eb3d 100644 --- a/packages/jest-types/src/Config.ts +++ b/packages/jest-types/src/Config.ts @@ -255,6 +255,7 @@ export type InitialOptions = Partial<{ globalSetup: string | null | undefined; globalTeardown: string | null | undefined; haste: HasteConfig; + id: string; injectGlobals: boolean; reporters: Array; logHeapUsage: boolean; @@ -269,7 +270,6 @@ export type InitialOptions = Partial<{ }; modulePathIgnorePatterns: Array; modulePaths: Array; - name: string; noStackTrace: boolean; notify: boolean; notifyMode: string; @@ -457,13 +457,13 @@ export type ProjectConfig = { globalTeardown?: string; globals: ConfigGlobals; haste: HasteConfig; + id: string; injectGlobals: boolean; moduleDirectories: Array; moduleFileExtensions: Array; moduleNameMapper: Array<[string, string]>; modulePathIgnorePatterns: Array; modulePaths?: Array; - name: string; prettierPath: string; resetMocks: boolean; resetModules: boolean; diff --git a/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts b/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts index bcc54ead1baf..c6055b1d740e 100644 --- a/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts +++ b/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts @@ -81,6 +81,7 @@ const validConfig = { forceExit: false, globals: {}, haste: {}, + id: 'string', logHeapUsage: true, moduleDirectories: ['node_modules'], moduleFileExtensions: ['js', 'json', 'jsx', 'node'], @@ -90,7 +91,6 @@ const validConfig = { }, modulePathIgnorePatterns: ['/build/'], modulePaths: ['/shared/vendor/modules'], - name: 'string', noStackTrace: false, notify: false, notifyMode: 'failure-change', diff --git a/packages/test-utils/src/config.ts b/packages/test-utils/src/config.ts index 448547d46749..30a8f10865de 100644 --- a/packages/test-utils/src/config.ts +++ b/packages/test-utils/src/config.ts @@ -85,13 +85,13 @@ const DEFAULT_PROJECT_CONFIG: Config.ProjectConfig = { globalTeardown: undefined, globals: {}, haste: {}, + id: 'test_name', injectGlobals: true, moduleDirectories: [], moduleFileExtensions: ['js'], moduleNameMapper: [], modulePathIgnorePatterns: [], modulePaths: [], - name: 'test_name', prettierPath: 'prettier', resetMocks: false, resetModules: false, From 09fa16428b8057cccef30f29292cde2022237cd8 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Fri, 8 Apr 2022 15:55:35 +0300 Subject: [PATCH 033/128] feat(jest-core, jest-watcher)!: move `TestWatcher` class to `jest-watcher` (#12652) --- CHANGELOG.md | 1 + e2e/transform/transform-runner/runner.ts | 2 +- packages/jest-core/package.json | 1 - packages/jest-core/src/TestScheduler.ts | 2 +- packages/jest-core/src/__tests__/watch.test.js | 3 +-- packages/jest-core/src/cli/index.ts | 2 +- packages/jest-core/src/index.ts | 1 - packages/jest-core/src/runJest.ts | 2 +- packages/jest-core/src/watch.ts | 2 +- .../jest-runner/__typetests__/jest-runner.test.ts | 2 +- packages/jest-runner/package.json | 1 + packages/jest-runner/src/__tests__/testRunner.test.ts | 2 +- packages/jest-runner/src/index.ts | 9 ++------- packages/jest-runner/src/types.ts | 11 +---------- packages/jest-runner/tsconfig.json | 1 + packages/jest-watcher/package.json | 1 + .../{jest-core => jest-watcher}/src/TestWatcher.ts | 0 packages/jest-watcher/src/index.ts | 1 + packages/jest/src/index.ts | 1 - yarn.lock | 3 ++- 20 files changed, 18 insertions(+), 30 deletions(-) rename packages/{jest-core => jest-watcher}/src/TestWatcher.ts (100%) diff --git a/CHANGELOG.md b/CHANGELOG.md index b443c26b5344..7be38c0984c0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -17,6 +17,7 @@ - `[jest-cli, jest-core]` Add `--ignoreProjects` CLI argument to ignore test suites by project name ([#12620](https://github.com/facebook/jest/pull/12620)) - `[jest-core]` Pass project config to `globalSetup`/`globalTeardown` function as second argument ([#12440](https://github.com/facebook/jest/pull/12440)) - `[jest-core]` Stabilize test runners with event emitters ([#12641](https://github.com/facebook/jest/pull/12641)) +- `[jest-core, jest-watcher]` [**BREAKING**] Move `TestWatcher` class to `jest-watcher` package ([#12652](https://github.com/facebook/jest/pull/12652)) - `[jest-environment-jsdom]` [**BREAKING**] Upgrade jsdom to 19.0.0 ([#12290](https://github.com/facebook/jest/pull/12290)) - `[jest-environment-jsdom]` [**BREAKING**] Add default `browser` condition to `exportConditions` for `jsdom` environment ([#11924](https://github.com/facebook/jest/pull/11924)) - `[jest-environment-jsdom]` [**BREAKING**] Pass global config to Jest environment constructor for `jsdom` environment ([#12461](https://github.com/facebook/jest/pull/12461)) diff --git a/e2e/transform/transform-runner/runner.ts b/e2e/transform/transform-runner/runner.ts index fb45dbf4be69..325956eae108 100644 --- a/e2e/transform/transform-runner/runner.ts +++ b/e2e/transform/transform-runner/runner.ts @@ -13,8 +13,8 @@ import type { OnTestStart, OnTestSuccess, TestRunnerContext, - TestWatcher, } from 'jest-runner'; +import type {TestWatcher} from 'jest-watcher'; export default class BaseTestRunner { private _globalConfig: Config.GlobalConfig; diff --git a/packages/jest-core/package.json b/packages/jest-core/package.json index 37a50b158f73..ccf923767447 100644 --- a/packages/jest-core/package.json +++ b/packages/jest-core/package.json @@ -20,7 +20,6 @@ "@types/node": "*", "ansi-escapes": "^4.2.1", "chalk": "^4.0.0", - "emittery": "^0.10.2", "exit": "^0.1.2", "graceful-fs": "^4.2.9", "jest-changed-files": "^28.0.0-alpha.3", diff --git a/packages/jest-core/src/TestScheduler.ts b/packages/jest-core/src/TestScheduler.ts index 2a8872edd507..9cceb5fb1bdd 100644 --- a/packages/jest-core/src/TestScheduler.ts +++ b/packages/jest-core/src/TestScheduler.ts @@ -36,8 +36,8 @@ import { cleanup as cleanupSnapshots, } from 'jest-snapshot'; import {requireOrImportModule} from 'jest-util'; +import type {TestWatcher} from 'jest-watcher'; import ReporterDispatcher from './ReporterDispatcher'; -import type TestWatcher from './TestWatcher'; import {shouldRunInBand} from './testSchedulerHelper'; type TestRunnerConstructor = new ( diff --git a/packages/jest-core/src/__tests__/watch.test.js b/packages/jest-core/src/__tests__/watch.test.js index d38508a2a64b..0ef865a7e74a 100644 --- a/packages/jest-core/src/__tests__/watch.test.js +++ b/packages/jest-core/src/__tests__/watch.test.js @@ -7,9 +7,8 @@ */ import chalk from 'chalk'; -import {JestHook, KEYS} from 'jest-watcher'; // eslint-disable-next-line import/order -import TestWatcher from '../TestWatcher'; +import {JestHook, KEYS, TestWatcher} from 'jest-watcher'; const runJestMock = jest.fn(); const watchPluginPath = `${__dirname}/__fixtures__/watchPlugin`; diff --git a/packages/jest-core/src/cli/index.ts b/packages/jest-core/src/cli/index.ts index b7727a263b93..c80f06b0040c 100644 --- a/packages/jest-core/src/cli/index.ts +++ b/packages/jest-core/src/cli/index.ts @@ -16,7 +16,7 @@ import {readConfigs} from 'jest-config'; import type HasteMap from 'jest-haste-map'; import Runtime, {Context} from 'jest-runtime'; import {createDirectory, preRunMessage} from 'jest-util'; -import TestWatcher from '../TestWatcher'; +import {TestWatcher} from 'jest-watcher'; import {formatHandleErrors} from '../collectHandles'; import getChangedFilesPromise from '../getChangedFilesPromise'; import getConfigsOfProjectsToRun from '../getConfigsOfProjectsToRun'; diff --git a/packages/jest-core/src/index.ts b/packages/jest-core/src/index.ts index 6912817f6bfa..17a839d33cd7 100644 --- a/packages/jest-core/src/index.ts +++ b/packages/jest-core/src/index.ts @@ -7,6 +7,5 @@ export {default as SearchSource} from './SearchSource'; export {createTestScheduler} from './TestScheduler'; -export {default as TestWatcher} from './TestWatcher'; export {runCLI} from './cli'; export {default as getVersion} from './version'; diff --git a/packages/jest-core/src/runJest.ts b/packages/jest-core/src/runJest.ts index 7e7bf5b86501..977cd07addfa 100644 --- a/packages/jest-core/src/runJest.ts +++ b/packages/jest-core/src/runJest.ts @@ -24,10 +24,10 @@ import Resolver from 'jest-resolve'; import type {Context} from 'jest-runtime'; import {requireOrImportModule, tryRealpath} from 'jest-util'; import {JestHook, JestHookEmitter} from 'jest-watcher'; +import type {TestWatcher} from 'jest-watcher'; import type FailedTestsCache from './FailedTestsCache'; import SearchSource from './SearchSource'; import {TestSchedulerContext, createTestScheduler} from './TestScheduler'; -import type TestWatcher from './TestWatcher'; import collectNodeHandles, {HandleCollectionResult} from './collectHandles'; import getNoTestsFoundMessage from './getNoTestsFoundMessage'; import runGlobalHook from './runGlobalHook'; diff --git a/packages/jest-core/src/watch.ts b/packages/jest-core/src/watch.ts index 357113ef8c9c..17eb04f1ad87 100644 --- a/packages/jest-core/src/watch.ts +++ b/packages/jest-core/src/watch.ts @@ -28,12 +28,12 @@ import { AllowedConfigOptions, JestHook, KEYS, + TestWatcher, WatchPlugin, WatchPluginClass, } from 'jest-watcher'; import FailedTestsCache from './FailedTestsCache'; import SearchSource from './SearchSource'; -import TestWatcher from './TestWatcher'; import getChangedFilesPromise from './getChangedFilesPromise'; import activeFilters from './lib/activeFiltersMessage'; import createContext from './lib/createContext'; diff --git a/packages/jest-runner/__typetests__/jest-runner.test.ts b/packages/jest-runner/__typetests__/jest-runner.test.ts index 95ec032693b5..04c00ab32d06 100644 --- a/packages/jest-runner/__typetests__/jest-runner.test.ts +++ b/packages/jest-runner/__typetests__/jest-runner.test.ts @@ -15,9 +15,9 @@ import type { OnTestSuccess, TestRunnerContext, TestRunnerOptions, - TestWatcher, UnsubscribeFn, } from 'jest-runner'; +import type {TestWatcher} from 'jest-watcher'; const globalConfig = {} as Config.GlobalConfig; const runnerContext = {} as TestRunnerContext; diff --git a/packages/jest-runner/package.json b/packages/jest-runner/package.json index 7103c9861d3c..441e7bd4c428 100644 --- a/packages/jest-runner/package.json +++ b/packages/jest-runner/package.json @@ -34,6 +34,7 @@ "jest-resolve": "^28.0.0-alpha.8", "jest-runtime": "^28.0.0-alpha.8", "jest-util": "^28.0.0-alpha.8", + "jest-watcher": "^28.0.0-alpha.8", "jest-worker": "^28.0.0-alpha.8", "source-map-support": "^0.5.6", "throat": "^6.0.1" diff --git a/packages/jest-runner/src/__tests__/testRunner.test.ts b/packages/jest-runner/src/__tests__/testRunner.test.ts index b71f179afa3d..85ee76e0f5d3 100644 --- a/packages/jest-runner/src/__tests__/testRunner.test.ts +++ b/packages/jest-runner/src/__tests__/testRunner.test.ts @@ -6,9 +6,9 @@ * */ -import {TestWatcher} from '@jest/core'; import type {TestContext} from '@jest/test-result'; import {makeGlobalConfig, makeProjectConfig} from '@jest/test-utils'; +import {TestWatcher} from 'jest-watcher'; import TestRunner from '../index'; let mockWorkerFarm; diff --git a/packages/jest-runner/src/index.ts b/packages/jest-runner/src/index.ts index 7a1f0a5a94b1..01434c043bf8 100644 --- a/packages/jest-runner/src/index.ts +++ b/packages/jest-runner/src/index.ts @@ -15,15 +15,11 @@ import type { TestResult, } from '@jest/test-result'; import {deepCyclicCopy} from 'jest-util'; +import type {TestWatcher} from 'jest-watcher'; import {PromiseWithCustomMessage, Worker} from 'jest-worker'; import runTest from './runTest'; import type {SerializableResolver, worker} from './testWorker'; -import { - EmittingTestRunner, - TestRunnerOptions, - TestWatcher, - UnsubscribeFn, -} from './types'; +import {EmittingTestRunner, TestRunnerOptions, UnsubscribeFn} from './types'; const TEST_WORKER_PATH = require.resolve('./testWorker'); @@ -36,7 +32,6 @@ export type { OnTestFailure, OnTestStart, OnTestSuccess, - TestWatcher, TestRunnerContext, TestRunnerOptions, JestTestRunner, diff --git a/packages/jest-runner/src/types.ts b/packages/jest-runner/src/types.ts index 71da90742fab..ddc901f6c378 100644 --- a/packages/jest-runner/src/types.ts +++ b/packages/jest-runner/src/types.ts @@ -5,7 +5,6 @@ * LICENSE file in the root directory of this source tree. */ -import type Emittery = require('emittery'); import type {JestEnvironment} from '@jest/environment'; import type { SerializableError, @@ -16,6 +15,7 @@ import type { } from '@jest/test-result'; import type {Config} from '@jest/types'; import type RuntimeType from 'jest-runtime'; +import type {TestWatcher} from 'jest-watcher'; export type ErrorWithCode = Error & {code?: string}; @@ -96,12 +96,3 @@ export abstract class EmittingTestRunner extends BaseTestRunner { } export type JestTestRunner = CallbackTestRunner | EmittingTestRunner; - -// TODO: Should live in `@jest/core` or `jest-watcher` -type WatcherState = {interrupted: boolean}; -export interface TestWatcher extends Emittery<{change: WatcherState}> { - state: WatcherState; - setState(state: WatcherState): void; - isInterrupted(): boolean; - isWatchMode(): boolean; -} diff --git a/packages/jest-runner/tsconfig.json b/packages/jest-runner/tsconfig.json index 7ce0efdb2782..36b3ff8099d2 100644 --- a/packages/jest-runner/tsconfig.json +++ b/packages/jest-runner/tsconfig.json @@ -20,6 +20,7 @@ {"path": "../jest-transform"}, {"path": "../jest-types"}, {"path": "../jest-util"}, + {"path": "../jest-watcher"}, {"path": "../jest-worker"} ] } diff --git a/packages/jest-watcher/package.json b/packages/jest-watcher/package.json index b44d8a1bb73a..027af5857016 100644 --- a/packages/jest-watcher/package.json +++ b/packages/jest-watcher/package.json @@ -17,6 +17,7 @@ "@types/node": "*", "ansi-escapes": "^4.2.1", "chalk": "^4.0.0", + "emittery": "^0.10.2", "jest-util": "^28.0.0-alpha.8", "string-length": "^4.0.1" }, diff --git a/packages/jest-core/src/TestWatcher.ts b/packages/jest-watcher/src/TestWatcher.ts similarity index 100% rename from packages/jest-core/src/TestWatcher.ts rename to packages/jest-watcher/src/TestWatcher.ts diff --git a/packages/jest-watcher/src/index.ts b/packages/jest-watcher/src/index.ts index 05ecbadbe682..0940eb17c89b 100644 --- a/packages/jest-watcher/src/index.ts +++ b/packages/jest-watcher/src/index.ts @@ -8,6 +8,7 @@ export {default as BaseWatchPlugin} from './BaseWatchPlugin'; export {default as JestHook} from './JestHooks'; export {default as PatternPrompt} from './PatternPrompt'; +export {default as TestWatcher} from './TestWatcher'; export * from './constants'; export type { AllowedConfigOptions, diff --git a/packages/jest/src/index.ts b/packages/jest/src/index.ts index 9c4f958cb98d..d101fd921a01 100644 --- a/packages/jest/src/index.ts +++ b/packages/jest/src/index.ts @@ -7,7 +7,6 @@ export { SearchSource, - TestWatcher, createTestScheduler, getVersion, runCLI, diff --git a/yarn.lock b/yarn.lock index 674344c1f98d..a9276f7a5f4a 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2557,7 +2557,6 @@ __metadata: "@types/rimraf": ^3.0.0 ansi-escapes: ^4.2.1 chalk: ^4.0.0 - emittery: ^0.10.2 exit: ^0.1.2 graceful-fs: ^4.2.9 jest-changed-files: ^28.0.0-alpha.3 @@ -13514,6 +13513,7 @@ __metadata: jest-resolve: ^28.0.0-alpha.8 jest-runtime: ^28.0.0-alpha.8 jest-util: ^28.0.0-alpha.8 + jest-watcher: ^28.0.0-alpha.8 jest-worker: ^28.0.0-alpha.8 source-map-support: ^0.5.6 throat: ^6.0.1 @@ -13721,6 +13721,7 @@ __metadata: "@types/node": "*" ansi-escapes: ^4.2.1 chalk: ^4.0.0 + emittery: ^0.10.2 jest-util: ^28.0.0-alpha.8 string-length: ^4.0.1 languageName: unknown From 62b4bd701db378b38d360094f55fbd9ba64ca937 Mon Sep 17 00:00:00 2001 From: Rajas Paranjpe <52586855+ChocolateLoverRaj@users.noreply.github.com> Date: Sat, 9 Apr 2022 02:16:08 -0700 Subject: [PATCH 034/128] fix: call custom resolver with node.js modules (#12654) --- CHANGELOG.md | 1 + .../__snapshots__/moduleNameMapper.test.ts.snap | 4 ++-- .../resolveNoFileExtensions.test.ts.snap | 2 +- .../jest-resolve/src/__tests__/resolve.test.ts | 15 +++++++++++++++ packages/jest-resolve/src/resolver.ts | 6 ++++-- 5 files changed, 23 insertions(+), 5 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7be38c0984c0..a743b652ca1a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -77,6 +77,7 @@ - `[jest-mock]` Fix function overloads for `spyOn` to allow more correct type inference in complex object ([#12442](https://github.com/facebook/jest/pull/12442)) - `[jest-reporters]` Notifications generated by the `--notify` flag are no longer persistent in GNOME Shell. ([#11733](https://github.com/facebook/jest/pull/11733)) - `[@jest/reporters]` Move missing icon file which is needed for `NotifyReporter` class. ([#12593](https://github.com/facebook/jest/pull/12593)) +- `[jest-resolver]` Call custom resolver with core node.js modules ([#12654](https://github.com/facebook/jest/pull/12654)) - `[jest-worker]` Fix `Farm` execution results memory leak ([#12497](https://github.com/facebook/jest/pull/12497)) ### Chore & Maintenance diff --git a/e2e/__tests__/__snapshots__/moduleNameMapper.test.ts.snap b/e2e/__tests__/__snapshots__/moduleNameMapper.test.ts.snap index b9c10e68936f..912914fe7348 100644 --- a/e2e/__tests__/__snapshots__/moduleNameMapper.test.ts.snap +++ b/e2e/__tests__/__snapshots__/moduleNameMapper.test.ts.snap @@ -41,7 +41,7 @@ exports[`moduleNameMapper wrong array configuration 1`] = ` 12 | module.exports = () => 'test'; 13 | - at createNoMappedModuleFoundError (../../packages/jest-resolve/build/resolver.js:899:17) + at createNoMappedModuleFoundError (../../packages/jest-resolve/build/resolver.js:901:17) at Object.require (index.js:10:1)" `; @@ -70,6 +70,6 @@ exports[`moduleNameMapper wrong configuration 1`] = ` 12 | module.exports = () => 'test'; 13 | - at createNoMappedModuleFoundError (../../packages/jest-resolve/build/resolver.js:899:17) + at createNoMappedModuleFoundError (../../packages/jest-resolve/build/resolver.js:901:17) at Object.require (index.js:10:1)" `; diff --git a/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.ts.snap b/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.ts.snap index 8ee95a4ed134..a457d7551b13 100644 --- a/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.ts.snap +++ b/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.ts.snap @@ -37,6 +37,6 @@ exports[`show error message with matching files 1`] = ` | ^ 9 | - at Resolver._throwModNotFoundError (../../packages/jest-resolve/build/resolver.js:491:11) + at Resolver._throwModNotFoundError (../../packages/jest-resolve/build/resolver.js:493:11) at Object.require (index.js:8:18)" `; diff --git a/packages/jest-resolve/src/__tests__/resolve.test.ts b/packages/jest-resolve/src/__tests__/resolve.test.ts index 34a286c57209..aa5d40bbcc54 100644 --- a/packages/jest-resolve/src/__tests__/resolve.test.ts +++ b/packages/jest-resolve/src/__tests__/resolve.test.ts @@ -399,6 +399,21 @@ describe('resolveModule', () => { expect(resolvedWithSlash).toBe(fooSlashIndex); expect(resolvedWithSlash).toBe(resolvedWithDot); }); + + it('custom resolver can resolve node modules', () => { + userResolver.mockImplementation(() => 'module'); + + const moduleMap = ModuleMap.create('/'); + const resolver = new Resolver(moduleMap, { + extensions: ['.js'], + resolver: require.resolve('../__mocks__/userResolver'), + } as ResolverConfig); + const src = require.resolve('../'); + resolver.resolveModule(src, 'fs'); + + expect(userResolver).toHaveBeenCalled(); + expect(userResolver.mock.calls[0][0]).toBe('fs'); + }); }); describe('resolveModuleAsync', () => { diff --git a/packages/jest-resolve/src/resolver.ts b/packages/jest-resolve/src/resolver.ts index bf3c8e7cdc23..1ac833d5bf55 100644 --- a/packages/jest-resolve/src/resolver.ts +++ b/packages/jest-resolve/src/resolver.ts @@ -218,7 +218,8 @@ export default class Resolver { // dependency graph because we don't have to look at modules that may not // exist and aren't mocked. const resolveNodeModule = (name: string, throwIfNotFound = false) => { - if (this.isCoreModule(name)) { + // Only skip default resolver + if (this.isCoreModule(name) && !this._options.resolver) { return name; } @@ -292,7 +293,8 @@ export default class Resolver { // dependency graph because we don't have to look at modules that may not // exist and aren't mocked. const resolveNodeModule = async (name: string, throwIfNotFound = false) => { - if (this.isCoreModule(name)) { + // Only skip default resolver + if (this.isCoreModule(name) && !this._options.resolver) { return name; } From 74ca3a6c0fc9316c219786d3fbd7c781a9b59743 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Sun, 10 Apr 2022 10:12:09 +0300 Subject: [PATCH 035/128] feat(jest-core): `GitHubActionsReporter` goes live (#12658) --- CHANGELOG.md | 2 +- jest.config.ci.js | 1 + packages/jest-config/src/constants.ts | 1 - packages/jest-config/src/normalize.ts | 4 +- packages/jest-core/package.json | 1 + packages/jest-core/src/TestScheduler.ts | 57 ++++++++++--------- .../src/__tests__/TestScheduler.test.js | 34 ++++++++++- .../src/GitHubActionsReporter.ts | 4 +- .../GitHubActionsReporter.test.js.snap | 3 +- yarn.lock | 1 + 10 files changed, 75 insertions(+), 33 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a743b652ca1a..0f48c8855293 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -37,7 +37,7 @@ - `[jest-mock]` [**BREAKING**] Improve the usage of `jest.fn` generic type argument ([#12489](https://github.com/facebook/jest/pull/12489)) - `[jest-mock]` Add support for auto-mocking async generator functions ([#11080](https://github.com/facebook/jest/pull/11080)) - `[jest-mock]` Add `contexts` member to mock functions ([#12601](https://github.com/facebook/jest/pull/12601)) -- `[jest-reporters]` Add GitHub Actions reporter ([#11320](https://github.com/facebook/jest/pull/11320)) +- `[jest-reporters]` Add GitHub Actions reporter ([#11320](https://github.com/facebook/jest/pull/11320), [#12658](https://github.com/facebook/jest/pull/12658) - `[jest-resolve]` [**BREAKING**] Add support for `package.json` `exports` ([#11961](https://github.com/facebook/jest/pull/11961), [#12373](https://github.com/facebook/jest/pull/12373)) - `[jest-resolve, jest-runtime]` Add support for `data:` URI import and mock ([#12392](https://github.com/facebook/jest/pull/12392)) - `[jest-resolve, jest-runtime]` Add support for async resolver ([#11540](https://github.com/facebook/jest/pull/11540)) diff --git a/jest.config.ci.js b/jest.config.ci.js index 68e16b4300ac..953f52e08310 100644 --- a/jest.config.ci.js +++ b/jest.config.ci.js @@ -11,6 +11,7 @@ module.exports = { ...require('./jest.config'), coverageReporters: ['json'], reporters: [ + 'github-actions', [ 'jest-junit', {outputDirectory: 'reports/junit', outputName: 'js-test-results.xml'}, diff --git a/packages/jest-config/src/constants.ts b/packages/jest-config/src/constants.ts index 35e13c6f0a46..c24a77233c00 100644 --- a/packages/jest-config/src/constants.ts +++ b/packages/jest-config/src/constants.ts @@ -9,7 +9,6 @@ import * as path from 'path'; export const NODE_MODULES = `${path.sep}node_modules${path.sep}`; export const DEFAULT_JS_PATTERN = '\\.[jt]sx?$'; -export const DEFAULT_REPORTER_LABEL = 'default'; export const PACKAGE_JSON = 'package.json'; export const JEST_CONFIG_BASE_NAME = 'jest.config'; export const JEST_CONFIG_EXT_CJS = '.cjs'; diff --git a/packages/jest-config/src/normalize.ts b/packages/jest-config/src/normalize.ts index 7f22cb5e72e7..b7fd07b904c9 100644 --- a/packages/jest-config/src/normalize.ts +++ b/packages/jest-config/src/normalize.ts @@ -32,7 +32,7 @@ import DEPRECATED_CONFIG from './Deprecated'; import {validateReporters} from './ReporterValidationErrors'; import VALID_CONFIG from './ValidConfig'; import {getDisplayNameColor} from './color'; -import {DEFAULT_JS_PATTERN, DEFAULT_REPORTER_LABEL} from './constants'; +import {DEFAULT_JS_PATTERN} from './constants'; import getMaxWorkers from './getMaxWorkers'; import {parseShardPair} from './parseShardPair'; import setFromArgv from './setFromArgv'; @@ -433,7 +433,7 @@ const normalizeReporters = (options: Config.InitialOptionsWithRootDir) => { normalizedReporterConfig[0], ); - if (reporterPath !== DEFAULT_REPORTER_LABEL) { + if (!['default', 'github-actions'].includes(reporterPath)) { const reporter = Resolver.findNodeModule(reporterPath, { basedir: options.rootDir, }); diff --git a/packages/jest-core/package.json b/packages/jest-core/package.json index ccf923767447..e260ce01689d 100644 --- a/packages/jest-core/package.json +++ b/packages/jest-core/package.json @@ -20,6 +20,7 @@ "@types/node": "*", "ansi-escapes": "^4.2.1", "chalk": "^4.0.0", + "ci-info": "^3.2.0", "exit": "^0.1.2", "graceful-fs": "^4.2.9", "jest-changed-files": "^28.0.0-alpha.3", diff --git a/packages/jest-core/src/TestScheduler.ts b/packages/jest-core/src/TestScheduler.ts index 9cceb5fb1bdd..9eb4465a77ca 100644 --- a/packages/jest-core/src/TestScheduler.ts +++ b/packages/jest-core/src/TestScheduler.ts @@ -8,10 +8,12 @@ /* eslint-disable local/ban-types-eventually */ import chalk = require('chalk'); +import {GITHUB_ACTIONS} from 'ci-info'; import exit = require('exit'); import { CoverageReporter, DefaultReporter, + GitHubActionsReporter, NotifyReporter, Reporter, SummaryReporter, @@ -330,25 +332,40 @@ class TestScheduler { } } - private _shouldAddDefaultReporters( - reporters?: Array, - ): boolean { - return ( - !reporters || - !!reporters.find( - reporter => this._getReporterProps(reporter).path === 'default', - ) - ); - } - async _setupReporters() { const {collectCoverage, notify, reporters} = this._globalConfig; - const isDefault = this._shouldAddDefaultReporters(reporters); + + if (notify) { + this.addReporter( + new NotifyReporter( + this._globalConfig, + this._options.startRun, + this._context, + ), + ); + } + + if (!reporters) { + this._setupDefaultReporters(collectCoverage); + return; + } + + const reporterNames = reporters.map( + reporter => this._getReporterProps(reporter).path, + ); + + const isDefault = reporterNames?.includes('default'); + const isGitHubActions = + GITHUB_ACTIONS && reporterNames?.includes('github-actions'); if (isDefault) { this._setupDefaultReporters(collectCoverage); } + if (isGitHubActions) { + this.addReporter(new GitHubActionsReporter()); + } + if (!isDefault && collectCoverage) { this.addReporter( new CoverageReporter(this._globalConfig, { @@ -359,19 +376,7 @@ class TestScheduler { ); } - if (notify) { - this.addReporter( - new NotifyReporter( - this._globalConfig, - this._options.startRun, - this._context, - ), - ); - } - - if (reporters && Array.isArray(reporters)) { - await this._addCustomReporters(reporters); - } + await this._addCustomReporters(reporters); } private _setupDefaultReporters(collectCoverage: boolean) { @@ -400,7 +405,7 @@ class TestScheduler { for (const reporter of reporters) { const {options, path} = this._getReporterProps(reporter); - if (path === 'default') continue; + if (['default', 'github-actions'].includes(path)) continue; try { const Reporter = await requireOrImportModule(path, true); diff --git a/packages/jest-core/src/__tests__/TestScheduler.test.js b/packages/jest-core/src/__tests__/TestScheduler.test.js index 98b0d705ad7e..24dd450ee9a1 100644 --- a/packages/jest-core/src/__tests__/TestScheduler.test.js +++ b/packages/jest-core/src/__tests__/TestScheduler.test.js @@ -6,12 +6,15 @@ * */ -import {SummaryReporter} from '@jest/reporters'; +import {GitHubActionsReporter, SummaryReporter} from '@jest/reporters'; import {makeGlobalConfig, makeProjectConfig} from '@jest/test-utils'; import {createTestScheduler} from '../TestScheduler'; import * as testSchedulerHelper from '../testSchedulerHelper'; +jest.mock('ci-info', () => ({GITHUB_ACTIONS: true})); + jest.mock('@jest/reporters'); + const mockSerialRunner = { isSerial: true, runTests: jest.fn(), @@ -78,6 +81,35 @@ test('config for reporters supports `default`', async () => { expect(emptyReportersScheduler._dispatcher._reporters.length).toBe(0); }); +test('config for reporters supports `github-actions`', async () => { + await createTestScheduler( + makeGlobalConfig({ + reporters: [], + }), + {}, + {}, + ); + expect(GitHubActionsReporter).toHaveBeenCalledTimes(0); + + await createTestScheduler( + makeGlobalConfig({ + reporters: ['github-actions'], + }), + {}, + {}, + ); + expect(GitHubActionsReporter).toHaveBeenCalledTimes(1); + + await createTestScheduler( + makeGlobalConfig({ + reporters: ['default', 'github-actions'], + }), + {}, + {}, + ); + expect(GitHubActionsReporter).toHaveBeenCalledTimes(2); +}); + test('.addReporter() .removeReporter()', async () => { const scheduler = await createTestScheduler(makeGlobalConfig(), {}, {}); const reporter = new SummaryReporter(); diff --git a/packages/jest-reporters/src/GitHubActionsReporter.ts b/packages/jest-reporters/src/GitHubActionsReporter.ts index b9188e701b7b..454eeb93705b 100644 --- a/packages/jest-reporters/src/GitHubActionsReporter.ts +++ b/packages/jest-reporters/src/GitHubActionsReporter.ts @@ -23,6 +23,8 @@ function replaceEntities(s: string): string { } export default class GitHubActionsReporter extends BaseReporter { + static readonly filename = __filename; + override onRunComplete( _contexts?: Set, aggregatedResults?: AggregatedResult, @@ -48,7 +50,7 @@ function getMessages(results: Array | undefined) { .filter((m): m is RegExpExecArray => m !== null) .map( ([message, line, col]) => - `::error file=${testFilePath},line=${line},col=${col}::${message}`, + `\n::error file=${testFilePath},line=${line},col=${col}::${message}`, ), ); } diff --git a/packages/jest-reporters/src/__tests__/__snapshots__/GitHubActionsReporter.test.js.snap b/packages/jest-reporters/src/__tests__/__snapshots__/GitHubActionsReporter.test.js.snap index c523c4dd3448..0deced8ea4cf 100644 --- a/packages/jest-reporters/src/__tests__/__snapshots__/GitHubActionsReporter.test.js.snap +++ b/packages/jest-reporters/src/__tests__/__snapshots__/GitHubActionsReporter.test.js.snap @@ -1,6 +1,7 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP exports[`reporter extracts the correct filename, line, and column 1`] = ` -"::error file=/home/runner/work/jest/jest/some.test.js,line=4,col=17::%0A Error: expect(received).toBe(expected) // Object.is equality%0A%0A %0A%0A Expected: "b"%0A%0A Received: "a"%0A%0A at Object. (/home/runner/work/jest/jest/some.test.js:4:17)%0A%0A at Object.asyncJestTest (/home/runner/work/jest/jest/node_modules/jest-jasmine2/build/jasmineAsyncInstall.js:106:37)%0A%0A at /home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:45:12%0A%0A at new Promise ()%0A%0A at mapper (/home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:28:19)%0A%0A at /home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:75:41%0A%0A at processTicksAndRejections (internal/process/task_queues.js:93:5)%0A +" +::error file=/home/runner/work/jest/jest/some.test.js,line=4,col=17::%0A Error: expect(received).toBe(expected) // Object.is equality%0A%0A %0A%0A Expected: "b"%0A%0A Received: "a"%0A%0A at Object. (/home/runner/work/jest/jest/some.test.js:4:17)%0A%0A at Object.asyncJestTest (/home/runner/work/jest/jest/node_modules/jest-jasmine2/build/jasmineAsyncInstall.js:106:37)%0A%0A at /home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:45:12%0A%0A at new Promise ()%0A%0A at mapper (/home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:28:19)%0A%0A at /home/runner/work/jest/jest/node_modules/jest-jasmine2/build/queueRunner.js:75:41%0A%0A at processTicksAndRejections (internal/process/task_queues.js:93:5)%0A " `; diff --git a/yarn.lock b/yarn.lock index a9276f7a5f4a..f1389152dc7e 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2557,6 +2557,7 @@ __metadata: "@types/rimraf": ^3.0.0 ansi-escapes: ^4.2.1 chalk: ^4.0.0 + ci-info: ^3.2.0 exit: ^0.1.2 graceful-fs: ^4.2.9 jest-changed-files: ^28.0.0-alpha.3 From 9e27d26f5c5f14cab24383154239c7e966fad666 Mon Sep 17 00:00:00 2001 From: "dependabot[bot]" <49699333+dependabot[bot]@users.noreply.github.com> Date: Mon, 11 Apr 2022 07:37:37 +0200 Subject: [PATCH 036/128] chore(deps): bump actions/stale from 4 to 5 (#12660) --- .github/workflows/close-stale.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/close-stale.yml b/.github/workflows/close-stale.yml index f98fa818cc25..2bd97a356e2c 100644 --- a/.github/workflows/close-stale.yml +++ b/.github/workflows/close-stale.yml @@ -8,7 +8,7 @@ jobs: name: 'Close month old issues and PRs' runs-on: ubuntu-latest steps: - - uses: actions/stale@v4 + - uses: actions/stale@v5 with: start-date: '2022-01-01T00:00:00Z' stale-issue-message: 'This issue is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 30 days.' @@ -27,7 +27,7 @@ jobs: name: 'Close year old issues and PRs' runs-on: ubuntu-latest steps: - - uses: actions/stale@v4 + - uses: actions/stale@v5 with: stale-issue-message: 'This issue is stale because it has been open for 1 year with no activity. Remove stale label or comment or this will be closed in 30 days.' stale-pr-message: 'This PR is stale because it has been open 1 year with no activity. Remove stale label or comment or this will be closed in 30 days.' From dc674da86e2aa291354462daf7bb4509128fef08 Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Mon, 11 Apr 2022 13:38:50 +0800 Subject: [PATCH 037/128] Fix line endings on checkout (#12661) --- .gitattributes | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.gitattributes b/.gitattributes index 176a458f94e0..6313b56c5784 100644 --- a/.gitattributes +++ b/.gitattributes @@ -1 +1 @@ -* text=auto +* text=auto eol=lf From fe5f37038c3771aa9014bc351c0bddb04c35da7d Mon Sep 17 00:00:00 2001 From: Aditya Agarwal <50960175+adi611@users.noreply.github.com> Date: Mon, 11 Apr 2022 13:20:50 +0530 Subject: [PATCH 038/128] Rework the docs for "Testing Asynchronous Code" (#12555) --- .eslintrc.cjs | 1 - docs/TestingAsyncCode.md | 137 ++++++++++-------- .../version-25.x/TestingAsyncCode.md | 137 ++++++++++-------- .../version-26.x/TestingAsyncCode.md | 137 ++++++++++-------- .../version-27.0/TestingAsyncCode.md | 137 ++++++++++-------- .../version-27.1/TestingAsyncCode.md | 137 ++++++++++-------- .../version-27.2/TestingAsyncCode.md | 137 ++++++++++-------- .../version-27.4/TestingAsyncCode.md | 137 ++++++++++-------- .../version-27.5/TestingAsyncCode.md | 137 ++++++++++-------- 9 files changed, 584 insertions(+), 513 deletions(-) diff --git a/.eslintrc.cjs b/.eslintrc.cjs index 8ee5a68dfe67..64caddbf7457 100644 --- a/.eslintrc.cjs +++ b/.eslintrc.cjs @@ -375,7 +375,6 @@ module.exports = { 'no-bitwise': 'warn', 'no-caller': 'error', 'no-case-declarations': 'off', - 'no-catch-shadow': 'error', 'no-class-assign': 'warn', 'no-cond-assign': 'off', 'no-confusing-arrow': 'off', diff --git a/docs/TestingAsyncCode.md b/docs/TestingAsyncCode.md index 432db44b3944..ef8762eb7d87 100644 --- a/docs/TestingAsyncCode.md +++ b/docs/TestingAsyncCode.md @@ -5,18 +5,82 @@ title: Testing Asynchronous Code It's common in JavaScript for code to run asynchronously. When you have code that runs asynchronously, Jest needs to know when the code it is testing has completed, before it can move on to another test. Jest has several ways to handle this. -## Callbacks +## Promises + +Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will fail. + +For example, let's say that `fetchData` returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: + +```js +test('the data is peanut butter', () => { + return fetchData().then(data => { + expect(data).toBe('peanut butter'); + }); +}); +``` + +## Async/Await + +Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: + +```js +test('the data is peanut butter', async () => { + const data = await fetchData(); + expect(data).toBe('peanut butter'); +}); -The most common asynchronous pattern is callbacks. +test('the fetch fails with an error', async () => { + expect.assertions(1); + try { + await fetchData(); + } catch (e) { + expect(e).toMatch('error'); + } +}); +``` + +You can combine `async` and `await` with `.resolves` or `.rejects`. + +```js +test('the data is peanut butter', async () => { + await expect(fetchData()).resolves.toBe('peanut butter'); +}); + +test('the fetch fails with an error', async () => { + await expect(fetchData()).rejects.toMatch('error'); +}); +``` + +In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. + +:::caution + +Be sure to return (or `await`) the promise - if you omit the `return`/`await` statement, your test will complete before the promise returned from `fetchData` resolves or rejects. + +::: + +If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. + +```js +test('the fetch fails with an error', () => { + expect.assertions(1); + return fetchData().catch(e => expect(e).toMatch('error')); +}); +``` + +## Callbacks -For example, let's say that you have a `fetchData(callback)` function that fetches some data and calls `callback(data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. +If you don't use promises, you can use callbacks. For example, let's say that `fetchData`, instead of returning a promise, expects a callback, i.e. fetches some data and calls `callback(null, data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. By default, Jest tests complete once they reach the end of their execution. That means this test will _not_ work as intended: ```js // Don't do this! test('the data is peanut butter', () => { - function callback(data) { + function callback(error, data) { + if (error) { + throw error; + } expect(data).toBe('peanut butter'); } @@ -30,7 +94,11 @@ There is an alternate form of `test` that fixes this. Instead of putting the tes ```js test('the data is peanut butter', done => { - function callback(data) { + function callback(error, data) { + if (error) { + done(error); + return; + } try { expect(data).toBe('peanut butter'); done(); @@ -49,31 +117,6 @@ If the `expect` statement fails, it throws an error and `done()` is not called. _Note: `done()` should not be mixed with Promises as this tends to lead to memory leaks in your tests._ -## Promises - -If your code uses promises, there is a more straightforward way to handle asynchronous tests. Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. - -For example, let's say that `fetchData`, instead of using a callback, returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: - -```js -test('the data is peanut butter', () => { - return fetchData().then(data => { - expect(data).toBe('peanut butter'); - }); -}); -``` - -Be sure to return the promise - if you omit this `return` statement, your test will complete before the promise returned from `fetchData` resolves and then() has a chance to execute the callback. - -If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. - -```js -test('the fetch fails with an error', () => { - expect.assertions(1); - return fetchData().catch(e => expect(e).toMatch('error')); -}); -``` - ## `.resolves` / `.rejects` You can also use the `.resolves` matcher in your expect statement, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. @@ -94,38 +137,4 @@ test('the fetch fails with an error', () => { }); ``` -## Async/Await - -Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: - -```js -test('the data is peanut butter', async () => { - const data = await fetchData(); - expect(data).toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - expect.assertions(1); - try { - await fetchData(); - } catch (e) { - expect(e).toMatch('error'); - } -}); -``` - -You can combine `async` and `await` with `.resolves` or `.rejects`. - -```js -test('the data is peanut butter', async () => { - await expect(fetchData()).resolves.toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - await expect(fetchData()).rejects.toMatch('error'); -}); -``` - -In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. - None of these forms is particularly superior to the others, and you can mix and match them across a codebase or even in a single file. It just depends on which style you feel makes your tests simpler. diff --git a/website/versioned_docs/version-25.x/TestingAsyncCode.md b/website/versioned_docs/version-25.x/TestingAsyncCode.md index 432db44b3944..ef8762eb7d87 100644 --- a/website/versioned_docs/version-25.x/TestingAsyncCode.md +++ b/website/versioned_docs/version-25.x/TestingAsyncCode.md @@ -5,18 +5,82 @@ title: Testing Asynchronous Code It's common in JavaScript for code to run asynchronously. When you have code that runs asynchronously, Jest needs to know when the code it is testing has completed, before it can move on to another test. Jest has several ways to handle this. -## Callbacks +## Promises + +Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will fail. + +For example, let's say that `fetchData` returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: + +```js +test('the data is peanut butter', () => { + return fetchData().then(data => { + expect(data).toBe('peanut butter'); + }); +}); +``` + +## Async/Await + +Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: + +```js +test('the data is peanut butter', async () => { + const data = await fetchData(); + expect(data).toBe('peanut butter'); +}); -The most common asynchronous pattern is callbacks. +test('the fetch fails with an error', async () => { + expect.assertions(1); + try { + await fetchData(); + } catch (e) { + expect(e).toMatch('error'); + } +}); +``` + +You can combine `async` and `await` with `.resolves` or `.rejects`. + +```js +test('the data is peanut butter', async () => { + await expect(fetchData()).resolves.toBe('peanut butter'); +}); + +test('the fetch fails with an error', async () => { + await expect(fetchData()).rejects.toMatch('error'); +}); +``` + +In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. + +:::caution + +Be sure to return (or `await`) the promise - if you omit the `return`/`await` statement, your test will complete before the promise returned from `fetchData` resolves or rejects. + +::: + +If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. + +```js +test('the fetch fails with an error', () => { + expect.assertions(1); + return fetchData().catch(e => expect(e).toMatch('error')); +}); +``` + +## Callbacks -For example, let's say that you have a `fetchData(callback)` function that fetches some data and calls `callback(data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. +If you don't use promises, you can use callbacks. For example, let's say that `fetchData`, instead of returning a promise, expects a callback, i.e. fetches some data and calls `callback(null, data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. By default, Jest tests complete once they reach the end of their execution. That means this test will _not_ work as intended: ```js // Don't do this! test('the data is peanut butter', () => { - function callback(data) { + function callback(error, data) { + if (error) { + throw error; + } expect(data).toBe('peanut butter'); } @@ -30,7 +94,11 @@ There is an alternate form of `test` that fixes this. Instead of putting the tes ```js test('the data is peanut butter', done => { - function callback(data) { + function callback(error, data) { + if (error) { + done(error); + return; + } try { expect(data).toBe('peanut butter'); done(); @@ -49,31 +117,6 @@ If the `expect` statement fails, it throws an error and `done()` is not called. _Note: `done()` should not be mixed with Promises as this tends to lead to memory leaks in your tests._ -## Promises - -If your code uses promises, there is a more straightforward way to handle asynchronous tests. Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. - -For example, let's say that `fetchData`, instead of using a callback, returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: - -```js -test('the data is peanut butter', () => { - return fetchData().then(data => { - expect(data).toBe('peanut butter'); - }); -}); -``` - -Be sure to return the promise - if you omit this `return` statement, your test will complete before the promise returned from `fetchData` resolves and then() has a chance to execute the callback. - -If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. - -```js -test('the fetch fails with an error', () => { - expect.assertions(1); - return fetchData().catch(e => expect(e).toMatch('error')); -}); -``` - ## `.resolves` / `.rejects` You can also use the `.resolves` matcher in your expect statement, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. @@ -94,38 +137,4 @@ test('the fetch fails with an error', () => { }); ``` -## Async/Await - -Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: - -```js -test('the data is peanut butter', async () => { - const data = await fetchData(); - expect(data).toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - expect.assertions(1); - try { - await fetchData(); - } catch (e) { - expect(e).toMatch('error'); - } -}); -``` - -You can combine `async` and `await` with `.resolves` or `.rejects`. - -```js -test('the data is peanut butter', async () => { - await expect(fetchData()).resolves.toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - await expect(fetchData()).rejects.toMatch('error'); -}); -``` - -In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. - None of these forms is particularly superior to the others, and you can mix and match them across a codebase or even in a single file. It just depends on which style you feel makes your tests simpler. diff --git a/website/versioned_docs/version-26.x/TestingAsyncCode.md b/website/versioned_docs/version-26.x/TestingAsyncCode.md index 432db44b3944..ef8762eb7d87 100644 --- a/website/versioned_docs/version-26.x/TestingAsyncCode.md +++ b/website/versioned_docs/version-26.x/TestingAsyncCode.md @@ -5,18 +5,82 @@ title: Testing Asynchronous Code It's common in JavaScript for code to run asynchronously. When you have code that runs asynchronously, Jest needs to know when the code it is testing has completed, before it can move on to another test. Jest has several ways to handle this. -## Callbacks +## Promises + +Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will fail. + +For example, let's say that `fetchData` returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: + +```js +test('the data is peanut butter', () => { + return fetchData().then(data => { + expect(data).toBe('peanut butter'); + }); +}); +``` + +## Async/Await + +Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: + +```js +test('the data is peanut butter', async () => { + const data = await fetchData(); + expect(data).toBe('peanut butter'); +}); -The most common asynchronous pattern is callbacks. +test('the fetch fails with an error', async () => { + expect.assertions(1); + try { + await fetchData(); + } catch (e) { + expect(e).toMatch('error'); + } +}); +``` + +You can combine `async` and `await` with `.resolves` or `.rejects`. + +```js +test('the data is peanut butter', async () => { + await expect(fetchData()).resolves.toBe('peanut butter'); +}); + +test('the fetch fails with an error', async () => { + await expect(fetchData()).rejects.toMatch('error'); +}); +``` + +In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. + +:::caution + +Be sure to return (or `await`) the promise - if you omit the `return`/`await` statement, your test will complete before the promise returned from `fetchData` resolves or rejects. + +::: + +If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. + +```js +test('the fetch fails with an error', () => { + expect.assertions(1); + return fetchData().catch(e => expect(e).toMatch('error')); +}); +``` + +## Callbacks -For example, let's say that you have a `fetchData(callback)` function that fetches some data and calls `callback(data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. +If you don't use promises, you can use callbacks. For example, let's say that `fetchData`, instead of returning a promise, expects a callback, i.e. fetches some data and calls `callback(null, data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. By default, Jest tests complete once they reach the end of their execution. That means this test will _not_ work as intended: ```js // Don't do this! test('the data is peanut butter', () => { - function callback(data) { + function callback(error, data) { + if (error) { + throw error; + } expect(data).toBe('peanut butter'); } @@ -30,7 +94,11 @@ There is an alternate form of `test` that fixes this. Instead of putting the tes ```js test('the data is peanut butter', done => { - function callback(data) { + function callback(error, data) { + if (error) { + done(error); + return; + } try { expect(data).toBe('peanut butter'); done(); @@ -49,31 +117,6 @@ If the `expect` statement fails, it throws an error and `done()` is not called. _Note: `done()` should not be mixed with Promises as this tends to lead to memory leaks in your tests._ -## Promises - -If your code uses promises, there is a more straightforward way to handle asynchronous tests. Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. - -For example, let's say that `fetchData`, instead of using a callback, returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: - -```js -test('the data is peanut butter', () => { - return fetchData().then(data => { - expect(data).toBe('peanut butter'); - }); -}); -``` - -Be sure to return the promise - if you omit this `return` statement, your test will complete before the promise returned from `fetchData` resolves and then() has a chance to execute the callback. - -If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. - -```js -test('the fetch fails with an error', () => { - expect.assertions(1); - return fetchData().catch(e => expect(e).toMatch('error')); -}); -``` - ## `.resolves` / `.rejects` You can also use the `.resolves` matcher in your expect statement, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. @@ -94,38 +137,4 @@ test('the fetch fails with an error', () => { }); ``` -## Async/Await - -Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: - -```js -test('the data is peanut butter', async () => { - const data = await fetchData(); - expect(data).toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - expect.assertions(1); - try { - await fetchData(); - } catch (e) { - expect(e).toMatch('error'); - } -}); -``` - -You can combine `async` and `await` with `.resolves` or `.rejects`. - -```js -test('the data is peanut butter', async () => { - await expect(fetchData()).resolves.toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - await expect(fetchData()).rejects.toMatch('error'); -}); -``` - -In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. - None of these forms is particularly superior to the others, and you can mix and match them across a codebase or even in a single file. It just depends on which style you feel makes your tests simpler. diff --git a/website/versioned_docs/version-27.0/TestingAsyncCode.md b/website/versioned_docs/version-27.0/TestingAsyncCode.md index 432db44b3944..ef8762eb7d87 100644 --- a/website/versioned_docs/version-27.0/TestingAsyncCode.md +++ b/website/versioned_docs/version-27.0/TestingAsyncCode.md @@ -5,18 +5,82 @@ title: Testing Asynchronous Code It's common in JavaScript for code to run asynchronously. When you have code that runs asynchronously, Jest needs to know when the code it is testing has completed, before it can move on to another test. Jest has several ways to handle this. -## Callbacks +## Promises + +Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will fail. + +For example, let's say that `fetchData` returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: + +```js +test('the data is peanut butter', () => { + return fetchData().then(data => { + expect(data).toBe('peanut butter'); + }); +}); +``` + +## Async/Await + +Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: + +```js +test('the data is peanut butter', async () => { + const data = await fetchData(); + expect(data).toBe('peanut butter'); +}); -The most common asynchronous pattern is callbacks. +test('the fetch fails with an error', async () => { + expect.assertions(1); + try { + await fetchData(); + } catch (e) { + expect(e).toMatch('error'); + } +}); +``` + +You can combine `async` and `await` with `.resolves` or `.rejects`. + +```js +test('the data is peanut butter', async () => { + await expect(fetchData()).resolves.toBe('peanut butter'); +}); + +test('the fetch fails with an error', async () => { + await expect(fetchData()).rejects.toMatch('error'); +}); +``` + +In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. + +:::caution + +Be sure to return (or `await`) the promise - if you omit the `return`/`await` statement, your test will complete before the promise returned from `fetchData` resolves or rejects. + +::: + +If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. + +```js +test('the fetch fails with an error', () => { + expect.assertions(1); + return fetchData().catch(e => expect(e).toMatch('error')); +}); +``` + +## Callbacks -For example, let's say that you have a `fetchData(callback)` function that fetches some data and calls `callback(data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. +If you don't use promises, you can use callbacks. For example, let's say that `fetchData`, instead of returning a promise, expects a callback, i.e. fetches some data and calls `callback(null, data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. By default, Jest tests complete once they reach the end of their execution. That means this test will _not_ work as intended: ```js // Don't do this! test('the data is peanut butter', () => { - function callback(data) { + function callback(error, data) { + if (error) { + throw error; + } expect(data).toBe('peanut butter'); } @@ -30,7 +94,11 @@ There is an alternate form of `test` that fixes this. Instead of putting the tes ```js test('the data is peanut butter', done => { - function callback(data) { + function callback(error, data) { + if (error) { + done(error); + return; + } try { expect(data).toBe('peanut butter'); done(); @@ -49,31 +117,6 @@ If the `expect` statement fails, it throws an error and `done()` is not called. _Note: `done()` should not be mixed with Promises as this tends to lead to memory leaks in your tests._ -## Promises - -If your code uses promises, there is a more straightforward way to handle asynchronous tests. Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. - -For example, let's say that `fetchData`, instead of using a callback, returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: - -```js -test('the data is peanut butter', () => { - return fetchData().then(data => { - expect(data).toBe('peanut butter'); - }); -}); -``` - -Be sure to return the promise - if you omit this `return` statement, your test will complete before the promise returned from `fetchData` resolves and then() has a chance to execute the callback. - -If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. - -```js -test('the fetch fails with an error', () => { - expect.assertions(1); - return fetchData().catch(e => expect(e).toMatch('error')); -}); -``` - ## `.resolves` / `.rejects` You can also use the `.resolves` matcher in your expect statement, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. @@ -94,38 +137,4 @@ test('the fetch fails with an error', () => { }); ``` -## Async/Await - -Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: - -```js -test('the data is peanut butter', async () => { - const data = await fetchData(); - expect(data).toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - expect.assertions(1); - try { - await fetchData(); - } catch (e) { - expect(e).toMatch('error'); - } -}); -``` - -You can combine `async` and `await` with `.resolves` or `.rejects`. - -```js -test('the data is peanut butter', async () => { - await expect(fetchData()).resolves.toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - await expect(fetchData()).rejects.toMatch('error'); -}); -``` - -In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. - None of these forms is particularly superior to the others, and you can mix and match them across a codebase or even in a single file. It just depends on which style you feel makes your tests simpler. diff --git a/website/versioned_docs/version-27.1/TestingAsyncCode.md b/website/versioned_docs/version-27.1/TestingAsyncCode.md index 432db44b3944..ef8762eb7d87 100644 --- a/website/versioned_docs/version-27.1/TestingAsyncCode.md +++ b/website/versioned_docs/version-27.1/TestingAsyncCode.md @@ -5,18 +5,82 @@ title: Testing Asynchronous Code It's common in JavaScript for code to run asynchronously. When you have code that runs asynchronously, Jest needs to know when the code it is testing has completed, before it can move on to another test. Jest has several ways to handle this. -## Callbacks +## Promises + +Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will fail. + +For example, let's say that `fetchData` returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: + +```js +test('the data is peanut butter', () => { + return fetchData().then(data => { + expect(data).toBe('peanut butter'); + }); +}); +``` + +## Async/Await + +Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: + +```js +test('the data is peanut butter', async () => { + const data = await fetchData(); + expect(data).toBe('peanut butter'); +}); -The most common asynchronous pattern is callbacks. +test('the fetch fails with an error', async () => { + expect.assertions(1); + try { + await fetchData(); + } catch (e) { + expect(e).toMatch('error'); + } +}); +``` + +You can combine `async` and `await` with `.resolves` or `.rejects`. + +```js +test('the data is peanut butter', async () => { + await expect(fetchData()).resolves.toBe('peanut butter'); +}); + +test('the fetch fails with an error', async () => { + await expect(fetchData()).rejects.toMatch('error'); +}); +``` + +In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. + +:::caution + +Be sure to return (or `await`) the promise - if you omit the `return`/`await` statement, your test will complete before the promise returned from `fetchData` resolves or rejects. + +::: + +If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. + +```js +test('the fetch fails with an error', () => { + expect.assertions(1); + return fetchData().catch(e => expect(e).toMatch('error')); +}); +``` + +## Callbacks -For example, let's say that you have a `fetchData(callback)` function that fetches some data and calls `callback(data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. +If you don't use promises, you can use callbacks. For example, let's say that `fetchData`, instead of returning a promise, expects a callback, i.e. fetches some data and calls `callback(null, data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. By default, Jest tests complete once they reach the end of their execution. That means this test will _not_ work as intended: ```js // Don't do this! test('the data is peanut butter', () => { - function callback(data) { + function callback(error, data) { + if (error) { + throw error; + } expect(data).toBe('peanut butter'); } @@ -30,7 +94,11 @@ There is an alternate form of `test` that fixes this. Instead of putting the tes ```js test('the data is peanut butter', done => { - function callback(data) { + function callback(error, data) { + if (error) { + done(error); + return; + } try { expect(data).toBe('peanut butter'); done(); @@ -49,31 +117,6 @@ If the `expect` statement fails, it throws an error and `done()` is not called. _Note: `done()` should not be mixed with Promises as this tends to lead to memory leaks in your tests._ -## Promises - -If your code uses promises, there is a more straightforward way to handle asynchronous tests. Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. - -For example, let's say that `fetchData`, instead of using a callback, returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: - -```js -test('the data is peanut butter', () => { - return fetchData().then(data => { - expect(data).toBe('peanut butter'); - }); -}); -``` - -Be sure to return the promise - if you omit this `return` statement, your test will complete before the promise returned from `fetchData` resolves and then() has a chance to execute the callback. - -If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. - -```js -test('the fetch fails with an error', () => { - expect.assertions(1); - return fetchData().catch(e => expect(e).toMatch('error')); -}); -``` - ## `.resolves` / `.rejects` You can also use the `.resolves` matcher in your expect statement, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. @@ -94,38 +137,4 @@ test('the fetch fails with an error', () => { }); ``` -## Async/Await - -Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: - -```js -test('the data is peanut butter', async () => { - const data = await fetchData(); - expect(data).toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - expect.assertions(1); - try { - await fetchData(); - } catch (e) { - expect(e).toMatch('error'); - } -}); -``` - -You can combine `async` and `await` with `.resolves` or `.rejects`. - -```js -test('the data is peanut butter', async () => { - await expect(fetchData()).resolves.toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - await expect(fetchData()).rejects.toMatch('error'); -}); -``` - -In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. - None of these forms is particularly superior to the others, and you can mix and match them across a codebase or even in a single file. It just depends on which style you feel makes your tests simpler. diff --git a/website/versioned_docs/version-27.2/TestingAsyncCode.md b/website/versioned_docs/version-27.2/TestingAsyncCode.md index 432db44b3944..ef8762eb7d87 100644 --- a/website/versioned_docs/version-27.2/TestingAsyncCode.md +++ b/website/versioned_docs/version-27.2/TestingAsyncCode.md @@ -5,18 +5,82 @@ title: Testing Asynchronous Code It's common in JavaScript for code to run asynchronously. When you have code that runs asynchronously, Jest needs to know when the code it is testing has completed, before it can move on to another test. Jest has several ways to handle this. -## Callbacks +## Promises + +Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will fail. + +For example, let's say that `fetchData` returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: + +```js +test('the data is peanut butter', () => { + return fetchData().then(data => { + expect(data).toBe('peanut butter'); + }); +}); +``` + +## Async/Await + +Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: + +```js +test('the data is peanut butter', async () => { + const data = await fetchData(); + expect(data).toBe('peanut butter'); +}); -The most common asynchronous pattern is callbacks. +test('the fetch fails with an error', async () => { + expect.assertions(1); + try { + await fetchData(); + } catch (e) { + expect(e).toMatch('error'); + } +}); +``` + +You can combine `async` and `await` with `.resolves` or `.rejects`. + +```js +test('the data is peanut butter', async () => { + await expect(fetchData()).resolves.toBe('peanut butter'); +}); + +test('the fetch fails with an error', async () => { + await expect(fetchData()).rejects.toMatch('error'); +}); +``` + +In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. + +:::caution + +Be sure to return (or `await`) the promise - if you omit the `return`/`await` statement, your test will complete before the promise returned from `fetchData` resolves or rejects. + +::: + +If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. + +```js +test('the fetch fails with an error', () => { + expect.assertions(1); + return fetchData().catch(e => expect(e).toMatch('error')); +}); +``` + +## Callbacks -For example, let's say that you have a `fetchData(callback)` function that fetches some data and calls `callback(data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. +If you don't use promises, you can use callbacks. For example, let's say that `fetchData`, instead of returning a promise, expects a callback, i.e. fetches some data and calls `callback(null, data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. By default, Jest tests complete once they reach the end of their execution. That means this test will _not_ work as intended: ```js // Don't do this! test('the data is peanut butter', () => { - function callback(data) { + function callback(error, data) { + if (error) { + throw error; + } expect(data).toBe('peanut butter'); } @@ -30,7 +94,11 @@ There is an alternate form of `test` that fixes this. Instead of putting the tes ```js test('the data is peanut butter', done => { - function callback(data) { + function callback(error, data) { + if (error) { + done(error); + return; + } try { expect(data).toBe('peanut butter'); done(); @@ -49,31 +117,6 @@ If the `expect` statement fails, it throws an error and `done()` is not called. _Note: `done()` should not be mixed with Promises as this tends to lead to memory leaks in your tests._ -## Promises - -If your code uses promises, there is a more straightforward way to handle asynchronous tests. Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. - -For example, let's say that `fetchData`, instead of using a callback, returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: - -```js -test('the data is peanut butter', () => { - return fetchData().then(data => { - expect(data).toBe('peanut butter'); - }); -}); -``` - -Be sure to return the promise - if you omit this `return` statement, your test will complete before the promise returned from `fetchData` resolves and then() has a chance to execute the callback. - -If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. - -```js -test('the fetch fails with an error', () => { - expect.assertions(1); - return fetchData().catch(e => expect(e).toMatch('error')); -}); -``` - ## `.resolves` / `.rejects` You can also use the `.resolves` matcher in your expect statement, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. @@ -94,38 +137,4 @@ test('the fetch fails with an error', () => { }); ``` -## Async/Await - -Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: - -```js -test('the data is peanut butter', async () => { - const data = await fetchData(); - expect(data).toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - expect.assertions(1); - try { - await fetchData(); - } catch (e) { - expect(e).toMatch('error'); - } -}); -``` - -You can combine `async` and `await` with `.resolves` or `.rejects`. - -```js -test('the data is peanut butter', async () => { - await expect(fetchData()).resolves.toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - await expect(fetchData()).rejects.toMatch('error'); -}); -``` - -In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. - None of these forms is particularly superior to the others, and you can mix and match them across a codebase or even in a single file. It just depends on which style you feel makes your tests simpler. diff --git a/website/versioned_docs/version-27.4/TestingAsyncCode.md b/website/versioned_docs/version-27.4/TestingAsyncCode.md index 432db44b3944..ef8762eb7d87 100644 --- a/website/versioned_docs/version-27.4/TestingAsyncCode.md +++ b/website/versioned_docs/version-27.4/TestingAsyncCode.md @@ -5,18 +5,82 @@ title: Testing Asynchronous Code It's common in JavaScript for code to run asynchronously. When you have code that runs asynchronously, Jest needs to know when the code it is testing has completed, before it can move on to another test. Jest has several ways to handle this. -## Callbacks +## Promises + +Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will fail. + +For example, let's say that `fetchData` returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: + +```js +test('the data is peanut butter', () => { + return fetchData().then(data => { + expect(data).toBe('peanut butter'); + }); +}); +``` + +## Async/Await + +Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: + +```js +test('the data is peanut butter', async () => { + const data = await fetchData(); + expect(data).toBe('peanut butter'); +}); -The most common asynchronous pattern is callbacks. +test('the fetch fails with an error', async () => { + expect.assertions(1); + try { + await fetchData(); + } catch (e) { + expect(e).toMatch('error'); + } +}); +``` + +You can combine `async` and `await` with `.resolves` or `.rejects`. + +```js +test('the data is peanut butter', async () => { + await expect(fetchData()).resolves.toBe('peanut butter'); +}); + +test('the fetch fails with an error', async () => { + await expect(fetchData()).rejects.toMatch('error'); +}); +``` + +In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. + +:::caution + +Be sure to return (or `await`) the promise - if you omit the `return`/`await` statement, your test will complete before the promise returned from `fetchData` resolves or rejects. + +::: + +If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. + +```js +test('the fetch fails with an error', () => { + expect.assertions(1); + return fetchData().catch(e => expect(e).toMatch('error')); +}); +``` + +## Callbacks -For example, let's say that you have a `fetchData(callback)` function that fetches some data and calls `callback(data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. +If you don't use promises, you can use callbacks. For example, let's say that `fetchData`, instead of returning a promise, expects a callback, i.e. fetches some data and calls `callback(null, data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. By default, Jest tests complete once they reach the end of their execution. That means this test will _not_ work as intended: ```js // Don't do this! test('the data is peanut butter', () => { - function callback(data) { + function callback(error, data) { + if (error) { + throw error; + } expect(data).toBe('peanut butter'); } @@ -30,7 +94,11 @@ There is an alternate form of `test` that fixes this. Instead of putting the tes ```js test('the data is peanut butter', done => { - function callback(data) { + function callback(error, data) { + if (error) { + done(error); + return; + } try { expect(data).toBe('peanut butter'); done(); @@ -49,31 +117,6 @@ If the `expect` statement fails, it throws an error and `done()` is not called. _Note: `done()` should not be mixed with Promises as this tends to lead to memory leaks in your tests._ -## Promises - -If your code uses promises, there is a more straightforward way to handle asynchronous tests. Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. - -For example, let's say that `fetchData`, instead of using a callback, returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: - -```js -test('the data is peanut butter', () => { - return fetchData().then(data => { - expect(data).toBe('peanut butter'); - }); -}); -``` - -Be sure to return the promise - if you omit this `return` statement, your test will complete before the promise returned from `fetchData` resolves and then() has a chance to execute the callback. - -If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. - -```js -test('the fetch fails with an error', () => { - expect.assertions(1); - return fetchData().catch(e => expect(e).toMatch('error')); -}); -``` - ## `.resolves` / `.rejects` You can also use the `.resolves` matcher in your expect statement, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. @@ -94,38 +137,4 @@ test('the fetch fails with an error', () => { }); ``` -## Async/Await - -Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: - -```js -test('the data is peanut butter', async () => { - const data = await fetchData(); - expect(data).toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - expect.assertions(1); - try { - await fetchData(); - } catch (e) { - expect(e).toMatch('error'); - } -}); -``` - -You can combine `async` and `await` with `.resolves` or `.rejects`. - -```js -test('the data is peanut butter', async () => { - await expect(fetchData()).resolves.toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - await expect(fetchData()).rejects.toMatch('error'); -}); -``` - -In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. - None of these forms is particularly superior to the others, and you can mix and match them across a codebase or even in a single file. It just depends on which style you feel makes your tests simpler. diff --git a/website/versioned_docs/version-27.5/TestingAsyncCode.md b/website/versioned_docs/version-27.5/TestingAsyncCode.md index 432db44b3944..ef8762eb7d87 100644 --- a/website/versioned_docs/version-27.5/TestingAsyncCode.md +++ b/website/versioned_docs/version-27.5/TestingAsyncCode.md @@ -5,18 +5,82 @@ title: Testing Asynchronous Code It's common in JavaScript for code to run asynchronously. When you have code that runs asynchronously, Jest needs to know when the code it is testing has completed, before it can move on to another test. Jest has several ways to handle this. -## Callbacks +## Promises + +Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will fail. + +For example, let's say that `fetchData` returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: + +```js +test('the data is peanut butter', () => { + return fetchData().then(data => { + expect(data).toBe('peanut butter'); + }); +}); +``` + +## Async/Await + +Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: + +```js +test('the data is peanut butter', async () => { + const data = await fetchData(); + expect(data).toBe('peanut butter'); +}); -The most common asynchronous pattern is callbacks. +test('the fetch fails with an error', async () => { + expect.assertions(1); + try { + await fetchData(); + } catch (e) { + expect(e).toMatch('error'); + } +}); +``` + +You can combine `async` and `await` with `.resolves` or `.rejects`. + +```js +test('the data is peanut butter', async () => { + await expect(fetchData()).resolves.toBe('peanut butter'); +}); + +test('the fetch fails with an error', async () => { + await expect(fetchData()).rejects.toMatch('error'); +}); +``` + +In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. + +:::caution + +Be sure to return (or `await`) the promise - if you omit the `return`/`await` statement, your test will complete before the promise returned from `fetchData` resolves or rejects. + +::: + +If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. + +```js +test('the fetch fails with an error', () => { + expect.assertions(1); + return fetchData().catch(e => expect(e).toMatch('error')); +}); +``` + +## Callbacks -For example, let's say that you have a `fetchData(callback)` function that fetches some data and calls `callback(data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. +If you don't use promises, you can use callbacks. For example, let's say that `fetchData`, instead of returning a promise, expects a callback, i.e. fetches some data and calls `callback(null, data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. By default, Jest tests complete once they reach the end of their execution. That means this test will _not_ work as intended: ```js // Don't do this! test('the data is peanut butter', () => { - function callback(data) { + function callback(error, data) { + if (error) { + throw error; + } expect(data).toBe('peanut butter'); } @@ -30,7 +94,11 @@ There is an alternate form of `test` that fixes this. Instead of putting the tes ```js test('the data is peanut butter', done => { - function callback(data) { + function callback(error, data) { + if (error) { + done(error); + return; + } try { expect(data).toBe('peanut butter'); done(); @@ -49,31 +117,6 @@ If the `expect` statement fails, it throws an error and `done()` is not called. _Note: `done()` should not be mixed with Promises as this tends to lead to memory leaks in your tests._ -## Promises - -If your code uses promises, there is a more straightforward way to handle asynchronous tests. Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. - -For example, let's say that `fetchData`, instead of using a callback, returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: - -```js -test('the data is peanut butter', () => { - return fetchData().then(data => { - expect(data).toBe('peanut butter'); - }); -}); -``` - -Be sure to return the promise - if you omit this `return` statement, your test will complete before the promise returned from `fetchData` resolves and then() has a chance to execute the callback. - -If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. - -```js -test('the fetch fails with an error', () => { - expect.assertions(1); - return fetchData().catch(e => expect(e).toMatch('error')); -}); -``` - ## `.resolves` / `.rejects` You can also use the `.resolves` matcher in your expect statement, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. @@ -94,38 +137,4 @@ test('the fetch fails with an error', () => { }); ``` -## Async/Await - -Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: - -```js -test('the data is peanut butter', async () => { - const data = await fetchData(); - expect(data).toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - expect.assertions(1); - try { - await fetchData(); - } catch (e) { - expect(e).toMatch('error'); - } -}); -``` - -You can combine `async` and `await` with `.resolves` or `.rejects`. - -```js -test('the data is peanut butter', async () => { - await expect(fetchData()).resolves.toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - await expect(fetchData()).rejects.toMatch('error'); -}); -``` - -In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. - None of these forms is particularly superior to the others, and you can mix and match them across a codebase or even in a single file. It just depends on which style you feel makes your tests simpler. From 8a8eb3686b31088c80bb107990da7a401dbf24da Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Tue, 12 Apr 2022 14:23:10 +0800 Subject: [PATCH 039/128] clean @ts-expect-error (#12664) Co-authored-by: Tom Mrazauskas --- packages/jest-runtime/src/index.ts | 2 -- packages/jest-types/src/Global.ts | 2 +- 2 files changed, 1 insertion(+), 3 deletions(-) diff --git a/packages/jest-runtime/src/index.ts b/packages/jest-runtime/src/index.ts index 17f69ced6dc3..c405a1191543 100644 --- a/packages/jest-runtime/src/index.ts +++ b/packages/jest-runtime/src/index.ts @@ -2100,13 +2100,11 @@ export default class Runtime { }); const setTimeout = (timeout: number) => { - // @ts-expect-error: https://github.com/Microsoft/TypeScript/issues/24587 this._environment.global[testTimeoutSymbol] = timeout; return jestObject; }; const retryTimes = (numTestRetries: number) => { - // @ts-expect-error: https://github.com/Microsoft/TypeScript/issues/24587 this._environment.global[retryTimesSymbol] = numTestRetries; return jestObject; }; diff --git a/packages/jest-types/src/Global.ts b/packages/jest-types/src/Global.ts index 486004f49bea..aed1c4b2a8c9 100644 --- a/packages/jest-types/src/Global.ts +++ b/packages/jest-types/src/Global.ts @@ -123,5 +123,5 @@ export interface GlobalAdditions extends TestFrameworkGlobals { export interface Global extends GlobalAdditions, Omit { - [extras: string]: unknown; + [extras: PropertyKey]: unknown; } From 816789920fe08b2f0245963e91d3a96fe80e1311 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Tue, 12 Apr 2022 09:32:01 +0300 Subject: [PATCH 040/128] feat(jest-reporters): pass `reporterContext` to custom reporter constructors as third argument (#12657) --- .eslintrc.cjs | 2 - CHANGELOG.md | 1 + docs/Configuration.md | 73 +++++----- .../customReporters.test.ts.snap | 24 +++- .../reporters/IncompleteReporter.js | 2 +- .../reporters/TestReporter.js | 14 +- .../__snapshots__/normalize.test.ts.snap | 68 +++++++++ .../src/__tests__/normalize.test.ts | 96 +++++++++++++ packages/jest-core/src/ReporterDispatcher.ts | 13 +- packages/jest-core/src/TestScheduler.ts | 136 +++++++----------- .../src/__tests__/TestScheduler.test.js | 18 +-- packages/jest-core/src/runJest.ts | 12 +- packages/jest-reporters/package.json | 3 +- packages/jest-reporters/src/BaseReporter.ts | 6 +- .../jest-reporters/src/CoverageReporter.ts | 41 +++--- packages/jest-reporters/src/CoverageWorker.ts | 16 +-- .../jest-reporters/src/DefaultReporter.ts | 3 +- .../src/GitHubActionsReporter.ts | 9 +- packages/jest-reporters/src/NotifyReporter.ts | 25 ++-- packages/jest-reporters/src/Status.ts | 3 +- .../jest-reporters/src/SummaryReporter.ts | 14 +- .../jest-reporters/src/VerboseReporter.ts | 2 +- .../src/__tests__/CoverageWorker.test.js | 3 +- .../src/__tests__/NotifyReporter.test.ts | 24 ++-- packages/jest-reporters/src/index.ts | 12 +- packages/jest-reporters/src/types.ts | 68 +++------ packages/jest-reporters/src/utils.ts | 4 +- packages/jest-reporters/tsconfig.json | 1 - packages/jest-types/src/Config.ts | 5 +- yarn.lock | 1 - 30 files changed, 405 insertions(+), 294 deletions(-) diff --git a/.eslintrc.cjs b/.eslintrc.cjs index 64caddbf7457..047f0c1944f1 100644 --- a/.eslintrc.cjs +++ b/.eslintrc.cjs @@ -101,8 +101,6 @@ module.exports = { 'packages/expect/src/print.ts', 'packages/expect/src/toThrowMatchers.ts', 'packages/expect-utils/src/utils.ts', - 'packages/jest-core/src/ReporterDispatcher.ts', - 'packages/jest-core/src/TestScheduler.ts', 'packages/jest-core/src/collectHandles.ts', 'packages/jest-core/src/plugins/UpdateSnapshotsInteractive.ts', 'packages/jest-haste-map/src/index.ts', diff --git a/CHANGELOG.md b/CHANGELOG.md index 0f48c8855293..29b70dfadf5b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -38,6 +38,7 @@ - `[jest-mock]` Add support for auto-mocking async generator functions ([#11080](https://github.com/facebook/jest/pull/11080)) - `[jest-mock]` Add `contexts` member to mock functions ([#12601](https://github.com/facebook/jest/pull/12601)) - `[jest-reporters]` Add GitHub Actions reporter ([#11320](https://github.com/facebook/jest/pull/11320), [#12658](https://github.com/facebook/jest/pull/12658) +- `[jest-reporters]` Pass `reporterContext` to custom reporter constructors as third argument ([#12657](https://github.com/facebook/jest/pull/12657)) - `[jest-resolve]` [**BREAKING**] Add support for `package.json` `exports` ([#11961](https://github.com/facebook/jest/pull/11961), [#12373](https://github.com/facebook/jest/pull/12373)) - `[jest-resolve, jest-runtime]` Add support for `data:` URI import and mock ([#12392](https://github.com/facebook/jest/pull/12392)) - `[jest-resolve, jest-runtime]` Add support for async resolver ([#11540](https://github.com/facebook/jest/pull/11540)) diff --git a/docs/Configuration.md b/docs/Configuration.md index ab5dc416f632..afb0a21b0481 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -822,73 +822,76 @@ When using multi-project runner, it's recommended to add a `displayName` for eac Default: `undefined` -Use this configuration option to add custom reporters to Jest. A custom reporter is a class that implements `onRunStart`, `onTestStart`, `onTestResult`, `onRunComplete` methods that will be called when any of those events occurs. - -If custom reporters are specified, the default Jest reporters will be overridden. To keep default reporters, `default` can be passed as a module name. - -This will override default reporters: +Use this configuration option to add reporters to Jest. It must be a list of reporter names, additional options can be passed to a reporter using the tuple form: ```json { - "reporters": ["/my-custom-reporter.js"] + "reporters": [ + "default", + ["/custom-reporter.js", {"banana": "yes", "pineapple": "no"}] + ] } ``` -This will use custom reporter in addition to default reporters that Jest provides: +#### Default Reporter + +If custom reporters are specified, the default Jest reporter will be overridden. If you wish to keep it, `'default'` must be passed as a reporters name: ```json { - "reporters": ["default", "/my-custom-reporter.js"] + "reporters": [ + "default", + ["jest-junit", {"outputDirectory": "reports", "outputName": "report.xml"}] + ] } ``` -Additionally, custom reporters can be configured by passing an `options` object as a second argument: +#### GitHub Actions Reporter + +If included in the list, the built-in GitHub Actions Reporter will annotate changed files with test failure messages: ```json { - "reporters": [ - "default", - ["/my-custom-reporter.js", {"banana": "yes", "pineapple": "no"}] - ] + "reporters": ["default", "github-actions"] } ``` -Custom reporter modules must define a class that takes a `GlobalConfig` and reporter options as constructor arguments: +#### Custom Reporters -Example reporter: +:::tip + +Hungry for reporters? Take a look at long list of [awesome reporters](https://github.com/jest-community/awesome-jest/blob/main/README.md#reporters) from Awesome Jest. + +::: -```js title="my-custom-reporter.js" -class MyCustomReporter { - constructor(globalConfig, options) { +Custom reporter module must export a class that takes `globalConfig`, `reporterOptions` and `reporterContext` as constructor arguments and implements at least `onRunComplete()` method (for the full list of methods and argument types see `Reporter` interface in [packages/jest-reporters/src/types.ts](https://github.com/facebook/jest/blob/main/packages/jest-reporters/src/types.ts)): + +```js title="custom-reporter.js" +class CustomReporter { + constructor(globalConfig, reporterOptions, reporterContext) { this._globalConfig = globalConfig; - this._options = options; + this._options = reporterOptions; + this._context = reporterContext; } - onRunComplete(contexts, results) { + onRunComplete(testContexts, results) { console.log('Custom reporter output:'); - console.log('GlobalConfig: ', this._globalConfig); - console.log('Options: ', this._options); + console.log('global config: ', this._globalConfig); + console.log('options for this reporter from Jest config: ', this._options); + console.log('reporter context passed from test scheduler: ', this._context); } -} -module.exports = MyCustomReporter; -// or export default MyCustomReporter; -``` - -Custom reporters can also force Jest to exit with non-0 code by returning an Error from `getLastError()` methods - -```js -class MyCustomReporter { - // ... + // Optionally, reporters can force Jest to exit with non zero code by returning + // an `Error` from `getLastError()` method. getLastError() { if (this._shouldFail) { - return new Error('my-custom-reporter.js reported an error'); + return new Error('Custom error reported!'); } } } -``` -For the full list of methods and argument types see `Reporter` interface in [packages/jest-reporters/src/types.ts](https://github.com/facebook/jest/blob/main/packages/jest-reporters/src/types.ts) +module.exports = CustomReporter; +``` ### `resetMocks` \[boolean] diff --git a/e2e/__tests__/__snapshots__/customReporters.test.ts.snap b/e2e/__tests__/__snapshots__/customReporters.test.ts.snap index 43299913cba8..7506630b07d2 100644 --- a/e2e/__tests__/__snapshots__/customReporters.test.ts.snap +++ b/e2e/__tests__/__snapshots__/customReporters.test.ts.snap @@ -27,7 +27,11 @@ Object { "called": true, "path": false, }, - "options": Object { + "reporterContext": Object { + "firstRun": true, + "previousSuccess": true, + }, + "reporterOptions": Object { "christoph": "pojer", "dmitrii": "abramov", "hello": "world", @@ -55,7 +59,11 @@ Object { "called": true, "path": false, }, - "options": Object { + "reporterContext": Object { + "firstRun": true, + "previousSuccess": true, + }, + "reporterOptions": Object { "christoph": "pojer", "dmitrii": "abramov", "hello": "world", @@ -97,7 +105,11 @@ Object { "called": true, "path": false, }, - "options": Object {}, + "reporterContext": Object { + "firstRun": true, + "previousSuccess": true, + }, + "reporterOptions": Object {}, } `; @@ -146,7 +158,11 @@ exports[`Custom Reporters Integration valid array format for adding reporters 1` "called": true, "path": false }, - "options": { + "reporterContext": { + "firstRun": true, + "previousSuccess": true + }, + "reporterOptions": { "Aaron Abramov": "Awesome" } }" diff --git a/e2e/custom-reporters/reporters/IncompleteReporter.js b/e2e/custom-reporters/reporters/IncompleteReporter.js index 760e101ac74c..0cfba83192a1 100644 --- a/e2e/custom-reporters/reporters/IncompleteReporter.js +++ b/e2e/custom-reporters/reporters/IncompleteReporter.js @@ -15,7 +15,7 @@ * This only implements one method onRunComplete which should be called */ class IncompleteReporter { - onRunComplete(contexts, results) { + onRunComplete(testContexts, results) { console.log('onRunComplete is called'); console.log(`Passed Tests: ${results.numPassedTests}`); console.log(`Failed Tests: ${results.numFailedTests}`); diff --git a/e2e/custom-reporters/reporters/TestReporter.js b/e2e/custom-reporters/reporters/TestReporter.js index 5cd404b766b2..300fb5478bd3 100644 --- a/e2e/custom-reporters/reporters/TestReporter.js +++ b/e2e/custom-reporters/reporters/TestReporter.js @@ -15,8 +15,9 @@ * to get the output. */ class TestReporter { - constructor(globalConfig, options) { - this._options = options; + constructor(globalConfig, reporterOptions, reporterContext) { + this._context = reporterContext; + this._options = reporterOptions; /** * statsCollected property @@ -30,7 +31,8 @@ class TestReporter { onRunStart: {}, onTestResult: {times: 0}, onTestStart: {}, - options, + reporterContext, + reporterOptions, }; } @@ -66,7 +68,7 @@ class TestReporter { onRunStart.options = typeof options; } - onRunComplete(contexts, results) { + onRunComplete(testContexts, results) { const onRunComplete = this._statsCollected.onRunComplete; onRunComplete.called = true; @@ -75,9 +77,9 @@ class TestReporter { onRunComplete.numFailedTests = results.numFailedTests; onRunComplete.numTotalTests = results.numTotalTests; - if (this._statsCollected.options.maxWorkers) { + if (this._statsCollected.reporterOptions.maxWorkers) { // Since it's a different number on different machines. - this._statsCollected.options.maxWorkers = '<>'; + this._statsCollected.reporterOptions.maxWorkers = '<>'; } // The Final Call process.stdout.write(JSON.stringify(this._statsCollected, null, 4)); diff --git a/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap b/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap index a3d700f5b943..284570033fc2 100644 --- a/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap +++ b/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap @@ -200,6 +200,74 @@ exports[`preset throws when preset not found 1`] = ` " `; +exports[`reporters throws an error if first value in the tuple is not a string 1`] = ` +"Reporter Validation Error: + + Unexpected value for Path at index 0 of reporter at index 0 + Expected: + string + Got: + number + Reporter configuration: + [ + 123 + ] + + Configuration Documentation: + https://jestjs.io/docs/configuration +" +`; + +exports[`reporters throws an error if second value in the tuple is not an object 1`] = ` +"Reporter Validation Error: + + Unexpected value for Reporter Configuration at index 1 of reporter at index 0 + Expected: + object + Got: + boolean + Reporter configuration: + [ + "some-reporter", + true + ] + + Configuration Documentation: + https://jestjs.io/docs/configuration +" +`; + +exports[`reporters throws an error if second value is missing in the tuple 1`] = ` +"Reporter Validation Error: + + Unexpected value for Reporter Configuration at index 1 of reporter at index 0 + Expected: + object + Got: + undefined + Reporter configuration: + [ + "some-reporter" + ] + + Configuration Documentation: + https://jestjs.io/docs/configuration +" +`; + +exports[`reporters throws an error if value is neither string nor array 1`] = ` +"Reporter Validation Error: + + Reporter at index 0 must be of type: + array or string + but instead received: + number + + Configuration Documentation: + https://jestjs.io/docs/configuration +" +`; + exports[`rootDir throws if the options is missing a rootDir property 1`] = ` "Validation Error: diff --git a/packages/jest-config/src/__tests__/normalize.test.ts b/packages/jest-config/src/__tests__/normalize.test.ts index d4e264ccebae..457baef302f1 100644 --- a/packages/jest-config/src/__tests__/normalize.test.ts +++ b/packages/jest-config/src/__tests__/normalize.test.ts @@ -309,6 +309,102 @@ describe('roots', () => { testPathArray('roots'); }); +describe('reporters', () => { + let Resolver; + beforeEach(() => { + Resolver = require('jest-resolve').default; + Resolver.findNodeModule = jest.fn(name => name); + }); + + it('allows empty list', async () => { + const {options} = await normalize( + { + reporters: [], + rootDir: '/root/', + }, + {} as Config.Argv, + ); + + expect(options.reporters).toEqual([]); + }); + + it('normalizes the path and options object', async () => { + const {options} = await normalize( + { + reporters: [ + 'default', + 'github-actions', + '/custom-reporter.js', + ['/custom-reporter.js', {banana: 'yes', pineapple: 'no'}], + ['jest-junit', {outputName: 'report.xml'}], + ], + rootDir: '/root/', + }, + {} as Config.Argv, + ); + + expect(options.reporters).toEqual([ + ['default', {}], + ['github-actions', {}], + ['/root/custom-reporter.js', {}], + ['/root/custom-reporter.js', {banana: 'yes', pineapple: 'no'}], + ['jest-junit', {outputName: 'report.xml'}], + ]); + }); + + it('throws an error if value is neither string nor array', async () => { + expect.assertions(1); + await expect( + normalize( + { + reporters: [123], + rootDir: '/root/', + }, + {} as Config.Argv, + ), + ).rejects.toThrowErrorMatchingSnapshot(); + }); + + it('throws an error if first value in the tuple is not a string', async () => { + expect.assertions(1); + await expect( + normalize( + { + reporters: [[123]], + rootDir: '/root/', + }, + {} as Config.Argv, + ), + ).rejects.toThrowErrorMatchingSnapshot(); + }); + + it('throws an error if second value is missing in the tuple', async () => { + expect.assertions(1); + await expect( + normalize( + { + reporters: [['some-reporter']], + rootDir: '/root/', + }, + {} as Config.Argv, + ), + ).rejects.toThrowErrorMatchingSnapshot(); + }); + + it('throws an error if second value in the tuple is not an object', async () => { + expect.assertions(1); + await expect( + normalize( + { + reporters: [['some-reporter', true]], + rootDir: '/root/', + }, + {} as Config.Argv, + ), + ).rejects.toThrowErrorMatchingSnapshot(); + }); +}); + describe('transform', () => { let Resolver; beforeEach(() => { diff --git a/packages/jest-core/src/ReporterDispatcher.ts b/packages/jest-core/src/ReporterDispatcher.ts index 992925cdd65b..a70691f5ddcf 100644 --- a/packages/jest-core/src/ReporterDispatcher.ts +++ b/packages/jest-core/src/ReporterDispatcher.ts @@ -5,16 +5,15 @@ * LICENSE file in the root directory of this source tree. */ -/* eslint-disable local/ban-types-eventually */ - import type {Reporter, ReporterOnStartOptions} from '@jest/reporters'; import type { AggregatedResult, Test, TestCaseResult, + TestContext, TestResult, } from '@jest/test-result'; -import type {Context} from 'jest-runtime'; +import type {ReporterConstructor} from './TestScheduler'; export default class ReporterDispatcher { private _reporters: Array; @@ -27,9 +26,9 @@ export default class ReporterDispatcher { this._reporters.push(reporter); } - unregister(ReporterClass: Function): void { + unregister(reporterConstructor: ReporterConstructor): void { this._reporters = this._reporters.filter( - reporter => !(reporter instanceof ReporterClass), + reporter => !(reporter instanceof reporterConstructor), ); } @@ -82,12 +81,12 @@ export default class ReporterDispatcher { } async onRunComplete( - contexts: Set, + testContexts: Set, results: AggregatedResult, ): Promise { for (const reporter of this._reporters) { if (reporter.onRunComplete) { - await reporter.onRunComplete(contexts, results); + await reporter.onRunComplete(testContexts, results); } } } diff --git a/packages/jest-core/src/TestScheduler.ts b/packages/jest-core/src/TestScheduler.ts index 9eb4465a77ca..0dcb80354e02 100644 --- a/packages/jest-core/src/TestScheduler.ts +++ b/packages/jest-core/src/TestScheduler.ts @@ -5,8 +5,6 @@ * LICENSE file in the root directory of this source tree. */ -/* eslint-disable local/ban-types-eventually */ - import chalk = require('chalk'); import {GITHUB_ACTIONS} from 'ci-info'; import exit = require('exit'); @@ -14,8 +12,10 @@ import { CoverageReporter, DefaultReporter, GitHubActionsReporter, + BaseReporter as JestReporter, NotifyReporter, Reporter, + ReporterContext, SummaryReporter, VerboseReporter, } from '@jest/reporters'; @@ -23,6 +23,7 @@ import { AggregatedResult, SerializableError, Test, + TestContext, TestResult, addResult, buildFailureTestResult, @@ -32,7 +33,6 @@ import {createScriptTransformer} from '@jest/transform'; import type {Config} from '@jest/types'; import {formatExecError} from 'jest-message-util'; import type {JestTestRunner, TestRunnerContext} from 'jest-runner'; -import type {Context} from 'jest-runtime'; import { buildSnapshotResolver, cleanup as cleanupSnapshots, @@ -42,27 +42,26 @@ import type {TestWatcher} from 'jest-watcher'; import ReporterDispatcher from './ReporterDispatcher'; import {shouldRunInBand} from './testSchedulerHelper'; +export type ReporterConstructor = new ( + globalConfig: Config.GlobalConfig, + reporterConfig: Record, + reporterContext: ReporterContext, +) => JestReporter; + type TestRunnerConstructor = new ( globalConfig: Config.GlobalConfig, - context: TestRunnerContext, + testRunnerContext: TestRunnerContext, ) => JestTestRunner; -export type TestSchedulerOptions = { - startRun: (globalConfig: Config.GlobalConfig) => void; -}; -export type TestSchedulerContext = { - firstRun: boolean; - previousSuccess: boolean; - changedFiles?: Set; - sourcesRelatedToTestsInChangedFiles?: Set; -}; +export type TestSchedulerContext = ReporterContext & TestRunnerContext; + +type ReporterMap = Record>; export async function createTestScheduler( globalConfig: Config.GlobalConfig, - options: TestSchedulerOptions, context: TestSchedulerContext, ): Promise { - const scheduler = new TestScheduler(globalConfig, options, context); + const scheduler = new TestScheduler(globalConfig, context); await scheduler._setupReporters(); @@ -70,28 +69,25 @@ export async function createTestScheduler( } class TestScheduler { + private readonly _context: TestSchedulerContext; private readonly _dispatcher: ReporterDispatcher; private readonly _globalConfig: Config.GlobalConfig; - private readonly _options: TestSchedulerOptions; - private readonly _context: TestSchedulerContext; constructor( globalConfig: Config.GlobalConfig, - options: TestSchedulerOptions, context: TestSchedulerContext, ) { + this._context = context; this._dispatcher = new ReporterDispatcher(); this._globalConfig = globalConfig; - this._options = options; - this._context = context; } addReporter(reporter: Reporter): void { this._dispatcher.register(reporter); } - removeReporter(ReporterClass: Function): void { - this._dispatcher.unregister(ReporterClass); + removeReporter(reporterConstructor: ReporterConstructor): void { + this._dispatcher.unregister(reporterConstructor); } async scheduleTests( @@ -102,9 +98,9 @@ class TestScheduler { this._dispatcher, ); const timings: Array = []; - const contexts = new Set(); + const testContexts = new Set(); tests.forEach(test => { - contexts.add(test.context); + testContexts.add(test.context); if (test.duration) { timings.push(test.duration); } @@ -155,7 +151,7 @@ class TestScheduler { testResult, aggregatedResults, ); - return this._bailIfNeeded(contexts, aggregatedResults, watcher); + return this._bailIfNeeded(testContexts, aggregatedResults, watcher); }; const onFailure = async (test: Test, error: SerializableError) => { @@ -179,7 +175,7 @@ class TestScheduler { const updateSnapshotState = async () => { const contextsWithSnapshotResolvers = await Promise.all( - Array.from(contexts).map( + Array.from(testContexts).map( async context => [context, await buildSnapshotResolver(context.config)] as const, ), @@ -214,9 +210,9 @@ class TestScheduler { }); const testRunners: Record = Object.create(null); - const contextsByTestRunner = new WeakMap(); + const contextsByTestRunner = new WeakMap(); await Promise.all( - Array.from(contexts).map(async context => { + Array.from(testContexts).map(async context => { const {config} = context; if (!testRunners[config.runner]) { const transformer = await createScriptTransformer(config); @@ -292,7 +288,7 @@ class TestScheduler { await updateSnapshotState(); aggregatedResults.wasInterrupted = watcher.isInterrupted(); - await this._dispatcher.onRunComplete(contexts, aggregatedResults); + await this._dispatcher.onRunComplete(testContexts, aggregatedResults); const anyTestFailures = !( aggregatedResults.numFailedTests === 0 && @@ -336,13 +332,7 @@ class TestScheduler { const {collectCoverage, notify, reporters} = this._globalConfig; if (notify) { - this.addReporter( - new NotifyReporter( - this._globalConfig, - this._options.startRun, - this._context, - ), - ); + this.addReporter(new NotifyReporter(this._globalConfig, this._context)); } if (!reporters) { @@ -350,13 +340,19 @@ class TestScheduler { return; } - const reporterNames = reporters.map( - reporter => this._getReporterProps(reporter).path, - ); + let reporterMap: ReporterMap = {}; - const isDefault = reporterNames?.includes('default'); + reporters.forEach(reporter => { + reporterMap = Object.assign(reporterMap, { + [reporter[0]]: reporter[1], + }); + }); + + const reporterNames = Object.keys(reporterMap); + + const isDefault = reporterNames.includes('default'); const isGitHubActions = - GITHUB_ACTIONS && reporterNames?.includes('github-actions'); + GITHUB_ACTIONS && reporterNames.includes('github-actions'); if (isDefault) { this._setupDefaultReporters(collectCoverage); @@ -367,16 +363,12 @@ class TestScheduler { } if (!isDefault && collectCoverage) { - this.addReporter( - new CoverageReporter(this._globalConfig, { - changedFiles: this._context?.changedFiles, - sourcesRelatedToTestsInChangedFiles: - this._context?.sourcesRelatedToTestsInChangedFiles, - }), - ); + this.addReporter(new CoverageReporter(this._globalConfig, this._context)); } - await this._addCustomReporters(reporters); + if (reporterNames.length) { + await this._addCustomReporters(reporterMap); + } } private _setupDefaultReporters(collectCoverage: boolean) { @@ -387,58 +379,32 @@ class TestScheduler { ); if (collectCoverage) { - this.addReporter( - new CoverageReporter(this._globalConfig, { - changedFiles: this._context?.changedFiles, - sourcesRelatedToTestsInChangedFiles: - this._context?.sourcesRelatedToTestsInChangedFiles, - }), - ); + this.addReporter(new CoverageReporter(this._globalConfig, this._context)); } this.addReporter(new SummaryReporter(this._globalConfig)); } - private async _addCustomReporters( - reporters: Array, - ) { - for (const reporter of reporters) { - const {options, path} = this._getReporterProps(reporter); - + private async _addCustomReporters(reporters: ReporterMap) { + for (const path in reporters) { if (['default', 'github-actions'].includes(path)) continue; try { - const Reporter = await requireOrImportModule(path, true); - this.addReporter(new Reporter(this._globalConfig, options)); + const Reporter: ReporterConstructor = await requireOrImportModule(path); + this.addReporter( + new Reporter(this._globalConfig, reporters[path], this._context), + ); } catch (error: any) { error.message = `An error occurred while adding the reporter at path "${chalk.bold( path, - )}".${error.message}`; + )}".\n${error.message}`; throw error; } } } - /** - * Get properties of a reporter in an object - * to make dealing with them less painful. - */ - private _getReporterProps(reporter: string | Config.ReporterConfig): { - path: string; - options: Record; - } { - if (typeof reporter === 'string') { - return {options: this._options, path: reporter}; - } else if (Array.isArray(reporter)) { - const [path, options] = reporter; - return {options, path}; - } - - throw new Error('Reporter should be either a string or an array'); - } - private async _bailIfNeeded( - contexts: Set, + testContexts: Set, aggregatedResults: AggregatedResult, watcher: TestWatcher, ): Promise { @@ -452,7 +418,7 @@ class TestScheduler { } try { - await this._dispatcher.onRunComplete(contexts, aggregatedResults); + await this._dispatcher.onRunComplete(testContexts, aggregatedResults); } finally { const exitCode = this._globalConfig.testFailureExitCode; exit(exitCode); diff --git a/packages/jest-core/src/__tests__/TestScheduler.test.js b/packages/jest-core/src/__tests__/TestScheduler.test.js index 24dd450ee9a1..005dcabfb300 100644 --- a/packages/jest-core/src/__tests__/TestScheduler.test.js +++ b/packages/jest-core/src/__tests__/TestScheduler.test.js @@ -49,17 +49,6 @@ test('config for reporters supports `default`', async () => { const numberOfReporters = undefinedReportersScheduler._dispatcher._reporters.length; - const stringDefaultReportersScheduler = await createTestScheduler( - makeGlobalConfig({ - reporters: ['default'], - }), - {}, - {}, - ); - expect(stringDefaultReportersScheduler._dispatcher._reporters.length).toBe( - numberOfReporters, - ); - const defaultReportersScheduler = await createTestScheduler( makeGlobalConfig({ reporters: [['default', {}]], @@ -93,7 +82,7 @@ test('config for reporters supports `github-actions`', async () => { await createTestScheduler( makeGlobalConfig({ - reporters: ['github-actions'], + reporters: [['github-actions', {}]], }), {}, {}, @@ -102,7 +91,10 @@ test('config for reporters supports `github-actions`', async () => { await createTestScheduler( makeGlobalConfig({ - reporters: ['default', 'github-actions'], + reporters: [ + ['default', {}], + ['github-actions', {}], + ], }), {}, {}, diff --git a/packages/jest-core/src/runJest.ts b/packages/jest-core/src/runJest.ts index 977cd07addfa..0ebc5e1a996b 100644 --- a/packages/jest-core/src/runJest.ts +++ b/packages/jest-core/src/runJest.ts @@ -23,8 +23,7 @@ import type {ChangedFiles, ChangedFilesPromise} from 'jest-changed-files'; import Resolver from 'jest-resolve'; import type {Context} from 'jest-runtime'; import {requireOrImportModule, tryRealpath} from 'jest-util'; -import {JestHook, JestHookEmitter} from 'jest-watcher'; -import type {TestWatcher} from 'jest-watcher'; +import {JestHook, JestHookEmitter, TestWatcher} from 'jest-watcher'; import type FailedTestsCache from './FailedTestsCache'; import SearchSource from './SearchSource'; import {TestSchedulerContext, createTestScheduler} from './TestScheduler'; @@ -280,11 +279,10 @@ export default async function runJest({ } } - const scheduler = await createTestScheduler( - globalConfig, - {startRun}, - testSchedulerContext, - ); + const scheduler = await createTestScheduler(globalConfig, { + startRun, + ...testSchedulerContext, + }); const results = await scheduler.scheduleTests(allTests, testWatcher); diff --git a/packages/jest-reporters/package.json b/packages/jest-reporters/package.json index 6f1d4006813b..7a84a37f6312 100644 --- a/packages/jest-reporters/package.json +++ b/packages/jest-reporters/package.json @@ -28,8 +28,6 @@ "istanbul-lib-report": "^3.0.0", "istanbul-lib-source-maps": "^4.0.0", "istanbul-reports": "^3.1.3", - "jest-haste-map": "^28.0.0-alpha.8", - "jest-resolve": "^28.0.0-alpha.8", "jest-util": "^28.0.0-alpha.8", "jest-worker": "^28.0.0-alpha.8", "slash": "^3.0.0", @@ -49,6 +47,7 @@ "@types/istanbul-lib-source-maps": "^4.0.0", "@types/istanbul-reports": "^3.0.0", "@types/node-notifier": "^8.0.0", + "jest-resolve": "^28.0.0-alpha.8", "mock-fs": "^5.1.2", "strip-ansi": "^6.0.0" }, diff --git a/packages/jest-reporters/src/BaseReporter.ts b/packages/jest-reporters/src/BaseReporter.ts index 4520c3e7146c..8f526555b12d 100644 --- a/packages/jest-reporters/src/BaseReporter.ts +++ b/packages/jest-reporters/src/BaseReporter.ts @@ -7,11 +7,13 @@ import type { AggregatedResult, + Test, TestCaseResult, + TestContext, TestResult, } from '@jest/test-result'; import {preRunMessage} from 'jest-util'; -import type {Context, Reporter, ReporterOnStartOptions, Test} from './types'; +import type {Reporter, ReporterOnStartOptions} from './types'; const {remove: preRunMessageRemove} = preRunMessage; @@ -40,7 +42,7 @@ export default class BaseReporter implements Reporter { onTestStart(_test?: Test): void {} onRunComplete( - _contexts?: Set, + _testContexts?: Set, _aggregatedResults?: AggregatedResult, ): Promise | void {} diff --git a/packages/jest-reporters/src/CoverageReporter.ts b/packages/jest-reporters/src/CoverageReporter.ts index 2390029f90b6..2aa808d97e75 100644 --- a/packages/jest-reporters/src/CoverageReporter.ts +++ b/packages/jest-reporters/src/CoverageReporter.ts @@ -19,6 +19,8 @@ import v8toIstanbul = require('v8-to-istanbul'); import type { AggregatedResult, RuntimeTransformResult, + Test, + TestContext, TestResult, V8CoverageResult, } from '@jest/test-result'; @@ -27,12 +29,7 @@ import {clearLine, isInteractive} from 'jest-util'; import {Worker} from 'jest-worker'; import BaseReporter from './BaseReporter'; import getWatermarks from './getWatermarks'; -import type { - Context, - CoverageReporterOptions, - CoverageWorker, - Test, -} from './types'; +import type {CoverageWorker, ReporterContext} from './types'; // This is fixed in a newer versions of source-map, but our dependencies are still stuck on old versions interface FixedRawSourceMap extends Omit { @@ -44,24 +41,21 @@ const FAIL_COLOR = chalk.bold.red; const RUNNING_TEST_COLOR = chalk.bold.dim; export default class CoverageReporter extends BaseReporter { + private _context: ReporterContext; private _coverageMap: istanbulCoverage.CoverageMap; private _globalConfig: Config.GlobalConfig; private _sourceMapStore: libSourceMaps.MapStore; - private _options: CoverageReporterOptions; private _v8CoverageResults: Array; static readonly filename = __filename; - constructor( - globalConfig: Config.GlobalConfig, - options?: CoverageReporterOptions, - ) { + constructor(globalConfig: Config.GlobalConfig, context: ReporterContext) { super(); + this._context = context; this._coverageMap = istanbulCoverage.createCoverageMap({}); this._globalConfig = globalConfig; this._sourceMapStore = libSourceMaps.createSourceMapStore(); this._v8CoverageResults = []; - this._options = options || {}; } override onTestResult(_test: Test, testResult: TestResult): void { @@ -76,10 +70,10 @@ export default class CoverageReporter extends BaseReporter { } override async onRunComplete( - contexts: Set, + testContexts: Set, aggregatedResults: AggregatedResult, ): Promise { - await this._addUntestedFiles(contexts); + await this._addUntestedFiles(testContexts); const {map, reportContext} = await this._getCoverageResult(); try { @@ -114,10 +108,12 @@ export default class CoverageReporter extends BaseReporter { this._checkThreshold(map); } - private async _addUntestedFiles(contexts: Set): Promise { + private async _addUntestedFiles( + testContexts: Set, + ): Promise { const files: Array<{config: Config.ProjectConfig; path: string}> = []; - contexts.forEach(context => { + testContexts.forEach(context => { const config = context.config; if ( this._globalConfig.collectCoverageFrom && @@ -175,16 +171,15 @@ export default class CoverageReporter extends BaseReporter { try { const result = await worker.worker({ config, - globalConfig: this._globalConfig, - options: { - ...this._options, + context: { changedFiles: - this._options.changedFiles && - Array.from(this._options.changedFiles), + this._context.changedFiles && + Array.from(this._context.changedFiles), sourcesRelatedToTestsInChangedFiles: - this._options.sourcesRelatedToTestsInChangedFiles && - Array.from(this._options.sourcesRelatedToTestsInChangedFiles), + this._context.sourcesRelatedToTestsInChangedFiles && + Array.from(this._context.sourcesRelatedToTestsInChangedFiles), }, + globalConfig: this._globalConfig, path: filename, }); diff --git a/packages/jest-reporters/src/CoverageWorker.ts b/packages/jest-reporters/src/CoverageWorker.ts index b7f9741c0320..e369636041cc 100644 --- a/packages/jest-reporters/src/CoverageWorker.ts +++ b/packages/jest-reporters/src/CoverageWorker.ts @@ -11,17 +11,15 @@ import type {Config} from '@jest/types'; import generateEmptyCoverage, { CoverageWorkerResult, } from './generateEmptyCoverage'; -import type {CoverageReporterSerializedOptions} from './types'; +import type {ReporterContextSerialized} from './types'; export type CoverageWorkerData = { - globalConfig: Config.GlobalConfig; config: Config.ProjectConfig; + context: ReporterContextSerialized; + globalConfig: Config.GlobalConfig; path: string; - options?: CoverageReporterSerializedOptions; }; -export type {CoverageWorkerResult}; - // Make sure uncaught errors are logged before we exit. process.on('uncaughtException', err => { console.error(err.stack); @@ -32,15 +30,15 @@ export function worker({ config, globalConfig, path, - options, + context, }: CoverageWorkerData): Promise { return generateEmptyCoverage( fs.readFileSync(path, 'utf8'), path, globalConfig, config, - options?.changedFiles && new Set(options.changedFiles), - options?.sourcesRelatedToTestsInChangedFiles && - new Set(options.sourcesRelatedToTestsInChangedFiles), + context.changedFiles && new Set(context.changedFiles), + context.sourcesRelatedToTestsInChangedFiles && + new Set(context.sourcesRelatedToTestsInChangedFiles), ); } diff --git a/packages/jest-reporters/src/DefaultReporter.ts b/packages/jest-reporters/src/DefaultReporter.ts index 3af42784283e..69d8c867e0ce 100644 --- a/packages/jest-reporters/src/DefaultReporter.ts +++ b/packages/jest-reporters/src/DefaultReporter.ts @@ -9,6 +9,7 @@ import chalk = require('chalk'); import {getConsoleOutput} from '@jest/console'; import type { AggregatedResult, + Test, TestCaseResult, TestResult, } from '@jest/test-result'; @@ -18,7 +19,7 @@ import BaseReporter from './BaseReporter'; import Status from './Status'; import getResultHeader from './getResultHeader'; import getSnapshotStatus from './getSnapshotStatus'; -import type {ReporterOnStartOptions, Test} from './types'; +import type {ReporterOnStartOptions} from './types'; type write = NodeJS.WriteStream['write']; type FlushBufferedOutput = () => void; diff --git a/packages/jest-reporters/src/GitHubActionsReporter.ts b/packages/jest-reporters/src/GitHubActionsReporter.ts index 454eeb93705b..7cff405fe962 100644 --- a/packages/jest-reporters/src/GitHubActionsReporter.ts +++ b/packages/jest-reporters/src/GitHubActionsReporter.ts @@ -6,9 +6,12 @@ */ import stripAnsi = require('strip-ansi'); -import type {AggregatedResult, TestResult} from '@jest/test-result'; +import type { + AggregatedResult, + TestContext, + TestResult, +} from '@jest/test-result'; import BaseReporter from './BaseReporter'; -import type {Context} from './types'; const lineAndColumnInStackTrace = /^.*?:([0-9]+):([0-9]+).*$/; @@ -26,7 +29,7 @@ export default class GitHubActionsReporter extends BaseReporter { static readonly filename = __filename; override onRunComplete( - _contexts?: Set, + _testContexts?: Set, aggregatedResults?: AggregatedResult, ): void { const messages = getMessages(aggregatedResults?.testResults); diff --git a/packages/jest-reporters/src/NotifyReporter.ts b/packages/jest-reporters/src/NotifyReporter.ts index 63d8a218ea2b..337022af8916 100644 --- a/packages/jest-reporters/src/NotifyReporter.ts +++ b/packages/jest-reporters/src/NotifyReporter.ts @@ -8,11 +8,11 @@ import * as path from 'path'; import * as util from 'util'; import exit = require('exit'); -import type {AggregatedResult} from '@jest/test-result'; +import type {AggregatedResult, TestContext} from '@jest/test-result'; import type {Config} from '@jest/types'; import {pluralize} from 'jest-util'; import BaseReporter from './BaseReporter'; -import type {Context, TestSchedulerContext} from './types'; +import type {ReporterContext} from './types'; const isDarwin = process.platform === 'darwin'; @@ -20,31 +20,25 @@ const icon = path.resolve(__dirname, '../assets/jest_logo.png'); export default class NotifyReporter extends BaseReporter { private _notifier = loadNotifier(); - private _startRun: (globalConfig: Config.GlobalConfig) => unknown; private _globalConfig: Config.GlobalConfig; - private _context: TestSchedulerContext; + private _context: ReporterContext; static readonly filename = __filename; - constructor( - globalConfig: Config.GlobalConfig, - startRun: (globalConfig: Config.GlobalConfig) => unknown, - context: TestSchedulerContext, - ) { + constructor(globalConfig: Config.GlobalConfig, context: ReporterContext) { super(); this._globalConfig = globalConfig; - this._startRun = startRun; this._context = context; } override onRunComplete( - contexts: Set, + testContexts: Set, result: AggregatedResult, ): void { const success = result.numFailedTests === 0 && result.numRuntimeErrorTestSuites === 0; - const firstContext = contexts.values().next(); + const firstContext = testContexts.values().next(); const hasteFS = firstContext && firstContext.value && firstContext.value.hasteFS; @@ -145,8 +139,11 @@ export default class NotifyReporter extends BaseReporter { exit(0); return; } - if (metadata.activationValue === restartAnswer) { - this._startRun(this._globalConfig); + if ( + metadata.activationValue === restartAnswer && + this._context.startRun + ) { + this._context.startRun(this._globalConfig); } }, ); diff --git a/packages/jest-reporters/src/Status.ts b/packages/jest-reporters/src/Status.ts index ba57f2883418..e357b0d9ddc0 100644 --- a/packages/jest-reporters/src/Status.ts +++ b/packages/jest-reporters/src/Status.ts @@ -9,11 +9,12 @@ import chalk = require('chalk'); import stringLength = require('string-length'); import type { AggregatedResult, + Test, TestCaseResult, TestResult, } from '@jest/test-result'; import type {Config} from '@jest/types'; -import type {ReporterOnStartOptions, Test} from './types'; +import type {ReporterOnStartOptions} from './types'; import { getSummary, printDisplayName, diff --git a/packages/jest-reporters/src/SummaryReporter.ts b/packages/jest-reporters/src/SummaryReporter.ts index 36e59aae3bb3..4c7ba39d965e 100644 --- a/packages/jest-reporters/src/SummaryReporter.ts +++ b/packages/jest-reporters/src/SummaryReporter.ts @@ -6,13 +6,17 @@ */ import chalk = require('chalk'); -import type {AggregatedResult, SnapshotSummary} from '@jest/test-result'; +import type { + AggregatedResult, + SnapshotSummary, + TestContext, +} from '@jest/test-result'; import type {Config} from '@jest/types'; import {testPathPatternToRegExp} from 'jest-util'; import BaseReporter from './BaseReporter'; import getResultHeader from './getResultHeader'; import getSnapshotSummary from './getSnapshotSummary'; -import type {Context, ReporterOnStartOptions} from './types'; +import type {ReporterOnStartOptions} from './types'; import {getSummary} from './utils'; const TEST_SUMMARY_THRESHOLD = 20; @@ -79,7 +83,7 @@ export default class SummaryReporter extends BaseReporter { } override onRunComplete( - contexts: Set, + testContexts: Set, aggregatedResults: AggregatedResult, ): void { const {numTotalTestSuites, testResults, wasInterrupted} = aggregatedResults; @@ -111,7 +115,7 @@ export default class SummaryReporter extends BaseReporter { message += `\n${ wasInterrupted ? chalk.bold.red('Test run was interrupted.') - : this._getTestSummary(contexts, this._globalConfig) + : this._getTestSummary(testContexts, this._globalConfig) }`; } this.log(message); @@ -188,7 +192,7 @@ export default class SummaryReporter extends BaseReporter { } private _getTestSummary( - contexts: Set, + contexts: Set, globalConfig: Config.GlobalConfig, ) { const getMatchingTestsInfo = () => { diff --git a/packages/jest-reporters/src/VerboseReporter.ts b/packages/jest-reporters/src/VerboseReporter.ts index 919767dbdf9b..f7675355fa45 100644 --- a/packages/jest-reporters/src/VerboseReporter.ts +++ b/packages/jest-reporters/src/VerboseReporter.ts @@ -10,12 +10,12 @@ import type { AggregatedResult, AssertionResult, Suite, + Test, TestResult, } from '@jest/test-result'; import type {Config} from '@jest/types'; import {formatTime, specialChars} from 'jest-util'; import DefaultReporter from './DefaultReporter'; -import type {Test} from './types'; const {ICONS} = specialChars; diff --git a/packages/jest-reporters/src/__tests__/CoverageWorker.test.js b/packages/jest-reporters/src/__tests__/CoverageWorker.test.js index d8b83408f52e..e83b1f13287c 100644 --- a/packages/jest-reporters/src/__tests__/CoverageWorker.test.js +++ b/packages/jest-reporters/src/__tests__/CoverageWorker.test.js @@ -11,7 +11,8 @@ jest.mock('graceful-fs').mock('../generateEmptyCoverage'); const globalConfig = {collectCoverage: true}; const config = {}; -const workerOptions = {config, globalConfig, path: 'banana.js'}; +const context = {}; +const workerOptions = {config, context, globalConfig, path: 'banana.js'}; let fs; let generateEmptyCoverage; diff --git a/packages/jest-reporters/src/__tests__/NotifyReporter.test.ts b/packages/jest-reporters/src/__tests__/NotifyReporter.test.ts index 3e9a22ea03fa..bc59000d41f8 100644 --- a/packages/jest-reporters/src/__tests__/NotifyReporter.test.ts +++ b/packages/jest-reporters/src/__tests__/NotifyReporter.test.ts @@ -5,20 +5,22 @@ * LICENSE file in the root directory of this source tree. */ -import type {AggregatedResult} from '@jest/test-result'; +import type {AggregatedResult, TestContext} from '@jest/test-result'; import {makeGlobalConfig} from '@jest/test-utils'; import type {Config} from '@jest/types'; import Resolver from 'jest-resolve'; import NotifyReporter from '../NotifyReporter'; +import type {ReporterContext} from '../types'; jest.mock('../DefaultReporter'); jest.mock('node-notifier', () => ({ notify: jest.fn(), })); -const initialContext = { +const initialContext: ReporterContext = { firstRun: true, previousSuccess: false, + startRun: () => {}, }; const aggregatedResultsSuccess = { @@ -78,20 +80,20 @@ const testModes = ({ Partial>) => { const notify = require('node-notifier'); - const config = makeGlobalConfig({notify: true, notifyMode, rootDir}); + const globalConfig = makeGlobalConfig({notify: true, notifyMode, rootDir}); let previousContext = initialContext; arl.forEach((ar, i) => { - const newContext = Object.assign(previousContext, { + const newContext: ReporterContext = Object.assign(previousContext, { firstRun: i === 0, previousSuccess: previousContext.previousSuccess, }); - const reporter = new NotifyReporter(config, () => {}, newContext); + const reporter = new NotifyReporter(globalConfig, newContext); previousContext = newContext; - const contexts = new Set(); + const testContexts = new Set(); if (moduleName != null) { - contexts.add({ + testContexts.add({ hasteFS: { getModuleName() { return moduleName; @@ -101,10 +103,10 @@ const testModes = ({ return ['package.json']; }, }, - }); + } as unknown as TestContext); } - reporter.onRunComplete(contexts, ar); + reporter.onRunComplete(testContexts, ar); if (ar.numTotalTests === 0) { expect(notify.notify).not.toHaveBeenCalled(); @@ -214,12 +216,12 @@ describe('node-notifier is an optional dependency', () => { }); const ctor = () => { - const config = makeGlobalConfig({ + const globalConfig = makeGlobalConfig({ notify: true, notifyMode: 'success', rootDir: 'some-test', }); - return new NotifyReporter(config, () => {}, initialContext); + return new NotifyReporter(globalConfig, initialContext); }; test('without node-notifier uses mock function that throws an error', () => { diff --git a/packages/jest-reporters/src/index.ts b/packages/jest-reporters/src/index.ts index 3f8089c3b689..f536c362a7f8 100644 --- a/packages/jest-reporters/src/index.ts +++ b/packages/jest-reporters/src/index.ts @@ -6,6 +6,8 @@ */ import getResultHeader from './getResultHeader'; +import getSnapshotStatus from './getSnapshotStatus'; +import getSnapshotSummary from './getSnapshotSummary'; import { formatTestPath, getSummary, @@ -14,12 +16,15 @@ import { trimAndFormatPath, } from './utils'; -export type {Config} from '@jest/types'; export type { AggregatedResult, SnapshotSummary, + Test, + TestCaseResult, + TestContext, TestResult, } from '@jest/test-result'; +export type {Config} from '@jest/types'; export {default as BaseReporter} from './BaseReporter'; export {default as CoverageReporter} from './CoverageReporter'; export {default as DefaultReporter} from './DefaultReporter'; @@ -28,15 +33,16 @@ export {default as SummaryReporter} from './SummaryReporter'; export {default as VerboseReporter} from './VerboseReporter'; export {default as GitHubActionsReporter} from './GitHubActionsReporter'; export type { - Context, Reporter, ReporterOnStartOptions, + ReporterContext, SummaryOptions, - Test, } from './types'; export const utils = { formatTestPath, getResultHeader, + getSnapshotStatus, + getSnapshotSummary, getSummary, printDisplayName, relativePath, diff --git a/packages/jest-reporters/src/types.ts b/packages/jest-reporters/src/types.ts index 693454d007af..453f151881e5 100644 --- a/packages/jest-reporters/src/types.ts +++ b/packages/jest-reporters/src/types.ts @@ -7,13 +7,12 @@ import type { AggregatedResult, - SerializableError, + Test, TestCaseResult, + TestContext, TestResult, } from '@jest/test-result'; import type {Config} from '@jest/types'; -import type {FS as HasteFS, ModuleMap} from 'jest-haste-map'; -import type Resolver from 'jest-resolve'; import type {worker} from './CoverageWorker'; export type ReporterOnStartOptions = { @@ -21,41 +20,8 @@ export type ReporterOnStartOptions = { showStatus: boolean; }; -export type Context = { - config: Config.ProjectConfig; - hasteFS: HasteFS; - moduleMap: ModuleMap; - resolver: Resolver; -}; - -export type Test = { - context: Context; - duration?: number; - path: string; -}; - export type CoverageWorker = {worker: typeof worker}; -export type CoverageReporterOptions = { - changedFiles?: Set; - sourcesRelatedToTestsInChangedFiles?: Set; -}; - -export type CoverageReporterSerializedOptions = { - changedFiles?: Array; - sourcesRelatedToTestsInChangedFiles?: Array; -}; - -export type OnTestStart = (test: Test) => Promise; -export type OnTestFailure = ( - test: Test, - error: SerializableError, -) => Promise; -export type OnTestSuccess = ( - test: Test, - result: TestResult, -) => Promise; - export interface Reporter { readonly onTestResult?: ( test: Test, @@ -78,30 +44,28 @@ export interface Reporter { readonly onTestStart?: (test: Test) => Promise | void; readonly onTestFileStart?: (test: Test) => Promise | void; readonly onRunComplete: ( - contexts: Set, + testContexts: Set, results: AggregatedResult, ) => Promise | void; readonly getLastError: () => Error | void; } +export type ReporterContext = { + firstRun: boolean; + previousSuccess: boolean; + changedFiles?: Set; + sourcesRelatedToTestsInChangedFiles?: Set; + startRun?: (globalConfig: Config.GlobalConfig) => unknown; +}; + +export type ReporterContextSerialized = { + changedFiles?: Array; + sourcesRelatedToTestsInChangedFiles?: Array; +}; + export type SummaryOptions = { currentTestCases?: Array<{test: Test; testCaseResult: TestCaseResult}>; estimatedTime?: number; roundTime?: boolean; width?: number; }; - -export type TestRunnerOptions = { - serial: boolean; -}; - -export type TestRunData = Array<{ - context: Context; - matches: {allTests: number; tests: Array; total: number}; -}>; - -export type TestSchedulerContext = { - firstRun: boolean; - previousSuccess: boolean; - changedFiles?: Set; -}; diff --git a/packages/jest-reporters/src/utils.ts b/packages/jest-reporters/src/utils.ts index 7701a3283a1a..158baaf9e6cd 100644 --- a/packages/jest-reporters/src/utils.ts +++ b/packages/jest-reporters/src/utils.ts @@ -8,10 +8,10 @@ import * as path from 'path'; import chalk = require('chalk'); import slash = require('slash'); -import type {AggregatedResult, TestCaseResult} from '@jest/test-result'; +import type {AggregatedResult, Test, TestCaseResult} from '@jest/test-result'; import type {Config} from '@jest/types'; import {formatTime, pluralize} from 'jest-util'; -import type {SummaryOptions, Test} from './types'; +import type {SummaryOptions} from './types'; const PROGRESS_BAR_WIDTH = 40; diff --git a/packages/jest-reporters/tsconfig.json b/packages/jest-reporters/tsconfig.json index d5c6ecc17d98..406051cc2489 100644 --- a/packages/jest-reporters/tsconfig.json +++ b/packages/jest-reporters/tsconfig.json @@ -8,7 +8,6 @@ "exclude": ["./**/__tests__/**/*"], "references": [ {"path": "../jest-console"}, - {"path": "../jest-haste-map"}, {"path": "../jest-resolve"}, {"path": "../jest-test-result"}, {"path": "../jest-transform"}, diff --git a/packages/jest-types/src/Config.ts b/packages/jest-types/src/Config.ts index 02dcf2d8eb3d..7cc11a5df789 100644 --- a/packages/jest-types/src/Config.ts +++ b/packages/jest-types/src/Config.ts @@ -411,7 +411,7 @@ export type GlobalConfig = { passWithNoTests: boolean; projects: Array; replname?: string; - reporters?: Array; + reporters?: Array; runTestsByPath: boolean; rootDir: string; shard?: ShardConfig; @@ -546,8 +546,9 @@ export type Argv = Arguments< onlyFailures: boolean; outputFile: string; preset: string | null | undefined; - projects: Array; prettierPath: string | null | undefined; + projects: Array; + reporters: Array; resetMocks: boolean; resetModules: boolean; resolver: string | null | undefined; diff --git a/yarn.lock b/yarn.lock index f1389152dc7e..bb711fbb3767 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2778,7 +2778,6 @@ __metadata: istanbul-lib-report: ^3.0.0 istanbul-lib-source-maps: ^4.0.0 istanbul-reports: ^3.1.3 - jest-haste-map: ^28.0.0-alpha.8 jest-resolve: ^28.0.0-alpha.8 jest-util: ^28.0.0-alpha.8 jest-worker: ^28.0.0-alpha.8 From bad30bc7e92af7ccbb7605e0e0112e58d3098a62 Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Tue, 12 Apr 2022 15:23:26 +0800 Subject: [PATCH 041/128] Use native esm for jest config (#12662) --- .github/workflows/nodejs.yml | 2 +- jest.config.ci.js => jest.config.ci.mjs | 6 +++--- jest.config.js => jest.config.mjs | 5 +++-- jest.config.tsd.js => jest.config.tsd.mjs | 8 +++----- package.json | 6 +++--- packages/jest-resolve/src/defaultResolver.ts | 6 ++---- 6 files changed, 15 insertions(+), 18 deletions(-) rename jest.config.ci.js => jest.config.ci.mjs (85%) rename jest.config.js => jest.config.mjs (96%) rename jest.config.tsd.js => jest.config.tsd.mjs (73%) diff --git a/.github/workflows/nodejs.yml b/.github/workflows/nodejs.yml index eae01938f0d3..2f7e83c597f4 100644 --- a/.github/workflows/nodejs.yml +++ b/.github/workflows/nodejs.yml @@ -174,7 +174,7 @@ jobs: uses: SimenB/github-actions-cpu-cores@v1 - name: run tests with coverage run: | - yarn jest-coverage --color --config jest.config.ci.js --max-workers ${{ steps.cpu-cores.outputs.count }} --shard=${{ matrix.shard }} + yarn jest-coverage --color --config jest.config.ci.mjs --max-workers ${{ steps.cpu-cores.outputs.count }} --shard=${{ matrix.shard }} yarn test-leak - name: map coverage run: node ./scripts/mapCoverage.mjs diff --git a/jest.config.ci.js b/jest.config.ci.mjs similarity index 85% rename from jest.config.ci.js rename to jest.config.ci.mjs index 953f52e08310..8934ee58bf63 100644 --- a/jest.config.ci.js +++ b/jest.config.ci.mjs @@ -5,10 +5,10 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; +import jestConfigBase from './jest.config.mjs'; -module.exports = { - ...require('./jest.config'), +export default { + ...jestConfigBase, coverageReporters: ['json'], reporters: [ 'github-actions', diff --git a/jest.config.js b/jest.config.mjs similarity index 96% rename from jest.config.js rename to jest.config.mjs index f6eb19eb57c9..a97cdaeeac97 100644 --- a/jest.config.js +++ b/jest.config.mjs @@ -5,10 +5,11 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; +import {createRequire} from 'module'; +const require = createRequire(import.meta.url); /** @type import('@jest/types').Config.InitialOptions */ -module.exports = { +export default { collectCoverageFrom: [ '**/packages/*/**/*.js', '**/packages/*/**/*.ts', diff --git a/jest.config.tsd.js b/jest.config.tsd.mjs similarity index 73% rename from jest.config.tsd.js rename to jest.config.tsd.mjs index 2ac85943e857..b34caaee4a88 100644 --- a/jest.config.tsd.js +++ b/jest.config.tsd.mjs @@ -5,16 +5,14 @@ * LICENSE file in the root directory of this source tree. */ -'use strict'; +import jestConfigBase from './jest.config.mjs'; -const {modulePathIgnorePatterns} = require('./jest.config'); - -module.exports = { +export default { displayName: { color: 'blue', name: 'types', }, - modulePathIgnorePatterns, + modulePathIgnorePatterns: jestConfigBase.modulePathIgnorePatterns, roots: ['/packages'], runner: 'jest-runner-tsd', testMatch: ['**/__typetests__/**/*.ts'], diff --git a/package.json b/package.json index 5125d1a77316..90528abb5c45 100644 --- a/package.json +++ b/package.json @@ -97,15 +97,15 @@ "crowdin:download": "echo 'Downloading translations from Crowdin' && crowdin download --config ./crowdin.yaml", "jest": "node ./packages/jest-cli/bin/jest.js", "jest-jasmine": "JEST_JASMINE=1 yarn jest", - "jest-jasmine-ci": "yarn jest-jasmine --color --config jest.config.ci.js", + "jest-jasmine-ci": "yarn jest-jasmine --color --config jest.config.ci.mjs", "jest-coverage": "yarn jest --coverage", "lint": "eslint . --cache --ext js,jsx,cjs,mjs,ts,tsx,md", "lint:prettier": "prettier '**/*.{json,md,yml,yaml}' 'website/**/*.{css,js}' --write", "lint:prettier:ci": "prettier '**/*.{json,md,yml,yaml}' 'website/**/*.{css,js}' --check", "remove-examples": "node ./scripts/remove-examples.mjs", - "test-types": "yarn jest --config jest.config.tsd.js", + "test-types": "yarn jest --config jest.config.tsd.mjs", "test-ci-partial": "yarn test-ci-partial:parallel -i", - "test-ci-partial:parallel": "yarn jest --color --config jest.config.ci.js", + "test-ci-partial:parallel": "yarn jest --color --config jest.config.ci.mjs", "test-pretty-format-perf": "node packages/pretty-format/perf/test.js", "test-leak": "yarn jest -i --detectLeaks --color jest-mock jest-diff jest-repl pretty-format", "test": "yarn lint && yarn jest", diff --git a/packages/jest-resolve/src/defaultResolver.ts b/packages/jest-resolve/src/defaultResolver.ts index f20921cb6ff6..9504a09d9f6c 100644 --- a/packages/jest-resolve/src/defaultResolver.ts +++ b/packages/jest-resolve/src/defaultResolver.ts @@ -124,13 +124,11 @@ function getPathInModule( const pkg = readPackageCached(packageJsonPath); if (pkg.exports) { - // we need to make sure resolve ignores `main` - delete pkg.main; - const subpath = segments.join('/') || '.'; const resolved = resolveExports( - pkg, + // we need to make sure resolve ignores `main` + {...pkg, main: undefined}, subpath, createResolveOptions(options.conditions), ); From 8784260267190498022cb7e93f9f0bb3d8623311 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Tue, 12 Apr 2022 09:32:33 +0200 Subject: [PATCH 042/128] chore: remove dead code --- packages/jest-resolve/src/defaultResolver.ts | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/packages/jest-resolve/src/defaultResolver.ts b/packages/jest-resolve/src/defaultResolver.ts index 9504a09d9f6c..a53f5cf55fc1 100644 --- a/packages/jest-resolve/src/defaultResolver.ts +++ b/packages/jest-resolve/src/defaultResolver.ts @@ -127,8 +127,7 @@ function getPathInModule( const subpath = segments.join('/') || '.'; const resolved = resolveExports( - // we need to make sure resolve ignores `main` - {...pkg, main: undefined}, + pkg, subpath, createResolveOptions(options.conditions), ); From ff7751766cbcdb01a2a9ac9b0af0a91ff501a476 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Tue, 12 Apr 2022 11:51:01 +0300 Subject: [PATCH 043/128] chore: remove `testSetupFile.js` (#12666) --- jest.config.mjs | 2 +- testSetupFile.js | 10 ---------- 2 files changed, 1 insertion(+), 11 deletions(-) delete mode 100644 testSetupFile.js diff --git a/jest.config.mjs b/jest.config.mjs index a97cdaeeac97..4da932105f68 100644 --- a/jest.config.mjs +++ b/jest.config.mjs @@ -32,7 +32,6 @@ export default { 'e2e/runtime-internal-module-registry/__mocks__', ], projects: ['', '/examples/*/'], - setupFilesAfterEnv: ['/testSetupFile.js'], snapshotFormat: { escapeString: false, }, @@ -66,6 +65,7 @@ export default { '/packages/pretty-format/perf/test.js', '/e2e/__tests__/iterator-to-null-test.ts', ], + testTimeout: 70000, transform: { '\\.[jt]sx?$': '/packages/babel-jest', }, diff --git a/testSetupFile.js b/testSetupFile.js deleted file mode 100644 index ef9ed18680f6..000000000000 --- a/testSetupFile.js +++ /dev/null @@ -1,10 +0,0 @@ -/** - * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -// Some of the `jest-runtime` tests are very slow and cause -// timeouts on travis -jest.setTimeout(70000); From 5441f83fcdc8efbf2b0b5e2df23a165bd92d4439 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Tue, 12 Apr 2022 11:51:34 +0300 Subject: [PATCH 044/128] chore: add `github-actions` reporter for type tests (#12665) --- jest.config.tsd.mjs | 1 + packages/jest-types/__typetests__/config.test.ts | 2 +- packages/jest-types/__typetests__/jest.test.ts | 2 +- 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/jest.config.tsd.mjs b/jest.config.tsd.mjs index b34caaee4a88..47edf683be0a 100644 --- a/jest.config.tsd.mjs +++ b/jest.config.tsd.mjs @@ -13,6 +13,7 @@ export default { name: 'types', }, modulePathIgnorePatterns: jestConfigBase.modulePathIgnorePatterns, + reporters: ['default', 'github-actions'], roots: ['/packages'], runner: 'jest-runner-tsd', testMatch: ['**/__typetests__/**/*.ts'], diff --git a/packages/jest-types/__typetests__/config.test.ts b/packages/jest-types/__typetests__/config.test.ts index 04027cae0dcb..0dd56d024ce9 100644 --- a/packages/jest-types/__typetests__/config.test.ts +++ b/packages/jest-types/__typetests__/config.test.ts @@ -5,7 +5,7 @@ * LICENSE file in the root directory of this source tree. */ -import {expectAssignable, expectError, expectNotAssignable} from 'tsd-lite'; +import {expectAssignable, expectError} from 'tsd-lite'; import type {Config} from '@jest/types'; expectAssignable({}); diff --git a/packages/jest-types/__typetests__/jest.test.ts b/packages/jest-types/__typetests__/jest.test.ts index ae46c5e4e372..cb32315548f9 100644 --- a/packages/jest-types/__typetests__/jest.test.ts +++ b/packages/jest-types/__typetests__/jest.test.ts @@ -7,7 +7,7 @@ import {expectError, expectType} from 'tsd-lite'; import {jest} from '@jest/globals'; -import type {Mock, ModuleMocker, SpyInstance, fn, spyOn} from 'jest-mock'; +import type {Mock, ModuleMocker, SpyInstance} from 'jest-mock'; expectType( jest From 2ce4a0a0505786bf555982b78579f06458abec35 Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Tue, 12 Apr 2022 16:51:58 +0800 Subject: [PATCH 045/128] chore: make dependency version more consistent across the monorepo (#12656) --- package.json | 18 ++-- packages/babel-jest/package.json | 2 +- packages/babel-plugin-jest-hoist/package.json | 4 +- packages/jest-circus/package.json | 4 +- packages/jest-config/package.json | 4 +- packages/jest-core/package.json | 2 +- packages/jest-haste-map/package.json | 2 +- packages/jest-reporters/package.json | 4 +- packages/jest-runner/package.json | 2 +- packages/jest-runtime/package.json | 2 +- packages/jest-snapshot/package.json | 12 +-- packages/jest-source-map/package.json | 4 +- packages/jest-transform/package.json | 6 +- packages/jest-util/package.json | 2 +- packages/test-utils/package.json | 2 +- website/package.json | 2 +- yarn.lock | 98 +++++++++---------- 17 files changed, 85 insertions(+), 85 deletions(-) diff --git a/package.json b/package.json index 90528abb5c45..4edd30a2c0c4 100644 --- a/package.json +++ b/package.json @@ -3,10 +3,10 @@ "private": true, "version": "0.0.0", "devDependencies": { - "@babel/core": "^7.3.4", + "@babel/core": "^7.11.6", "@babel/plugin-transform-modules-commonjs": "^7.1.0", "@babel/preset-env": "^7.1.0", - "@babel/preset-react": "^7.0.0", + "@babel/preset-react": "^7.12.1", "@babel/preset-typescript": "^7.0.0", "@babel/register": "^7.0.0", "@crowdin/cli": "^3.5.2", @@ -15,10 +15,10 @@ "@microsoft/api-extractor": "^7.19.4", "@tsconfig/node12": "^1.0.9", "@tsd/typescript": "~4.6.2", - "@types/babel__core": "^7.0.0", + "@types/babel__core": "^7.1.14", "@types/babel__generator": "^7.0.0", - "@types/babel__template": "^7.0.0", - "@types/dedent": "0.7.0", + "@types/babel__template": "^7.0.2", + "@types/dedent": "^0.7.0", "@types/jest": "^27.4.0", "@types/node": "~12.12.0", "@types/which": "^2.0.0", @@ -43,8 +43,8 @@ "execa": "^5.0.0", "fast-check": "^2.0.0", "find-process": "^1.4.1", - "glob": "^7.1.1", - "globby": "^11.0.0", + "glob": "^7.1.3", + "globby": "^11.0.1", "graceful-fs": "^4.2.9", "isbinaryfile": "^4.0.0", "istanbul-lib-coverage": "^3.0.0", @@ -70,9 +70,9 @@ "progress": "^2.0.0", "promise": "^8.0.2", "read-pkg": "^5.2.0", - "resolve": "^1.15.0", + "resolve": "^1.20.0", "rimraf": "^3.0.0", - "semver": "^7.3.2", + "semver": "^7.3.5", "slash": "^3.0.0", "string-length": "^4.0.1", "strip-ansi": "^6.0.0", diff --git a/packages/babel-jest/package.json b/packages/babel-jest/package.json index e4f440ac0341..9569215554fc 100644 --- a/packages/babel-jest/package.json +++ b/packages/babel-jest/package.json @@ -27,7 +27,7 @@ "slash": "^3.0.0" }, "devDependencies": { - "@babel/core": "^7.8.0", + "@babel/core": "^7.11.6", "@jest/test-utils": "^28.0.0-alpha.8", "@types/graceful-fs": "^4.1.3" }, diff --git a/packages/babel-plugin-jest-hoist/package.json b/packages/babel-plugin-jest-hoist/package.json index ff4e6113733d..4d098a389a54 100644 --- a/packages/babel-plugin-jest-hoist/package.json +++ b/packages/babel-plugin-jest-hoist/package.json @@ -22,7 +22,7 @@ "dependencies": { "@babel/template": "^7.3.3", "@babel/types": "^7.3.3", - "@types/babel__core": "^7.0.0", + "@types/babel__core": "^7.1.14", "@types/babel__traverse": "^7.0.6" }, "devDependencies": { @@ -30,7 +30,7 @@ "@babel/preset-react": "^7.12.1", "@types/babel__template": "^7.0.2", "@types/node": "*", - "@types/prettier": "^2.0.0", + "@types/prettier": "^2.1.5", "babel-plugin-tester": "^10.0.0", "prettier": "^2.1.1" }, diff --git a/packages/jest-circus/package.json b/packages/jest-circus/package.json index 2af0ca3d196b..e16e8e5df6ef 100644 --- a/packages/jest-circus/package.json +++ b/packages/jest-circus/package.json @@ -39,9 +39,9 @@ "throat": "^6.0.1" }, "devDependencies": { - "@babel/core": "^7.1.0", + "@babel/core": "^7.11.6", "@babel/register": "^7.0.0", - "@types/co": "^4.6.0", + "@types/co": "^4.6.2", "@types/dedent": "^0.7.0", "@types/graceful-fs": "^4.1.3", "@types/stack-utils": "^2.0.0", diff --git a/packages/jest-config/package.json b/packages/jest-config/package.json index ed1166374e3d..13534e8ccc7b 100644 --- a/packages/jest-config/package.json +++ b/packages/jest-config/package.json @@ -29,14 +29,14 @@ } }, "dependencies": { - "@babel/core": "^7.8.0", + "@babel/core": "^7.11.6", "@jest/test-sequencer": "^28.0.0-alpha.8", "@jest/types": "^28.0.0-alpha.8", "babel-jest": "^28.0.0-alpha.8", "chalk": "^4.0.0", "ci-info": "^3.2.0", "deepmerge": "^4.2.2", - "glob": "^7.1.1", + "glob": "^7.1.3", "graceful-fs": "^4.2.9", "jest-circus": "^28.0.0-alpha.8", "jest-environment-node": "^28.0.0-alpha.8", diff --git a/packages/jest-core/package.json b/packages/jest-core/package.json index e260ce01689d..9c5071862154 100644 --- a/packages/jest-core/package.json +++ b/packages/jest-core/package.json @@ -46,7 +46,7 @@ "@jest/test-sequencer": "^28.0.0-alpha.8", "@jest/test-utils": "^28.0.0-alpha.8", "@types/exit": "^0.1.30", - "@types/graceful-fs": "^4.1.2", + "@types/graceful-fs": "^4.1.3", "@types/micromatch": "^4.0.1", "@types/rimraf": "^3.0.0" }, diff --git a/packages/jest-haste-map/package.json b/packages/jest-haste-map/package.json index 5cde56afce8c..b3d7dfc72f66 100644 --- a/packages/jest-haste-map/package.json +++ b/packages/jest-haste-map/package.json @@ -18,7 +18,7 @@ }, "dependencies": { "@jest/types": "^28.0.0-alpha.8", - "@types/graceful-fs": "^4.1.2", + "@types/graceful-fs": "^4.1.3", "@types/node": "*", "anymatch": "^3.0.3", "fb-watchman": "^2.0.0", diff --git a/packages/jest-reporters/package.json b/packages/jest-reporters/package.json index 7a84a37f6312..f85dc29e942b 100644 --- a/packages/jest-reporters/package.json +++ b/packages/jest-reporters/package.json @@ -21,7 +21,7 @@ "chalk": "^4.0.0", "collect-v8-coverage": "^1.0.0", "exit": "^0.1.2", - "glob": "^7.1.2", + "glob": "^7.1.3", "graceful-fs": "^4.2.9", "istanbul-lib-coverage": "^3.0.0", "istanbul-lib-instrument": "^5.1.0", @@ -31,7 +31,7 @@ "jest-util": "^28.0.0-alpha.8", "jest-worker": "^28.0.0-alpha.8", "slash": "^3.0.0", - "source-map": "^0.6.0", + "source-map": "^0.6.1", "string-length": "^4.0.1", "terminal-link": "^2.0.0", "v8-to-istanbul": "^8.1.0" diff --git a/packages/jest-runner/package.json b/packages/jest-runner/package.json index 441e7bd4c428..e3de29991744 100644 --- a/packages/jest-runner/package.json +++ b/packages/jest-runner/package.json @@ -42,7 +42,7 @@ "devDependencies": { "@tsd/typescript": "~4.6.2", "@types/exit": "^0.1.30", - "@types/graceful-fs": "^4.1.2", + "@types/graceful-fs": "^4.1.3", "@types/source-map-support": "^0.5.0", "jest-jasmine2": "^28.0.0-alpha.8", "tsd-lite": "^0.5.1" diff --git a/packages/jest-runtime/package.json b/packages/jest-runtime/package.json index f5fd2705e56c..203dc44050ff 100644 --- a/packages/jest-runtime/package.json +++ b/packages/jest-runtime/package.json @@ -43,7 +43,7 @@ "devDependencies": { "@jest/test-utils": "^28.0.0-alpha.8", "@types/glob": "^7.1.1", - "@types/graceful-fs": "^4.1.2", + "@types/graceful-fs": "^4.1.3", "@types/node": "^14.0.27", "jest-environment-node": "^28.0.0-alpha.8" }, diff --git a/packages/jest-snapshot/package.json b/packages/jest-snapshot/package.json index cfea828d9016..e7a723585dc8 100644 --- a/packages/jest-snapshot/package.json +++ b/packages/jest-snapshot/package.json @@ -17,15 +17,15 @@ "./package.json": "./package.json" }, "dependencies": { - "@babel/core": "^7.7.2", + "@babel/core": "^7.11.6", "@babel/generator": "^7.7.2", "@babel/plugin-syntax-typescript": "^7.7.2", "@babel/traverse": "^7.7.2", - "@babel/types": "^7.0.0", + "@babel/types": "^7.3.3", "@jest/expect-utils": "^28.0.0-alpha.8", "@jest/transform": "^28.0.0-alpha.8", "@jest/types": "^28.0.0-alpha.8", - "@types/babel__traverse": "^7.0.4", + "@types/babel__traverse": "^7.0.6", "@types/prettier": "^2.1.5", "babel-preset-current-node-syntax": "^1.0.0", "chalk": "^4.0.0", @@ -39,18 +39,18 @@ "jest-util": "^28.0.0-alpha.8", "natural-compare": "^1.4.0", "pretty-format": "^28.0.0-alpha.8", - "semver": "^7.3.2" + "semver": "^7.3.5" }, "devDependencies": { "@babel/preset-flow": "^7.7.2", - "@babel/preset-react": "^7.7.2", + "@babel/preset-react": "^7.12.1", "@jest/test-utils": "^28.0.0-alpha.8", "@types/graceful-fs": "^4.1.3", "@types/natural-compare": "^1.4.0", "@types/semver": "^7.1.0", "ansi-regex": "^5.0.1", "ansi-styles": "^5.0.0", - "prettier": "^2.0.0" + "prettier": "^2.1.1" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-source-map/package.json b/packages/jest-source-map/package.json index 91f7a80446f1..f26f1d26ad40 100644 --- a/packages/jest-source-map/package.json +++ b/packages/jest-source-map/package.json @@ -19,10 +19,10 @@ "dependencies": { "callsites": "^3.0.0", "graceful-fs": "^4.2.9", - "source-map": "^0.6.0" + "source-map": "^0.6.1" }, "devDependencies": { - "@types/graceful-fs": "^4.1.2" + "@types/graceful-fs": "^4.1.3" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-transform/package.json b/packages/jest-transform/package.json index 8b869bda2754..7731c6c7f242 100644 --- a/packages/jest-transform/package.json +++ b/packages/jest-transform/package.json @@ -17,7 +17,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@babel/core": "^7.1.0", + "@babel/core": "^7.11.6", "@jest/types": "^28.0.0-alpha.8", "babel-plugin-istanbul": "^6.1.1", "chalk": "^4.0.0", @@ -35,10 +35,10 @@ }, "devDependencies": { "@jest/test-utils": "^28.0.0-alpha.8", - "@types/babel__core": "^7.1.0", + "@types/babel__core": "^7.1.14", "@types/convert-source-map": "^1.5.1", "@types/fast-json-stable-stringify": "^2.0.0", - "@types/graceful-fs": "^4.1.2", + "@types/graceful-fs": "^4.1.3", "@types/micromatch": "^4.0.1", "@types/write-file-atomic": "^4.0.0", "dedent": "^0.7.0" diff --git a/packages/jest-util/package.json b/packages/jest-util/package.json index 56a708729741..91e53cc5f20c 100644 --- a/packages/jest-util/package.json +++ b/packages/jest-util/package.json @@ -25,7 +25,7 @@ "picomatch": "^2.2.3" }, "devDependencies": { - "@types/graceful-fs": "^4.1.2", + "@types/graceful-fs": "^4.1.3", "@types/picomatch": "^2.2.2" }, "engines": { diff --git a/packages/test-utils/package.json b/packages/test-utils/package.json index a2fec8186e93..ddeaeec7b285 100644 --- a/packages/test-utils/package.json +++ b/packages/test-utils/package.json @@ -18,7 +18,7 @@ "ansi-regex": "^5.0.1", "ansi-styles": "^5.0.0", "pretty-format": "^28.0.0-alpha.8", - "semver": "^7.3.2" + "semver": "^7.3.5" }, "devDependencies": { "@types/semver": "^7.1.0" diff --git a/website/package.json b/website/package.json index 6a4bab45207b..5c52084fe002 100644 --- a/website/package.json +++ b/website/package.json @@ -43,7 +43,7 @@ "react-markdown": "^8.0.0" }, "devDependencies": { - "@babel/core": "^7.0.0", + "@babel/core": "^7.11.6", "@crowdin/cli": "^3.5.2", "@types/react": "^17.0.3", "graphql": "^16.3.0", diff --git a/yarn.lock b/yarn.lock index bb711fbb3767..f8d2457c09c3 100644 --- a/yarn.lock +++ b/yarn.lock @@ -287,7 +287,7 @@ __metadata: languageName: node linkType: hard -"@babel/core@npm:*, @babel/core@npm:^7.0.0, @babel/core@npm:^7.1.0, @babel/core@npm:^7.11.1, @babel/core@npm:^7.11.6, @babel/core@npm:^7.12.3, @babel/core@npm:^7.13.16, @babel/core@npm:^7.14.0, @babel/core@npm:^7.15.5, @babel/core@npm:^7.17.8, @babel/core@npm:^7.3.4, @babel/core@npm:^7.7.2, @babel/core@npm:^7.8.0": +"@babel/core@npm:*, @babel/core@npm:^7.11.1, @babel/core@npm:^7.11.6, @babel/core@npm:^7.12.3, @babel/core@npm:^7.13.16, @babel/core@npm:^7.14.0, @babel/core@npm:^7.15.5, @babel/core@npm:^7.17.8": version: 7.17.9 resolution: "@babel/core@npm:7.17.9" dependencies: @@ -1746,7 +1746,7 @@ __metadata: languageName: node linkType: hard -"@babel/preset-react@npm:*, @babel/preset-react@npm:^7.0.0, @babel/preset-react@npm:^7.12.1, @babel/preset-react@npm:^7.14.5, @babel/preset-react@npm:^7.16.7, @babel/preset-react@npm:^7.7.2": +"@babel/preset-react@npm:*, @babel/preset-react@npm:^7.12.1, @babel/preset-react@npm:^7.14.5, @babel/preset-react@npm:^7.16.7": version: 7.16.7 resolution: "@babel/preset-react@npm:7.16.7" dependencies: @@ -2551,7 +2551,7 @@ __metadata: "@jest/transform": ^28.0.0-alpha.8 "@jest/types": ^28.0.0-alpha.8 "@types/exit": ^0.1.30 - "@types/graceful-fs": ^4.1.2 + "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 "@types/node": "*" "@types/rimraf": ^3.0.0 @@ -2665,10 +2665,10 @@ __metadata: version: 0.0.0-use.local resolution: "@jest/monorepo@workspace:." dependencies: - "@babel/core": ^7.3.4 + "@babel/core": ^7.11.6 "@babel/plugin-transform-modules-commonjs": ^7.1.0 "@babel/preset-env": ^7.1.0 - "@babel/preset-react": ^7.0.0 + "@babel/preset-react": ^7.12.1 "@babel/preset-typescript": ^7.0.0 "@babel/register": ^7.0.0 "@crowdin/cli": ^3.5.2 @@ -2677,10 +2677,10 @@ __metadata: "@microsoft/api-extractor": ^7.19.4 "@tsconfig/node12": ^1.0.9 "@tsd/typescript": ~4.6.2 - "@types/babel__core": ^7.0.0 + "@types/babel__core": ^7.1.14 "@types/babel__generator": ^7.0.0 - "@types/babel__template": ^7.0.0 - "@types/dedent": 0.7.0 + "@types/babel__template": ^7.0.2 + "@types/dedent": ^0.7.0 "@types/jest": ^27.4.0 "@types/node": ~12.12.0 "@types/which": ^2.0.0 @@ -2705,8 +2705,8 @@ __metadata: execa: ^5.0.0 fast-check: ^2.0.0 find-process: ^1.4.1 - glob: ^7.1.1 - globby: ^11.0.0 + glob: ^7.1.3 + globby: ^11.0.1 graceful-fs: ^4.2.9 isbinaryfile: ^4.0.0 istanbul-lib-coverage: ^3.0.0 @@ -2732,9 +2732,9 @@ __metadata: progress: ^2.0.0 promise: ^8.0.2 read-pkg: ^5.2.0 - resolve: ^1.15.0 + resolve: ^1.20.0 rimraf: ^3.0.0 - semver: ^7.3.2 + semver: ^7.3.5 slash: ^3.0.0 string-length: ^4.0.1 strip-ansi: ^6.0.0 @@ -2771,7 +2771,7 @@ __metadata: chalk: ^4.0.0 collect-v8-coverage: ^1.0.0 exit: ^0.1.2 - glob: ^7.1.2 + glob: ^7.1.3 graceful-fs: ^4.2.9 istanbul-lib-coverage: ^3.0.0 istanbul-lib-instrument: ^5.1.0 @@ -2783,7 +2783,7 @@ __metadata: jest-worker: ^28.0.0-alpha.8 mock-fs: ^5.1.2 slash: ^3.0.0 - source-map: ^0.6.0 + source-map: ^0.6.1 string-length: ^4.0.1 strip-ansi: ^6.0.0 terminal-link: ^2.0.0 @@ -2808,10 +2808,10 @@ __metadata: version: 0.0.0-use.local resolution: "@jest/source-map@workspace:packages/jest-source-map" dependencies: - "@types/graceful-fs": ^4.1.2 + "@types/graceful-fs": ^4.1.3 callsites: ^3.0.0 graceful-fs: ^4.2.9 - source-map: ^0.6.0 + source-map: ^0.6.1 languageName: unknown linkType: soft @@ -2862,7 +2862,7 @@ __metadata: ansi-regex: ^5.0.1 ansi-styles: ^5.0.0 pretty-format: ^28.0.0-alpha.8 - semver: ^7.3.2 + semver: ^7.3.5 languageName: unknown linkType: soft @@ -2870,13 +2870,13 @@ __metadata: version: 0.0.0-use.local resolution: "@jest/transform@workspace:packages/jest-transform" dependencies: - "@babel/core": ^7.1.0 + "@babel/core": ^7.11.6 "@jest/test-utils": ^28.0.0-alpha.8 "@jest/types": ^28.0.0-alpha.8 - "@types/babel__core": ^7.1.0 + "@types/babel__core": ^7.1.14 "@types/convert-source-map": ^1.5.1 "@types/fast-json-stable-stringify": ^2.0.0 - "@types/graceful-fs": ^4.1.2 + "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 "@types/write-file-atomic": ^4.0.0 babel-plugin-istanbul: ^6.1.1 @@ -4789,7 +4789,7 @@ __metadata: languageName: node linkType: hard -"@types/babel__core@npm:*, @types/babel__core@npm:^7.0.0, @types/babel__core@npm:^7.1.0, @types/babel__core@npm:^7.1.14": +"@types/babel__core@npm:*, @types/babel__core@npm:^7.1.14": version: 7.1.19 resolution: "@types/babel__core@npm:7.1.19" dependencies: @@ -4811,7 +4811,7 @@ __metadata: languageName: node linkType: hard -"@types/babel__template@npm:*, @types/babel__template@npm:^7.0.0, @types/babel__template@npm:^7.0.2": +"@types/babel__template@npm:*, @types/babel__template@npm:^7.0.2": version: 7.4.1 resolution: "@types/babel__template@npm:7.4.1" dependencies: @@ -4821,7 +4821,7 @@ __metadata: languageName: node linkType: hard -"@types/babel__traverse@npm:*, @types/babel__traverse@npm:^7.0.4, @types/babel__traverse@npm:^7.0.6": +"@types/babel__traverse@npm:*, @types/babel__traverse@npm:^7.0.6": version: 7.14.2 resolution: "@types/babel__traverse@npm:7.14.2" dependencies: @@ -4856,7 +4856,7 @@ __metadata: languageName: node linkType: hard -"@types/co@npm:^4.6.0, @types/co@npm:^4.6.2": +"@types/co@npm:^4.6.2": version: 4.6.3 resolution: "@types/co@npm:4.6.3" checksum: 3c7460bfd3a893bd749a3a3c3cf004cbcac796b67037ad0ed10d26a34a2d495ea632cfd66086cee67e2ade9e738ed144b3ddda5731f1fc225ebfd8a703f6e56e @@ -4898,7 +4898,7 @@ __metadata: languageName: node linkType: hard -"@types/dedent@npm:0.7.0, @types/dedent@npm:^0.7.0": +"@types/dedent@npm:^0.7.0": version: 0.7.0 resolution: "@types/dedent@npm:0.7.0" checksum: b9b7f0c42d99da764be75dd00b2f2be162f5a0ca43aafe0c740efa76b5f37f8a4f4e2ccc84883054e06e05c1169733aa8ee7750da0334c9cba26d9e10ae844f1 @@ -5267,7 +5267,7 @@ __metadata: languageName: node linkType: hard -"@types/prettier@npm:*, @types/prettier@npm:^2.0.0, @types/prettier@npm:^2.1.5": +"@types/prettier@npm:*, @types/prettier@npm:^2.1.5": version: 2.4.4 resolution: "@types/prettier@npm:2.4.4" checksum: 2c2cc57efd49c7d8907415a72f96c84a6dd8696dd3bf8aa4ca3a667427bebf71cbfbc912673624bdfc935d272d1c008c639cf155f6449315990a4dc110f0d216 @@ -6684,7 +6684,7 @@ __metadata: version: 0.0.0-use.local resolution: "babel-jest@workspace:packages/babel-jest" dependencies: - "@babel/core": ^7.8.0 + "@babel/core": ^7.11.6 "@jest/test-utils": ^28.0.0-alpha.8 "@jest/transform": ^28.0.0-alpha.8 "@types/babel__core": ^7.1.14 @@ -6774,11 +6774,11 @@ __metadata: "@babel/preset-react": ^7.12.1 "@babel/template": ^7.3.3 "@babel/types": ^7.3.3 - "@types/babel__core": ^7.0.0 + "@types/babel__core": ^7.1.14 "@types/babel__template": ^7.0.2 "@types/babel__traverse": ^7.0.6 "@types/node": "*" - "@types/prettier": ^2.0.0 + "@types/prettier": ^2.1.5 babel-plugin-tester: ^10.0.0 prettier: ^2.1.1 languageName: unknown @@ -11280,7 +11280,7 @@ __metadata: languageName: node linkType: hard -"glob@npm:^7.0.0, glob@npm:^7.1.1, glob@npm:^7.1.2, glob@npm:^7.1.3, glob@npm:^7.1.4, glob@npm:^7.1.6, glob@npm:^7.2.0": +"glob@npm:^7.0.0, glob@npm:^7.1.1, glob@npm:^7.1.3, glob@npm:^7.1.4, glob@npm:^7.1.6, glob@npm:^7.2.0": version: 7.2.0 resolution: "glob@npm:7.2.0" dependencies: @@ -11339,7 +11339,7 @@ __metadata: languageName: node linkType: hard -"globby@npm:^11.0.0, globby@npm:^11.0.1, globby@npm:^11.0.2, globby@npm:^11.0.4, globby@npm:^11.1.0": +"globby@npm:^11.0.1, globby@npm:^11.0.2, globby@npm:^11.0.4, globby@npm:^11.1.0": version: 11.1.0 resolution: "globby@npm:11.1.0" dependencies: @@ -13014,13 +13014,13 @@ __metadata: version: 0.0.0-use.local resolution: "jest-circus@workspace:packages/jest-circus" dependencies: - "@babel/core": ^7.1.0 + "@babel/core": ^7.11.6 "@babel/register": ^7.0.0 "@jest/environment": ^28.0.0-alpha.8 "@jest/expect": ^28.0.0-alpha.8 "@jest/test-result": ^28.0.0-alpha.8 "@jest/types": ^28.0.0-alpha.8 - "@types/co": ^4.6.0 + "@types/co": ^4.6.2 "@types/dedent": ^0.7.0 "@types/graceful-fs": ^4.1.3 "@types/node": "*" @@ -13078,7 +13078,7 @@ __metadata: version: 0.0.0-use.local resolution: "jest-config@workspace:packages/jest-config" dependencies: - "@babel/core": ^7.8.0 + "@babel/core": ^7.11.6 "@jest/test-sequencer": ^28.0.0-alpha.8 "@jest/types": ^28.0.0-alpha.8 "@types/glob": ^7.1.1 @@ -13088,7 +13088,7 @@ __metadata: chalk: ^4.0.0 ci-info: ^3.2.0 deepmerge: ^4.2.2 - glob: ^7.1.1 + glob: ^7.1.3 graceful-fs: ^4.2.9 jest-circus: ^28.0.0-alpha.8 jest-environment-node: ^28.0.0-alpha.8 @@ -13220,7 +13220,7 @@ __metadata: "@jest/test-utils": ^28.0.0-alpha.8 "@jest/types": ^28.0.0-alpha.8 "@types/fb-watchman": ^2.0.0 - "@types/graceful-fs": ^4.1.2 + "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 "@types/node": "*" anymatch: ^3.0.3 @@ -13498,7 +13498,7 @@ __metadata: "@jest/types": ^28.0.0-alpha.8 "@tsd/typescript": ~4.6.2 "@types/exit": ^0.1.30 - "@types/graceful-fs": ^4.1.2 + "@types/graceful-fs": ^4.1.3 "@types/node": "*" "@types/source-map-support": ^0.5.0 chalk: ^4.0.0 @@ -13534,7 +13534,7 @@ __metadata: "@jest/transform": ^28.0.0-alpha.8 "@jest/types": ^28.0.0-alpha.8 "@types/glob": ^7.1.1 - "@types/graceful-fs": ^4.1.2 + "@types/graceful-fs": ^4.1.3 "@types/node": ^14.0.27 chalk: ^4.0.0 cjs-module-lexer: ^1.0.0 @@ -13589,18 +13589,18 @@ __metadata: version: 0.0.0-use.local resolution: "jest-snapshot@workspace:packages/jest-snapshot" dependencies: - "@babel/core": ^7.7.2 + "@babel/core": ^7.11.6 "@babel/generator": ^7.7.2 "@babel/plugin-syntax-typescript": ^7.7.2 "@babel/preset-flow": ^7.7.2 - "@babel/preset-react": ^7.7.2 + "@babel/preset-react": ^7.12.1 "@babel/traverse": ^7.7.2 - "@babel/types": ^7.0.0 + "@babel/types": ^7.3.3 "@jest/expect-utils": ^28.0.0-alpha.8 "@jest/test-utils": ^28.0.0-alpha.8 "@jest/transform": ^28.0.0-alpha.8 "@jest/types": ^28.0.0-alpha.8 - "@types/babel__traverse": ^7.0.4 + "@types/babel__traverse": ^7.0.6 "@types/graceful-fs": ^4.1.3 "@types/natural-compare": ^1.4.0 "@types/prettier": ^2.1.5 @@ -13618,9 +13618,9 @@ __metadata: jest-message-util: ^28.0.0-alpha.8 jest-util: ^28.0.0-alpha.8 natural-compare: ^1.4.0 - prettier: ^2.0.0 + prettier: ^2.1.1 pretty-format: ^28.0.0-alpha.8 - semver: ^7.3.2 + semver: ^7.3.5 languageName: unknown linkType: soft @@ -13629,7 +13629,7 @@ __metadata: resolution: "jest-util@workspace:packages/jest-util" dependencies: "@jest/types": ^28.0.0-alpha.8 - "@types/graceful-fs": ^4.1.2 + "@types/graceful-fs": ^4.1.3 "@types/node": "*" "@types/picomatch": ^2.2.2 chalk: ^4.0.0 @@ -13746,7 +13746,7 @@ __metadata: version: 0.0.0-use.local resolution: "jest-website@workspace:website" dependencies: - "@babel/core": ^7.0.0 + "@babel/core": ^7.11.6 "@crowdin/cli": ^3.5.2 "@docusaurus/core": ^2.0.0-beta.17 "@docusaurus/plugin-client-redirects": ^2.0.0-beta.17 @@ -17938,7 +17938,7 @@ __metadata: languageName: node linkType: hard -"prettier@npm:^2.0.0, prettier@npm:^2.0.1, prettier@npm:^2.1.1": +"prettier@npm:^2.0.1, prettier@npm:^2.1.1": version: 2.6.2 resolution: "prettier@npm:2.6.2" bin: @@ -19423,7 +19423,7 @@ __metadata: languageName: node linkType: hard -"resolve@npm:^1.1.6, resolve@npm:^1.10.0, resolve@npm:^1.14.2, resolve@npm:^1.15.0, resolve@npm:^1.19.0, resolve@npm:^1.20.0, resolve@npm:^1.22.0, resolve@npm:^1.3.2": +"resolve@npm:^1.1.6, resolve@npm:^1.10.0, resolve@npm:^1.14.2, resolve@npm:^1.19.0, resolve@npm:^1.20.0, resolve@npm:^1.22.0, resolve@npm:^1.3.2": version: 1.22.0 resolution: "resolve@npm:1.22.0" dependencies: @@ -19455,7 +19455,7 @@ __metadata: languageName: node linkType: hard -"resolve@patch:resolve@^1.1.6#~builtin, resolve@patch:resolve@^1.10.0#~builtin, resolve@patch:resolve@^1.14.2#~builtin, resolve@patch:resolve@^1.15.0#~builtin, resolve@patch:resolve@^1.19.0#~builtin, resolve@patch:resolve@^1.20.0#~builtin, resolve@patch:resolve@^1.22.0#~builtin, resolve@patch:resolve@^1.3.2#~builtin": +"resolve@patch:resolve@^1.1.6#~builtin, resolve@patch:resolve@^1.10.0#~builtin, resolve@patch:resolve@^1.14.2#~builtin, resolve@patch:resolve@^1.19.0#~builtin, resolve@patch:resolve@^1.20.0#~builtin, resolve@patch:resolve@^1.22.0#~builtin, resolve@patch:resolve@^1.3.2#~builtin": version: 1.22.0 resolution: "resolve@patch:resolve@npm%3A1.22.0#~builtin::version=1.22.0&hash=07638b" dependencies: From 7e6c458e7bffa0045cc2ad8de022c2a54acaf5b6 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Tue, 12 Apr 2022 11:26:41 +0200 Subject: [PATCH 046/128] chore: do not run tests of e2e tests (#12667) --- jest.config.mjs | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/jest.config.mjs b/jest.config.mjs index 4da932105f68..0ef5e177d735 100644 --- a/jest.config.mjs +++ b/jest.config.mjs @@ -44,6 +44,9 @@ export default { '/e2e/.*/__tests__', '/e2e/global-setup', '/e2e/global-teardown', + '/e2e/custom-*', + '/e2e/test-in-root', + '/e2e/run-programmatically-multiple-projects', '\\.snap$', '/packages/.*/build', '/packages/.*/src/__tests__/setPrettyPrint.ts', @@ -67,11 +70,11 @@ export default { ], testTimeout: 70000, transform: { - '\\.[jt]sx?$': '/packages/babel-jest', + '\\.[jt]sx?$': require.resolve('babel-jest'), }, watchPathIgnorePatterns: ['coverage'], watchPlugins: [ - 'jest-watch-typeahead/filename', - 'jest-watch-typeahead/testname', + require.resolve('jest-watch-typeahead/filename'), + require.resolve('jest-watch-typeahead/testname'), ], }; From 59d3e51de6d21fdc0d9e0520f24144e1ec89e84c Mon Sep 17 00:00:00 2001 From: fisker Cheung Date: Tue, 12 Apr 2022 17:28:06 +0800 Subject: [PATCH 047/128] chore: run prettier on everything (#12653) --- .eslintignore | 11 ++++++++--- .eslintrc.cjs | 8 ++------ .prettierignore | 15 +++++++++++++++ examples/angular/.babelrc.js | 2 +- examples/react-native/.watchmanconfig | 2 +- package.json | 4 ++-- 6 files changed, 29 insertions(+), 13 deletions(-) diff --git a/.eslintignore b/.eslintignore index 48fa766a507d..36c1940c60f0 100644 --- a/.eslintignore +++ b/.eslintignore @@ -1,14 +1,19 @@ +!.* **/coverage/** **/node_modules/** bin/ -flow-typed/** packages/*/build/** packages/*/dist/** -packages/jest-diff/src/cleanupSemantic.ts website/.docusaurus website/blog website/build website/node_modules website/i18n/*.js website/static -!.eslintrc.js + +# Third-party script +packages/jest-diff/src/cleanupSemantic.ts + +**/.yarn +**/.pnp.* + diff --git a/.eslintrc.cjs b/.eslintrc.cjs index 047f0c1944f1..935c37b2f7d1 100644 --- a/.eslintrc.cjs +++ b/.eslintrc.cjs @@ -184,12 +184,6 @@ module.exports = { 'import/order': 'off', }, }, - { - files: 'packages/jest-types/**/*', - rules: { - 'import/no-extraneous-dependencies': 'off', - }, - }, { files: 'packages/**/*.ts', rules: { @@ -247,6 +241,8 @@ module.exports = { '**/__tests__/**', 'e2e/**', '**/pretty-format/perf/**', + 'packages/jest-types/**/*', + '.eslintplugin/**', ], rules: { 'import/no-extraneous-dependencies': 'off', diff --git a/.prettierignore b/.prettierignore index 38dc19d98aa6..cf9b97f586fc 100644 --- a/.prettierignore +++ b/.prettierignore @@ -1,11 +1,26 @@ +.idea +.DS_STORE +.eslintcache +*.swp +*~ api-extractor.json coverage /packages/*/build +/packages/*/dist /packages/jest-config/src/__tests__/jest-preset.json /packages/pretty-format/perf/world.geo.json +# Breaks tests +/e2e/coverage-handlebars/greet.hbs + +# Third-party script +packages/jest-diff/src/cleanupSemantic.ts + /website/.docusaurus /website/backers.json /website/build /website/versions.json + +**/.yarn +**/.pnp.* diff --git a/examples/angular/.babelrc.js b/examples/angular/.babelrc.js index 7a1d6c383636..118538499498 100644 --- a/examples/angular/.babelrc.js +++ b/examples/angular/.babelrc.js @@ -19,5 +19,5 @@ module.exports = { }, ], '@babel/preset-typescript', - ] + ], }; diff --git a/examples/react-native/.watchmanconfig b/examples/react-native/.watchmanconfig index 9e26dfeeb6e6..0967ef424bce 100644 --- a/examples/react-native/.watchmanconfig +++ b/examples/react-native/.watchmanconfig @@ -1 +1 @@ -{} \ No newline at end of file +{} diff --git a/package.json b/package.json index 4edd30a2c0c4..3d077d945539 100644 --- a/package.json +++ b/package.json @@ -100,8 +100,8 @@ "jest-jasmine-ci": "yarn jest-jasmine --color --config jest.config.ci.mjs", "jest-coverage": "yarn jest --coverage", "lint": "eslint . --cache --ext js,jsx,cjs,mjs,ts,tsx,md", - "lint:prettier": "prettier '**/*.{json,md,yml,yaml}' 'website/**/*.{css,js}' --write", - "lint:prettier:ci": "prettier '**/*.{json,md,yml,yaml}' 'website/**/*.{css,js}' --check", + "lint:prettier": "prettier . \"!**/*.{js,jsx,cjs,mjs,ts,tsx}\" --write", + "lint:prettier:ci": "prettier . \"!**/*.{js,jsx,cjs,mjs,ts,tsx}\" --check", "remove-examples": "node ./scripts/remove-examples.mjs", "test-types": "yarn jest --config jest.config.tsd.mjs", "test-ci-partial": "yarn test-ci-partial:parallel -i", From fb18e9a0264b7691eeb18c647e856c6cbaa8519c Mon Sep 17 00:00:00 2001 From: Ignacio Le Fluk Date: Wed, 13 Apr 2022 07:59:57 -0400 Subject: [PATCH 048/128] fix(jest-each): fixes error message with incorrect count of missing arguments (#12464) --- CHANGELOG.md | 1 + .../__snapshots__/template.test.ts.snap | 44 +++++++++---------- packages/jest-each/src/validation.ts | 5 ++- 3 files changed, 26 insertions(+), 24 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 29b70dfadf5b..43db8088d062 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -66,6 +66,7 @@ - `[jest-config, jest-haste-map]` Allow searching for tests in `node_modules` by exposing `retainAllFiles` ([#11084](https://github.com/facebook/jest/pull/11084)) - `[jest-core]` [**BREAKING**] Exit with status `1` if no tests are found with `--findRelatedTests` flag ([#12487](https://github.com/facebook/jest/pull/12487)) - `[jest-each]` `%#` is not replaced with index of the test case ([#12517](https://github.com/facebook/jest/pull/12517)) +- `[jest-each]` Fixes error message with incorrect count of missing arguments ([#12464](https://github.com/facebook/jest/pull/12464)) - `[jest-environment-jsdom]` Make `jsdom` accessible to extending environments again ([#12232](https://github.com/facebook/jest/pull/12232)) - `[jest-environment-jsdom]` Log JSDOM errors more cleanly ([#12386](https://github.com/facebook/jest/pull/12386)) - `[jest-environment-node]` Add `MessageChannel`, `MessageEvent` to globals ([#12553](https://github.com/facebook/jest/pull/12553)) diff --git a/packages/jest-each/src/__tests__/__snapshots__/template.test.ts.snap b/packages/jest-each/src/__tests__/__snapshots__/template.test.ts.snap index c4e912980be2..bf551eeec425 100644 --- a/packages/jest-each/src/__tests__/__snapshots__/template.test.ts.snap +++ b/packages/jest-each/src/__tests__/__snapshots__/template.test.ts.snap @@ -54,7 +54,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .describe throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -67,7 +67,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .describe throws error when there are no arguments for given headings 1`] = ` @@ -129,7 +129,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .describe.only throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -142,7 +142,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .describe.only throws error when there are no arguments for given headings 1`] = ` @@ -204,7 +204,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .fdescribe throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -217,7 +217,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .fdescribe throws error when there are no arguments for given headings 1`] = ` @@ -279,7 +279,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .fit throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -292,7 +292,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .fit throws error when there are no arguments for given headings 1`] = ` @@ -354,7 +354,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .it throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -367,7 +367,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .it throws error when there are no arguments for given headings 1`] = ` @@ -429,7 +429,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .it.only throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -442,7 +442,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .it.only throws error when there are no arguments for given headings 1`] = ` @@ -504,7 +504,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -517,7 +517,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test throws error when there are no arguments for given headings 1`] = ` @@ -579,7 +579,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test.concurrent throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -592,7 +592,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test.concurrent throws error when there are no arguments for given headings 1`] = ` @@ -654,7 +654,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test.concurrent.only throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -667,7 +667,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test.concurrent.only throws error when there are no arguments for given headings 1`] = ` @@ -729,7 +729,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test.concurrent.skip throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -742,7 +742,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test.concurrent.skip throws error when there are no arguments for given headings 1`] = ` @@ -804,7 +804,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test.only throws error when there are fewer arguments than headings when given one row 1`] = ` @@ -817,7 +817,7 @@ Received: 1, ] -Missing 2 arguments" +Missing 1 argument" `; exports[`jest-each .test.only throws error when there are no arguments for given headings 1`] = ` diff --git a/packages/jest-each/src/validation.ts b/packages/jest-each/src/validation.ts index 036d3261f726..a2b0088cb2b4 100644 --- a/packages/jest-each/src/validation.ts +++ b/packages/jest-each/src/validation.ts @@ -54,9 +54,10 @@ export const validateTemplateTableArguments = ( headings: Array, data: TemplateData, ): void => { - const missingData = data.length % headings.length; + const incompleteData = data.length % headings.length; + const missingData = headings.length - incompleteData; - if (missingData > 0) { + if (incompleteData > 0) { throw new Error( `Not enough arguments supplied for given headings:\n${EXPECTED_COLOR( headings.join(' | '), From 045367ad9ca773536a73efdfad019eeb2778ee32 Mon Sep 17 00:00:00 2001 From: Andrey Pozdnyakov <46034951+L4vlet@users.noreply.github.com> Date: Thu, 14 Apr 2022 13:58:19 +0300 Subject: [PATCH 049/128] Fix pretty print for closeTo matcher (#12626) --- CHANGELOG.md | 1 + packages/expect/src/asymmetricMatchers.ts | 9 +++ packages/expect/src/index.ts | 1 + packages/pretty-format/package.json | 1 + .../src/__tests__/AsymmetricMatcher.test.ts | 55 +++++++++++++++++++ .../src/plugins/AsymmetricMatcher.ts | 6 ++ packages/pretty-format/tsconfig.json | 1 + scripts/buildTs.mjs | 9 ++- yarn.lock | 1 + 9 files changed, 83 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 43db8088d062..dfa05c42e017 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -59,6 +59,7 @@ - `[expect]` Move typings of `.not`, `.rejects` and `.resolves` modifiers outside of `Matchers` interface ([#12346](https://github.com/facebook/jest/pull/12346)) - `[expect]` Throw useful error if `expect.extend` is called with invalid matchers ([#12488](https://github.com/facebook/jest/pull/12488)) - `[expect]` Fix `iterableEquality` ignores other properties ([#8359](https://github.com/facebook/jest/pull/8359)) +- `[expect]` Fix print for the `closeTo` matcher ([#12626](https://github.com/facebook/jest/pull/12626)) - `[jest-circus, @jest/types]` Disallow undefined value in `TestContext` type ([#12507](https://github.com/facebook/jest/pull/12507)) - `[jest-config]` Correctly detect CI environment and update snapshots accordingly ([#12378](https://github.com/facebook/jest/pull/12378)) - `[jest-config]` Pass `moduleTypes` to `ts-node` to enforce CJS when transpiling ([#12397](https://github.com/facebook/jest/pull/12397)) diff --git a/packages/expect/src/asymmetricMatchers.ts b/packages/expect/src/asymmetricMatchers.ts index 58390fc11421..e9aff27f9a75 100644 --- a/packages/expect/src/asymmetricMatchers.ts +++ b/packages/expect/src/asymmetricMatchers.ts @@ -13,6 +13,7 @@ import { subsetEquality, } from '@jest/expect-utils'; import * as matcherUtils from 'jest-matcher-utils'; +import {pluralize} from 'jest-util'; import {getState} from './jestMatchersObject'; import type { AsymmetricMatcher as AsymmetricMatcherInterface, @@ -329,6 +330,14 @@ class CloseTo extends AsymmetricMatcher { override getExpectedType() { return 'number'; } + + override toAsymmetricMatcher(): string { + return [ + this.toString(), + this.sample, + `(${pluralize('digit', this.precision)})`, + ].join(' '); + } } export const any = (expectedObject: unknown): Any => new Any(expectedObject); diff --git a/packages/expect/src/index.ts b/packages/expect/src/index.ts index ee6179aa8402..4511b9e0b8bb 100644 --- a/packages/expect/src/index.ts +++ b/packages/expect/src/index.ts @@ -49,6 +49,7 @@ import type { ThrowingMatcherFn, } from './types'; +export {AsymmetricMatcher} from './asymmetricMatchers'; export type { AsymmetricMatchers, BaseExpect, diff --git a/packages/pretty-format/package.json b/packages/pretty-format/package.json index 689422ef07bc..690af3ce4e36 100644 --- a/packages/pretty-format/package.json +++ b/packages/pretty-format/package.json @@ -29,6 +29,7 @@ "@types/react": "*", "@types/react-is": "^17.0.0", "@types/react-test-renderer": "*", + "expect": "^28.0.0-alpha.8", "immutable": "^4.0.0", "jest-util": "^28.0.0-alpha.8", "react": "*", diff --git a/packages/pretty-format/src/__tests__/AsymmetricMatcher.test.ts b/packages/pretty-format/src/__tests__/AsymmetricMatcher.test.ts index dd0495fb17d4..42da89bd9b25 100644 --- a/packages/pretty-format/src/__tests__/AsymmetricMatcher.test.ts +++ b/packages/pretty-format/src/__tests__/AsymmetricMatcher.test.ts @@ -5,6 +5,7 @@ * LICENSE file in the root directory of this source tree. */ +import {AsymmetricMatcher as AbstractAsymmetricMatcher} from 'expect'; import prettyFormat, {plugins} from '../'; import type {OptionsReceived} from '../types'; @@ -131,6 +132,42 @@ test('stringNotMatching(string)', () => { expect(result).toEqual('StringNotMatching /jest/'); }); +test('closeTo(number, precision)', () => { + const result = prettyFormat(expect.closeTo(1.2345, 4), options); + expect(result).toEqual('NumberCloseTo 1.2345 (4 digits)'); +}); + +test('notCloseTo(number, precision)', () => { + const result = prettyFormat(expect.not.closeTo(1.2345, 1), options); + expect(result).toEqual('NumberNotCloseTo 1.2345 (1 digit)'); +}); + +test('closeTo(number)', () => { + const result = prettyFormat(expect.closeTo(1.2345), options); + expect(result).toEqual('NumberCloseTo 1.2345 (2 digits)'); +}); + +test('closeTo(Infinity)', () => { + const result = prettyFormat(expect.closeTo(-Infinity), options); + expect(result).toEqual('NumberCloseTo -Infinity (2 digits)'); +}); + +test('closeTo(scientific number)', () => { + const result = prettyFormat(expect.closeTo(1.56e-3, 4), options); + expect(result).toEqual('NumberCloseTo 0.00156 (4 digits)'); +}); + +test('closeTo(very small scientific number)', () => { + const result = prettyFormat(expect.closeTo(1.56e-10, 4), options); + expect(result).toEqual('NumberCloseTo 1.56e-10 (4 digits)'); +}); + +test('correctly handles inability to pretty-print matcher', () => { + expect(() => prettyFormat(new DummyMatcher(1), options)).toThrow( + 'Asymmetric matcher DummyMatcher does not implement toAsymmetricMatcher()', + ); +}); + test('supports multiple nested asymmetric matchers', () => { const result = prettyFormat( { @@ -311,3 +348,21 @@ test('min option', () => { '{"test": {"nested": ObjectContaining {"a": ArrayContaining [1], "b": Anything, "c": Any, "d": StringContaining "jest", "e": StringMatching /jest/, "f": ObjectContaining {"test": "case"}}}}', ); }); + +class DummyMatcher extends AbstractAsymmetricMatcher { + constructor(sample: number) { + super(sample); + } + + asymmetricMatch(other: number) { + return this.sample === other; + } + + toString() { + return 'DummyMatcher'; + } + + override getExpectedType() { + return 'number'; + } +} diff --git a/packages/pretty-format/src/plugins/AsymmetricMatcher.ts b/packages/pretty-format/src/plugins/AsymmetricMatcher.ts index 7457cdd8973b..331b64e1dbb5 100644 --- a/packages/pretty-format/src/plugins/AsymmetricMatcher.ts +++ b/packages/pretty-format/src/plugins/AsymmetricMatcher.ts @@ -80,6 +80,12 @@ export const serialize: NewPlugin['serialize'] = ( ); } + if (typeof val.toAsymmetricMatcher !== 'function') { + throw new Error( + `Asymmetric matcher ${val.constructor.name} does not implement toAsymmetricMatcher()`, + ); + } + return val.toAsymmetricMatcher(); }; diff --git a/packages/pretty-format/tsconfig.json b/packages/pretty-format/tsconfig.json index b91ffb6b1f33..6f91b2984094 100644 --- a/packages/pretty-format/tsconfig.json +++ b/packages/pretty-format/tsconfig.json @@ -6,5 +6,6 @@ }, "include": ["./src/**/*"], "exclude": ["./**/__tests__/**/*"], + // no `expect`, only used in tests "references": [{"path": "../jest-schemas"}, {"path": "../jest-util"}] } diff --git a/scripts/buildTs.mjs b/scripts/buildTs.mjs index 6ab57279aced..c8fb4267c076 100644 --- a/scripts/buildTs.mjs +++ b/scripts/buildTs.mjs @@ -62,6 +62,13 @@ import {getPackages} from './buildUtils.mjs'; } } + // dev dep + if (pkg.name === 'pretty-format') { + if (dep === 'expect') { + return false; + } + } + return true; }) .map(dep => @@ -84,7 +91,7 @@ import {getPackages} from './buildUtils.mjs'; assert.deepStrictEqual( references, jestDependenciesOfPackage, - `Expected declared references to match dependencies in packages ${ + `Expected declared references to match dependencies in package ${ pkg.name }. Got:\n\n${references.join( '\n', diff --git a/yarn.lock b/yarn.lock index f8d2457c09c3..2455bf6708ea 100644 --- a/yarn.lock +++ b/yarn.lock @@ -17974,6 +17974,7 @@ __metadata: "@types/react-test-renderer": "*" ansi-regex: ^5.0.1 ansi-styles: ^5.0.0 + expect: ^28.0.0-alpha.8 immutable: ^4.0.0 jest-util: ^28.0.0-alpha.8 react: "*" From 1cce9a7dc194103576fad6c2086052efbea5ae77 Mon Sep 17 00:00:00 2001 From: Gerrit Birkeland Date: Thu, 14 Apr 2022 05:18:55 -0600 Subject: [PATCH 050/128] docs: Update --listTests docs to reflect what it does (#12612) --- docs/CLI.md | 2 +- website/versioned_docs/version-25.x/CLI.md | 2 +- website/versioned_docs/version-26.x/CLI.md | 2 +- website/versioned_docs/version-27.0/CLI.md | 2 +- website/versioned_docs/version-27.1/CLI.md | 2 +- website/versioned_docs/version-27.2/CLI.md | 2 +- website/versioned_docs/version-27.4/CLI.md | 2 +- website/versioned_docs/version-27.5/CLI.md | 2 +- 8 files changed, 8 insertions(+), 8 deletions(-) diff --git a/docs/CLI.md b/docs/CLI.md index a08018b955e5..d32e327f2474 100644 --- a/docs/CLI.md +++ b/docs/CLI.md @@ -262,7 +262,7 @@ Run all tests affected by file changes in the last commit made. Behaves similarl ### `--listTests` -Lists all tests as JSON that Jest will run given the arguments, and exits. This can be used together with `--findRelatedTests` to know which tests Jest will run. +Lists all test files that Jest will run given the arguments, and exits. ### `--logHeapUsage` diff --git a/website/versioned_docs/version-25.x/CLI.md b/website/versioned_docs/version-25.x/CLI.md index 26b677e6dfca..458c41a5a502 100644 --- a/website/versioned_docs/version-25.x/CLI.md +++ b/website/versioned_docs/version-25.x/CLI.md @@ -222,7 +222,7 @@ Run all tests affected by file changes in the last commit made. Behaves similarl ### `--listTests` -Lists all tests as JSON that Jest will run given the arguments, and exits. This can be used together with `--findRelatedTests` to know which tests Jest will run. +Lists all test files that Jest will run given the arguments, and exits. ### `--logHeapUsage` diff --git a/website/versioned_docs/version-26.x/CLI.md b/website/versioned_docs/version-26.x/CLI.md index bb0730a2a966..616edf089126 100644 --- a/website/versioned_docs/version-26.x/CLI.md +++ b/website/versioned_docs/version-26.x/CLI.md @@ -234,7 +234,7 @@ Run all tests affected by file changes in the last commit made. Behaves similarl ### `--listTests` -Lists all tests as JSON that Jest will run given the arguments, and exits. This can be used together with `--findRelatedTests` to know which tests Jest will run. +Lists all test files that Jest will run given the arguments, and exits. ### `--logHeapUsage` diff --git a/website/versioned_docs/version-27.0/CLI.md b/website/versioned_docs/version-27.0/CLI.md index 05952b17e30d..74e9d12c8d15 100644 --- a/website/versioned_docs/version-27.0/CLI.md +++ b/website/versioned_docs/version-27.0/CLI.md @@ -234,7 +234,7 @@ Run all tests affected by file changes in the last commit made. Behaves similarl ### `--listTests` -Lists all tests as JSON that Jest will run given the arguments, and exits. This can be used together with `--findRelatedTests` to know which tests Jest will run. +Lists all test files that Jest will run given the arguments, and exits. ### `--logHeapUsage` diff --git a/website/versioned_docs/version-27.1/CLI.md b/website/versioned_docs/version-27.1/CLI.md index 05952b17e30d..74e9d12c8d15 100644 --- a/website/versioned_docs/version-27.1/CLI.md +++ b/website/versioned_docs/version-27.1/CLI.md @@ -234,7 +234,7 @@ Run all tests affected by file changes in the last commit made. Behaves similarl ### `--listTests` -Lists all tests as JSON that Jest will run given the arguments, and exits. This can be used together with `--findRelatedTests` to know which tests Jest will run. +Lists all test files that Jest will run given the arguments, and exits. ### `--logHeapUsage` diff --git a/website/versioned_docs/version-27.2/CLI.md b/website/versioned_docs/version-27.2/CLI.md index 251741cddd3f..05d4bf724b88 100644 --- a/website/versioned_docs/version-27.2/CLI.md +++ b/website/versioned_docs/version-27.2/CLI.md @@ -234,7 +234,7 @@ Run all tests affected by file changes in the last commit made. Behaves similarl ### `--listTests` -Lists all tests as JSON that Jest will run given the arguments, and exits. This can be used together with `--findRelatedTests` to know which tests Jest will run. +Lists all test files that Jest will run given the arguments, and exits. ### `--logHeapUsage` diff --git a/website/versioned_docs/version-27.4/CLI.md b/website/versioned_docs/version-27.4/CLI.md index 0b69d0785eda..4e4602e4d99f 100644 --- a/website/versioned_docs/version-27.4/CLI.md +++ b/website/versioned_docs/version-27.4/CLI.md @@ -230,7 +230,7 @@ Run all tests affected by file changes in the last commit made. Behaves similarl ### `--listTests` -Lists all tests as JSON that Jest will run given the arguments, and exits. This can be used together with `--findRelatedTests` to know which tests Jest will run. +Lists all test files that Jest will run given the arguments, and exits. ### `--logHeapUsage` diff --git a/website/versioned_docs/version-27.5/CLI.md b/website/versioned_docs/version-27.5/CLI.md index 0b69d0785eda..4e4602e4d99f 100644 --- a/website/versioned_docs/version-27.5/CLI.md +++ b/website/versioned_docs/version-27.5/CLI.md @@ -230,7 +230,7 @@ Run all tests affected by file changes in the last commit made. Behaves similarl ### `--listTests` -Lists all tests as JSON that Jest will run given the arguments, and exits. This can be used together with `--findRelatedTests` to know which tests Jest will run. +Lists all test files that Jest will run given the arguments, and exits. ### `--logHeapUsage` From 719c2aa30982708c076d6a699b04a8b25f1811ed Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Fri, 15 Apr 2022 11:27:08 +0200 Subject: [PATCH 051/128] fix: only set name of mocked function if string (#12674) --- CHANGELOG.md | 1 + packages/jest-mock/src/__tests__/index.test.ts | 11 +++++++++++ packages/jest-mock/src/index.ts | 8 ++++++-- 3 files changed, 18 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index dfa05c42e017..20361f200741 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -78,6 +78,7 @@ - `[jest-jasmine2]` Do not set `duration` to `0` for skipped tests ([#12518](https://github.com/facebook/jest/pull/12518)) - `[jest-matcher-utils]` Pass maxWidth to `pretty-format` to avoid printing every element in arrays by default ([#12402](https://github.com/facebook/jest/pull/12402)) - `[jest-mock]` Fix function overloads for `spyOn` to allow more correct type inference in complex object ([#12442](https://github.com/facebook/jest/pull/12442)) +- `[jest-mock]` Handle overridden `Function.name` property ([#12674](https://github.com/facebook/jest/pull/12674)) - `[jest-reporters]` Notifications generated by the `--notify` flag are no longer persistent in GNOME Shell. ([#11733](https://github.com/facebook/jest/pull/11733)) - `[@jest/reporters]` Move missing icon file which is needed for `NotifyReporter` class. ([#12593](https://github.com/facebook/jest/pull/12593)) - `[jest-resolver]` Call custom resolver with core node.js modules ([#12654](https://github.com/facebook/jest/pull/12654)) diff --git a/packages/jest-mock/src/__tests__/index.test.ts b/packages/jest-mock/src/__tests__/index.test.ts index 4bb1e01af98c..07a4706f29a5 100644 --- a/packages/jest-mock/src/__tests__/index.test.ts +++ b/packages/jest-mock/src/__tests__/index.test.ts @@ -30,6 +30,17 @@ describe('moduleMocker', () => { expect(metadata.name).toBe('x'); }); + it('does not return broken name property', () => { + class By { + static name() { + return 'this is not a name'; + } + } + const metadata = moduleMocker.getMetadata(By); + expect(typeof By.name).toBe('function'); + expect(metadata).not.toHaveProperty('name'); + }); + it('mocks constant values', () => { const metadata = moduleMocker.getMetadata(Symbol.for('bowties.are.cool')); expect(metadata.value).toEqual(Symbol.for('bowties.are.cool')); diff --git a/packages/jest-mock/src/index.ts b/packages/jest-mock/src/index.ts index 85fe4aeb229c..b4164f26463c 100644 --- a/packages/jest-mock/src/index.ts +++ b/packages/jest-mock/src/index.ts @@ -971,8 +971,12 @@ export class ModuleMocker { metadata.value = component; return metadata; } else if (type === 'function') { - // @ts-expect-error component is a function so it has a name - metadata.name = component.name; + // @ts-expect-error component is a function so it has a name, but not + // necessarily a string: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/name#function_names_in_classes + const componentName = component.name; + if (typeof componentName === 'string') { + metadata.name = componentName; + } if (this.isMockFunction(component)) { metadata.mockImpl = component.getMockImplementation() as T; } From e746660e87b38d73555f98fbe7f37a4ae847440c Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Sat, 16 Apr 2022 15:57:59 +0300 Subject: [PATCH 052/128] chore(type-test): composite false (#12681) --- packages/expect/__typetests__/tsconfig.json | 1 + packages/jest-expect/__typetests__/tsconfig.json | 1 + packages/jest-mock/__typetests__/tsconfig.json | 1 + packages/jest-runner/__typetests__/tsconfig.json | 1 + packages/jest-types/__typetests__/tsconfig.json | 1 + 5 files changed, 5 insertions(+) diff --git a/packages/expect/__typetests__/tsconfig.json b/packages/expect/__typetests__/tsconfig.json index fe8eab794254..165ba1343021 100644 --- a/packages/expect/__typetests__/tsconfig.json +++ b/packages/expect/__typetests__/tsconfig.json @@ -1,6 +1,7 @@ { "extends": "../../../tsconfig.json", "compilerOptions": { + "composite": false, "noUnusedLocals": false, "noUnusedParameters": false, "skipLibCheck": true, diff --git a/packages/jest-expect/__typetests__/tsconfig.json b/packages/jest-expect/__typetests__/tsconfig.json index fe8eab794254..165ba1343021 100644 --- a/packages/jest-expect/__typetests__/tsconfig.json +++ b/packages/jest-expect/__typetests__/tsconfig.json @@ -1,6 +1,7 @@ { "extends": "../../../tsconfig.json", "compilerOptions": { + "composite": false, "noUnusedLocals": false, "noUnusedParameters": false, "skipLibCheck": true, diff --git a/packages/jest-mock/__typetests__/tsconfig.json b/packages/jest-mock/__typetests__/tsconfig.json index fe8eab794254..165ba1343021 100644 --- a/packages/jest-mock/__typetests__/tsconfig.json +++ b/packages/jest-mock/__typetests__/tsconfig.json @@ -1,6 +1,7 @@ { "extends": "../../../tsconfig.json", "compilerOptions": { + "composite": false, "noUnusedLocals": false, "noUnusedParameters": false, "skipLibCheck": true, diff --git a/packages/jest-runner/__typetests__/tsconfig.json b/packages/jest-runner/__typetests__/tsconfig.json index fe8eab794254..165ba1343021 100644 --- a/packages/jest-runner/__typetests__/tsconfig.json +++ b/packages/jest-runner/__typetests__/tsconfig.json @@ -1,6 +1,7 @@ { "extends": "../../../tsconfig.json", "compilerOptions": { + "composite": false, "noUnusedLocals": false, "noUnusedParameters": false, "skipLibCheck": true, diff --git a/packages/jest-types/__typetests__/tsconfig.json b/packages/jest-types/__typetests__/tsconfig.json index fe8eab794254..165ba1343021 100644 --- a/packages/jest-types/__typetests__/tsconfig.json +++ b/packages/jest-types/__typetests__/tsconfig.json @@ -1,6 +1,7 @@ { "extends": "../../../tsconfig.json", "compilerOptions": { + "composite": false, "noUnusedLocals": false, "noUnusedParameters": false, "skipLibCheck": true, From 06040d35456f04f47a383d5e7c1be526b275bed6 Mon Sep 17 00:00:00 2001 From: Rob Hogan <2590098+robhogan@users.noreply.github.com> Date: Sat, 16 Apr 2022 13:59:24 +0100 Subject: [PATCH 053/128] chore(jest-haste-map): Remove legacy `isRegExpSupported` (#12676) --- CHANGELOG.md | 1 + .../lib/__tests__/dependencyExtractor.test.js | 27 +++++++++---------- .../lib/__tests__/isRegExpSupported.test.js | 18 ------------- .../src/lib/dependencyExtractor.ts | 6 +---- .../src/lib/isRegExpSupported.ts | 16 ----------- 5 files changed, 14 insertions(+), 54 deletions(-) delete mode 100644 packages/jest-haste-map/src/lib/__tests__/isRegExpSupported.test.js delete mode 100644 packages/jest-haste-map/src/lib/isRegExpSupported.ts diff --git a/CHANGELOG.md b/CHANGELOG.md index 20361f200741..a99f215c5391 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -105,6 +105,7 @@ - `[@jest/core]` Use `index.ts` instead of `jest.ts` as main export ([#12329](https://github.com/facebook/jest/pull/12329)) - `[jest-environment-jsdom]` [**BREAKING**] Migrate to ESM ([#12340](https://github.com/facebook/jest/pull/12340)) - `[jest-environment-node]` [**BREAKING**] Migrate to ESM ([#12340](https://github.com/facebook/jest/pull/12340)) +- `[jest-haste-map]` Remove legacy `isRegExpSupported` ([#12676](https://github.com/facebook/jest/pull/12676)) - `[@jest/fake-timers]` Update `@sinonjs/fake_timers` to v9 ([#12357](https://github.com/facebook/jest/pull/12357)) - `[jest-jasmine2, jest-runtime]` [**BREAKING**] Use `Symbol` to pass `jest.setTimeout` value instead of `jasmine` specific logic ([#12124](https://github.com/facebook/jest/pull/12124)) - `[jest-phabricator]` [**BREAKING**] Migrate to ESM ([#12341](https://github.com/facebook/jest/pull/12341)) diff --git a/packages/jest-haste-map/src/lib/__tests__/dependencyExtractor.test.js b/packages/jest-haste-map/src/lib/__tests__/dependencyExtractor.test.js index f2b142dfc675..84f42db86d28 100644 --- a/packages/jest-haste-map/src/lib/__tests__/dependencyExtractor.test.js +++ b/packages/jest-haste-map/src/lib/__tests__/dependencyExtractor.test.js @@ -6,9 +6,6 @@ */ import {extractor} from '../dependencyExtractor'; -import isRegExpSupported from '../isRegExpSupported'; - -const COMMENT_NO_NEG_LB = isRegExpSupported('(? { it('should not extract dependencies inside comments', () => { @@ -65,8 +62,8 @@ describe('dependencyExtractor', () => { }, depDefault from 'dep4'; // Bad - ${COMMENT_NO_NEG_LB} foo . import ('inv1'); - ${COMMENT_NO_NEG_LB} foo . export ('inv2'); + foo . import ('inv1'); + foo . export ('inv2'); `; expect(extractor.extract(code)).toEqual( new Set(['dep1', 'dep2', 'dep3', 'dep4']), @@ -114,8 +111,8 @@ describe('dependencyExtractor', () => { }, depDefault from 'dep4'; // Bad - ${COMMENT_NO_NEG_LB} foo . export ('inv1'); - ${COMMENT_NO_NEG_LB} foo . export ('inv2'); + foo . export ('inv1'); + foo . export ('inv2'); `; expect(extractor.extract(code)).toEqual( new Set(['dep1', 'dep2', 'dep3', 'dep4']), @@ -137,8 +134,8 @@ describe('dependencyExtractor', () => { }, depDefault from 'dep4'; // Bad - ${COMMENT_NO_NEG_LB} foo . export ('inv1'); - ${COMMENT_NO_NEG_LB} foo . export ('inv2'); + foo . export ('inv1'); + foo . export ('inv2'); `; expect(extractor.extract(code)).toEqual( new Set(['dep1', 'dep2', 'dep3', 'dep4']), @@ -164,7 +161,7 @@ describe('dependencyExtractor', () => { if (await import(\`dep3\`)) {} // Bad - ${COMMENT_NO_NEG_LB} await foo . import('inv1') + await foo . import('inv1') await ximport('inv2'); importx('inv3'); import('inv4', 'inv5'); @@ -182,7 +179,7 @@ describe('dependencyExtractor', () => { if (require(\`dep3\`).cond) {} // Bad - ${COMMENT_NO_NEG_LB} foo . require('inv1') + foo . require('inv1') xrequire('inv2'); requirex('inv3'); require('inv4', 'inv5'); @@ -202,7 +199,7 @@ describe('dependencyExtractor', () => { .requireActual('dep4'); // Bad - ${COMMENT_NO_NEG_LB} foo . jest.requireActual('inv1') + foo . jest.requireActual('inv1') xjest.requireActual('inv2'); jest.requireActualx('inv3'); jest.requireActual('inv4', 'inv5'); @@ -224,7 +221,7 @@ describe('dependencyExtractor', () => { .requireMock('dep4'); // Bad - ${COMMENT_NO_NEG_LB} foo . jest.requireMock('inv1') + foo . jest.requireMock('inv1') xjest.requireMock('inv2'); jest.requireMockx('inv3'); jest.requireMock('inv4', 'inv5'); @@ -246,7 +243,7 @@ describe('dependencyExtractor', () => { .requireMock('dep4'); // Bad - ${COMMENT_NO_NEG_LB} foo . jest.genMockFromModule('inv1') + foo . jest.genMockFromModule('inv1') xjest.genMockFromModule('inv2'); jest.genMockFromModulex('inv3'); jest.genMockFromModule('inv4', 'inv5'); @@ -268,7 +265,7 @@ describe('dependencyExtractor', () => { .requireMock('dep4'); // Bad - ${COMMENT_NO_NEG_LB} foo . jest.createMockFromModule('inv1') + foo . jest.createMockFromModule('inv1') xjest.createMockFromModule('inv2'); jest.createMockFromModulex('inv3'); jest.createMockFromModule('inv4', 'inv5'); diff --git a/packages/jest-haste-map/src/lib/__tests__/isRegExpSupported.test.js b/packages/jest-haste-map/src/lib/__tests__/isRegExpSupported.test.js deleted file mode 100644 index b27295eaa320..000000000000 --- a/packages/jest-haste-map/src/lib/__tests__/isRegExpSupported.test.js +++ /dev/null @@ -1,18 +0,0 @@ -/** - * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -import isRegExpSupported from '../isRegExpSupported'; - -describe('isRegExpSupported', () => { - it('should return true when passing valid regular expression', () => { - expect(isRegExpSupported('(?:foo|bar)')).toBe(true); - }); - - it('should return false when passing an invalid regular expression', () => { - expect(isRegExpSupported('(?_foo|bar)')).toBe(false); - }); -}); diff --git a/packages/jest-haste-map/src/lib/dependencyExtractor.ts b/packages/jest-haste-map/src/lib/dependencyExtractor.ts index 8a54303346dd..73dcf0db0e30 100644 --- a/packages/jest-haste-map/src/lib/dependencyExtractor.ts +++ b/packages/jest-haste-map/src/lib/dependencyExtractor.ts @@ -6,12 +6,8 @@ */ import type {DependencyExtractor} from '../types'; -import isRegExpSupported from './isRegExpSupported'; -// Negative look behind is only supported in Node 9+ -const NOT_A_DOT = isRegExpSupported('(? `([\`'"])([^'"\`]*?)(?:\\${pos})`; const WORD_SEPARATOR = '\\b'; diff --git a/packages/jest-haste-map/src/lib/isRegExpSupported.ts b/packages/jest-haste-map/src/lib/isRegExpSupported.ts deleted file mode 100644 index b8db382928f3..000000000000 --- a/packages/jest-haste-map/src/lib/isRegExpSupported.ts +++ /dev/null @@ -1,16 +0,0 @@ -/** - * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -export default function isRegExpSupported(value: string): boolean { - try { - // eslint-disable-next-line no-new - new RegExp(value); - return true; - } catch { - return false; - } -} From defbc0535a46119d4682f97bf8a13b5562c1445b Mon Sep 17 00:00:00 2001 From: Rob Hogan <2590098+robhogan@users.noreply.github.com> Date: Sat, 16 Apr 2022 14:01:25 +0100 Subject: [PATCH 054/128] fix(jest-haste-map): Make watchman existence check lazy+async (#12675) --- CHANGELOG.md | 1 + .../src/__tests__/index.test.js | 14 +++++-- packages/jest-haste-map/src/index.ts | 39 ++++++++++--------- .../lib/__tests__/isWatchmanInstalled.test.js | 37 ++++++++++++++++++ .../src/lib/isWatchmanInstalled.ts | 18 +++++++++ 5 files changed, 87 insertions(+), 22 deletions(-) create mode 100644 packages/jest-haste-map/src/lib/__tests__/isWatchmanInstalled.test.js create mode 100644 packages/jest-haste-map/src/lib/isWatchmanInstalled.ts diff --git a/CHANGELOG.md b/CHANGELOG.md index a99f215c5391..488c1f0e6e1c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -74,6 +74,7 @@ - `[jest-environment-node]` Add `structuredClone` to globals ([#12631](https://github.com/facebook/jest/pull/12631)) - `[@jest/expect-utils]` [**BREAKING**] Fix false positives when looking for `undefined` prop ([#8923](https://github.com/facebook/jest/pull/8923)) - `[jest-haste-map]` Don't use partial results if file crawl errors ([#12420](https://github.com/facebook/jest/pull/12420)) +- `[jest-haste-map]` Make watchman existence check lazy+async ([#12675](https://github.com/facebook/jest/pull/12675)) - `[jest-jasmine2, jest-types]` [**BREAKING**] Move all `jasmine` specific types from `@jest/types` to its own package ([#12125](https://github.com/facebook/jest/pull/12125)) - `[jest-jasmine2]` Do not set `duration` to `0` for skipped tests ([#12518](https://github.com/facebook/jest/pull/12518)) - `[jest-matcher-utils]` Pass maxWidth to `pretty-format` to avoid printing every element in arrays by default ([#12402](https://github.com/facebook/jest/pull/12402)) diff --git a/packages/jest-haste-map/src/__tests__/index.test.js b/packages/jest-haste-map/src/__tests__/index.test.js index 7aeb7fec76f4..a3b2c6efc923 100644 --- a/packages/jest-haste-map/src/__tests__/index.test.js +++ b/packages/jest-haste-map/src/__tests__/index.test.js @@ -13,9 +13,11 @@ function mockHashContents(contents) { return crypto.createHash('sha1').update(contents).digest('hex'); } -jest.mock('child_process', () => ({ - // If this does not throw, we'll use the (mocked) watchman crawler - execSync() {}, +const mockIsWatchmanInstalled = jest.fn().mockResolvedValue(true); + +jest.mock('../lib/isWatchmanInstalled', () => ({ + __esModule: true, + default: mockIsWatchmanInstalled, })); jest.mock('jest-worker', () => ({ @@ -612,6 +614,8 @@ describe('HasteMap', () => { }); }); + mockIsWatchmanInstalled.mockClear(); + const hasteMap = await HasteMap.create({ ...defaultConfig, computeSha1: true, @@ -621,6 +625,10 @@ describe('HasteMap', () => { const data = (await hasteMap.build()).__hasteMapForTest; + expect(mockIsWatchmanInstalled).toHaveBeenCalledTimes( + useWatchman ? 1 : 0, + ); + expect(data.files).toEqual( createMap({ [path.join('fruits', 'Banana.js')]: [ diff --git a/packages/jest-haste-map/src/index.ts b/packages/jest-haste-map/src/index.ts index 76d16bcfde5e..4254eb2c52ad 100644 --- a/packages/jest-haste-map/src/index.ts +++ b/packages/jest-haste-map/src/index.ts @@ -7,7 +7,6 @@ /* eslint-disable local/ban-types-eventually */ -import {execSync} from 'child_process'; import {createHash} from 'crypto'; import {EventEmitter} from 'events'; import {tmpdir} from 'os'; @@ -26,6 +25,7 @@ import {watchmanCrawl} from './crawlers/watchman'; import getMockName from './getMockName'; import * as fastPath from './lib/fast_path'; import getPlatformExtension from './lib/getPlatformExtension'; +import isWatchmanInstalled from './lib/isWatchmanInstalled'; import normalizePathSep from './lib/normalizePathSep'; import type { ChangeEvent, @@ -124,14 +124,6 @@ const VCS_DIRECTORIES = ['.git', '.hg'] .map(vcs => escapePathForRegex(path.sep + vcs + path.sep)) .join('|'); -const canUseWatchman = ((): boolean => { - try { - execSync('watchman --version', {stdio: ['ignore']}); - return true; - } catch {} - return false; -})(); - function invariant(condition: unknown, message?: string): asserts condition { if (!condition) { throw new Error(message); @@ -221,6 +213,7 @@ export default class HasteMap extends EventEmitter { private _cachePath: string; private _changeInterval?: ReturnType; private _console: Console; + private _isWatchmanInstalledPromise: Promise | null = null; private _options: InternalOptions; private _watchers: Array; private _worker: WorkerInterface | null; @@ -763,11 +756,10 @@ export default class HasteMap extends EventEmitter { return this._worker; } - private _crawl(hasteMap: InternalHasteMap) { + private async _crawl(hasteMap: InternalHasteMap) { const options = this._options; const ignore = this._ignore.bind(this); - const crawl = - canUseWatchman && this._options.useWatchman ? watchmanCrawl : nodeCrawl; + const crawl = (await this._shouldUseWatchman()) ? watchmanCrawl : nodeCrawl; const crawlerOptions: CrawlerOptions = { computeSha1: options.computeSha1, data: hasteMap, @@ -811,7 +803,7 @@ export default class HasteMap extends EventEmitter { /** * Watch mode */ - private _watch(hasteMap: InternalHasteMap): Promise { + private async _watch(hasteMap: InternalHasteMap): Promise { if (!this._options.watch) { return Promise.resolve(); } @@ -822,12 +814,11 @@ export default class HasteMap extends EventEmitter { this._options.retainAllFiles = true; // WatchmanWatcher > FSEventsWatcher > sane.NodeWatcher - const Watcher = - canUseWatchman && this._options.useWatchman - ? WatchmanWatcher - : FSEventsWatcher.isSupported() - ? FSEventsWatcher - : NodeWatcher; + const Watcher = (await this._shouldUseWatchman()) + ? WatchmanWatcher + : FSEventsWatcher.isSupported() + ? FSEventsWatcher + : NodeWatcher; const extensions = this._options.extensions; const ignorePattern = this._options.ignorePattern; @@ -1110,6 +1101,16 @@ export default class HasteMap extends EventEmitter { ); } + private async _shouldUseWatchman(): Promise { + if (!this._options.useWatchman) { + return false; + } + if (!this._isWatchmanInstalledPromise) { + this._isWatchmanInstalledPromise = isWatchmanInstalled(); + } + return this._isWatchmanInstalledPromise; + } + private _createEmptyMap(): InternalHasteMap { return { clocks: new Map(), diff --git a/packages/jest-haste-map/src/lib/__tests__/isWatchmanInstalled.test.js b/packages/jest-haste-map/src/lib/__tests__/isWatchmanInstalled.test.js new file mode 100644 index 000000000000..e2f9d35b3800 --- /dev/null +++ b/packages/jest-haste-map/src/lib/__tests__/isWatchmanInstalled.test.js @@ -0,0 +1,37 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +import {execFile} from 'child_process'; +import isWatchmanInstalled from '../isWatchmanInstalled'; + +jest.mock('child_process'); + +describe('isWatchmanInstalled', () => { + beforeEach(() => jest.clearAllMocks()); + + it('executes watchman --version and returns true on success', async () => { + execFile.mockImplementation((file, args, cb) => { + expect(file).toBe('watchman'); + expect(args).toStrictEqual(['--version']); + cb(null, {stdout: 'v123'}); + }); + expect(await isWatchmanInstalled()).toBe(true); + expect(execFile).toHaveBeenCalledWith( + 'watchman', + ['--version'], + expect.any(Function), + ); + }); + + it('returns false when execFile fails', async () => { + execFile.mockImplementation((file, args, cb) => { + cb(new Error()); + }); + expect(await isWatchmanInstalled()).toBe(false); + expect(execFile).toHaveBeenCalled(); + }); +}); diff --git a/packages/jest-haste-map/src/lib/isWatchmanInstalled.ts b/packages/jest-haste-map/src/lib/isWatchmanInstalled.ts new file mode 100644 index 000000000000..8dee697d61f4 --- /dev/null +++ b/packages/jest-haste-map/src/lib/isWatchmanInstalled.ts @@ -0,0 +1,18 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +import {execFile} from 'child_process'; +import {promisify} from 'util'; + +export default async function isWatchmanInstalled(): Promise { + try { + await promisify(execFile)('watchman', ['--version']); + return true; + } catch { + return false; + } +} From 77b0f171cda2aa7a2b5abc11809cfdb03135f01c Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Sun, 17 Apr 2022 13:40:30 +0200 Subject: [PATCH 055/128] feat(resolver): support package self-reference (#12682) --- CHANGELOG.md | 1 + .../src/__mocks__/self-ref/foo/file.js | 0 .../foo/nested-with-no-exports/file.js | 0 .../foo/nested-with-no-exports/package.json | 3 ++ .../self-ref/foo/nested-with-own-pkg/file.js | 0 .../foo/nested-with-own-pkg/package.json | 4 ++ .../src/__mocks__/self-ref/foo/nested/file.js | 0 .../src/__mocks__/self-ref/foo/package.json | 4 ++ .../src/__mocks__/self-ref/package.json | 3 ++ .../src/__tests__/resolve.test.ts | 48 +++++++++++++++++++ packages/jest-resolve/src/defaultResolver.ts | 36 ++++++++++++-- 11 files changed, 95 insertions(+), 4 deletions(-) create mode 100644 packages/jest-resolve/src/__mocks__/self-ref/foo/file.js create mode 100644 packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-no-exports/file.js create mode 100644 packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-no-exports/package.json create mode 100644 packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-own-pkg/file.js create mode 100644 packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-own-pkg/package.json create mode 100644 packages/jest-resolve/src/__mocks__/self-ref/foo/nested/file.js create mode 100644 packages/jest-resolve/src/__mocks__/self-ref/foo/package.json create mode 100644 packages/jest-resolve/src/__mocks__/self-ref/package.json diff --git a/CHANGELOG.md b/CHANGELOG.md index 488c1f0e6e1c..518b20a25b87 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -40,6 +40,7 @@ - `[jest-reporters]` Add GitHub Actions reporter ([#11320](https://github.com/facebook/jest/pull/11320), [#12658](https://github.com/facebook/jest/pull/12658) - `[jest-reporters]` Pass `reporterContext` to custom reporter constructors as third argument ([#12657](https://github.com/facebook/jest/pull/12657)) - `[jest-resolve]` [**BREAKING**] Add support for `package.json` `exports` ([#11961](https://github.com/facebook/jest/pull/11961), [#12373](https://github.com/facebook/jest/pull/12373)) +- `[jest-resolve]` Support package self-reference ([#12682](https://github.com/facebook/jest/pull/12682)) - `[jest-resolve, jest-runtime]` Add support for `data:` URI import and mock ([#12392](https://github.com/facebook/jest/pull/12392)) - `[jest-resolve, jest-runtime]` Add support for async resolver ([#11540](https://github.com/facebook/jest/pull/11540)) - `[jest-runner]` Allow `setupFiles` module to export an async function ([#12042](https://github.com/facebook/jest/pull/12042)) diff --git a/packages/jest-resolve/src/__mocks__/self-ref/foo/file.js b/packages/jest-resolve/src/__mocks__/self-ref/foo/file.js new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-no-exports/file.js b/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-no-exports/file.js new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-no-exports/package.json b/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-no-exports/package.json new file mode 100644 index 000000000000..9e734769dce1 --- /dev/null +++ b/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-no-exports/package.json @@ -0,0 +1,3 @@ +{ + "name": "foo-no-exports" +} diff --git a/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-own-pkg/file.js b/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-own-pkg/file.js new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-own-pkg/package.json b/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-own-pkg/package.json new file mode 100644 index 000000000000..31bd0de86850 --- /dev/null +++ b/packages/jest-resolve/src/__mocks__/self-ref/foo/nested-with-own-pkg/package.json @@ -0,0 +1,4 @@ +{ + "name": "foo-other-name", + "exports": "./file.js" +} diff --git a/packages/jest-resolve/src/__mocks__/self-ref/foo/nested/file.js b/packages/jest-resolve/src/__mocks__/self-ref/foo/nested/file.js new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/packages/jest-resolve/src/__mocks__/self-ref/foo/package.json b/packages/jest-resolve/src/__mocks__/self-ref/foo/package.json new file mode 100644 index 000000000000..94f7815d3f1b --- /dev/null +++ b/packages/jest-resolve/src/__mocks__/self-ref/foo/package.json @@ -0,0 +1,4 @@ +{ + "name": "foo", + "exports": "./file.js" +} diff --git a/packages/jest-resolve/src/__mocks__/self-ref/package.json b/packages/jest-resolve/src/__mocks__/self-ref/package.json new file mode 100644 index 000000000000..1ff7d9e976ef --- /dev/null +++ b/packages/jest-resolve/src/__mocks__/self-ref/package.json @@ -0,0 +1,3 @@ +{ + "name": "self-ref" +} diff --git a/packages/jest-resolve/src/__tests__/resolve.test.ts b/packages/jest-resolve/src/__tests__/resolve.test.ts index aa5d40bbcc54..0b4b22a0647c 100644 --- a/packages/jest-resolve/src/__tests__/resolve.test.ts +++ b/packages/jest-resolve/src/__tests__/resolve.test.ts @@ -37,6 +37,8 @@ beforeEach(() => { userResolver.mockClear(); userResolverAsync.async.mockClear(); mockResolveSync.mockClear(); + + Resolver.clearDefaultResolverCache(); }); describe('isCoreModule', () => { @@ -251,6 +253,52 @@ describe('findNodeModule', () => { ); }); }); + + describe('self-reference', () => { + const selfRefRoot = path.resolve(__dirname, '../__mocks__/self-ref'); + + test('supports self-reference', () => { + const result = Resolver.findNodeModule('foo', { + basedir: path.resolve(selfRefRoot, './foo/index.js'), + conditions: [], + }); + + expect(result).toEqual(path.resolve(selfRefRoot, './foo/file.js')); + }); + + test('supports nested self-reference', () => { + const result = Resolver.findNodeModule('foo', { + basedir: path.resolve(selfRefRoot, './foo/nested/index.js'), + conditions: [], + }); + + expect(result).toEqual(path.resolve(selfRefRoot, './foo/file.js')); + }); + + test('fails if own pkg.json with different name', () => { + const result = Resolver.findNodeModule('foo', { + basedir: path.resolve( + selfRefRoot, + './foo/nested-with-own-pkg/index.js', + ), + conditions: [], + }); + + expect(result).toEqual(null); + }); + + test('fails if own pkg.json with no exports', () => { + const result = Resolver.findNodeModule('foo-no-exports', { + basedir: path.resolve( + selfRefRoot, + './foo/nested-with-no-exports/index.js', + ), + conditions: [], + }); + + expect(result).toEqual(null); + }); + }); }); describe('findNodeModuleAsync', () => { diff --git a/packages/jest-resolve/src/defaultResolver.ts b/packages/jest-resolve/src/defaultResolver.ts index a53f5cf55fc1..b5a834b32b3a 100644 --- a/packages/jest-resolve/src/defaultResolver.ts +++ b/packages/jest-resolve/src/defaultResolver.ts @@ -14,6 +14,7 @@ import { } from 'resolve.exports'; import { PkgJson, + findClosestPackageJson, isDirectory, isFile, readPackageCached, @@ -36,7 +37,7 @@ interface ResolverOptions { } type UpstreamResolveOptionsWithConditions = UpstreamResolveOptions & - Pick; + Pick; export type SyncResolver = (path: string, options: ResolverOptions) => string; export type AsyncResolver = ( @@ -112,6 +113,30 @@ function getPathInModule( moduleName = `${moduleName}/${segments.shift()}`; } + // self-reference + const closestPackageJson = findClosestPackageJson(options.basedir); + if (closestPackageJson) { + const pkg = readPackageCached(closestPackageJson); + + if (pkg.name === moduleName && pkg.exports) { + const subpath = segments.join('/') || '.'; + + const resolved = resolveExports( + pkg, + subpath, + createResolveOptions(options.conditions), + ); + + if (!resolved) { + throw new Error( + '`exports` exists, but no results - this is a bug in Jest. Please report an issue', + ); + } + + return pathResolve(dirname(closestPackageJson), resolved); + } + } + let packageJsonPath = ''; try { @@ -132,10 +157,13 @@ function getPathInModule( createResolveOptions(options.conditions), ); - // TODO: should we throw if not? - if (resolved) { - return pathResolve(dirname(packageJsonPath), resolved); + if (!resolved) { + throw new Error( + '`exports` exists, but no results - this is a bug in Jest. Please report an issue', + ); } + + return pathResolve(dirname(packageJsonPath), resolved); } } } From dd972da1fa6b660232050f3ffe984d4e45c9124d Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Mon, 18 Apr 2022 13:53:01 +0300 Subject: [PATCH 056/128] feat(jest-core): allow using Summary Reporter as stand-alone reporter (#12687) --- CHANGELOG.md | 1 + docs/Configuration.md | 10 + e2e/__tests__/customReporters.test.ts | 2 - jest.config.ci.mjs | 1 + packages/jest-config/src/normalize.ts | 2 +- packages/jest-core/src/TestScheduler.ts | 102 +++----- .../src/__tests__/TestScheduler.test.js | 246 +++++++++++++----- 7 files changed, 238 insertions(+), 126 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 518b20a25b87..b64c2d6b4f7b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -18,6 +18,7 @@ - `[jest-core]` Pass project config to `globalSetup`/`globalTeardown` function as second argument ([#12440](https://github.com/facebook/jest/pull/12440)) - `[jest-core]` Stabilize test runners with event emitters ([#12641](https://github.com/facebook/jest/pull/12641)) - `[jest-core, jest-watcher]` [**BREAKING**] Move `TestWatcher` class to `jest-watcher` package ([#12652](https://github.com/facebook/jest/pull/12652)) +- `[jest-core]` Allow using Summary Reporter as stand-alone reporter ([#12687](https://github.com/facebook/jest/pull/12687)) - `[jest-environment-jsdom]` [**BREAKING**] Upgrade jsdom to 19.0.0 ([#12290](https://github.com/facebook/jest/pull/12290)) - `[jest-environment-jsdom]` [**BREAKING**] Add default `browser` condition to `exportConditions` for `jsdom` environment ([#11924](https://github.com/facebook/jest/pull/11924)) - `[jest-environment-jsdom]` [**BREAKING**] Pass global config to Jest environment constructor for `jsdom` environment ([#12461](https://github.com/facebook/jest/pull/12461)) diff --git a/docs/Configuration.md b/docs/Configuration.md index afb0a21b0481..11d60d5f4896 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -856,6 +856,16 @@ If included in the list, the built-in GitHub Actions Reporter will annotate chan } ``` +#### Summary Reporter + +Summary reporter prints out summary of all tests. It is a part of default reporter, hence it will be enabled if `'default'` is included in the list. For instance, you might want to use it as stand-alone reporter instead of the default one, or together with [Silent Reporter](https://github.com/rickhanlonii/jest-silent-reporter): + +```json +{ + "reporters": ["jest-silent-reporter", "summary"] +} +``` + #### Custom Reporters :::tip diff --git a/e2e/__tests__/customReporters.test.ts b/e2e/__tests__/customReporters.test.ts index 8ae42e478d2a..90aca200027b 100644 --- a/e2e/__tests__/customReporters.test.ts +++ b/e2e/__tests__/customReporters.test.ts @@ -142,7 +142,6 @@ describe('Custom Reporters Integration', () => { 'package.json': JSON.stringify({ jest: { reporters: ['default', '/reporter.js'], - testEnvironment: 'node', }, }), 'reporter.js': ` @@ -167,7 +166,6 @@ describe('Custom Reporters Integration', () => { 'package.json': JSON.stringify({ jest: { reporters: ['default', '/reporter.mjs'], - testEnvironment: 'node', }, }), 'reporter.mjs': ` diff --git a/jest.config.ci.mjs b/jest.config.ci.mjs index 8934ee58bf63..ffba96d753c6 100644 --- a/jest.config.ci.mjs +++ b/jest.config.ci.mjs @@ -20,5 +20,6 @@ export default { 'jest-silent-reporter', {showPaths: true, showWarnings: true, useDots: true}, ], + 'summary', ], }; diff --git a/packages/jest-config/src/normalize.ts b/packages/jest-config/src/normalize.ts index b7fd07b904c9..1f1fa8c65d13 100644 --- a/packages/jest-config/src/normalize.ts +++ b/packages/jest-config/src/normalize.ts @@ -433,7 +433,7 @@ const normalizeReporters = (options: Config.InitialOptionsWithRootDir) => { normalizedReporterConfig[0], ); - if (!['default', 'github-actions'].includes(reporterPath)) { + if (!['default', 'github-actions', 'summary'].includes(reporterPath)) { const reporter = Resolver.findNodeModule(reporterPath, { basedir: options.rootDir, }); diff --git a/packages/jest-core/src/TestScheduler.ts b/packages/jest-core/src/TestScheduler.ts index 0dcb80354e02..7c088051334b 100644 --- a/packages/jest-core/src/TestScheduler.ts +++ b/packages/jest-core/src/TestScheduler.ts @@ -55,8 +55,6 @@ type TestRunnerConstructor = new ( export type TestSchedulerContext = ReporterContext & TestRunnerContext; -type ReporterMap = Record>; - export async function createTestScheduler( globalConfig: Config.GlobalConfig, context: TestSchedulerContext, @@ -329,77 +327,59 @@ class TestScheduler { } async _setupReporters() { - const {collectCoverage, notify, reporters} = this._globalConfig; + const {collectCoverage: coverage, notify, verbose} = this._globalConfig; + const reporters = this._globalConfig.reporters || [['default', {}]]; + let summary = false; + + for (const [reporter, options] of reporters) { + switch (reporter) { + case 'default': + summary = true; + verbose + ? this.addReporter(new VerboseReporter(this._globalConfig)) + : this.addReporter(new DefaultReporter(this._globalConfig)); + break; + case 'github-actions': + GITHUB_ACTIONS && this.addReporter(new GitHubActionsReporter()); + break; + case 'summary': + summary = true; + break; + default: + await this._addCustomReporter(reporter, options); + } + } if (notify) { this.addReporter(new NotifyReporter(this._globalConfig, this._context)); } - if (!reporters) { - this._setupDefaultReporters(collectCoverage); - return; - } - - let reporterMap: ReporterMap = {}; - - reporters.forEach(reporter => { - reporterMap = Object.assign(reporterMap, { - [reporter[0]]: reporter[1], - }); - }); - - const reporterNames = Object.keys(reporterMap); - - const isDefault = reporterNames.includes('default'); - const isGitHubActions = - GITHUB_ACTIONS && reporterNames.includes('github-actions'); - - if (isDefault) { - this._setupDefaultReporters(collectCoverage); - } - - if (isGitHubActions) { - this.addReporter(new GitHubActionsReporter()); - } - - if (!isDefault && collectCoverage) { + if (coverage) { this.addReporter(new CoverageReporter(this._globalConfig, this._context)); } - if (reporterNames.length) { - await this._addCustomReporters(reporterMap); - } - } - - private _setupDefaultReporters(collectCoverage: boolean) { - this.addReporter( - this._globalConfig.verbose - ? new VerboseReporter(this._globalConfig) - : new DefaultReporter(this._globalConfig), - ); - - if (collectCoverage) { - this.addReporter(new CoverageReporter(this._globalConfig, this._context)); + if (summary) { + this.addReporter(new SummaryReporter(this._globalConfig)); } - - this.addReporter(new SummaryReporter(this._globalConfig)); } - private async _addCustomReporters(reporters: ReporterMap) { - for (const path in reporters) { - if (['default', 'github-actions'].includes(path)) continue; + private async _addCustomReporter( + reporter: string, + options: Record, + ) { + try { + const Reporter: ReporterConstructor = await requireOrImportModule( + reporter, + ); - try { - const Reporter: ReporterConstructor = await requireOrImportModule(path); - this.addReporter( - new Reporter(this._globalConfig, reporters[path], this._context), - ); - } catch (error: any) { - error.message = `An error occurred while adding the reporter at path "${chalk.bold( - path, - )}".\n${error.message}`; - throw error; - } + this.addReporter( + new Reporter(this._globalConfig, options, this._context), + ); + } catch (error: any) { + error.message = `An error occurred while adding the reporter at path "${chalk.bold( + reporter, + )}".\n${error instanceof Error ? error.message : ''}`; + throw error; } } diff --git a/packages/jest-core/src/__tests__/TestScheduler.test.js b/packages/jest-core/src/__tests__/TestScheduler.test.js index 005dcabfb300..66aba2262bb0 100644 --- a/packages/jest-core/src/__tests__/TestScheduler.test.js +++ b/packages/jest-core/src/__tests__/TestScheduler.test.js @@ -6,14 +6,29 @@ * */ -import {GitHubActionsReporter, SummaryReporter} from '@jest/reporters'; +import { + CoverageReporter, + DefaultReporter, + GitHubActionsReporter, + NotifyReporter, + SummaryReporter, + VerboseReporter, +} from '@jest/reporters'; import {makeGlobalConfig, makeProjectConfig} from '@jest/test-utils'; import {createTestScheduler} from '../TestScheduler'; import * as testSchedulerHelper from '../testSchedulerHelper'; -jest.mock('ci-info', () => ({GITHUB_ACTIONS: true})); - -jest.mock('@jest/reporters'); +jest + .mock('ci-info', () => ({GITHUB_ACTIONS: true})) + .mock('@jest/reporters') + .mock( + '/custom-reporter.js', + () => + jest.fn(() => ({ + onTestStart() {}, + })), + {virtual: true}, + ); const mockSerialRunner = { isSerial: true, @@ -38,68 +53,175 @@ beforeEach(() => { spyShouldRunInBand.mockClear(); }); -test('config for reporters supports `default`', async () => { - const undefinedReportersScheduler = await createTestScheduler( - makeGlobalConfig({ - reporters: undefined, - }), - {}, - {}, - ); - const numberOfReporters = - undefinedReportersScheduler._dispatcher._reporters.length; +describe('reporters', () => { + const CustomReporter = require('/custom-reporter.js'); - const defaultReportersScheduler = await createTestScheduler( - makeGlobalConfig({ - reporters: [['default', {}]], - }), - {}, - {}, - ); - expect(defaultReportersScheduler._dispatcher._reporters.length).toBe( - numberOfReporters, - ); + afterEach(() => { + jest.clearAllMocks(); + }); - const emptyReportersScheduler = await createTestScheduler( - makeGlobalConfig({ - reporters: [], - }), - {}, - {}, - ); - expect(emptyReportersScheduler._dispatcher._reporters.length).toBe(0); -}); + test('works with default value', async () => { + await createTestScheduler( + makeGlobalConfig({ + reporters: undefined, + }), + {}, + {}, + ); + + expect(DefaultReporter).toBeCalledTimes(1); + expect(VerboseReporter).toBeCalledTimes(0); + expect(GitHubActionsReporter).toBeCalledTimes(0); + expect(NotifyReporter).toBeCalledTimes(0); + expect(CoverageReporter).toBeCalledTimes(0); + expect(SummaryReporter).toBeCalledTimes(1); + }); -test('config for reporters supports `github-actions`', async () => { - await createTestScheduler( - makeGlobalConfig({ - reporters: [], - }), - {}, - {}, - ); - expect(GitHubActionsReporter).toHaveBeenCalledTimes(0); + test('does not enable any reporters, if empty list is passed', async () => { + await createTestScheduler( + makeGlobalConfig({ + reporters: [], + }), + {}, + {}, + ); + + expect(DefaultReporter).toBeCalledTimes(0); + expect(VerboseReporter).toBeCalledTimes(0); + expect(GitHubActionsReporter).toBeCalledTimes(0); + expect(NotifyReporter).toBeCalledTimes(0); + expect(CoverageReporter).toBeCalledTimes(0); + expect(SummaryReporter).toBeCalledTimes(0); + }); - await createTestScheduler( - makeGlobalConfig({ - reporters: [['github-actions', {}]], - }), - {}, - {}, - ); - expect(GitHubActionsReporter).toHaveBeenCalledTimes(1); - - await createTestScheduler( - makeGlobalConfig({ - reporters: [ - ['default', {}], - ['github-actions', {}], - ], - }), - {}, - {}, - ); - expect(GitHubActionsReporter).toHaveBeenCalledTimes(2); + test('sets up default reporters', async () => { + await createTestScheduler( + makeGlobalConfig({ + reporters: [['default', {}]], + }), + {}, + {}, + ); + + expect(DefaultReporter).toBeCalledTimes(1); + expect(VerboseReporter).toBeCalledTimes(0); + expect(GitHubActionsReporter).toBeCalledTimes(0); + expect(NotifyReporter).toBeCalledTimes(0); + expect(CoverageReporter).toBeCalledTimes(0); + expect(SummaryReporter).toBeCalledTimes(1); + }); + + test('sets up verbose reporter', async () => { + await createTestScheduler( + makeGlobalConfig({ + reporters: [['default', {}]], + verbose: true, + }), + {}, + {}, + ); + + expect(DefaultReporter).toBeCalledTimes(0); + expect(VerboseReporter).toBeCalledTimes(1); + expect(GitHubActionsReporter).toBeCalledTimes(0); + expect(NotifyReporter).toBeCalledTimes(0); + expect(CoverageReporter).toBeCalledTimes(0); + expect(SummaryReporter).toBeCalledTimes(1); + }); + + test('sets up github actions reporter', async () => { + await createTestScheduler( + makeGlobalConfig({ + reporters: [ + ['default', {}], + ['github-actions', {}], + ], + }), + {}, + {}, + ); + + expect(DefaultReporter).toBeCalledTimes(1); + expect(VerboseReporter).toBeCalledTimes(0); + expect(GitHubActionsReporter).toBeCalledTimes(1); + expect(NotifyReporter).toBeCalledTimes(0); + expect(CoverageReporter).toBeCalledTimes(0); + expect(SummaryReporter).toBeCalledTimes(1); + }); + + test('sets up notify reporter', async () => { + await createTestScheduler( + makeGlobalConfig({ + notify: true, + reporters: [['default', {}]], + }), + {}, + {}, + ); + + expect(DefaultReporter).toBeCalledTimes(1); + expect(VerboseReporter).toBeCalledTimes(0); + expect(GitHubActionsReporter).toBeCalledTimes(0); + expect(NotifyReporter).toBeCalledTimes(1); + expect(CoverageReporter).toBeCalledTimes(0); + expect(SummaryReporter).toBeCalledTimes(1); + }); + + test('sets up coverage reporter', async () => { + await createTestScheduler( + makeGlobalConfig({ + collectCoverage: true, + reporters: [['default', {}]], + }), + {}, + {}, + ); + + expect(DefaultReporter).toBeCalledTimes(1); + expect(VerboseReporter).toBeCalledTimes(0); + expect(GitHubActionsReporter).toBeCalledTimes(0); + expect(NotifyReporter).toBeCalledTimes(0); + expect(CoverageReporter).toBeCalledTimes(1); + expect(SummaryReporter).toBeCalledTimes(1); + }); + + test('allows enabling summary reporter separately', async () => { + await createTestScheduler( + makeGlobalConfig({ + reporters: [['summary', {}]], + }), + {}, + {}, + ); + + expect(DefaultReporter).toBeCalledTimes(0); + expect(VerboseReporter).toBeCalledTimes(0); + expect(GitHubActionsReporter).toBeCalledTimes(0); + expect(NotifyReporter).toBeCalledTimes(0); + expect(CoverageReporter).toBeCalledTimes(0); + expect(SummaryReporter).toBeCalledTimes(1); + }); + + test('sets up custom reporter', async () => { + await createTestScheduler( + makeGlobalConfig({ + reporters: [ + ['default', {}], + ['/custom-reporter.js', {}], + ], + }), + {}, + {}, + ); + + expect(DefaultReporter).toBeCalledTimes(1); + expect(VerboseReporter).toBeCalledTimes(0); + expect(GitHubActionsReporter).toBeCalledTimes(0); + expect(NotifyReporter).toBeCalledTimes(0); + expect(CoverageReporter).toBeCalledTimes(0); + expect(SummaryReporter).toBeCalledTimes(1); + expect(CustomReporter).toBeCalledTimes(1); + }); }); test('.addReporter() .removeReporter()', async () => { From ac3f5f26f76d86e8f39b6fe646a9e5cf01c9c9cb Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Mon, 18 Apr 2022 14:01:03 +0300 Subject: [PATCH 057/128] refactor(jest-reporters, jest-runner): use `SerializeSet` type helper (#12686) --- packages/jest-reporters/src/CoverageWorker.ts | 15 +++++++++++++-- packages/jest-reporters/src/types.ts | 5 ----- packages/jest-runner/src/types.ts | 6 +++--- 3 files changed, 16 insertions(+), 10 deletions(-) diff --git a/packages/jest-reporters/src/CoverageWorker.ts b/packages/jest-reporters/src/CoverageWorker.ts index e369636041cc..15c32e4f551a 100644 --- a/packages/jest-reporters/src/CoverageWorker.ts +++ b/packages/jest-reporters/src/CoverageWorker.ts @@ -11,11 +11,22 @@ import type {Config} from '@jest/types'; import generateEmptyCoverage, { CoverageWorkerResult, } from './generateEmptyCoverage'; -import type {ReporterContextSerialized} from './types'; +import type {ReporterContext} from './types'; + +type SerializeSet = T extends Set ? Array : T; + +type CoverageReporterContext = Pick< + ReporterContext, + 'changedFiles' | 'sourcesRelatedToTestsInChangedFiles' +>; + +type CoverageReporterSerializedContext = { + [K in keyof CoverageReporterContext]: SerializeSet; +}; export type CoverageWorkerData = { config: Config.ProjectConfig; - context: ReporterContextSerialized; + context: CoverageReporterSerializedContext; globalConfig: Config.GlobalConfig; path: string; }; diff --git a/packages/jest-reporters/src/types.ts b/packages/jest-reporters/src/types.ts index 453f151881e5..0eb323ff334d 100644 --- a/packages/jest-reporters/src/types.ts +++ b/packages/jest-reporters/src/types.ts @@ -58,11 +58,6 @@ export type ReporterContext = { startRun?: (globalConfig: Config.GlobalConfig) => unknown; }; -export type ReporterContextSerialized = { - changedFiles?: Array; - sourcesRelatedToTestsInChangedFiles?: Array; -}; - export type SummaryOptions = { currentTestCases?: Array<{test: Test; testCaseResult: TestCaseResult}>; estimatedTime?: number; diff --git a/packages/jest-runner/src/types.ts b/packages/jest-runner/src/types.ts index ddc901f6c378..4a80e06e8a1b 100644 --- a/packages/jest-runner/src/types.ts +++ b/packages/jest-runner/src/types.ts @@ -44,15 +44,15 @@ export type TestRunnerOptions = { serial: boolean; }; -// make sure all props here are present in the type below it as well export type TestRunnerContext = { changedFiles?: Set; sourcesRelatedToTestsInChangedFiles?: Set; }; +type SerializeSet = T extends Set ? Array : T; + export type TestRunnerSerializedContext = { - changedFiles?: Array; - sourcesRelatedToTestsInChangedFiles?: Array; + [K in keyof TestRunnerContext]: SerializeSet; }; export type UnsubscribeFn = () => void; From 3b69f2322d75badd545d0dae0e7a4bca40e039e9 Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Mon, 18 Apr 2022 19:01:44 +0800 Subject: [PATCH 058/128] Add badge for ci status and code coverage (#12683) --- README.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/README.md b/README.md index f2d8c83d9d1c..18868708d026 100644 --- a/README.md +++ b/README.md @@ -9,6 +9,10 @@ Follow on Twitter

+

+ GitHub CI Status + Coverage Status +

Gitpod ready-to-code

From d2f3dc694d72c0208f47fc2e2ca101e26a9a6d68 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Mon, 18 Apr 2022 14:03:41 +0300 Subject: [PATCH 059/128] refactor(jest-runtime)!: remove `Context` type, it must be imported from `@jest/test-result` (#12685) --- CHANGELOG.md | 1 + packages/jest-core/src/SearchSource.ts | 9 ++++----- packages/jest-core/src/cli/index.ts | 8 ++++---- packages/jest-core/src/lib/createContext.ts | 5 +++-- packages/jest-core/src/runJest.ts | 4 ++-- packages/jest-core/src/types.ts | 5 ++--- packages/jest-core/src/watch.ts | 4 ++-- packages/jest-reporters/src/SummaryReporter.ts | 6 +++--- packages/jest-runtime/src/index.ts | 11 ++++++----- packages/jest-runtime/src/types.ts | 17 ----------------- packages/jest-test-sequencer/package.json | 1 - .../src/__tests__/test_sequencer.test.ts | 7 +++---- packages/jest-test-sequencer/src/index.ts | 9 ++++----- packages/jest-test-sequencer/tsconfig.json | 1 - yarn.lock | 1 - 15 files changed, 34 insertions(+), 55 deletions(-) delete mode 100644 packages/jest-runtime/src/types.ts diff --git a/CHANGELOG.md b/CHANGELOG.md index b64c2d6b4f7b..42f143013922 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -49,6 +49,7 @@ - `[jest-runner]` Exposing `CallbackTestRunner`, `EmittingTestRunner` abstract classes to help typing third party runners ([#12646](https://github.com/facebook/jest/pull/12646)) - `[jest-runtime]` [**BREAKING**] `Runtime.createHasteMap` now returns a promise ([#12008](https://github.com/facebook/jest/pull/12008)) - `[jest-runtime]` Calling `jest.resetModules` function will clear FS and transform cache ([#12531](https://github.com/facebook/jest/pull/12531)) +- `[jest-runtime]` [**BREAKING**] Remove `Context` type export, it must be imported from `@jest/test-result` ([#12685](https://github.com/facebook/jest/pull/12685)) - `[@jest/schemas]` New module for JSON schemas for Jest's config ([#12384](https://github.com/facebook/jest/pull/12384)) - `[jest-transform]` [**BREAKING**] Make it required for `process()` and `processAsync()` methods to always return structured data ([#12638](https://github.com/facebook/jest/pull/12638)) - `[jest-test-result]` Add duration property to JSON test output ([#12518](https://github.com/facebook/jest/pull/12518)) diff --git a/packages/jest-core/src/SearchSource.ts b/packages/jest-core/src/SearchSource.ts index fd8d254204b6..b1c8d31125fd 100644 --- a/packages/jest-core/src/SearchSource.ts +++ b/packages/jest-core/src/SearchSource.ts @@ -8,13 +8,12 @@ import * as os from 'os'; import * as path from 'path'; import micromatch = require('micromatch'); -import type {Test} from '@jest/test-result'; +import type {Test, TestContext} from '@jest/test-result'; import type {Config} from '@jest/types'; import type {ChangedFiles} from 'jest-changed-files'; import {replaceRootDirInPath} from 'jest-config'; import {escapePathForRegex} from 'jest-regex-util'; import {DependencyResolver} from 'jest-resolve-dependencies'; -import type {Context} from 'jest-runtime'; import {buildSnapshotResolver} from 'jest-snapshot'; import {globsToMatcher, testPathPatternToRegExp} from 'jest-util'; import type {Filter, Stats, TestPathCases} from './types'; @@ -41,7 +40,7 @@ const regexToMatcher = (testRegex: Config.ProjectConfig['testRegex']) => { }); }; -const toTests = (context: Context, tests: Array) => +const toTests = (context: TestContext, tests: Array) => tests.map(path => ({ context, duration: undefined, @@ -56,11 +55,11 @@ const hasSCM = (changedFilesInfo: ChangedFiles) => { }; export default class SearchSource { - private _context: Context; + private _context: TestContext; private _dependencyResolver: DependencyResolver | null; private _testPathCases: TestPathCases = []; - constructor(context: Context) { + constructor(context: TestContext) { const {config} = context; this._context = context; this._dependencyResolver = null; diff --git a/packages/jest-core/src/cli/index.ts b/packages/jest-core/src/cli/index.ts index c80f06b0040c..478b7f0d9cc4 100644 --- a/packages/jest-core/src/cli/index.ts +++ b/packages/jest-core/src/cli/index.ts @@ -9,12 +9,12 @@ import chalk = require('chalk'); import exit = require('exit'); import rimraf = require('rimraf'); import {CustomConsole} from '@jest/console'; -import type {AggregatedResult} from '@jest/test-result'; +import type {AggregatedResult, TestContext} from '@jest/test-result'; import type {Config} from '@jest/types'; import type {ChangedFilesPromise} from 'jest-changed-files'; import {readConfigs} from 'jest-config'; import type HasteMap from 'jest-haste-map'; -import Runtime, {Context} from 'jest-runtime'; +import Runtime from 'jest-runtime'; import {createDirectory, preRunMessage} from 'jest-util'; import {TestWatcher} from 'jest-watcher'; import {formatHandleErrors} from '../collectHandles'; @@ -227,7 +227,7 @@ const _run10000 = async ( }; const runWatch = async ( - contexts: Array, + contexts: Array, _configs: Array, hasDeprecationWarnings: boolean, globalConfig: Config.GlobalConfig, @@ -265,7 +265,7 @@ const runWatch = async ( const runWithoutWatch = async ( globalConfig: Config.GlobalConfig, - contexts: Array, + contexts: Array, outputStream: NodeJS.WriteStream, onComplete: OnCompleteCallback, changedFilesPromise?: ChangedFilesPromise, diff --git a/packages/jest-core/src/lib/createContext.ts b/packages/jest-core/src/lib/createContext.ts index 0b5e3a7c8444..be1a75061dd9 100644 --- a/packages/jest-core/src/lib/createContext.ts +++ b/packages/jest-core/src/lib/createContext.ts @@ -5,14 +5,15 @@ * LICENSE file in the root directory of this source tree. */ +import type {TestContext} from '@jest/test-result'; import type {Config} from '@jest/types'; import type {HasteMapObject} from 'jest-haste-map'; -import Runtime, {Context} from 'jest-runtime'; +import Runtime from 'jest-runtime'; export default function createContext( config: Config.ProjectConfig, {hasteFS, moduleMap}: HasteMapObject, -): Context { +): TestContext { return { config, hasteFS, diff --git a/packages/jest-core/src/runJest.ts b/packages/jest-core/src/runJest.ts index 0ebc5e1a996b..7061d3d282e7 100644 --- a/packages/jest-core/src/runJest.ts +++ b/packages/jest-core/src/runJest.ts @@ -13,6 +13,7 @@ import {CustomConsole} from '@jest/console'; import { AggregatedResult, Test, + TestContext, TestResultsProcessor, formatTestResults, makeEmptyAggregatedTestResult, @@ -21,7 +22,6 @@ import type TestSequencer from '@jest/test-sequencer'; import type {Config} from '@jest/types'; import type {ChangedFiles, ChangedFilesPromise} from 'jest-changed-files'; import Resolver from 'jest-resolve'; -import type {Context} from 'jest-runtime'; import {requireOrImportModule, tryRealpath} from 'jest-util'; import {JestHook, JestHookEmitter, TestWatcher} from 'jest-watcher'; import type FailedTestsCache from './FailedTestsCache'; @@ -136,7 +136,7 @@ export default async function runJest({ filter, }: { globalConfig: Config.GlobalConfig; - contexts: Array; + contexts: Array; outputStream: NodeJS.WriteStream; testWatcher: TestWatcher; jestHooks?: JestHookEmitter; diff --git a/packages/jest-core/src/types.ts b/packages/jest-core/src/types.ts index f29b8b3e2535..98119f1c6375 100644 --- a/packages/jest-core/src/types.ts +++ b/packages/jest-core/src/types.ts @@ -5,8 +5,7 @@ * LICENSE file in the root directory of this source tree. */ -import type {Test} from '@jest/test-result'; -import type {Context} from 'jest-runtime'; +import type {Test, TestContext} from '@jest/test-result'; export type Stats = { roots: number; @@ -17,7 +16,7 @@ export type Stats = { }; export type TestRunData = Array<{ - context: Context; + context: TestContext; matches: { allTests: number; tests: Array; diff --git a/packages/jest-core/src/watch.ts b/packages/jest-core/src/watch.ts index 17eb04f1ad87..ca0a6a421f26 100644 --- a/packages/jest-core/src/watch.ts +++ b/packages/jest-core/src/watch.ts @@ -10,13 +10,13 @@ import ansiEscapes = require('ansi-escapes'); import chalk = require('chalk'); import exit = require('exit'); import slash = require('slash'); +import type {TestContext} from '@jest/test-result'; import type {Config} from '@jest/types'; import type { ChangeEvent as HasteChangeEvent, default as HasteMap, } from 'jest-haste-map'; import {formatExecError} from 'jest-message-util'; -import type {Context} from 'jest-runtime'; import { isInteractive, preRunMessage, @@ -91,7 +91,7 @@ const RESERVED_KEY_PLUGINS = new Map< export default async function watch( initialGlobalConfig: Config.GlobalConfig, - contexts: Array, + contexts: Array, outputStream: NodeJS.WriteStream, hasteMapInstances: Array, stdin: NodeJS.ReadStream = process.stdin, diff --git a/packages/jest-reporters/src/SummaryReporter.ts b/packages/jest-reporters/src/SummaryReporter.ts index 4c7ba39d965e..cef51dda1b36 100644 --- a/packages/jest-reporters/src/SummaryReporter.ts +++ b/packages/jest-reporters/src/SummaryReporter.ts @@ -192,7 +192,7 @@ export default class SummaryReporter extends BaseReporter { } private _getTestSummary( - contexts: Set, + testContexts: Set, globalConfig: Config.GlobalConfig, ) { const getMatchingTestsInfo = () => { @@ -227,8 +227,8 @@ export default class SummaryReporter extends BaseReporter { } const contextInfo = - contexts.size > 1 - ? chalk.dim(' in ') + contexts.size + chalk.dim(' projects') + testContexts.size > 1 + ? chalk.dim(' in ') + testContexts.size + chalk.dim(' projects') : ''; return ( diff --git a/packages/jest-runtime/src/index.ts b/packages/jest-runtime/src/index.ts index c405a1191543..49eb7b38fe5b 100644 --- a/packages/jest-runtime/src/index.ts +++ b/packages/jest-runtime/src/index.ts @@ -33,7 +33,11 @@ import type { import type {LegacyFakeTimers, ModernFakeTimers} from '@jest/fake-timers'; import type * as JestGlobals from '@jest/globals'; import type {SourceMapRegistry} from '@jest/source-map'; -import type {RuntimeTransformResult, V8CoverageResult} from '@jest/test-result'; +import type { + RuntimeTransformResult, + TestContext, + V8CoverageResult, +} from '@jest/test-result'; import { CallerTransformOptions, ScriptTransformer, @@ -57,9 +61,6 @@ import { decodePossibleOutsideJestVmPath, findSiblingsWithFileExtension, } from './helpers'; -import type {Context} from './types'; - -export type {Context} from './types'; const esmIsAvailable = typeof SourceTextModule === 'function'; @@ -332,7 +333,7 @@ export default class Runtime { watch?: boolean; watchman: boolean; }, - ): Promise { + ): Promise { createDirectory(config.cacheDirectory); const instance = await Runtime.createHasteMap(config, { console: options.console, diff --git a/packages/jest-runtime/src/types.ts b/packages/jest-runtime/src/types.ts deleted file mode 100644 index b78f08090446..000000000000 --- a/packages/jest-runtime/src/types.ts +++ /dev/null @@ -1,17 +0,0 @@ -/** - * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. - * - * This source code is licensed under the MIT license found in the - * LICENSE file in the root directory of this source tree. - */ - -import type {Config} from '@jest/types'; -import type {FS as HasteFS, ModuleMap} from 'jest-haste-map'; -import type Resolver from 'jest-resolve'; - -export type Context = { - config: Config.ProjectConfig; - hasteFS: HasteFS; - moduleMap: ModuleMap; - resolver: Resolver; -}; diff --git a/packages/jest-test-sequencer/package.json b/packages/jest-test-sequencer/package.json index 7b843967dce2..468c5360f8a0 100644 --- a/packages/jest-test-sequencer/package.json +++ b/packages/jest-test-sequencer/package.json @@ -20,7 +20,6 @@ "@jest/test-result": "^28.0.0-alpha.8", "graceful-fs": "^4.2.9", "jest-haste-map": "^28.0.0-alpha.8", - "jest-runtime": "^28.0.0-alpha.8", "slash": "^3.0.0" }, "devDependencies": { diff --git a/packages/jest-test-sequencer/src/__tests__/test_sequencer.test.ts b/packages/jest-test-sequencer/src/__tests__/test_sequencer.test.ts index 4830a53d1040..52a48762e22c 100644 --- a/packages/jest-test-sequencer/src/__tests__/test_sequencer.test.ts +++ b/packages/jest-test-sequencer/src/__tests__/test_sequencer.test.ts @@ -7,9 +7,8 @@ import * as path from 'path'; import * as mockedFs from 'graceful-fs'; -import type {Test} from '@jest/test-result'; +import type {Test, TestContext} from '@jest/test-result'; import {makeProjectConfig} from '@jest/test-utils'; -import type {Context} from 'jest-runtime'; import TestSequencer from '../index'; jest.mock('graceful-fs', () => ({ @@ -24,7 +23,7 @@ let sequencer: TestSequencer; const fs = jest.mocked(mockedFs); -const context: Context = { +const context: TestContext = { config: makeProjectConfig({ cache: true, cacheDirectory: '/cache', @@ -36,7 +35,7 @@ const context: Context = { }, }; -const secondContext: Context = { +const secondContext: TestContext = { config: makeProjectConfig({ cache: true, cacheDirectory: '/cache2', diff --git a/packages/jest-test-sequencer/src/index.ts b/packages/jest-test-sequencer/src/index.ts index 711765dd2cd8..2a643c4f777d 100644 --- a/packages/jest-test-sequencer/src/index.ts +++ b/packages/jest-test-sequencer/src/index.ts @@ -9,9 +9,8 @@ import * as crypto from 'crypto'; import * as path from 'path'; import * as fs from 'graceful-fs'; import slash = require('slash'); -import type {AggregatedResult, Test} from '@jest/test-result'; +import type {AggregatedResult, Test, TestContext} from '@jest/test-result'; import HasteMap from 'jest-haste-map'; -import type {Context} from 'jest-runtime'; const FAIL = 0; const SUCCESS = 1; @@ -39,10 +38,10 @@ export type ShardOptions = { * is called to store/update this information on the cache map. */ export default class TestSequencer { - private _cache: Map = new Map(); + private _cache: Map = new Map(); - _getCachePath(context: Context): string { - const {config} = context; + _getCachePath(testContext: TestContext): string { + const {config} = testContext; const HasteMapClass = HasteMap.getStatic(config); return HasteMapClass.getCacheFilePath( config.cacheDirectory, diff --git a/packages/jest-test-sequencer/tsconfig.json b/packages/jest-test-sequencer/tsconfig.json index 70822da7c647..7d3736031d3b 100644 --- a/packages/jest-test-sequencer/tsconfig.json +++ b/packages/jest-test-sequencer/tsconfig.json @@ -8,7 +8,6 @@ "exclude": ["./**/__tests__/**/*"], "references": [ {"path": "../jest-haste-map"}, - {"path": "../jest-runtime"}, {"path": "../jest-test-result"}, {"path": "../test-utils"} ] diff --git a/yarn.lock b/yarn.lock index 2455bf6708ea..e1456f4c1e05 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2847,7 +2847,6 @@ __metadata: "@types/graceful-fs": ^4.1.3 graceful-fs: ^4.2.9 jest-haste-map: ^28.0.0-alpha.8 - jest-runtime: ^28.0.0-alpha.8 slash: ^3.0.0 languageName: unknown linkType: soft From aa3692ddb90865a83a5045e0ab20cb798c462bfd Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Mon, 18 Apr 2022 21:25:17 +0300 Subject: [PATCH 060/128] docs: add upgrading guide (#12633) --- CHANGELOG.md | 1 + docs/UpgradingToJest28.md | 184 ++++++++++++++++++++++++++++++++++++++ website/sidebars.json | 3 +- 3 files changed, 187 insertions(+), 1 deletion(-) create mode 100644 docs/UpgradingToJest28.md diff --git a/CHANGELOG.md b/CHANGELOG.md index 42f143013922..a098459a0efd 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -99,6 +99,7 @@ - `[docs, examples]` Update React examples to match with the new React guidelines for code examples ([#12217](https://github.com/facebook/jest/pull/12217)) - `[docs]` Add clarity for module factory hoisting limitations ([#12453](https://github.com/facebook/jest/pull/12453)) - `[docs]` Add more information about how code transformers work ([#12407](https://github.com/facebook/jest/pull/12407)) +- `[docs]` Add upgrading guide ([#12633](https://github.com/facebook/jest/pull/12633)) - `[expect]` [**BREAKING**] Remove support for importing `build/utils` ([#12323](https://github.com/facebook/jest/pull/12323)) - `[expect]` [**BREAKING**] Migrate to ESM ([#12344](https://github.com/facebook/jest/pull/12344)) - `[expect]` [**BREAKING**] Snapshot matcher types are moved to `@jest/expect` ([#12404](https://github.com/facebook/jest/pull/12404)) diff --git a/docs/UpgradingToJest28.md b/docs/UpgradingToJest28.md new file mode 100644 index 000000000000..d6d682656687 --- /dev/null +++ b/docs/UpgradingToJest28.md @@ -0,0 +1,184 @@ +--- +id: upgrading-to-jest28 +title: From v27 to v28 +--- + +Upgrading Jest from v27 to v28? This guide aims to help refactoring your configuration and tests. + +:::info + +See [changelog](https://github.com/facebook/jest/blob/main/CHANGELOG.md) for the full list of changes. + +::: + +## Compatibility + +The supported Node versions are 12.13, 14.15, 16.13 and above. + +If you plan to use type definitions of Jest (or any of its packages), make sure to install TypeScript version 4.3 or above. + +## Configuration Options + +### `extraGlobals` + +The `extraGlobals` option was renamed to [`sandboxInjectedGlobals`](Configuration.md#sandboxinjectedglobals-arraystring): + +```diff +- extraGlobals: ['Math'] ++ sandboxInjectedGlobals: ['Math'] +``` + +### `timers` + +The `timers` option was renamed to [`fakeTimers`](Configuration.md#faketimers-object). See [Fake Timers](#fake-timers) section bellow for details. + +### `testURL` + +The `testURL` option is removed. Now you should use [`testEnvironmentOptions`](Configuration.md#testenvironmentoptions-object) to pass `url` option to JSDOM environment: + +```diff +- testURL: 'https://jestjs.io' ++ testEnvironmentOptions: { ++ url: 'https://jestjs.io' ++ } +``` + +## Fake Timers + +Fake timers were refactored to allow passing options to the underlying [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). + +### `fakeTimers` + +The `timers` configuration option was renamed to [`fakeTimers`](Configuration.md#faketimers-object) and now takes an object with options: + +```diff +- timers: 'real' ++ fakeTimers: { ++ enableGlobally: false ++ } +``` + +```diff +- timers: 'fake' ++ fakeTimers: { ++ enableGlobally: true ++ } +``` + +```diff +- timers: 'modern' ++ fakeTimers: { ++ enableGlobally: true ++ } +``` + +```diff +- timers: 'legacy' ++ fakeTimers: { ++ enableGlobally: true, ++ legacyFakeTimers: true ++ } +``` + +### `jest.useFakeTimers()` + +An object with options now should be passed to [`jest.useFakeTimers()`](JestObjectAPI.md#jestusefaketimersfaketimersconfig) as well: + +```diff +- jest.useFakeTimers('modern') ++ jest.useFakeTimers() +``` + +```diff +- jest.useFakeTimers('legacy') ++ jest.useFakeTimers({ ++ legacyFakeTimers: true ++ }) +``` + +If legacy fake timers are enabled in Jest config file, but you would like to disable them in a particular test file: + +```diff +- jest.useFakeTimers('modern') ++ jest.useFakeTimers({ ++ legacyFakeTimers: false ++ }) +``` + +## Test Environment + +### Custom Environment + +The constructor of [test environment](Configuration.md#testenvironment-string) class now receives an object with Jest's `globalConfig` and `projectConfig` as its first argument. The second argument is now mandatory. + +```diff + class CustomEnvironment extends NodeEnvironment { +- constructor(config) { +- super(config); ++ constructor({globalConfig, projectConfig}, context) { ++ super({globalConfig, projectConfig}, context); ++ const config = projectConfig; +``` + +### `jsdom` + +If you are using JSDOM [test environment](Configuration.md#testenvironment-string), `jest-environment-jsdom` package now must be installed separately: + +```bash npm2yarn +npm install --save-dev jest-environment-jsdom +``` + +## Test Runner + +If you are using Jasmine [test runner](Configuration.md#testrunner-string), `jest-jasmine2` package now must be installed separately: + +```bash npm2yarn +npm install --save-dev jest-jasmine2 +``` + +## Transformer + +`process()` and `processAsync()` methods of a custom [transformer module](CodeTransformation.md) cannot return a string anymore. They must always return an object: + +```diff + process(sourceText, sourcePath, options) { +- return `module.exports = ${JSON.stringify(path.basename(sourcePath))};`; ++ return { ++ code: `module.exports = ${JSON.stringify(path.basename(sourcePath))};`, ++ }; + } +``` + +## TypeScript + +:::info + +The TypeScript examples from this page will only work as document if you import `jest` from `'@jest/globals'`: + +```ts +import {jest} from '@jest/globals'; +``` + +::: + +### `jest.fn()` + +`jest.fn()` now takes only one generic type argument. See [Mock Functions API](MockFunctionAPI.md) page for more usage examples. + +```diff + import add from './add'; +- const mockAdd = jest.fn, Parameters>(); ++ const mockAdd = jest.fn(); +``` + +```diff +- const mock = jest.fn() ++ const mock = jest.fn<() => number>() + .mockReturnValue(42) + .mockReturnValueOnce(12); + +- const asyncMock = jest.fn, []>() ++ const asyncMock = jest.fn<() => Promise>() + .mockResolvedValue('default') + .mockResolvedValueOnce('first call'); +``` diff --git a/website/sidebars.json b/website/sidebars.json index d40f62713a60..3f05a1a9c107 100644 --- a/website/sidebars.json +++ b/website/sidebars.json @@ -32,7 +32,8 @@ "tutorial-react", "tutorial-react-native", "testing-frameworks" - ] + ], + "Upgrade Guides": ["upgrading-to-jest28"] }, "api": [ "api", From 7f484cbf51d6483a9f51f7c973f98d104d7f7807 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Tue, 19 Apr 2022 13:29:13 +0300 Subject: [PATCH 061/128] chore: cleanup benchmark scripts (#12688) --- .eslintrc.cjs | 9 +++---- .prettierignore | 2 +- jest.config.mjs | 5 ++-- package.json | 1 - packages/diff-sequences/.npmignore | 1 + .../{perf => __benchmarks__}/example.md | 0 .../{perf/index.js => __benchmarks__/test.js} | 24 ++++++++++++------- packages/diff-sequences/package.json | 3 --- packages/jest-worker/.npmignore | 2 +- .../test.js | 15 +++++++----- .../workers/jest_worker.js | 0 .../workers/pi.js | 0 .../workers/worker_farm.js | 0 packages/jest-worker/tsconfig.json | 2 +- packages/pretty-format/.npmignore | 2 +- .../{perf => __benchmarks__}/test.js | 11 +++++++-- .../{perf => __benchmarks__}/world.geo.json | 0 17 files changed, 44 insertions(+), 33 deletions(-) rename packages/diff-sequences/{perf => __benchmarks__}/example.md (100%) rename packages/diff-sequences/{perf/index.js => __benchmarks__/test.js} (91%) rename packages/jest-worker/{src/__performance_tests__ => __benchmarks__}/test.js (92%) rename packages/jest-worker/{src/__performance_tests__ => __benchmarks__}/workers/jest_worker.js (100%) rename packages/jest-worker/{src/__performance_tests__ => __benchmarks__}/workers/pi.js (100%) rename packages/jest-worker/{src/__performance_tests__ => __benchmarks__}/workers/worker_farm.js (100%) rename packages/pretty-format/{perf => __benchmarks__}/test.js (96%) rename packages/pretty-format/{perf => __benchmarks__}/world.geo.json (100%) diff --git a/.eslintrc.cjs b/.eslintrc.cjs index 935c37b2f7d1..44d9227dfa97 100644 --- a/.eslintrc.cjs +++ b/.eslintrc.cjs @@ -237,10 +237,10 @@ module.exports = { }, { files: [ + 'e2e/**', 'website/**', + '**/__benchmarks__/**', '**/__tests__/**', - 'e2e/**', - '**/pretty-format/perf/**', 'packages/jest-types/**/*', '.eslintplugin/**', ], @@ -263,6 +263,7 @@ module.exports = { { files: [ 'scripts/*', + 'packages/*/__benchmarks__/test.js', 'packages/jest-cli/src/init/index.ts', 'packages/jest-repl/src/cli/runtime-cli.ts', ], @@ -274,14 +275,10 @@ module.exports = { files: [ 'e2e/**', 'examples/**', - 'scripts/*', 'website/**', '**/__mocks__/**', '**/__tests__/**', '**/__typetests__/**', - '**/__performance_tests__/**', - 'packages/diff-sequences/perf/index.js', - 'packages/pretty-format/perf/test.js', ], rules: { '@typescript-eslint/no-unused-vars': 'off', diff --git a/.prettierignore b/.prettierignore index cf9b97f586fc..0d516049dd16 100644 --- a/.prettierignore +++ b/.prettierignore @@ -9,7 +9,7 @@ coverage /packages/*/build /packages/*/dist /packages/jest-config/src/__tests__/jest-preset.json -/packages/pretty-format/perf/world.geo.json +/packages/pretty-format/__benchmarks__/world.geo.json # Breaks tests /e2e/coverage-handlebars/greet.hbs diff --git a/jest.config.mjs b/jest.config.mjs index 0ef5e177d735..6084cf82b9d3 100644 --- a/jest.config.mjs +++ b/jest.config.mjs @@ -15,7 +15,7 @@ export default { '**/packages/*/**/*.ts', '!**/bin/**', '!**/cli/**', - '!**/perf/**', + '!**/__benchmarks__/**', '!**/__mocks__/**', '!**/__tests__/**', '!**/__typetests__/**', @@ -38,6 +38,7 @@ export default { snapshotSerializers: [require.resolve('pretty-format/ConvertAnsi')], testPathIgnorePatterns: [ '/__arbitraries__/', + '/__benchmarks__/', '/__typetests__/', '/node_modules/', '/examples/', @@ -64,8 +65,6 @@ export default { '/packages/jest-snapshot/src/__tests__/plugins', '/packages/jest-snapshot/src/__tests__/fixtures/', '/packages/jest-validate/src/__tests__/fixtures/', - '/packages/jest-worker/src/__performance_tests__', - '/packages/pretty-format/perf/test.js', '/e2e/__tests__/iterator-to-null-test.ts', ], testTimeout: 70000, diff --git a/package.json b/package.json index 3d077d945539..765fec82eb3f 100644 --- a/package.json +++ b/package.json @@ -106,7 +106,6 @@ "test-types": "yarn jest --config jest.config.tsd.mjs", "test-ci-partial": "yarn test-ci-partial:parallel -i", "test-ci-partial:parallel": "yarn jest --color --config jest.config.ci.mjs", - "test-pretty-format-perf": "node packages/pretty-format/perf/test.js", "test-leak": "yarn jest -i --detectLeaks --color jest-mock jest-diff jest-repl pretty-format", "test": "yarn lint && yarn jest", "verify-old-ts": "node ./scripts/verifyOldTs.mjs", diff --git a/packages/diff-sequences/.npmignore b/packages/diff-sequences/.npmignore index 80bf61eb922c..8dda7de8f4fe 100644 --- a/packages/diff-sequences/.npmignore +++ b/packages/diff-sequences/.npmignore @@ -1,5 +1,6 @@ **/__mocks__/** **/__tests__/** +__benchmarks__ __typetests__ src tsconfig.json diff --git a/packages/diff-sequences/perf/example.md b/packages/diff-sequences/__benchmarks__/example.md similarity index 100% rename from packages/diff-sequences/perf/example.md rename to packages/diff-sequences/__benchmarks__/example.md diff --git a/packages/diff-sequences/perf/index.js b/packages/diff-sequences/__benchmarks__/test.js similarity index 91% rename from packages/diff-sequences/perf/index.js rename to packages/diff-sequences/__benchmarks__/test.js index f537b61f14e2..04da41dc9900 100644 --- a/packages/diff-sequences/perf/index.js +++ b/packages/diff-sequences/__benchmarks__/test.js @@ -5,19 +5,23 @@ * LICENSE file in the root directory of this source tree. */ -// Make sure to run node with --expose-gc option! - -// The times are reliable if about 1% relative mean error if you run it: +/** + * To start the test, build the repo and run: + * node --expose-gc test.js + */ -// * immediately after restart -// * with 100% battery charge -// * not connected to network +/** + * The times are reliable if about 1% relative mean error if you run it: + * - immediately after restart + * - with 100% battery charge + * - not connected to network + */ -/* eslint import/no-extraneous-dependencies: "off" */ +'use strict'; const Benchmark = require('benchmark'); const diffBaseline = require('diff').diffLines; -const diffImproved = require('../build/index.js').default; +const diffImproved = require('../').default; const testBaseline = (a, b) => { const benchmark = new Benchmark({ @@ -163,6 +167,10 @@ const testLength = n => { ); // simulate TDD }; +if (!globalThis.gc) { + throw new Error('GC not present, start with: node --expose-gc test.js'); +} + writeHeading2(); testLength(20); diff --git a/packages/diff-sequences/package.json b/packages/diff-sequences/package.json index 2f82c6e97cbe..813282810b5b 100644 --- a/packages/diff-sequences/package.json +++ b/packages/diff-sequences/package.json @@ -27,9 +27,6 @@ }, "./package.json": "./package.json" }, - "scripts": { - "perf": "node --expose-gc perf/index.js" - }, "devDependencies": { "benchmark": "^2.1.4", "diff": "^5.0.0", diff --git a/packages/jest-worker/.npmignore b/packages/jest-worker/.npmignore index b2b3ff7d1089..8dda7de8f4fe 100644 --- a/packages/jest-worker/.npmignore +++ b/packages/jest-worker/.npmignore @@ -1,6 +1,6 @@ **/__mocks__/** **/__tests__/** -**/__performance_tests__/** +__benchmarks__ __typetests__ src tsconfig.json diff --git a/packages/jest-worker/src/__performance_tests__/test.js b/packages/jest-worker/__benchmarks__/test.js similarity index 92% rename from packages/jest-worker/src/__performance_tests__/test.js rename to packages/jest-worker/__benchmarks__/test.js index 77bd431357a8..3d72d37844e0 100644 --- a/packages/jest-worker/src/__performance_tests__/test.js +++ b/packages/jest-worker/__benchmarks__/test.js @@ -5,22 +5,25 @@ * LICENSE file in the root directory of this source tree. */ +/** + * To start the test, build the repo and run: + * node --expose-gc test.js empty 100000 + * node --expose-gc test.js loadTest 10000 + */ + 'use strict'; const assert = require('assert'); const {performance} = require('perf_hooks'); -// eslint-disable-next-line import/no-extraneous-dependencies const workerFarm = require('worker-farm'); -const JestWorker = require('../../build').Worker; +const JestWorker = require('../').Worker; -// Typical tests: node --expose-gc test.js empty 100000 -// node --expose-gc test.js loadTest 10000 assert(process.argv[2], 'Pass a child method name'); assert(process.argv[3], 'Pass the number of iterations'); const sleep = ms => new Promise(resolve => setTimeout(resolve, ms)); const method = process.argv[2]; -const calls = +process.argv[3]; +const calls = Number(process.argv[3]); const threads = 6; const iterations = 10; @@ -127,7 +130,7 @@ function profileEnd(x) { async function main() { if (!globalThis.gc) { - console.warn('GC not present, start with node --expose-gc'); + throw new Error('GC not present, start with node --expose-gc'); } const wFResults = []; diff --git a/packages/jest-worker/src/__performance_tests__/workers/jest_worker.js b/packages/jest-worker/__benchmarks__/workers/jest_worker.js similarity index 100% rename from packages/jest-worker/src/__performance_tests__/workers/jest_worker.js rename to packages/jest-worker/__benchmarks__/workers/jest_worker.js diff --git a/packages/jest-worker/src/__performance_tests__/workers/pi.js b/packages/jest-worker/__benchmarks__/workers/pi.js similarity index 100% rename from packages/jest-worker/src/__performance_tests__/workers/pi.js rename to packages/jest-worker/__benchmarks__/workers/pi.js diff --git a/packages/jest-worker/src/__performance_tests__/workers/worker_farm.js b/packages/jest-worker/__benchmarks__/workers/worker_farm.js similarity index 100% rename from packages/jest-worker/src/__performance_tests__/workers/worker_farm.js rename to packages/jest-worker/__benchmarks__/workers/worker_farm.js diff --git a/packages/jest-worker/tsconfig.json b/packages/jest-worker/tsconfig.json index 1eb1744765cb..8f5708f84441 100644 --- a/packages/jest-worker/tsconfig.json +++ b/packages/jest-worker/tsconfig.json @@ -5,6 +5,6 @@ "outDir": "build" }, "include": ["./src/**/*"], - "exclude": ["./**/__performance_tests__/**/*", "./**/__tests__/**/*"], + "exclude": ["./**/__tests__/**/*"], "references": [{"path": "../jest-leak-detector"}] } diff --git a/packages/pretty-format/.npmignore b/packages/pretty-format/.npmignore index e4c4063f4efd..8dda7de8f4fe 100644 --- a/packages/pretty-format/.npmignore +++ b/packages/pretty-format/.npmignore @@ -1,8 +1,8 @@ **/__mocks__/** **/__tests__/** +__benchmarks__ __typetests__ src -perf tsconfig.json tsconfig.tsbuildinfo api-extractor.json diff --git a/packages/pretty-format/perf/test.js b/packages/pretty-format/__benchmarks__/test.js similarity index 96% rename from packages/pretty-format/perf/test.js rename to packages/pretty-format/__benchmarks__/test.js index bbe5d5b50e74..e5f8a3ced407 100644 --- a/packages/pretty-format/perf/test.js +++ b/packages/pretty-format/__benchmarks__/test.js @@ -5,13 +5,20 @@ * LICENSE file in the root directory of this source tree. */ +/** + * To start the test, build the repo and run: + * node test.js + */ + +'use strict'; + const util = require('util'); const chalk = require('chalk'); const React = require('react'); const ReactTestRenderer = require('react-test-renderer'); const {formatTime} = require('jest-util'); -const prettyFormat = require('../build'); -const ReactTestComponent = require('../build/plugins/ReactTestComponent'); +const prettyFormat = require('../').format; +const {ReactTestComponent} = require('../').plugins; const worldGeoJson = require('./world.geo.json'); const NANOSECONDS = 1000000000; diff --git a/packages/pretty-format/perf/world.geo.json b/packages/pretty-format/__benchmarks__/world.geo.json similarity index 100% rename from packages/pretty-format/perf/world.geo.json rename to packages/pretty-format/__benchmarks__/world.geo.json From ccecdaeaaebd0057067ec06a8ed699fb6270b38e Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Tue, 19 Apr 2022 18:48:43 +0800 Subject: [PATCH 062/128] Enforce same version of a dependency (#12668) --- .github/workflows/nodejs.yml | 16 +- .yarn/plugins/@yarnpkg/plugin-constraints.cjs | 52 ++++ .yarnrc.yml | 2 + CONTRIBUTING.md | 12 + constraints.pro | 82 +++++ ...ckTraceSourceMapsWithCoverage.test.ts.snap | 4 +- e2e/babel-plugin-jest-hoist/package.json | 2 +- e2e/babel-plugin-jest-hoist/yarn.lock | 4 +- e2e/coverage-remapping/package.json | 2 +- e2e/coverage-remapping/yarn.lock | 18 +- .../package.json | 2 +- .../yarn.lock | 18 +- e2e/stack-trace-source-maps/package.json | 2 +- e2e/stack-trace-source-maps/yarn.lock | 18 +- .../multiple-transformers/package.json | 6 +- e2e/transform/multiple-transformers/yarn.lock | 12 +- e2e/typescript-coverage/package.json | 2 +- e2e/typescript-coverage/yarn.lock | 18 +- examples/angular/package.json | 14 +- examples/async/package.json | 8 +- examples/automatic-mocks/package.json | 8 +- examples/enzyme/package.json | 10 +- examples/expect-extend/package.json | 6 +- examples/getting-started/package.json | 8 +- examples/jquery/package.json | 10 +- examples/manual-mocks/package.json | 8 +- examples/module-mock/package.json | 8 +- examples/mongodb/package.json | 13 +- examples/react-native/package.json | 8 +- examples/react-testing-library/package.json | 14 +- examples/react/package.json | 14 +- examples/snapshot/package.json | 14 +- examples/timer/package.json | 8 +- examples/typescript/package.json | 20 +- package.json | 2 +- packages/jest-cli/package.json | 2 +- .../typescript-in-dependencies/package.json | 2 +- .../package.json | 2 +- packages/jest-config/package.json | 2 +- packages/jest-console/package.json | 3 +- packages/jest-core/package.json | 2 +- packages/jest-reporters/package.json | 2 +- packages/jest-runtime/package.json | 2 +- packages/jest-watcher/package.json | 2 +- packages/jest/package.json | 3 +- packages/pretty-format/package.json | 10 +- packages/test-utils/package.json | 1 - scripts/checkCopyrightHeaders.mjs | 1 + website/package.json | 2 +- yarn.lock | 293 +++++++++--------- 50 files changed, 464 insertions(+), 310 deletions(-) create mode 100644 .yarn/plugins/@yarnpkg/plugin-constraints.cjs create mode 100644 constraints.pro diff --git a/.github/workflows/nodejs.yml b/.github/workflows/nodejs.yml index 2f7e83c597f4..e69d8c36226f 100644 --- a/.github/workflows/nodejs.yml +++ b/.github/workflows/nodejs.yml @@ -59,7 +59,7 @@ jobs: run: yarn verify-old-ts lint: - name: Running ESLint + name: Running Lint runs-on: ubuntu-latest needs: prepare-yarn-cache @@ -82,6 +82,20 @@ jobs: - name: check copyright headers run: yarn check-copyright-headers + yarn-validate: + name: Validate Yarn constraints + runs-on: ubuntu-latest + needs: prepare-yarn-cache + steps: + - uses: actions/checkout@v3 + - uses: actions/setup-node@v3 + with: + node-version: lts/* + cache: yarn + - name: 'Check for unmet constraints (fix w/ "yarn constraints --fix")' + run: | + yarn constraints + test: name: Node v${{ matrix.node-version }} on ${{ matrix.os }} (${{ matrix.shard }}) strategy: diff --git a/.yarn/plugins/@yarnpkg/plugin-constraints.cjs b/.yarn/plugins/@yarnpkg/plugin-constraints.cjs new file mode 100644 index 000000000000..f3b0db0c0243 --- /dev/null +++ b/.yarn/plugins/@yarnpkg/plugin-constraints.cjs @@ -0,0 +1,52 @@ +/* eslint-disable */ +//prettier-ignore +module.exports = { +name: "@yarnpkg/plugin-constraints", +factory: function (require) { +var plugin=(()=>{var Li=Object.create,Je=Object.defineProperty;var Hi=Object.getOwnPropertyDescriptor;var Gi=Object.getOwnPropertyNames;var Yi=Object.getPrototypeOf,Ui=Object.prototype.hasOwnProperty;var Zi=r=>Je(r,"__esModule",{value:!0});var I=(r,u)=>()=>(u||r((u={exports:{}}).exports,u),u.exports),Qi=(r,u)=>{for(var p in u)Je(r,p,{get:u[p],enumerable:!0})},Ji=(r,u,p)=>{if(u&&typeof u=="object"||typeof u=="function")for(let c of Gi(u))!Ui.call(r,c)&&c!=="default"&&Je(r,c,{get:()=>u[c],enumerable:!(p=Hi(u,c))||p.enumerable});return r},G=r=>Ji(Zi(Je(r!=null?Li(Yi(r)):{},"default",r&&r.__esModule&&"default"in r?{get:()=>r.default,enumerable:!0}:{value:r,enumerable:!0})),r);var Xr=I((Nu,_r)=>{var Ki;(function(r){var u=function(){return{"append/2":[new r.type.Rule(new r.type.Term("append",[new r.type.Var("X"),new r.type.Var("L")]),new r.type.Term("foldl",[new r.type.Term("append",[]),new r.type.Var("X"),new r.type.Term("[]",[]),new r.type.Var("L")]))],"append/3":[new r.type.Rule(new r.type.Term("append",[new r.type.Term("[]",[]),new r.type.Var("X"),new r.type.Var("X")]),null),new r.type.Rule(new r.type.Term("append",[new r.type.Term(".",[new r.type.Var("H"),new r.type.Var("T")]),new r.type.Var("X"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Var("S")])]),new r.type.Term("append",[new r.type.Var("T"),new r.type.Var("X"),new r.type.Var("S")]))],"member/2":[new r.type.Rule(new r.type.Term("member",[new r.type.Var("X"),new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("_")])]),null),new r.type.Rule(new r.type.Term("member",[new r.type.Var("X"),new r.type.Term(".",[new r.type.Var("_"),new r.type.Var("Xs")])]),new r.type.Term("member",[new r.type.Var("X"),new r.type.Var("Xs")]))],"permutation/2":[new r.type.Rule(new r.type.Term("permutation",[new r.type.Term("[]",[]),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("permutation",[new r.type.Term(".",[new r.type.Var("H"),new r.type.Var("T")]),new r.type.Var("S")]),new r.type.Term(",",[new r.type.Term("permutation",[new r.type.Var("T"),new r.type.Var("P")]),new r.type.Term(",",[new r.type.Term("append",[new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("P")]),new r.type.Term("append",[new r.type.Var("X"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Var("Y")]),new r.type.Var("S")])])]))],"maplist/2":[new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("_"),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Xs")])]),new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("P"),new r.type.Var("X")]),new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Var("Xs")])]))],"maplist/3":[new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("_"),new r.type.Term("[]",[]),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("A"),new r.type.Var("As")]),new r.type.Term(".",[new r.type.Var("B"),new r.type.Var("Bs")])]),new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("P"),new r.type.Var("A"),new r.type.Var("B")]),new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Var("As"),new r.type.Var("Bs")])]))],"maplist/4":[new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("_"),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("A"),new r.type.Var("As")]),new r.type.Term(".",[new r.type.Var("B"),new r.type.Var("Bs")]),new r.type.Term(".",[new r.type.Var("C"),new r.type.Var("Cs")])]),new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("P"),new r.type.Var("A"),new r.type.Var("B"),new r.type.Var("C")]),new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Var("As"),new r.type.Var("Bs"),new r.type.Var("Cs")])]))],"maplist/5":[new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("_"),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("A"),new r.type.Var("As")]),new r.type.Term(".",[new r.type.Var("B"),new r.type.Var("Bs")]),new r.type.Term(".",[new r.type.Var("C"),new r.type.Var("Cs")]),new r.type.Term(".",[new r.type.Var("D"),new r.type.Var("Ds")])]),new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("P"),new r.type.Var("A"),new r.type.Var("B"),new r.type.Var("C"),new r.type.Var("D")]),new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Var("As"),new r.type.Var("Bs"),new r.type.Var("Cs"),new r.type.Var("Ds")])]))],"maplist/6":[new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("_"),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("A"),new r.type.Var("As")]),new r.type.Term(".",[new r.type.Var("B"),new r.type.Var("Bs")]),new r.type.Term(".",[new r.type.Var("C"),new r.type.Var("Cs")]),new r.type.Term(".",[new r.type.Var("D"),new r.type.Var("Ds")]),new r.type.Term(".",[new r.type.Var("E"),new r.type.Var("Es")])]),new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("P"),new r.type.Var("A"),new r.type.Var("B"),new r.type.Var("C"),new r.type.Var("D"),new r.type.Var("E")]),new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Var("As"),new r.type.Var("Bs"),new r.type.Var("Cs"),new r.type.Var("Ds"),new r.type.Var("Es")])]))],"maplist/7":[new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("_"),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("A"),new r.type.Var("As")]),new r.type.Term(".",[new r.type.Var("B"),new r.type.Var("Bs")]),new r.type.Term(".",[new r.type.Var("C"),new r.type.Var("Cs")]),new r.type.Term(".",[new r.type.Var("D"),new r.type.Var("Ds")]),new r.type.Term(".",[new r.type.Var("E"),new r.type.Var("Es")]),new r.type.Term(".",[new r.type.Var("F"),new r.type.Var("Fs")])]),new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("P"),new r.type.Var("A"),new r.type.Var("B"),new r.type.Var("C"),new r.type.Var("D"),new r.type.Var("E"),new r.type.Var("F")]),new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Var("As"),new r.type.Var("Bs"),new r.type.Var("Cs"),new r.type.Var("Ds"),new r.type.Var("Es"),new r.type.Var("Fs")])]))],"maplist/8":[new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("_"),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[]),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("A"),new r.type.Var("As")]),new r.type.Term(".",[new r.type.Var("B"),new r.type.Var("Bs")]),new r.type.Term(".",[new r.type.Var("C"),new r.type.Var("Cs")]),new r.type.Term(".",[new r.type.Var("D"),new r.type.Var("Ds")]),new r.type.Term(".",[new r.type.Var("E"),new r.type.Var("Es")]),new r.type.Term(".",[new r.type.Var("F"),new r.type.Var("Fs")]),new r.type.Term(".",[new r.type.Var("G"),new r.type.Var("Gs")])]),new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("P"),new r.type.Var("A"),new r.type.Var("B"),new r.type.Var("C"),new r.type.Var("D"),new r.type.Var("E"),new r.type.Var("F"),new r.type.Var("G")]),new r.type.Term("maplist",[new r.type.Var("P"),new r.type.Var("As"),new r.type.Var("Bs"),new r.type.Var("Cs"),new r.type.Var("Ds"),new r.type.Var("Es"),new r.type.Var("Fs"),new r.type.Var("Gs")])]))],"include/3":[new r.type.Rule(new r.type.Term("include",[new r.type.Var("_"),new r.type.Term("[]",[]),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("include",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Var("T")]),new r.type.Var("L")]),new r.type.Term(",",[new r.type.Term("=..",[new r.type.Var("P"),new r.type.Var("A")]),new r.type.Term(",",[new r.type.Term("append",[new r.type.Var("A"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Term("[]",[])]),new r.type.Var("B")]),new r.type.Term(",",[new r.type.Term("=..",[new r.type.Var("F"),new r.type.Var("B")]),new r.type.Term(",",[new r.type.Term(";",[new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("F")]),new r.type.Term(",",[new r.type.Term("=",[new r.type.Var("L"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Var("S")])]),new r.type.Term("!",[])])]),new r.type.Term("=",[new r.type.Var("L"),new r.type.Var("S")])]),new r.type.Term("include",[new r.type.Var("P"),new r.type.Var("T"),new r.type.Var("S")])])])])]))],"exclude/3":[new r.type.Rule(new r.type.Term("exclude",[new r.type.Var("_"),new r.type.Term("[]",[]),new r.type.Term("[]",[])]),null),new r.type.Rule(new r.type.Term("exclude",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Var("T")]),new r.type.Var("S")]),new r.type.Term(",",[new r.type.Term("exclude",[new r.type.Var("P"),new r.type.Var("T"),new r.type.Var("E")]),new r.type.Term(",",[new r.type.Term("=..",[new r.type.Var("P"),new r.type.Var("L")]),new r.type.Term(",",[new r.type.Term("append",[new r.type.Var("L"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Term("[]",[])]),new r.type.Var("Q")]),new r.type.Term(",",[new r.type.Term("=..",[new r.type.Var("R"),new r.type.Var("Q")]),new r.type.Term(";",[new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("R")]),new r.type.Term(",",[new r.type.Term("!",[]),new r.type.Term("=",[new r.type.Var("S"),new r.type.Var("E")])])]),new r.type.Term("=",[new r.type.Var("S"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Var("E")])])])])])])]))],"foldl/4":[new r.type.Rule(new r.type.Term("foldl",[new r.type.Var("_"),new r.type.Term("[]",[]),new r.type.Var("I"),new r.type.Var("I")]),null),new r.type.Rule(new r.type.Term("foldl",[new r.type.Var("P"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Var("T")]),new r.type.Var("I"),new r.type.Var("R")]),new r.type.Term(",",[new r.type.Term("=..",[new r.type.Var("P"),new r.type.Var("L")]),new r.type.Term(",",[new r.type.Term("append",[new r.type.Var("L"),new r.type.Term(".",[new r.type.Var("I"),new r.type.Term(".",[new r.type.Var("H"),new r.type.Term(".",[new r.type.Var("X"),new r.type.Term("[]",[])])])]),new r.type.Var("L2")]),new r.type.Term(",",[new r.type.Term("=..",[new r.type.Var("P2"),new r.type.Var("L2")]),new r.type.Term(",",[new r.type.Term("call",[new r.type.Var("P2")]),new r.type.Term("foldl",[new r.type.Var("P"),new r.type.Var("T"),new r.type.Var("X"),new r.type.Var("R")])])])])]))],"select/3":[new r.type.Rule(new r.type.Term("select",[new r.type.Var("E"),new r.type.Term(".",[new r.type.Var("E"),new r.type.Var("Xs")]),new r.type.Var("Xs")]),null),new r.type.Rule(new r.type.Term("select",[new r.type.Var("E"),new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Xs")]),new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Ys")])]),new r.type.Term("select",[new r.type.Var("E"),new r.type.Var("Xs"),new r.type.Var("Ys")]))],"sum_list/2":[new r.type.Rule(new r.type.Term("sum_list",[new r.type.Term("[]",[]),new r.type.Num(0,!1)]),null),new r.type.Rule(new r.type.Term("sum_list",[new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Xs")]),new r.type.Var("S")]),new r.type.Term(",",[new r.type.Term("sum_list",[new r.type.Var("Xs"),new r.type.Var("Y")]),new r.type.Term("is",[new r.type.Var("S"),new r.type.Term("+",[new r.type.Var("X"),new r.type.Var("Y")])])]))],"max_list/2":[new r.type.Rule(new r.type.Term("max_list",[new r.type.Term(".",[new r.type.Var("X"),new r.type.Term("[]",[])]),new r.type.Var("X")]),null),new r.type.Rule(new r.type.Term("max_list",[new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Xs")]),new r.type.Var("S")]),new r.type.Term(",",[new r.type.Term("max_list",[new r.type.Var("Xs"),new r.type.Var("Y")]),new r.type.Term(";",[new r.type.Term(",",[new r.type.Term(">=",[new r.type.Var("X"),new r.type.Var("Y")]),new r.type.Term(",",[new r.type.Term("=",[new r.type.Var("S"),new r.type.Var("X")]),new r.type.Term("!",[])])]),new r.type.Term("=",[new r.type.Var("S"),new r.type.Var("Y")])])]))],"min_list/2":[new r.type.Rule(new r.type.Term("min_list",[new r.type.Term(".",[new r.type.Var("X"),new r.type.Term("[]",[])]),new r.type.Var("X")]),null),new r.type.Rule(new r.type.Term("min_list",[new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Xs")]),new r.type.Var("S")]),new r.type.Term(",",[new r.type.Term("min_list",[new r.type.Var("Xs"),new r.type.Var("Y")]),new r.type.Term(";",[new r.type.Term(",",[new r.type.Term("=<",[new r.type.Var("X"),new r.type.Var("Y")]),new r.type.Term(",",[new r.type.Term("=",[new r.type.Var("S"),new r.type.Var("X")]),new r.type.Term("!",[])])]),new r.type.Term("=",[new r.type.Var("S"),new r.type.Var("Y")])])]))],"prod_list/2":[new r.type.Rule(new r.type.Term("prod_list",[new r.type.Term("[]",[]),new r.type.Num(1,!1)]),null),new r.type.Rule(new r.type.Term("prod_list",[new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Xs")]),new r.type.Var("S")]),new r.type.Term(",",[new r.type.Term("prod_list",[new r.type.Var("Xs"),new r.type.Var("Y")]),new r.type.Term("is",[new r.type.Var("S"),new r.type.Term("*",[new r.type.Var("X"),new r.type.Var("Y")])])]))],"last/2":[new r.type.Rule(new r.type.Term("last",[new r.type.Term(".",[new r.type.Var("X"),new r.type.Term("[]",[])]),new r.type.Var("X")]),null),new r.type.Rule(new r.type.Term("last",[new r.type.Term(".",[new r.type.Var("_"),new r.type.Var("Xs")]),new r.type.Var("X")]),new r.type.Term("last",[new r.type.Var("Xs"),new r.type.Var("X")]))],"prefix/2":[new r.type.Rule(new r.type.Term("prefix",[new r.type.Var("Part"),new r.type.Var("Whole")]),new r.type.Term("append",[new r.type.Var("Part"),new r.type.Var("_"),new r.type.Var("Whole")]))],"nth0/3":[new r.type.Rule(new r.type.Term("nth0",[new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z")]),new r.type.Term(";",[new r.type.Term("->",[new r.type.Term("var",[new r.type.Var("X")]),new r.type.Term("nth",[new r.type.Num(0,!1),new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("_")])]),new r.type.Term(",",[new r.type.Term(">=",[new r.type.Var("X"),new r.type.Num(0,!1)]),new r.type.Term(",",[new r.type.Term("nth",[new r.type.Num(0,!1),new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("_")]),new r.type.Term("!",[])])])]))],"nth1/3":[new r.type.Rule(new r.type.Term("nth1",[new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z")]),new r.type.Term(";",[new r.type.Term("->",[new r.type.Term("var",[new r.type.Var("X")]),new r.type.Term("nth",[new r.type.Num(1,!1),new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("_")])]),new r.type.Term(",",[new r.type.Term(">",[new r.type.Var("X"),new r.type.Num(0,!1)]),new r.type.Term(",",[new r.type.Term("nth",[new r.type.Num(1,!1),new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("_")]),new r.type.Term("!",[])])])]))],"nth0/4":[new r.type.Rule(new r.type.Term("nth0",[new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("W")]),new r.type.Term(";",[new r.type.Term("->",[new r.type.Term("var",[new r.type.Var("X")]),new r.type.Term("nth",[new r.type.Num(0,!1),new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("W")])]),new r.type.Term(",",[new r.type.Term(">=",[new r.type.Var("X"),new r.type.Num(0,!1)]),new r.type.Term(",",[new r.type.Term("nth",[new r.type.Num(0,!1),new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("W")]),new r.type.Term("!",[])])])]))],"nth1/4":[new r.type.Rule(new r.type.Term("nth1",[new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("W")]),new r.type.Term(";",[new r.type.Term("->",[new r.type.Term("var",[new r.type.Var("X")]),new r.type.Term("nth",[new r.type.Num(1,!1),new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("W")])]),new r.type.Term(",",[new r.type.Term(">",[new r.type.Var("X"),new r.type.Num(0,!1)]),new r.type.Term(",",[new r.type.Term("nth",[new r.type.Num(1,!1),new r.type.Var("X"),new r.type.Var("Y"),new r.type.Var("Z"),new r.type.Var("W")]),new r.type.Term("!",[])])])]))],"nth/5":[new r.type.Rule(new r.type.Term("nth",[new r.type.Var("N"),new r.type.Var("N"),new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Xs")]),new r.type.Var("X"),new r.type.Var("Xs")]),null),new r.type.Rule(new r.type.Term("nth",[new r.type.Var("N"),new r.type.Var("O"),new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Xs")]),new r.type.Var("Y"),new r.type.Term(".",[new r.type.Var("X"),new r.type.Var("Ys")])]),new r.type.Term(",",[new r.type.Term("is",[new r.type.Var("M"),new r.type.Term("+",[new r.type.Var("N"),new r.type.Num(1,!1)])]),new r.type.Term("nth",[new r.type.Var("M"),new r.type.Var("O"),new r.type.Var("Xs"),new r.type.Var("Y"),new r.type.Var("Ys")])]))],"length/2":function(c,w,_){var v=_.args[0],g=_.args[1];if(!r.type.is_variable(g)&&!r.type.is_integer(g))c.throw_error(r.error.type("integer",g,_.indicator));else if(r.type.is_integer(g)&&g.value<0)c.throw_error(r.error.domain("not_less_than_zero",g,_.indicator));else{var h=new r.type.Term("length",[v,new r.type.Num(0,!1),g]);r.type.is_integer(g)&&(h=new r.type.Term(",",[h,new r.type.Term("!",[])])),c.prepend([new r.type.State(w.goal.replace(h),w.substitution,w)])}},"length/3":[new r.type.Rule(new r.type.Term("length",[new r.type.Term("[]",[]),new r.type.Var("N"),new r.type.Var("N")]),null),new r.type.Rule(new r.type.Term("length",[new r.type.Term(".",[new r.type.Var("_"),new r.type.Var("X")]),new r.type.Var("A"),new r.type.Var("N")]),new r.type.Term(",",[new r.type.Term("succ",[new r.type.Var("A"),new r.type.Var("B")]),new r.type.Term("length",[new r.type.Var("X"),new r.type.Var("B"),new r.type.Var("N")])]))],"replicate/3":function(c,w,_){var v=_.args[0],g=_.args[1],h=_.args[2];if(r.type.is_variable(g))c.throw_error(r.error.instantiation(_.indicator));else if(!r.type.is_integer(g))c.throw_error(r.error.type("integer",g,_.indicator));else if(g.value<0)c.throw_error(r.error.domain("not_less_than_zero",g,_.indicator));else if(!r.type.is_variable(h)&&!r.type.is_list(h))c.throw_error(r.error.type("list",h,_.indicator));else{for(var x=new r.type.Term("[]"),T=0;T0;b--)T[b].equals(T[b-1])&&T.splice(b,1);for(var C=new r.type.Term("[]"),b=T.length-1;b>=0;b--)C=new r.type.Term(".",[T[b],C]);c.prepend([new r.type.State(w.goal.replace(new r.type.Term("=",[C,g])),w.substitution,w)])}}},"msort/2":function(c,w,_){var v=_.args[0],g=_.args[1];if(r.type.is_variable(v))c.throw_error(r.error.instantiation(_.indicator));else if(!r.type.is_variable(g)&&!r.type.is_fully_list(g))c.throw_error(r.error.type("list",g,_.indicator));else{for(var h=[],x=v;x.indicator==="./2";)h.push(x.args[0]),x=x.args[1];if(r.type.is_variable(x))c.throw_error(r.error.instantiation(_.indicator));else if(!r.type.is_empty_list(x))c.throw_error(r.error.type("list",v,_.indicator));else{for(var T=h.sort(r.compare),b=new r.type.Term("[]"),C=T.length-1;C>=0;C--)b=new r.type.Term(".",[T[C],b]);c.prepend([new r.type.State(w.goal.replace(new r.type.Term("=",[b,g])),w.substitution,w)])}}},"keysort/2":function(c,w,_){var v=_.args[0],g=_.args[1];if(r.type.is_variable(v))c.throw_error(r.error.instantiation(_.indicator));else if(!r.type.is_variable(g)&&!r.type.is_fully_list(g))c.throw_error(r.error.type("list",g,_.indicator));else{for(var h=[],x,T=v;T.indicator==="./2";){if(x=T.args[0],r.type.is_variable(x)){c.throw_error(r.error.instantiation(_.indicator));return}else if(!r.type.is_term(x)||x.indicator!=="-/2"){c.throw_error(r.error.type("pair",x,_.indicator));return}x.args[0].pair=x.args[1],h.push(x.args[0]),T=T.args[1]}if(r.type.is_variable(T))c.throw_error(r.error.instantiation(_.indicator));else if(!r.type.is_empty_list(T))c.throw_error(r.error.type("list",v,_.indicator));else{for(var b=h.sort(r.compare),C=new r.type.Term("[]"),N=b.length-1;N>=0;N--)C=new r.type.Term(".",[new r.type.Term("-",[b[N],b[N].pair]),C]),delete b[N].pair;c.prepend([new r.type.State(w.goal.replace(new r.type.Term("=",[C,g])),w.substitution,w)])}}},"take/3":function(c,w,_){var v=_.args[0],g=_.args[1],h=_.args[2];if(r.type.is_variable(g)||r.type.is_variable(v))c.throw_error(r.error.instantiation(_.indicator));else if(!r.type.is_list(g))c.throw_error(r.error.type("list",g,_.indicator));else if(!r.type.is_integer(v))c.throw_error(r.error.type("integer",v,_.indicator));else if(!r.type.is_variable(h)&&!r.type.is_list(h))c.throw_error(r.error.type("list",h,_.indicator));else{for(var x=v.value,T=[],b=g;x>0&&b.indicator==="./2";)T.push(b.args[0]),b=b.args[1],x--;if(x===0){for(var C=new r.type.Term("[]"),x=T.length-1;x>=0;x--)C=new r.type.Term(".",[T[x],C]);c.prepend([new r.type.State(w.goal.replace(new r.type.Term("=",[C,h])),w.substitution,w)])}}},"drop/3":function(c,w,_){var v=_.args[0],g=_.args[1],h=_.args[2];if(r.type.is_variable(g)||r.type.is_variable(v))c.throw_error(r.error.instantiation(_.indicator));else if(!r.type.is_list(g))c.throw_error(r.error.type("list",g,_.indicator));else if(!r.type.is_integer(v))c.throw_error(r.error.type("integer",v,_.indicator));else if(!r.type.is_variable(h)&&!r.type.is_list(h))c.throw_error(r.error.type("list",h,_.indicator));else{for(var x=v.value,T=[],b=g;x>0&&b.indicator==="./2";)T.push(b.args[0]),b=b.args[1],x--;x===0&&c.prepend([new r.type.State(w.goal.replace(new r.type.Term("=",[b,h])),w.substitution,w)])}},"reverse/2":function(c,w,_){var v=_.args[0],g=_.args[1],h=r.type.is_instantiated_list(v),x=r.type.is_instantiated_list(g);if(r.type.is_variable(v)&&r.type.is_variable(g))c.throw_error(r.error.instantiation(_.indicator));else if(!r.type.is_variable(v)&&!r.type.is_fully_list(v))c.throw_error(r.error.type("list",v,_.indicator));else if(!r.type.is_variable(g)&&!r.type.is_fully_list(g))c.throw_error(r.error.type("list",g,_.indicator));else if(!h&&!x)c.throw_error(r.error.instantiation(_.indicator));else{for(var T=h?v:g,b=new r.type.Term("[]",[]);T.indicator==="./2";)b=new r.type.Term(".",[T.args[0],b]),T=T.args[1];c.prepend([new r.type.State(w.goal.replace(new r.type.Term("=",[b,h?g:v])),w.substitution,w)])}},"list_to_set/2":function(c,w,_){var v=_.args[0],g=_.args[1];if(r.type.is_variable(v))c.throw_error(r.error.instantiation(_.indicator));else{for(var h=v,x=[];h.indicator==="./2";)x.push(h.args[0]),h=h.args[1];if(r.type.is_variable(h))c.throw_error(r.error.instantiation(_.indicator));else if(!r.type.is_term(h)||h.indicator!=="[]/0")c.throw_error(r.error.type("list",v,_.indicator));else{for(var T=[],b=new r.type.Term("[]",[]),C,N=0;N=0;N--)b=new r.type.Term(".",[T[N],b]);c.prepend([new r.type.State(w.goal.replace(new r.type.Term("=",[g,b])),w.substitution,w)])}}}}},p=["append/2","append/3","member/2","permutation/2","maplist/2","maplist/3","maplist/4","maplist/5","maplist/6","maplist/7","maplist/8","include/3","exclude/3","foldl/4","sum_list/2","max_list/2","min_list/2","prod_list/2","last/2","prefix/2","nth0/3","nth1/3","nth0/4","nth1/4","length/2","replicate/3","select/3","sort/2","msort/2","keysort/2","take/3","drop/3","reverse/2","list_to_set/2"];typeof _r!="undefined"?_r.exports=function(c){r=c,new r.type.Module("lists",u(),p)}:new r.type.Module("lists",u(),p)})(Ki)});var et=I(M=>{"use strict";var Ve=process.platform==="win32",wr="aes-256-cbc",ji="sha256",Br="The current environment doesn't support interactive reading from TTY.",z=require("fs"),Fr=process.binding("tty_wrap").TTY,gr=require("child_process"),_e=require("path"),dr={prompt:"> ",hideEchoBack:!1,mask:"*",limit:[],limitMessage:"Input another, please.$<( [)limit(])>",defaultInput:"",trueValue:[],falseValue:[],caseSensitive:!1,keepWhitespace:!1,encoding:"utf8",bufferSize:1024,print:void 0,history:!0,cd:!1,phContent:void 0,preCheck:void 0},fe="none",oe,Ce,zr=!1,we,Ke,vr,es=0,hr="",Se=[],je,Wr=!1,mr=!1,$e=!1;function Lr(r){function u(p){return p.replace(/[^\w\u0080-\uFFFF]/g,function(c){return"#"+c.charCodeAt(0)+";"})}return Ke.concat(function(p){var c=[];return Object.keys(p).forEach(function(w){p[w]==="boolean"?r[w]&&c.push("--"+w):p[w]==="string"&&r[w]&&c.push("--"+w,u(r[w]))}),c}({display:"string",displayOnly:"boolean",keyIn:"boolean",hideEchoBack:"boolean",mask:"string",limit:"string",caseSensitive:"boolean"}))}function rs(r,u){function p(j){var U,Ue="",Ze;for(vr=vr||require("os").tmpdir();;){U=_e.join(vr,j+Ue);try{Ze=z.openSync(U,"wx")}catch(Qe){if(Qe.code==="EEXIST"){Ue++;continue}else throw Qe}z.closeSync(Ze);break}return U}var c,w,_,v={},g,h,x=p("readline-sync.stdout"),T=p("readline-sync.stderr"),b=p("readline-sync.exit"),C=p("readline-sync.done"),N=require("crypto"),W,ee,te;W=N.createHash(ji),W.update(""+process.pid+es+++Math.random()),te=W.digest("hex"),ee=N.createDecipher(wr,te),c=Lr(r),Ve?(w=process.env.ComSpec||"cmd.exe",process.env.Q='"',_=["/V:ON","/S","/C","(%Q%"+w+"%Q% /V:ON /S /C %Q%%Q%"+we+"%Q%"+c.map(function(j){return" %Q%"+j+"%Q%"}).join("")+" & (echo !ERRORLEVEL!)>%Q%"+b+"%Q%%Q%) 2>%Q%"+T+"%Q% |%Q%"+process.execPath+"%Q% %Q%"+__dirname+"\\encrypt.js%Q% %Q%"+wr+"%Q% %Q%"+te+"%Q% >%Q%"+x+"%Q% & (echo 1)>%Q%"+C+"%Q%"]):(w="/bin/sh",_=["-c",'("'+we+'"'+c.map(function(j){return" '"+j.replace(/'/g,"'\\''")+"'"}).join("")+'; echo $?>"'+b+'") 2>"'+T+'" |"'+process.execPath+'" "'+__dirname+'/encrypt.js" "'+wr+'" "'+te+'" >"'+x+'"; echo 1 >"'+C+'"']),$e&&$e("_execFileSync",c);try{gr.spawn(w,_,u)}catch(j){v.error=new Error(j.message),v.error.method="_execFileSync - spawn",v.error.program=w,v.error.args=_}for(;z.readFileSync(C,{encoding:r.encoding}).trim()!=="1";);return(g=z.readFileSync(b,{encoding:r.encoding}).trim())==="0"?v.input=ee.update(z.readFileSync(x,{encoding:"binary"}),"hex",r.encoding)+ee.final(r.encoding):(h=z.readFileSync(T,{encoding:r.encoding}).trim(),v.error=new Error(Br+(h?` +`+h:"")),v.error.method="_execFileSync",v.error.program=w,v.error.args=_,v.error.extMessage=h,v.error.exitCode=+g),z.unlinkSync(x),z.unlinkSync(T),z.unlinkSync(b),z.unlinkSync(C),v}function ts(r){var u,p={},c,w={env:process.env,encoding:r.encoding};if(we||(Ve?process.env.PSModulePath?(we="powershell.exe",Ke=["-ExecutionPolicy","Bypass","-File",__dirname+"\\read.ps1"]):(we="cscript.exe",Ke=["//nologo",__dirname+"\\read.cs.js"]):(we="/bin/sh",Ke=[__dirname+"/read.sh"])),Ve&&!process.env.PSModulePath&&(w.stdio=[process.stdin]),gr.execFileSync){u=Lr(r),$e&&$e("execFileSync",u);try{p.input=gr.execFileSync(we,u,w)}catch(_){c=_.stderr?(_.stderr+"").trim():"",p.error=new Error(Br+(c?` +`+c:"")),p.error.method="execFileSync",p.error.program=we,p.error.args=u,p.error.extMessage=c,p.error.exitCode=_.status,p.error.code=_.code,p.error.signal=_.signal}}else p=rs(r,w);return p.error||(p.input=p.input.replace(/^\s*'|'\s*$/g,""),r.display=""),p}function br(r){var u="",p=r.display,c=!r.display&&r.keyIn&&r.hideEchoBack&&!r.mask;function w(){var _=ts(r);if(_.error)throw _.error;return _.input}return mr&&mr(r),function(){var _,v,g;function h(){return _||(_=process.binding("fs"),v=process.binding("constants")),_}if(typeof fe=="string")if(fe=null,Ve){if(g=function(x){var T=x.replace(/^\D+/,"").split("."),b=0;return(T[0]=+T[0])&&(b+=T[0]*1e4),(T[1]=+T[1])&&(b+=T[1]*100),(T[2]=+T[2])&&(b+=T[2]),b}(process.version),!(g>=20302&&g<40204||g>=5e4&&g<50100||g>=50600&&g<60200)&&process.stdin.isTTY)process.stdin.pause(),fe=process.stdin.fd,Ce=process.stdin._handle;else try{fe=h().open("CONIN$",v.O_RDWR,parseInt("0666",8)),Ce=new Fr(fe,!0)}catch(x){}if(process.stdout.isTTY)oe=process.stdout.fd;else{try{oe=z.openSync("\\\\.\\CON","w")}catch(x){}if(typeof oe!="number")try{oe=h().open("CONOUT$",v.O_RDWR,parseInt("0666",8))}catch(x){}}}else{if(process.stdin.isTTY){process.stdin.pause();try{fe=z.openSync("/dev/tty","r"),Ce=process.stdin._handle}catch(x){}}else try{fe=z.openSync("/dev/tty","r"),Ce=new Fr(fe,!1)}catch(x){}if(process.stdout.isTTY)oe=process.stdout.fd;else try{oe=z.openSync("/dev/tty","w")}catch(x){}}}(),function(){var _,v,g=!r.hideEchoBack&&!r.keyIn,h,x,T,b,C;je="";function N(W){return W===zr?!0:Ce.setRawMode(W)!==0?!1:(zr=W,!0)}if(Wr||!Ce||typeof oe!="number"&&(r.display||!g)){u=w();return}if(r.display&&(z.writeSync(oe,r.display),r.display=""),!r.displayOnly){if(!N(!g)){u=w();return}for(x=r.keyIn?1:r.bufferSize,h=Buffer.allocUnsafe&&Buffer.alloc?Buffer.alloc(x):new Buffer(x),r.keyIn&&r.limit&&(v=new RegExp("[^"+r.limit+"]","g"+(r.caseSensitive?"":"i")));;){T=0;try{T=z.readSync(fe,h,0,x)}catch(W){if(W.code!=="EOF"){N(!1),u+=w();return}}if(T>0?(b=h.toString(r.encoding,0,T),je+=b):(b=` +`,je+=String.fromCharCode(0)),b&&typeof(C=(b.match(/^(.*?)[\r\n]/)||[])[1])=="string"&&(b=C,_=!0),b&&(b=b.replace(/[\x00-\x08\x0b\x0c\x0e-\x1f\x7f]/g,"")),b&&v&&(b=b.replace(v,"")),b&&(g||(r.hideEchoBack?r.mask&&z.writeSync(oe,new Array(b.length+1).join(r.mask)):z.writeSync(oe,b)),u+=b),!r.keyIn&&_||r.keyIn&&u.length>=x)break}!g&&!c&&z.writeSync(oe,` +`),N(!1)}}(),r.print&&!c&&r.print(p+(r.displayOnly?"":(r.hideEchoBack?new Array(u.length+1).join(r.mask):u)+` +`),r.encoding),r.displayOnly?"":hr=r.keepWhitespace||r.keyIn?u:u.trim()}function ns(r,u){var p=[];function c(w){w!=null&&(Array.isArray(w)?w.forEach(c):(!u||u(w))&&p.push(w))}return c(r),p}function Tr(r){return r.replace(/[\x00-\x7f]/g,function(u){return"\\x"+("00"+u.charCodeAt().toString(16)).substr(-2)})}function Z(){var r=Array.prototype.slice.call(arguments),u,p;return r.length&&typeof r[0]=="boolean"&&(p=r.shift(),p&&(u=Object.keys(dr),r.unshift(dr))),r.reduce(function(c,w){return w==null||(w.hasOwnProperty("noEchoBack")&&!w.hasOwnProperty("hideEchoBack")&&(w.hideEchoBack=w.noEchoBack,delete w.noEchoBack),w.hasOwnProperty("noTrim")&&!w.hasOwnProperty("keepWhitespace")&&(w.keepWhitespace=w.noTrim,delete w.noTrim),p||(u=Object.keys(w)),u.forEach(function(_){var v;if(!!w.hasOwnProperty(_))switch(v=w[_],_){case"mask":case"limitMessage":case"defaultInput":case"encoding":v=v!=null?v+"":"",v&&_!=="limitMessage"&&(v=v.replace(/[\r\n]/g,"")),c[_]=v;break;case"bufferSize":!isNaN(v=parseInt(v,10))&&typeof v=="number"&&(c[_]=v);break;case"displayOnly":case"keyIn":case"hideEchoBack":case"caseSensitive":case"keepWhitespace":case"history":case"cd":c[_]=!!v;break;case"limit":case"trueValue":case"falseValue":c[_]=ns(v,function(g){var h=typeof g;return h==="string"||h==="number"||h==="function"||g instanceof RegExp}).map(function(g){return typeof g=="string"?g.replace(/[\r\n]/g,""):g});break;case"print":case"phContent":case"preCheck":c[_]=typeof v=="function"?v:void 0;break;case"prompt":case"display":c[_]=v!=null?v:"";break}})),c},{})}function xr(r,u,p){return u.some(function(c){var w=typeof c;return w==="string"?p?r===c:r.toLowerCase()===c.toLowerCase():w==="number"?parseFloat(r)===c:w==="function"?c(r):c instanceof RegExp?c.test(r):!1})}function Vr(r,u){var p=_e.normalize(Ve?(process.env.HOMEDRIVE||"")+(process.env.HOMEPATH||""):process.env.HOME||"").replace(/[\/\\]+$/,"");return r=_e.normalize(r),u?r.replace(/^~(?=\/|\\|$)/,p):r.replace(new RegExp("^"+Tr(p)+"(?=\\/|\\\\|$)",Ve?"i":""),"~")}function Oe(r,u){var p="(?:\\(([\\s\\S]*?)\\))?(\\w+|.-.)(?:\\(([\\s\\S]*?)\\))?",c=new RegExp("(\\$)?(\\$<"+p+">)","g"),w=new RegExp("(\\$)?(\\$\\{"+p+"\\})","g");function _(v,g,h,x,T,b){var C;return g||typeof(C=u(T))!="string"?h:C?(x||"")+C+(b||""):""}return r.replace(c,_).replace(w,_)}function Hr(r,u,p){var c,w=[],_=-1,v=0,g="",h;function x(T,b){return b.length>3?(T.push(b[0]+"..."+b[b.length-1]),h=!0):b.length&&(T=T.concat(b)),T}return c=r.reduce(function(T,b){return T.concat((b+"").split(""))},[]).reduce(function(T,b){var C,N;return u||(b=b.toLowerCase()),C=/^\d$/.test(b)?1:/^[A-Z]$/.test(b)?2:/^[a-z]$/.test(b)?3:0,p&&C===0?g+=b:(N=b.charCodeAt(0),C&&C===_&&N===v+1?w.push(b):(T=x(T,w),w=[b],_=C),v=N),T},[]),c=x(c,w),g&&(c.push(g),h=!0),{values:c,suppressed:h}}function Gr(r,u){return r.join(r.length>2?", ":u?" / ":"/")}function Yr(r,u){var p,c,w={},_;if(u.phContent&&(p=u.phContent(r,u)),typeof p!="string")switch(r){case"hideEchoBack":case"mask":case"defaultInput":case"caseSensitive":case"keepWhitespace":case"encoding":case"bufferSize":case"history":case"cd":p=u.hasOwnProperty(r)?typeof u[r]=="boolean"?u[r]?"on":"off":u[r]+"":"";break;case"limit":case"trueValue":case"falseValue":c=u[u.hasOwnProperty(r+"Src")?r+"Src":r],u.keyIn?(w=Hr(c,u.caseSensitive),c=w.values):c=c.filter(function(v){var g=typeof v;return g==="string"||g==="number"}),p=Gr(c,w.suppressed);break;case"limitCount":case"limitCountNotZero":p=u[u.hasOwnProperty("limitSrc")?"limitSrc":"limit"].length,p=p||r!=="limitCountNotZero"?p+"":"";break;case"lastInput":p=hr;break;case"cwd":case"CWD":case"cwdHome":p=process.cwd(),r==="CWD"?p=_e.basename(p):r==="cwdHome"&&(p=Vr(p));break;case"date":case"time":case"localeDate":case"localeTime":p=new Date()["to"+r.replace(/^./,function(v){return v.toUpperCase()})+"String"]();break;default:typeof(_=(r.match(/^history_m(\d+)$/)||[])[1])=="string"&&(p=Se[Se.length-_]||"")}return p}function Ur(r){var u=/^(.)-(.)$/.exec(r),p="",c,w,_,v;if(!u)return null;for(c=u[1].charCodeAt(0),w=u[2].charCodeAt(0),v=c +And the length must be: $`,trueValue:null,falseValue:null,caseSensitive:!0},u,{history:!1,cd:!1,phContent:function(N){return N==="charlist"?p.text:N==="length"?c+"..."+w:null}}),v,g,h,x,T,b,C;for(u=u||{},v=Oe(u.charlist?u.charlist+"":"$",Ur),(isNaN(c=parseInt(u.min,10))||typeof c!="number")&&(c=12),(isNaN(w=parseInt(u.max,10))||typeof w!="number")&&(w=24),x=new RegExp("^["+Tr(v)+"]{"+c+","+w+"}$"),p=Hr([v],_.caseSensitive,!0),p.text=Gr(p.values,p.suppressed),g=u.confirmMessage!=null?u.confirmMessage:"Reinput a same one to confirm it: ",h=u.unmatchMessage!=null?u.unmatchMessage:"It differs from first one. Hit only the Enter key if you want to retry from first one.",r==null&&(r="Input new password: "),T=_.limitMessage;!C;)_.limit=x,_.limitMessage=T,b=M.question(r,_),_.limit=[b,""],_.limitMessage=h,C=M.question(g,_);return b};function Jr(r,u,p){var c;function w(_){return c=p(_),!isNaN(c)&&typeof c=="number"}return M.question(r,Z({limitMessage:"Input valid number, please."},u,{limit:w,cd:!1})),c}M.questionInt=function(r,u){return Jr(r,u,function(p){return parseInt(p,10)})};M.questionFloat=function(r,u){return Jr(r,u,parseFloat)};M.questionPath=function(r,u){var p,c="",w=Z({hideEchoBack:!1,limitMessage:`$Input valid path, please.$<( Min:)min>$<( Max:)max>`,history:!0,cd:!0},u,{keepWhitespace:!1,limit:function(_){var v,g,h;_=Vr(_,!0),c="";function x(T){T.split(/\/|\\/).reduce(function(b,C){var N=_e.resolve(b+=C+_e.sep);if(!z.existsSync(N))z.mkdirSync(N);else if(!z.statSync(N).isDirectory())throw new Error("Non directory already exists: "+N);return b},"")}try{if(v=z.existsSync(_),p=v?z.realpathSync(_):_e.resolve(_),!u.hasOwnProperty("exists")&&!v||typeof u.exists=="boolean"&&u.exists!==v)return c=(v?"Already exists":"No such file or directory")+": "+p,!1;if(!v&&u.create&&(u.isDirectory?x(p):(x(_e.dirname(p)),z.closeSync(z.openSync(p,"w"))),p=z.realpathSync(p)),v&&(u.min||u.max||u.isFile||u.isDirectory)){if(g=z.statSync(p),u.isFile&&!g.isFile())return c="Not file: "+p,!1;if(u.isDirectory&&!g.isDirectory())return c="Not directory: "+p,!1;if(u.min&&g.size<+u.min||u.max&&g.size>+u.max)return c="Size "+g.size+" is out of range: "+p,!1}if(typeof u.validate=="function"&&(h=u.validate(p))!==!0)return typeof h=="string"&&(c=h),!1}catch(T){return c=T+"",!1}return!0},phContent:function(_){return _==="error"?c:_!=="min"&&_!=="max"?null:u.hasOwnProperty(_)?u[_]+"":""}});return u=u||{},r==null&&(r='Input path (you can "cd" and "pwd"): '),M.question(r,w),p};function Kr(r,u){var p={},c={};return typeof r=="object"?(Object.keys(r).forEach(function(w){typeof r[w]=="function"&&(c[u.caseSensitive?w:w.toLowerCase()]=r[w])}),p.preCheck=function(w){var _;return p.args=Sr(w),_=p.args[0]||"",u.caseSensitive||(_=_.toLowerCase()),p.hRes=_!=="_"&&c.hasOwnProperty(_)?c[_].apply(w,p.args.slice(1)):c.hasOwnProperty("_")?c._.apply(w,p.args):null,{res:w,forceNext:!1}},c.hasOwnProperty("_")||(p.limit=function(){var w=p.args[0]||"";return u.caseSensitive||(w=w.toLowerCase()),c.hasOwnProperty(w)})):p.preCheck=function(w){return p.args=Sr(w),p.hRes=typeof r=="function"?r.apply(w,p.args):!0,{res:w,forceNext:!1}},p}M.promptCL=function(r,u){var p=Z({hideEchoBack:!1,limitMessage:"Requested command is not available.",caseSensitive:!1,history:!0},u),c=Kr(r,p);return p.limit=c.limit,p.preCheck=c.preCheck,M.prompt(p),c.args};M.promptLoop=function(r,u){for(var p=Z({hideEchoBack:!1,trueValue:null,falseValue:null,caseSensitive:!1,history:!0},u);!r(M.prompt(p)););};M.promptCLLoop=function(r,u){var p=Z({hideEchoBack:!1,limitMessage:"Requested command is not available.",caseSensitive:!1,history:!0},u),c=Kr(r,p);for(p.limit=c.limit,p.preCheck=c.preCheck;M.prompt(p),!c.hRes;);};M.promptSimShell=function(r){return M.prompt(Z({hideEchoBack:!1,history:!0},r,{prompt:function(){return Ve?"$>":(process.env.USER||"")+(process.env.HOSTNAME?"@"+process.env.HOSTNAME.replace(/\..*$/,""):"")+":$$ "}()}))};function jr(r,u,p){var c;return r==null&&(r="Are you sure? "),(!u||u.guide!==!1)&&(r+="")&&(r=r.replace(/\s*:?\s*$/,"")+" [y/n]: "),c=M.keyIn(r,Z(u,{hideEchoBack:!1,limit:p,trueValue:"y",falseValue:"n",caseSensitive:!1})),typeof c=="boolean"?c:""}M.keyInYN=function(r,u){return jr(r,u)};M.keyInYNStrict=function(r,u){return jr(r,u,"yn")};M.keyInPause=function(r,u){r==null&&(r="Continue..."),(!u||u.guide!==!1)&&(r+="")&&(r=r.replace(/\s+$/,"")+" (Hit any key)"),M.keyIn(r,Z({limit:null},u,{hideEchoBack:!0,mask:""}))};M.keyInSelect=function(r,u,p){var c=Z({hideEchoBack:!1},p,{trueValue:null,falseValue:null,caseSensitive:!1,phContent:function(h){return h==="itemsCount"?r.length+"":h==="firstItem"?(r[0]+"").trim():h==="lastItem"?(r[r.length-1]+"").trim():null}}),w="",_={},v=49,g=` +`;if(!Array.isArray(r)||!r.length||r.length>35)throw"`items` must be Array (max length: 35).";return r.forEach(function(h,x){var T=String.fromCharCode(v);w+=T,_[T]=x,g+="["+T+"] "+(h+"").trim()+` +`,v=v===57?97:v+1}),(!p||p.cancel!==!1)&&(w+="0",_["0"]=-1,g+="[0] "+(p&&p.cancel!=null&&typeof p.cancel!="boolean"?(p.cancel+"").trim():"CANCEL")+` +`),c.limit=w,g+=` +`,u==null&&(u="Choose one from list: "),(u+="")&&((!p||p.guide!==!1)&&(u=u.replace(/\s*:?\s*$/,"")+" [$]: "),g+=u),_[M.keyIn(g,c).toLowerCase()]};M.getRawInput=function(){return je};function De(r,u){var p;return u.length&&(p={},p[r]=u[0]),M.setDefaultOptions(p)[r]}M.setPrint=function(){return De("print",arguments)};M.setPrompt=function(){return De("prompt",arguments)};M.setEncoding=function(){return De("encoding",arguments)};M.setMask=function(){return De("mask",arguments)};M.setBufferSize=function(){return De("bufferSize",arguments)}});var kr=I((Mu,ie)=>{(function(){var r={major:0,minor:2,patch:66,status:"beta"};tau_file_system={files:{},open:function(e,n,t){var s=tau_file_system.files[e];if(!s){if(t==="read")return null;s={path:e,text:"",type:n,get:function(a,l){return l===this.text.length||l>this.text.length?"end_of_file":this.text.substring(l,l+a)},put:function(a,l){return l==="end_of_file"?(this.text+=a,!0):l==="past_end_of_file"?null:(this.text=this.text.substring(0,l)+a+this.text.substring(l+a.length),!0)},get_byte:function(a){if(a==="end_of_stream")return-1;var l=Math.floor(a/2);if(this.text.length<=l)return-1;var f=_(this.text[Math.floor(a/2)],0);return a%2==0?f&255:f/256>>>0},put_byte:function(a,l){var f=l==="end_of_stream"?this.text.length:Math.floor(l/2);if(this.text.length>>0,y=(y&255)<<8|a&255):(y=y&255,y=(a&255)<<8|y&255),this.text.length===f?this.text+=v(y):this.text=this.text.substring(0,f)+v(y)+this.text.substring(f+1),!0},flush:function(){return!0},close:function(){var a=tau_file_system.files[this.path];return a?!0:null}},tau_file_system.files[e]=s}return t==="write"&&(s.text=""),s}},tau_user_input={buffer:"",get:function(e,n){for(var t;tau_user_input.buffer.length\?\@\^\~\\]+|'(?:[^']*?(?:\\(?:x?\d+)?\\)*(?:'')*(?:\\')*)*')/,number:/^(?:0o[0-7]+|0x[0-9a-fA-F]+|0b[01]+|0'(?:''|\\[abfnrtv\\'"`]|\\x?\d+\\|[^\\])|\d+(?:\.\d+(?:[eE][+-]?\d+)?)?)/,string:/^(?:"([^"]|""|\\")*"|`([^`]|``|\\`)*`)/,l_brace:/^(?:\[)/,r_brace:/^(?:\])/,l_bracket:/^(?:\{)/,r_bracket:/^(?:\})/,bar:/^(?:\|)/,l_paren:/^(?:\()/,r_paren:/^(?:\))/};function te(e,n){return e.get_flag("char_conversion").id==="on"?n.replace(/./g,function(t){return e.get_char_conversion(t)}):n}function j(e){this.thread=e,this.text="",this.tokens=[]}j.prototype.set_last_tokens=function(e){return this.tokens=e},j.prototype.new_text=function(e){this.text=e,this.tokens=[]},j.prototype.get_tokens=function(e){var n,t=0,s=0,a=0,l=[],f=!1;if(e){var y=this.tokens[e-1];t=y.len,n=te(this.thread,this.text.substr(y.len)),s=y.line,a=y.start}else n=this.text;if(/^\s*$/.test(n))return null;for(;n!=="";){var d=[],m=!1;if(/^\n/.exec(n)!==null){s++,a=0,t++,n=n.replace(/\n/,""),f=!0;continue}for(var S in ee)if(ee.hasOwnProperty(S)){var P=ee[S].exec(n);P&&d.push({value:P[0],name:S,matches:P})}if(!d.length)return this.set_last_tokens([{value:n,matches:[],name:"lexical",line:s,start:a}]);var y=p(d,function(B,q){return B.value.length>=q.value.length?B:q});switch(y.start=a,y.line=s,n=n.replace(y.value,""),a+=y.value.length,t+=y.value.length,y.name){case"atom":y.raw=y.value,y.value.charAt(0)==="'"&&(y.value=C(y.value.substr(1,y.value.length-2),"'"),y.value===null&&(y.name="lexical",y.value="unknown escape sequence"));break;case"number":y.float=y.value.substring(0,2)!=="0x"&&y.value.match(/[.eE]/)!==null&&y.value!=="0'.",y.value=W(y.value),y.blank=m;break;case"string":var A=y.value.charAt(0);y.value=C(y.value.substr(1,y.value.length-2),A),y.value===null&&(y.name="lexical",y.value="unknown escape sequence");break;case"whitespace":var R=l[l.length-1];R&&(R.space=!0),m=!0;continue;case"r_bracket":l.length>0&&l[l.length-1].name==="l_bracket"&&(y=l.pop(),y.name="atom",y.value="{}",y.raw="{}",y.space=!1);break;case"r_brace":l.length>0&&l[l.length-1].name==="l_brace"&&(y=l.pop(),y.name="atom",y.value="[]",y.raw="[]",y.space=!1);break}y.len=t,l.push(y),m=!1}var k=this.set_last_tokens(l);return k.length===0?null:k};function U(e,n,t,s,a){if(!n[t])return{type:g,value:i.error.syntax(n[t-1],"expression expected",!0)};var l;if(s==="0"){var f=n[t];switch(f.name){case"number":return{type:h,len:t+1,value:new i.type.Num(f.value,f.float)};case"variable":return{type:h,len:t+1,value:new i.type.Var(f.value)};case"string":var y;switch(e.get_flag("double_quotes").id){case"atom":y=new o(f.value,[]);break;case"codes":y=new o("[]",[]);for(var d=f.value.length-1;d>=0;d--)y=new o(".",[new i.type.Num(_(f.value,d),!1),y]);break;case"chars":y=new o("[]",[]);for(var d=f.value.length-1;d>=0;d--)y=new o(".",[new i.type.Term(f.value.charAt(d),[]),y]);break}return{type:h,len:t+1,value:y};case"l_paren":var k=U(e,n,t+1,e.__get_max_priority(),!0);return k.type!==h?k:n[k.len]&&n[k.len].name==="r_paren"?(k.len++,k):{type:g,derived:!0,value:i.error.syntax(n[k.len]?n[k.len]:n[k.len-1],") or operator expected",!n[k.len])};case"l_bracket":var k=U(e,n,t+1,e.__get_max_priority(),!0);return k.type!==h?k:n[k.len]&&n[k.len].name==="r_bracket"?(k.len++,k.value=new o("{}",[k.value]),k):{type:g,derived:!0,value:i.error.syntax(n[k.len]?n[k.len]:n[k.len-1],"} or operator expected",!n[k.len])}}var m=Ue(e,n,t,a);return m.type===h||m.derived||(m=Ze(e,n,t),m.type===h||m.derived)?m:{type:g,derived:!1,value:i.error.syntax(n[t],"unexpected token")}}var S=e.__get_max_priority(),P=e.__get_next_priority(s),A=t;if(n[t].name==="atom"&&n[t+1]&&(n[t].space||n[t+1].name!=="l_paren")){var f=n[t++],R=e.__lookup_operator_classes(s,f.value);if(R&&R.indexOf("fy")>-1){var k=U(e,n,t,s,a);if(k.type!==g)return f.value==="-"&&!f.space&&i.type.is_number(k.value)?{value:new i.type.Num(-k.value.value,k.value.is_float),len:k.len,type:h}:{value:new i.type.Term(f.value,[k.value]),len:k.len,type:h};l=k}else if(R&&R.indexOf("fx")>-1){var k=U(e,n,t,P,a);if(k.type!==g)return{value:new i.type.Term(f.value,[k.value]),len:k.len,type:h};l=k}}t=A;var k=U(e,n,t,P,a);if(k.type===h){t=k.len;var f=n[t];if(n[t]&&(n[t].name==="atom"&&e.__lookup_operator_classes(s,f.value)||n[t].name==="bar"&&e.__lookup_operator_classes(s,"|"))){var L=P,B=s,R=e.__lookup_operator_classes(s,f.value);if(R.indexOf("xf")>-1)return{value:new i.type.Term(f.value,[k.value]),len:++k.len,type:h};if(R.indexOf("xfx")>-1){var q=U(e,n,t+1,L,a);return q.type===h?{value:new i.type.Term(f.value,[k.value,q.value]),len:q.len,type:h}:(q.derived=!0,q)}else if(R.indexOf("xfy")>-1){var q=U(e,n,t+1,B,a);return q.type===h?{value:new i.type.Term(f.value,[k.value,q.value]),len:q.len,type:h}:(q.derived=!0,q)}else if(k.type!==g)for(;;){t=k.len;var f=n[t];if(f&&f.name==="atom"&&e.__lookup_operator_classes(s,f.value)){var R=e.__lookup_operator_classes(s,f.value);if(R.indexOf("yf")>-1)k={value:new i.type.Term(f.value,[k.value]),len:++t,type:h};else if(R.indexOf("yfx")>-1){var q=U(e,n,++t,L,a);if(q.type===g)return q.derived=!0,q;t=q.len,k={value:new i.type.Term(f.value,[k.value,q.value]),len:t,type:h}}else break}else break}}else l={type:g,value:i.error.syntax(n[k.len-1],"operator expected")};return k}return k}function Ue(e,n,t,s){if(!n[t]||n[t].name==="atom"&&n[t].raw==="."&&!s&&(n[t].space||!n[t+1]||n[t+1].name!=="l_paren"))return{type:g,derived:!1,value:i.error.syntax(n[t-1],"unfounded token")};var a=n[t],l=[];if(n[t].name==="atom"&&n[t].raw!==","){if(t++,n[t-1].space)return{type:h,len:t,value:new i.type.Term(a.value,l)};if(n[t]&&n[t].name==="l_paren"){if(n[t+1]&&n[t+1].name==="r_paren")return{type:g,derived:!0,value:i.error.syntax(n[t+1],"argument expected")};var f=U(e,n,++t,"999",!0);if(f.type===g)return f.derived?f:{type:g,derived:!0,value:i.error.syntax(n[t]?n[t]:n[t-1],"argument expected",!n[t])};for(l.push(f.value),t=f.len;n[t]&&n[t].name==="atom"&&n[t].value===",";){if(f=U(e,n,t+1,"999",!0),f.type===g)return f.derived?f:{type:g,derived:!0,value:i.error.syntax(n[t+1]?n[t+1]:n[t],"argument expected",!n[t+1])};l.push(f.value),t=f.len}if(n[t]&&n[t].name==="r_paren")t++;else return{type:g,derived:!0,value:i.error.syntax(n[t]?n[t]:n[t-1],", or ) expected",!n[t])}}return{type:h,len:t,value:new i.type.Term(a.value,l)}}return{type:g,derived:!1,value:i.error.syntax(n[t],"term expected")}}function Ze(e,n,t){if(!n[t])return{type:g,derived:!1,value:i.error.syntax(n[t-1],"[ expected")};if(n[t]&&n[t].name==="l_brace"){var s=U(e,n,++t,"999",!0),a=[s.value],l=void 0;if(s.type===g)return n[t]&&n[t].name==="r_brace"?{type:h,len:t+1,value:new i.type.Term("[]",[])}:{type:g,derived:!0,value:i.error.syntax(n[t],"] expected")};for(t=s.len;n[t]&&n[t].name==="atom"&&n[t].value===",";){if(s=U(e,n,t+1,"999",!0),s.type===g)return s.derived?s:{type:g,derived:!0,value:i.error.syntax(n[t+1]?n[t+1]:n[t],"argument expected",!n[t+1])};a.push(s.value),t=s.len}var f=!1;if(n[t]&&n[t].name==="bar"){if(f=!0,s=U(e,n,t+1,"999",!0),s.type===g)return s.derived?s:{type:g,derived:!0,value:i.error.syntax(n[t+1]?n[t+1]:n[t],"argument expected",!n[t+1])};l=s.value,t=s.len}return n[t]&&n[t].name==="r_brace"?{type:h,len:t+1,value:he(a,l)}:{type:g,derived:!0,value:i.error.syntax(n[t]?n[t]:n[t-1],f?"] expected":", or | or ] expected",!n[t])}}return{type:g,derived:!1,value:i.error.syntax(n[t],"list expected")}}function Qe(e,n,t){var s=n[t].line,a=U(e,n,t,e.__get_max_priority(),!1),l=null,f;if(a.type!==g)if(t=a.len,n[t]&&n[t].name==="atom"&&n[t].raw===".")if(t++,i.type.is_term(a.value)){if(a.value.indicator===":-/2"?(l=new i.type.Rule(a.value.args[0],ve(a.value.args[1])),f={value:l,len:t,type:h}):a.value.indicator==="-->/2"?(l=Bi(new i.type.Rule(a.value.args[0],a.value.args[1]),e),l.body=ve(l.body),f={value:l,len:t,type:i.type.is_rule(l)?h:g}):(l=new i.type.Rule(a.value,null),f={value:l,len:t,type:h}),l){var y=l.singleton_variables();y.length>0&&e.throw_warning(i.warning.singleton(y,l.head.indicator,s))}return f}else return{type:g,value:i.error.syntax(n[t],"callable expected")};else return{type:g,value:i.error.syntax(n[t]?n[t]:n[t-1],". or operator expected")};return a}function Di(e,n,t){t=t||{},t.from=t.from?t.from:"$tau-js",t.reconsult=t.reconsult!==void 0?t.reconsult:!0;var s=new j(e),a={},l;s.new_text(n);var f=0,y=s.get_tokens(f);do{if(y===null||!y[f])break;var d=Qe(e,y,f);if(d.type===g)return new o("throw",[d.value]);if(d.value.body===null&&d.value.head.indicator==="?-/1"){var m=new X(e.session);m.add_goal(d.value.head.args[0]),m.answer(function(P){i.type.is_error(P)?e.throw_warning(P.args[0]):(P===!1||P===null)&&e.throw_warning(i.warning.failed_goal(d.value.head.args[0],d.len))}),f=d.len;var S=!0}else if(d.value.body===null&&d.value.head.indicator===":-/1"){var S=e.run_directive(d.value.head.args[0]);f=d.len,d.value.head.args[0].indicator==="char_conversion/2"&&(y=s.get_tokens(f),f=0)}else{l=d.value.head.indicator,t.reconsult!==!1&&a[l]!==!0&&!e.is_multifile_predicate(l)&&(e.session.rules[l]=w(e.session.rules[l]||[],function(A){return A.dynamic}),a[l]=!0);var S=e.add_rule(d.value,t);f=d.len}if(!S)return S}while(!0);return!0}function Xi(e,n){var t=new j(e);t.new_text(n);var s=0;do{var a=t.get_tokens(s);if(a===null)break;var l=U(e,a,0,e.__get_max_priority(),!1);if(l.type!==g){var f=l.len,y=f;if(a[f]&&a[f].name==="atom"&&a[f].raw===".")e.add_goal(ve(l.value));else{var d=a[f];return new o("throw",[i.error.syntax(d||a[f-1],". or operator expected",!d)])}s=l.len+1}else return new o("throw",[l.value])}while(!0);return!0}function Bi(e,n){e=e.rename(n);var t=n.next_free_variable(),s=pr(e.body,t,n);return s.error?s.value:(e.body=s.value,e.head.args=e.head.args.concat([t,s.variable]),e.head=new o(e.head.id,e.head.args),e)}function pr(e,n,t){var s;if(i.type.is_term(e)&&e.indicator==="!/0")return{value:e,variable:n,error:!1};if(i.type.is_term(e)&&e.indicator===",/2"){var a=pr(e.args[0],n,t);if(a.error)return a;var l=pr(e.args[1],a.variable,t);return l.error?l:{value:new o(",",[a.value,l.value]),variable:l.variable,error:!1}}else{if(i.type.is_term(e)&&e.indicator==="{}/1")return{value:e.args[0],variable:n,error:!1};if(i.type.is_empty_list(e))return{value:new o("true",[]),variable:n,error:!1};if(i.type.is_list(e)){s=t.next_free_variable();for(var f=e,y;f.indicator==="./2";)y=f,f=f.args[1];return i.type.is_variable(f)?{value:i.error.instantiation("DCG"),variable:n,error:!0}:i.type.is_empty_list(f)?(y.args[1]=s,{value:new o("=",[n,e]),variable:s,error:!1}):{value:i.error.type("list",e,"DCG"),variable:n,error:!0}}else return i.type.is_callable(e)?(s=t.next_free_variable(),e.args=e.args.concat([n,s]),e=new o(e.id,e.args),{value:e,variable:s,error:!1}):{value:i.error.type("callable",e,"DCG"),variable:n,error:!0}}}function ve(e){return i.type.is_variable(e)?new o("call",[e]):i.type.is_term(e)&&[",/2",";/2","->/2"].indexOf(e.indicator)!==-1?new o(e.id,[ve(e.args[0]),ve(e.args[1])]):e}function he(e,n){for(var t=n||new i.type.Term("[]",[]),s=e.length-1;s>=0;s--)t=new i.type.Term(".",[e[s],t]);return t}function Fi(e,n){for(var t=e.length-1;t>=0;t--)e[t]===n&&e.splice(t,1)}function yr(e){for(var n={},t=[],s=0;s=0;n--)if(e.charAt(n)==="/")return new o("/",[new o(e.substring(0,n)),new E(parseInt(e.substring(n+1)),!1)])}function O(e){this.id=e}function E(e,n){this.is_float=n!==void 0?n:parseInt(e)!==e,this.value=this.is_float?e:parseInt(e)}var $r=0;function o(e,n,t){this.ref=t||++$r,this.id=e,this.args=n||[],this.indicator=e+"/"+this.args.length}var Wi=0;function ne(e,n,t,s,a,l){this.id=Wi++,this.stream=e,this.mode=n,this.alias=t,this.type=s!==void 0?s:"text",this.reposition=a!==void 0?a:!0,this.eof_action=l!==void 0?l:"eof_code",this.position=this.mode==="append"?"end_of_stream":0,this.output=this.mode==="write"||this.mode==="append",this.input=this.mode==="read"}function Y(e){e=e||{},this.links=e}function V(e,n,t){n=n||new Y,t=t||null,this.goal=e,this.substitution=n,this.parent=t}function Q(e,n,t){this.head=e,this.body=n,this.dynamic=t||!1}function D(e){e=e===void 0||e<=0?1e3:e,this.rules={},this.src_predicates={},this.rename=0,this.modules=[],this.thread=new X(this),this.total_threads=1,this.renamed_variables={},this.public_predicates={},this.multifile_predicates={},this.limit=e,this.streams={user_input:new ne(typeof ie!="undefined"&&ie.exports?nodejs_user_input:tau_user_input,"read","user_input","text",!1,"reset"),user_output:new ne(typeof ie!="undefined"&&ie.exports?nodejs_user_output:tau_user_output,"write","user_output","text",!1,"eof_code")},this.file_system=typeof ie!="undefined"&&ie.exports?nodejs_file_system:tau_file_system,this.standard_input=this.streams.user_input,this.standard_output=this.streams.user_output,this.current_input=this.streams.user_input,this.current_output=this.streams.user_output,this.format_success=function(n){return n.substitution},this.format_error=function(n){return n.goal},this.flag={bounded:i.flag.bounded.value,max_integer:i.flag.max_integer.value,min_integer:i.flag.min_integer.value,integer_rounding_function:i.flag.integer_rounding_function.value,char_conversion:i.flag.char_conversion.value,debug:i.flag.debug.value,max_arity:i.flag.max_arity.value,unknown:i.flag.unknown.value,double_quotes:i.flag.double_quotes.value,occurs_check:i.flag.occurs_check.value,dialect:i.flag.dialect.value,version_data:i.flag.version_data.value,nodejs:i.flag.nodejs.value},this.__loaded_modules=[],this.__char_conversion={},this.__operators={1200:{":-":["fx","xfx"],"-->":["xfx"],"?-":["fx"]},1100:{";":["xfy"]},1050:{"->":["xfy"]},1e3:{",":["xfy"]},900:{"\\+":["fy"]},700:{"=":["xfx"],"\\=":["xfx"],"==":["xfx"],"\\==":["xfx"],"@<":["xfx"],"@=<":["xfx"],"@>":["xfx"],"@>=":["xfx"],"=..":["xfx"],is:["xfx"],"=:=":["xfx"],"=\\=":["xfx"],"<":["xfx"],"=<":["xfx"],">":["xfx"],">=":["xfx"]},600:{":":["xfy"]},500:{"+":["yfx"],"-":["yfx"],"/\\":["yfx"],"\\/":["yfx"]},400:{"*":["yfx"],"/":["yfx"],"//":["yfx"],rem:["yfx"],mod:["yfx"],"<<":["yfx"],">>":["yfx"]},200:{"**":["xfx"],"^":["xfy"],"-":["fy"],"+":["fy"],"\\":["fy"]}}}function X(e){this.epoch=Date.now(),this.session=e,this.session.total_threads++,this.total_steps=0,this.cpu_time=0,this.cpu_time_last=0,this.points=[],this.debugger=!1,this.debugger_states=[],this.level="top_level/0",this.__calls=[],this.current_limit=this.session.limit,this.warnings=[]}function Dr(e,n,t){this.id=e,this.rules=n,this.exports=t,i.module[e]=this}Dr.prototype.exports_predicate=function(e){return this.exports.indexOf(e)!==-1},O.prototype.unify=function(e,n){if(n&&u(e.variables(),this.id)!==-1&&!i.type.is_variable(e))return null;var t={};return t[this.id]=e,new Y(t)},E.prototype.unify=function(e,n){return i.type.is_number(e)&&this.value===e.value&&this.is_float===e.is_float?new Y:null},o.prototype.unify=function(e,n){if(i.type.is_term(e)&&this.indicator===e.indicator){for(var t=new Y,s=0;s=0){var s=this.args[0].value,a=Math.floor(s/26),l=s%26;return"ABCDEFGHIJKLMNOPQRSTUVWXYZ"[l]+(a!==0?a:"")}switch(this.indicator){case"[]/0":case"{}/0":case"!/0":return this.id;case"{}/1":return"{"+this.args[0].toString(e)+"}";case"./2":for(var f="["+this.args[0].toString(e),y=this.args[1];y.indicator==="./2";)f+=", "+y.args[0].toString(e),y=y.args[1];return y.indicator!=="[]/0"&&(f+="|"+y.toString(e)),f+="]",f;case",/2":return"("+this.args[0].toString(e)+", "+this.args[1].toString(e)+")";default:var d=this.id,m=e.session?e.session.lookup_operator(this.id,this.args.length):null;if(e.session===void 0||e.ignore_ops||m===null)return e.quoted&&!/^(!|,|;|[a-z][0-9a-zA-Z_]*)$/.test(d)&&d!=="{}"&&d!=="[]"&&(d="'"+N(d)+"'"),d+(this.args.length?"("+c(this.args,function(R){return R.toString(e)}).join(", ")+")":"");var S=m.priority>n.priority||m.priority===n.priority&&(m.class==="xfy"&&this.indicator!==n.indicator||m.class==="yfx"&&this.indicator!==n.indicator||this.indicator===n.indicator&&m.class==="yfx"&&t==="right"||this.indicator===n.indicator&&m.class==="xfy"&&t==="left");m.indicator=this.indicator;var P=S?"(":"",A=S?")":"";return this.args.length===0?"("+this.id+")":["fy","fx"].indexOf(m.class)!==-1?P+d+" "+this.args[0].toString(e,m)+A:["yf","xf"].indexOf(m.class)!==-1?P+this.args[0].toString(e,m)+" "+d+A:P+this.args[0].toString(e,m,"left")+" "+this.id+" "+this.args[1].toString(e,m,"right")+A}},ne.prototype.toString=function(e){return"("+this.id+")"},Y.prototype.toString=function(e){var n="{";for(var t in this.links)!this.links.hasOwnProperty(t)||(n!=="{"&&(n+=", "),n+=t+"/"+this.links[t].toString(e));return n+="}",n},V.prototype.toString=function(e){return this.goal===null?"<"+this.substitution.toString(e)+">":"<"+this.goal.toString(e)+", "+this.substitution.toString(e)+">"},Q.prototype.toString=function(e){return this.body?this.head.toString(e)+" :- "+this.body.toString(e)+".":this.head.toString(e)+"."},D.prototype.toString=function(e){for(var n="",t=0;t=0;a--)s=new o(".",[n[a],s]);return s}return new o(this.id,c(this.args,function(l){return l.apply(e)}),this.ref)},ne.prototype.apply=function(e){return this},Q.prototype.apply=function(e){return new Q(this.head.apply(e),this.body!==null?this.body.apply(e):null)},Y.prototype.apply=function(e){var n,t={};for(n in this.links)!this.links.hasOwnProperty(n)||(t[n]=this.links[n].apply(e));return new Y(t)},o.prototype.select=function(){for(var e=this;e.indicator===",/2";)e=e.args[0];return e},o.prototype.replace=function(e){return this.indicator===",/2"?this.args[0].indicator===",/2"?new o(",",[this.args[0].replace(e),this.args[1]]):e===null?this.args[1]:new o(",",[e,this.args[1]]):e},o.prototype.search=function(e){if(i.type.is_term(e)&&e.ref!==void 0&&this.ref===e.ref)return!0;for(var n=0;nn&&s0&&(n=this.head_point().substitution.domain());u(n,i.format_variable(this.session.rename))!==-1;)this.session.rename++;if(e.id==="_")return new O(i.format_variable(this.session.rename));this.session.renamed_variables[e.id]=i.format_variable(this.session.rename)}return new O(this.session.renamed_variables[e.id])},D.prototype.next_free_variable=function(){return this.thread.next_free_variable()},X.prototype.next_free_variable=function(){this.session.rename++;var e=[];for(this.points.length>0&&(e=this.head_point().substitution.domain());u(e,i.format_variable(this.session.rename))!==-1;)this.session.rename++;return new O(i.format_variable(this.session.rename))},D.prototype.is_public_predicate=function(e){return!this.public_predicates.hasOwnProperty(e)||this.public_predicates[e]===!0},X.prototype.is_public_predicate=function(e){return this.session.is_public_predicate(e)},D.prototype.is_multifile_predicate=function(e){return this.multifile_predicates.hasOwnProperty(e)&&this.multifile_predicates[e]===!0},X.prototype.is_multifile_predicate=function(e){return this.session.is_multifile_predicate(e)},D.prototype.prepend=function(e){return this.thread.prepend(e)},X.prototype.prepend=function(e){for(var n=e.length-1;n>=0;n--)this.points.push(e[n])},D.prototype.success=function(e,n){return this.thread.success(e,n)},X.prototype.success=function(e,n){var n=typeof n=="undefined"?e:n;this.prepend([new V(e.goal.replace(null),e.substitution,n)])},D.prototype.throw_error=function(e){return this.thread.throw_error(e)},X.prototype.throw_error=function(e){this.prepend([new V(new o("throw",[e]),new Y,null,null)])},D.prototype.step_rule=function(e,n){return this.thread.step_rule(e,n)},X.prototype.step_rule=function(e,n){var t=n.indicator;if(e==="user"&&(e=null),e===null&&this.session.rules.hasOwnProperty(t))return this.session.rules[t];for(var s=e===null?this.session.modules:u(this.session.modules,e)===-1?[]:[e],a=0;a1)&&this.again()},D.prototype.answers=function(e,n,t){return this.thread.answers(e,n,t)},X.prototype.answers=function(e,n,t){var s=n||1e3,a=this;if(n<=0){t&&t();return}this.answer(function(l){e(l),l!==!1?setTimeout(function(){a.answers(e,n-1,t)},1):t&&t()})},D.prototype.again=function(e){return this.thread.again(e)},X.prototype.again=function(e){for(var n,t=Date.now();this.__calls.length>0;){for(this.warnings=[],e!==!1&&(this.current_limit=this.session.limit);this.current_limit>0&&this.points.length>0&&this.head_point().goal!==null&&!i.type.is_error(this.head_point().goal);)if(this.current_limit--,this.step()===!0)return;var s=Date.now();this.cpu_time_last=s-t,this.cpu_time+=this.cpu_time_last;var a=this.__calls.shift();this.current_limit<=0?a(null):this.points.length===0?a(!1):i.type.is_error(this.head_point().goal)?(n=this.session.format_error(this.points.pop()),this.points=[],a(n)):(this.debugger&&this.debugger_states.push(this.head_point()),n=this.session.format_success(this.points.pop()),a(n))}},D.prototype.unfold=function(e){if(e.body===null)return!1;var n=e.head,t=e.body,s=t.select(),a=new X(this),l=[];a.add_goal(s),a.step();for(var f=a.points.length-1;f>=0;f--){var y=a.points[f],d=n.apply(y.substitution),m=t.replace(y.goal);m!==null&&(m=m.apply(y.substitution)),l.push(new Q(d,m))}var S=this.rules[n.indicator],P=u(S,e);return l.length>0&&P!==-1?(S.splice.apply(S,[P,1].concat(l)),!0):!1},X.prototype.unfold=function(e){return this.session.unfold(e)},O.prototype.interpret=function(e){return i.error.instantiation(e.level)},E.prototype.interpret=function(e){return this},o.prototype.interpret=function(e){return i.type.is_unitary_list(this)?this.args[0].interpret(e):i.operate(e,this)},O.prototype.compare=function(e){return this.ide.id?1:0},E.prototype.compare=function(e){if(this.value===e.value&&this.is_float===e.is_float)return 0;if(this.valuee.value)return 1},o.prototype.compare=function(e){if(this.args.lengthe.args.length||this.args.length===e.args.length&&this.id>e.id)return 1;for(var n=0;ns)return 1;if(e.constructor===E){if(e.is_float&&n.is_float)return 0;if(e.is_float)return-1;if(n.is_float)return 1}return 0},is_substitution:function(e){return e instanceof Y},is_state:function(e){return e instanceof V},is_rule:function(e){return e instanceof Q},is_variable:function(e){return e instanceof O},is_stream:function(e){return e instanceof ne},is_anonymous_var:function(e){return e instanceof O&&e.id==="_"},is_callable:function(e){return e instanceof o},is_number:function(e){return e instanceof E},is_integer:function(e){return e instanceof E&&!e.is_float},is_float:function(e){return e instanceof E&&e.is_float},is_term:function(e){return e instanceof o},is_atom:function(e){return e instanceof o&&e.args.length===0},is_ground:function(e){if(e instanceof O)return!1;if(e instanceof o){for(var n=0;n0},is_list:function(e){return e instanceof o&&(e.indicator==="[]/0"||e.indicator==="./2")},is_empty_list:function(e){return e instanceof o&&e.indicator==="[]/0"},is_non_empty_list:function(e){return e instanceof o&&e.indicator==="./2"},is_fully_list:function(e){for(;e instanceof o&&e.indicator==="./2";)e=e.args[1];return e instanceof O||e instanceof o&&e.indicator==="[]/0"},is_instantiated_list:function(e){for(;e instanceof o&&e.indicator==="./2";)e=e.args[1];return e instanceof o&&e.indicator==="[]/0"},is_unitary_list:function(e){return e instanceof o&&e.indicator==="./2"&&e.args[1]instanceof o&&e.args[1].indicator==="[]/0"},is_character:function(e){return e instanceof o&&(e.id.length===1||e.id.length>0&&e.id.length<=2&&_(e.id,0)>=65536)},is_character_code:function(e){return e instanceof E&&!e.is_float&&e.value>=0&&e.value<=1114111},is_byte:function(e){return e instanceof E&&!e.is_float&&e.value>=0&&e.value<=255},is_operator:function(e){return e instanceof o&&i.arithmetic.evaluation[e.indicator]},is_directive:function(e){return e instanceof o&&i.directive[e.indicator]!==void 0},is_builtin:function(e){return e instanceof o&&i.predicate[e.indicator]!==void 0},is_error:function(e){return e instanceof o&&e.indicator==="throw/1"},is_predicate_indicator:function(e){return e instanceof o&&e.indicator==="//2"&&e.args[0]instanceof o&&e.args[0].args.length===0&&e.args[1]instanceof E&&e.args[1].is_float===!1},is_flag:function(e){return e instanceof o&&e.args.length===0&&i.flag[e.id]!==void 0},is_value_flag:function(e,n){if(!i.type.is_flag(e))return!1;for(var t in i.flag[e.id].allowed)if(!!i.flag[e.id].allowed.hasOwnProperty(t)&&i.flag[e.id].allowed[t].equals(n))return!0;return!1},is_io_mode:function(e){return i.type.is_atom(e)&&["read","write","append"].indexOf(e.id)!==-1},is_stream_option:function(e){return i.type.is_term(e)&&(e.indicator==="alias/1"&&i.type.is_atom(e.args[0])||e.indicator==="reposition/1"&&i.type.is_atom(e.args[0])&&(e.args[0].id==="true"||e.args[0].id==="false")||e.indicator==="type/1"&&i.type.is_atom(e.args[0])&&(e.args[0].id==="text"||e.args[0].id==="binary")||e.indicator==="eof_action/1"&&i.type.is_atom(e.args[0])&&(e.args[0].id==="error"||e.args[0].id==="eof_code"||e.args[0].id==="reset"))},is_stream_position:function(e){return i.type.is_integer(e)&&e.value>=0||i.type.is_atom(e)&&(e.id==="end_of_stream"||e.id==="past_end_of_stream")},is_stream_property:function(e){return i.type.is_term(e)&&(e.indicator==="input/0"||e.indicator==="output/0"||e.indicator==="alias/1"&&(i.type.is_variable(e.args[0])||i.type.is_atom(e.args[0]))||e.indicator==="file_name/1"&&(i.type.is_variable(e.args[0])||i.type.is_atom(e.args[0]))||e.indicator==="position/1"&&(i.type.is_variable(e.args[0])||i.type.is_stream_position(e.args[0]))||e.indicator==="reposition/1"&&(i.type.is_variable(e.args[0])||i.type.is_atom(e.args[0])&&(e.args[0].id==="true"||e.args[0].id==="false"))||e.indicator==="type/1"&&(i.type.is_variable(e.args[0])||i.type.is_atom(e.args[0])&&(e.args[0].id==="text"||e.args[0].id==="binary"))||e.indicator==="mode/1"&&(i.type.is_variable(e.args[0])||i.type.is_atom(e.args[0])&&(e.args[0].id==="read"||e.args[0].id==="write"||e.args[0].id==="append"))||e.indicator==="eof_action/1"&&(i.type.is_variable(e.args[0])||i.type.is_atom(e.args[0])&&(e.args[0].id==="error"||e.args[0].id==="eof_code"||e.args[0].id==="reset"))||e.indicator==="end_of_stream/1"&&(i.type.is_variable(e.args[0])||i.type.is_atom(e.args[0])&&(e.args[0].id==="at"||e.args[0].id==="past"||e.args[0].id==="not")))},is_streamable:function(e){return e.__proto__.stream!==void 0},is_read_option:function(e){return i.type.is_term(e)&&["variables/1","variable_names/1","singletons/1"].indexOf(e.indicator)!==-1},is_write_option:function(e){return i.type.is_term(e)&&(e.indicator==="quoted/1"&&i.type.is_atom(e.args[0])&&(e.args[0].id==="true"||e.args[0].id==="false")||e.indicator==="ignore_ops/1"&&i.type.is_atom(e.args[0])&&(e.args[0].id==="true"||e.args[0].id==="false")||e.indicator==="numbervars/1"&&i.type.is_atom(e.args[0])&&(e.args[0].id==="true"||e.args[0].id==="false"))},is_close_option:function(e){return i.type.is_term(e)&&e.indicator==="force/1"&&i.type.is_atom(e.args[0])&&(e.args[0].id==="true"||e.args[0].id==="false")},is_modifiable_flag:function(e){return i.type.is_flag(e)&&i.flag[e.id].changeable},is_module:function(e){return e instanceof o&&e.indicator==="library/1"&&e.args[0]instanceof o&&e.args[0].args.length===0&&i.module[e.args[0].id]!==void 0}},arithmetic:{evaluation:{"e/0":{type_args:null,type_result:!0,fn:function(e){return Math.E}},"pi/0":{type_args:null,type_result:!0,fn:function(e){return Math.PI}},"tau/0":{type_args:null,type_result:!0,fn:function(e){return 2*Math.PI}},"epsilon/0":{type_args:null,type_result:!0,fn:function(e){return Number.EPSILON}},"+/1":{type_args:null,type_result:null,fn:function(e,n){return e}},"-/1":{type_args:null,type_result:null,fn:function(e,n){return-e}},"\\/1":{type_args:!1,type_result:!1,fn:function(e,n){return~e}},"abs/1":{type_args:null,type_result:null,fn:function(e,n){return Math.abs(e)}},"sign/1":{type_args:null,type_result:null,fn:function(e,n){return Math.sign(e)}},"float_integer_part/1":{type_args:!0,type_result:!1,fn:function(e,n){return parseInt(e)}},"float_fractional_part/1":{type_args:!0,type_result:!0,fn:function(e,n){return e-parseInt(e)}},"float/1":{type_args:null,type_result:!0,fn:function(e,n){return parseFloat(e)}},"floor/1":{type_args:!0,type_result:!1,fn:function(e,n){return Math.floor(e)}},"truncate/1":{type_args:!0,type_result:!1,fn:function(e,n){return parseInt(e)}},"round/1":{type_args:!0,type_result:!1,fn:function(e,n){return Math.round(e)}},"ceiling/1":{type_args:!0,type_result:!1,fn:function(e,n){return Math.ceil(e)}},"sin/1":{type_args:null,type_result:!0,fn:function(e,n){return Math.sin(e)}},"cos/1":{type_args:null,type_result:!0,fn:function(e,n){return Math.cos(e)}},"tan/1":{type_args:null,type_result:!0,fn:function(e,n){return Math.tan(e)}},"asin/1":{type_args:null,type_result:!0,fn:function(e,n){return Math.asin(e)}},"acos/1":{type_args:null,type_result:!0,fn:function(e,n){return Math.acos(e)}},"atan/1":{type_args:null,type_result:!0,fn:function(e,n){return Math.atan(e)}},"atan2/2":{type_args:null,type_result:!0,fn:function(e,n,t){return Math.atan2(e,n)}},"exp/1":{type_args:null,type_result:!0,fn:function(e,n){return Math.exp(e)}},"sqrt/1":{type_args:null,type_result:!0,fn:function(e,n){return Math.sqrt(e)}},"log/1":{type_args:null,type_result:!0,fn:function(e,n){return e>0?Math.log(e):i.error.evaluation("undefined",n.__call_indicator)}},"+/2":{type_args:null,type_result:null,fn:function(e,n,t){return e+n}},"-/2":{type_args:null,type_result:null,fn:function(e,n,t){return e-n}},"*/2":{type_args:null,type_result:null,fn:function(e,n,t){return e*n}},"//2":{type_args:null,type_result:!0,fn:function(e,n,t){return n?e/n:i.error.evaluation("zero_division",t.__call_indicator)}},"///2":{type_args:!1,type_result:!1,fn:function(e,n,t){return n?parseInt(e/n):i.error.evaluation("zero_division",t.__call_indicator)}},"**/2":{type_args:null,type_result:!0,fn:function(e,n,t){return Math.pow(e,n)}},"^/2":{type_args:null,type_result:null,fn:function(e,n,t){return Math.pow(e,n)}},"<>/2":{type_args:!1,type_result:!1,fn:function(e,n,t){return e>>n}},"/\\/2":{type_args:!1,type_result:!1,fn:function(e,n,t){return e&n}},"\\//2":{type_args:!1,type_result:!1,fn:function(e,n,t){return e|n}},"xor/2":{type_args:!1,type_result:!1,fn:function(e,n,t){return e^n}},"rem/2":{type_args:!1,type_result:!1,fn:function(e,n,t){return n?e%n:i.error.evaluation("zero_division",t.__call_indicator)}},"mod/2":{type_args:!1,type_result:!1,fn:function(e,n,t){return n?e-parseInt(e/n)*n:i.error.evaluation("zero_division",t.__call_indicator)}},"max/2":{type_args:null,type_result:null,fn:function(e,n,t){return Math.max(e,n)}},"min/2":{type_args:null,type_result:null,fn:function(e,n,t){return Math.min(e,n)}}}},directive:{"dynamic/1":function(e,n){var t=n.args[0];if(i.type.is_variable(t))e.throw_error(i.error.instantiation(n.indicator));else if(!i.type.is_compound(t)||t.indicator!=="//2")e.throw_error(i.error.type("predicate_indicator",t,n.indicator));else if(i.type.is_variable(t.args[0])||i.type.is_variable(t.args[1]))e.throw_error(i.error.instantiation(n.indicator));else if(!i.type.is_atom(t.args[0]))e.throw_error(i.error.type("atom",t.args[0],n.indicator));else if(!i.type.is_integer(t.args[1]))e.throw_error(i.error.type("integer",t.args[1],n.indicator));else{var s=n.args[0].args[0].id+"/"+n.args[0].args[1].value;e.session.public_predicates[s]=!0,e.session.rules[s]||(e.session.rules[s]=[])}},"multifile/1":function(e,n){var t=n.args[0];i.type.is_variable(t)?e.throw_error(i.error.instantiation(n.indicator)):!i.type.is_compound(t)||t.indicator!=="//2"?e.throw_error(i.error.type("predicate_indicator",t,n.indicator)):i.type.is_variable(t.args[0])||i.type.is_variable(t.args[1])?e.throw_error(i.error.instantiation(n.indicator)):i.type.is_atom(t.args[0])?i.type.is_integer(t.args[1])?e.session.multifile_predicates[n.args[0].args[0].id+"/"+n.args[0].args[1].value]=!0:e.throw_error(i.error.type("integer",t.args[1],n.indicator)):e.throw_error(i.error.type("atom",t.args[0],n.indicator))},"set_prolog_flag/2":function(e,n){var t=n.args[0],s=n.args[1];i.type.is_variable(t)||i.type.is_variable(s)?e.throw_error(i.error.instantiation(n.indicator)):i.type.is_atom(t)?i.type.is_flag(t)?i.type.is_value_flag(t,s)?i.type.is_modifiable_flag(t)?e.session.flag[t.id]=s:e.throw_error(i.error.permission("modify","flag",t)):e.throw_error(i.error.domain("flag_value",new o("+",[t,s]),n.indicator)):e.throw_error(i.error.domain("prolog_flag",t,n.indicator)):e.throw_error(i.error.type("atom",t,n.indicator))},"use_module/1":function(e,n){var t=n.args[0];if(i.type.is_variable(t))e.throw_error(i.error.instantiation(n.indicator));else if(!i.type.is_term(t))e.throw_error(i.error.type("term",t,n.indicator));else if(i.type.is_module(t)){var s=t.args[0].id;u(e.session.modules,s)===-1&&e.session.modules.push(s)}},"char_conversion/2":function(e,n){var t=n.args[0],s=n.args[1];i.type.is_variable(t)||i.type.is_variable(s)?e.throw_error(i.error.instantiation(n.indicator)):i.type.is_character(t)?i.type.is_character(s)?t.id===s.id?delete e.session.__char_conversion[t.id]:e.session.__char_conversion[t.id]=s.id:e.throw_error(i.error.type("character",s,n.indicator)):e.throw_error(i.error.type("character",t,n.indicator))},"op/3":function(e,n){var t=n.args[0],s=n.args[1],a=n.args[2];if(i.type.is_variable(t)||i.type.is_variable(s)||i.type.is_variable(a))e.throw_error(i.error.instantiation(n.indicator));else if(!i.type.is_integer(t))e.throw_error(i.error.type("integer",t,n.indicator));else if(!i.type.is_atom(s))e.throw_error(i.error.type("atom",s,n.indicator));else if(!i.type.is_atom(a))e.throw_error(i.error.type("atom",a,n.indicator));else if(t.value<0||t.value>1200)e.throw_error(i.error.domain("operator_priority",t,n.indicator));else if(a.id===",")e.throw_error(i.error.permission("modify","operator",a,n.indicator));else if(a.id==="|"&&(t.value<1001||s.id.length!==3))e.throw_error(i.error.permission("modify","operator",a,n.indicator));else if(["fy","fx","yf","xf","xfx","yfx","xfy"].indexOf(s.id)===-1)e.throw_error(i.error.domain("operator_specifier",s,n.indicator));else{var l={prefix:null,infix:null,postfix:null};for(var f in e.session.__operators)if(!!e.session.__operators.hasOwnProperty(f)){var y=e.session.__operators[f][a.id];y&&(u(y,"fx")!==-1&&(l.prefix={priority:f,type:"fx"}),u(y,"fy")!==-1&&(l.prefix={priority:f,type:"fy"}),u(y,"xf")!==-1&&(l.postfix={priority:f,type:"xf"}),u(y,"yf")!==-1&&(l.postfix={priority:f,type:"yf"}),u(y,"xfx")!==-1&&(l.infix={priority:f,type:"xfx"}),u(y,"xfy")!==-1&&(l.infix={priority:f,type:"xfy"}),u(y,"yfx")!==-1&&(l.infix={priority:f,type:"yfx"}))}var d;switch(s.id){case"fy":case"fx":d="prefix";break;case"yf":case"xf":d="postfix";break;default:d="infix";break}if(((l.prefix&&d==="prefix"||l.postfix&&d==="postfix"||l.infix&&d==="infix")&&l[d].type!==s.id||l.infix&&d==="postfix"||l.postfix&&d==="infix")&&t.value!==0)e.throw_error(i.error.permission("create","operator",a,n.indicator));else return l[d]&&(Fi(e.session.__operators[l[d].priority][a.id],s.id),e.session.__operators[l[d].priority][a.id].length===0&&delete e.session.__operators[l[d].priority][a.id]),t.value>0&&(e.session.__operators[t.value]||(e.session.__operators[t.value.toString()]={}),e.session.__operators[t.value][a.id]||(e.session.__operators[t.value][a.id]=[]),e.session.__operators[t.value][a.id].push(s.id)),!0}}},predicate:{"op/3":function(e,n,t){i.directive["op/3"](e,t)&&e.success(n)},"current_op/3":function(e,n,t){var s=t.args[0],a=t.args[1],l=t.args[2],f=[];for(var y in e.session.__operators)for(var d in e.session.__operators[y])for(var m=0;m/2"){var s=e.points,a=e.session.format_success,l=e.session.format_error;e.session.format_success=function(m){return m.substitution},e.session.format_error=function(m){return m.goal},e.points=[new V(t.args[0].args[0],n.substitution,n)];var f=function(m){e.points=s,e.session.format_success=a,e.session.format_error=l,m===!1?e.prepend([new V(n.goal.replace(t.args[1]),n.substitution,n)]):i.type.is_error(m)?e.throw_error(m.args[0]):m===null?(e.prepend([n]),e.__calls.shift()(null)):e.prepend([new V(n.goal.replace(t.args[0].args[1]).apply(m),n.substitution.apply(m),n)])};e.__calls.unshift(f)}else{var y=new V(n.goal.replace(t.args[0]),n.substitution,n),d=new V(n.goal.replace(t.args[1]),n.substitution,n);e.prepend([y,d])}},"!/0":function(e,n,t){var s,a,l=[];for(s=n,a=null;s.parent!==null&&s.parent.goal.search(t);)if(a=s,s=s.parent,s.goal!==null){var f=s.goal.select();if(f&&f.id==="call"&&f.search(t)){s=a;break}}for(var y=e.points.length-1;y>=0;y--){for(var d=e.points[y],m=d.parent;m!==null&&m!==s.parent;)m=m.parent;m===null&&m!==s.parent&&l.push(d)}e.points=l.reverse(),e.success(n)},"\\+/1":function(e,n,t){var s=t.args[0];i.type.is_variable(s)?e.throw_error(i.error.instantiation(e.level)):i.type.is_callable(s)?e.prepend([new V(n.goal.replace(new o(",",[new o(",",[new o("call",[s]),new o("!",[])]),new o("fail",[])])),n.substitution,n),new V(n.goal.replace(null),n.substitution,n)]):e.throw_error(i.error.type("callable",s,e.level))},"->/2":function(e,n,t){var s=n.goal.replace(new o(",",[t.args[0],new o(",",[new o("!"),t.args[1]])]));e.prepend([new V(s,n.substitution,n)])},"fail/0":function(e,n,t){},"false/0":function(e,n,t){},"true/0":function(e,n,t){e.success(n)},"call/1":ye(1),"call/2":ye(2),"call/3":ye(3),"call/4":ye(4),"call/5":ye(5),"call/6":ye(6),"call/7":ye(7),"call/8":ye(8),"once/1":function(e,n,t){var s=t.args[0];e.prepend([new V(n.goal.replace(new o(",",[new o("call",[s]),new o("!",[])])),n.substitution,n)])},"forall/2":function(e,n,t){var s=t.args[0],a=t.args[1];e.prepend([new V(n.goal.replace(new o("\\+",[new o(",",[new o("call",[s]),new o("\\+",[new o("call",[a])])])])),n.substitution,n)])},"repeat/0":function(e,n,t){e.prepend([new V(n.goal.replace(null),n.substitution,n),n])},"throw/1":function(e,n,t){i.type.is_variable(t.args[0])?e.throw_error(i.error.instantiation(e.level)):e.throw_error(t.args[0])},"catch/3":function(e,n,t){var s=e.points;e.points=[],e.prepend([new V(t.args[0],n.substitution,n)]);var a=e.session.format_success,l=e.session.format_error;e.session.format_success=function(y){return y.substitution},e.session.format_error=function(y){return y.goal};var f=function(y){var d=e.points;if(e.points=s,e.session.format_success=a,e.session.format_error=l,i.type.is_error(y)){for(var m=[],S=e.points.length-1;S>=0;S--){for(var R=e.points[S],P=R.parent;P!==null&&P!==n.parent;)P=P.parent;P===null&&P!==n.parent&&m.push(R)}e.points=m;var A=e.get_flag("occurs_check").indicator==="true/0",R=new V,k=i.unify(y.args[0],t.args[1],A);k!==null?(R.substitution=n.substitution.apply(k),R.goal=n.goal.replace(t.args[2]).apply(k),R.parent=n,e.prepend([R])):e.throw_error(y.args[0])}else if(y!==!1){for(var L=y===null?[]:[new V(n.goal.apply(y).replace(null),n.substitution.apply(y),n)],B=[],S=d.length-1;S>=0;S--){B.push(d[S]);var q=d[S].goal!==null?d[S].goal.select():null;if(i.type.is_term(q)&&q.indicator==="!/0")break}var F=c(B,function(H){return H.goal===null&&(H.goal=new o("true",[])),H=new V(n.goal.replace(new o("catch",[H.goal,t.args[1],t.args[2]])),n.substitution.apply(H.substitution),H.parent),H.exclude=t.args[0].variables(),H}).reverse();e.prepend(F),e.prepend(L),y===null&&(this.current_limit=0,e.__calls.shift()(null))}};e.__calls.unshift(f)},"=/2":function(e,n,t){var s=e.get_flag("occurs_check").indicator==="true/0",a=new V,l=i.unify(t.args[0],t.args[1],s);l!==null&&(a.goal=n.goal.apply(l).replace(null),a.substitution=n.substitution.apply(l),a.parent=n,e.prepend([a]))},"unify_with_occurs_check/2":function(e,n,t){var s=new V,a=i.unify(t.args[0],t.args[1],!0);a!==null&&(s.goal=n.goal.apply(a).replace(null),s.substitution=n.substitution.apply(a),s.parent=n,e.prepend([s]))},"\\=/2":function(e,n,t){var s=e.get_flag("occurs_check").indicator==="true/0",a=i.unify(t.args[0],t.args[1],s);a===null&&e.success(n)},"subsumes_term/2":function(e,n,t){var s=e.get_flag("occurs_check").indicator==="true/0",a=i.unify(t.args[1],t.args[0],s);a!==null&&t.args[1].apply(a).equals(t.args[1])&&e.success(n)},"findall/3":function(e,n,t){var s=t.args[0],a=t.args[1],l=t.args[2];if(i.type.is_variable(a))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_callable(a))e.throw_error(i.error.type("callable",a,t.indicator));else if(!i.type.is_variable(l)&&!i.type.is_list(l))e.throw_error(i.error.type("list",l,t.indicator));else{var f=e.next_free_variable(),y=new o(",",[a,new o("=",[f,s])]),d=e.points,m=e.session.limit,S=e.session.format_success;e.session.format_success=function(R){return R.substitution},e.add_goal(y,!0,n);var P=[],A=function(R){if(R!==!1&&R!==null&&!i.type.is_error(R))e.__calls.unshift(A),P.push(R.links[f.id]),e.session.limit=e.current_limit;else if(e.points=d,e.session.limit=m,e.session.format_success=S,i.type.is_error(R))e.throw_error(R.args[0]);else if(e.current_limit>0){for(var k=new o("[]"),L=P.length-1;L>=0;L--)k=new o(".",[P[L],k]);e.prepend([new V(n.goal.replace(new o("=",[l,k])),n.substitution,n)])}};e.__calls.unshift(A)}},"bagof/3":function(e,n,t){var s,a=t.args[0],l=t.args[1],f=t.args[2];if(i.type.is_variable(l))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_callable(l))e.throw_error(i.error.type("callable",l,t.indicator));else if(!i.type.is_variable(f)&&!i.type.is_list(f))e.throw_error(i.error.type("list",f,t.indicator));else{var y=e.next_free_variable(),d;l.indicator==="^/2"?(d=l.args[0].variables(),l=l.args[1]):d=[],d=d.concat(a.variables());for(var m=l.variables().filter(function(F){return u(d,F)===-1}),S=new o("[]"),P=m.length-1;P>=0;P--)S=new o(".",[new O(m[P]),S]);var A=new o(",",[l,new o("=",[y,new o(",",[S,a])])]),R=e.points,k=e.session.limit,L=e.session.format_success;e.session.format_success=function(F){return F.substitution},e.add_goal(A,!0,n);var B=[],q=function(F){if(F!==!1&&F!==null&&!i.type.is_error(F)){e.__calls.unshift(q);var H=!1,J=F.links[y.id].args[0],me=F.links[y.id].args[1];for(var be in B)if(!!B.hasOwnProperty(be)){var Me=B[be];if(Me.variables.equals(J)){Me.answers.push(me),H=!0;break}}H||B.push({variables:J,answers:[me]}),e.session.limit=e.current_limit}else if(e.points=R,e.session.limit=k,e.session.format_success=L,i.type.is_error(F))e.throw_error(F.args[0]);else if(e.current_limit>0){for(var qe=[],ce=0;ce=0;xe--)Te=new o(".",[F[xe],Te]);qe.push(new V(n.goal.replace(new o(",",[new o("=",[S,B[ce].variables]),new o("=",[f,Te])])),n.substitution,n))}e.prepend(qe)}};e.__calls.unshift(q)}},"setof/3":function(e,n,t){var s,a=t.args[0],l=t.args[1],f=t.args[2];if(i.type.is_variable(l))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_callable(l))e.throw_error(i.error.type("callable",l,t.indicator));else if(!i.type.is_variable(f)&&!i.type.is_list(f))e.throw_error(i.error.type("list",f,t.indicator));else{var y=e.next_free_variable(),d;l.indicator==="^/2"?(d=l.args[0].variables(),l=l.args[1]):d=[],d=d.concat(a.variables());for(var m=l.variables().filter(function(F){return u(d,F)===-1}),S=new o("[]"),P=m.length-1;P>=0;P--)S=new o(".",[new O(m[P]),S]);var A=new o(",",[l,new o("=",[y,new o(",",[S,a])])]),R=e.points,k=e.session.limit,L=e.session.format_success;e.session.format_success=function(F){return F.substitution},e.add_goal(A,!0,n);var B=[],q=function(F){if(F!==!1&&F!==null&&!i.type.is_error(F)){e.__calls.unshift(q);var H=!1,J=F.links[y.id].args[0],me=F.links[y.id].args[1];for(var be in B)if(!!B.hasOwnProperty(be)){var Me=B[be];if(Me.variables.equals(J)){Me.answers.push(me),H=!0;break}}H||B.push({variables:J,answers:[me]}),e.session.limit=e.current_limit}else if(e.points=R,e.session.limit=k,e.session.format_success=L,i.type.is_error(F))e.throw_error(F.args[0]);else if(e.current_limit>0){for(var qe=[],ce=0;ce=0;xe--)Te=new o(".",[F[xe],Te]);qe.push(new V(n.goal.replace(new o(",",[new o("=",[S,B[ce].variables]),new o("=",[f,Te])])),n.substitution,n))}e.prepend(qe)}};e.__calls.unshift(q)}},"functor/3":function(e,n,t){var s,a=t.args[0],l=t.args[1],f=t.args[2];if(i.type.is_variable(a)&&(i.type.is_variable(l)||i.type.is_variable(f)))e.throw_error(i.error.instantiation("functor/3"));else if(!i.type.is_variable(f)&&!i.type.is_integer(f))e.throw_error(i.error.type("integer",t.args[2],"functor/3"));else if(!i.type.is_variable(l)&&!i.type.is_atomic(l))e.throw_error(i.error.type("atomic",t.args[1],"functor/3"));else if(i.type.is_integer(l)&&i.type.is_integer(f)&&f.value!==0)e.throw_error(i.error.type("atom",t.args[1],"functor/3"));else if(i.type.is_variable(a)){if(t.args[2].value>=0){for(var y=[],d=0;d0&&s<=t.args[1].args.length){var a=new o("=",[t.args[1].args[s-1],t.args[2]]);e.prepend([new V(n.goal.replace(a),n.substitution,n)])}}},"=../2":function(e,n,t){var s;if(i.type.is_variable(t.args[0])&&(i.type.is_variable(t.args[1])||i.type.is_non_empty_list(t.args[1])&&i.type.is_variable(t.args[1].args[0])))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_fully_list(t.args[1]))e.throw_error(i.error.type("list",t.args[1],t.indicator));else if(i.type.is_variable(t.args[0])){if(!i.type.is_variable(t.args[1])){var l=[];for(s=t.args[1].args[1];s.indicator==="./2";)l.push(s.args[0]),s=s.args[1];i.type.is_variable(t.args[0])&&i.type.is_variable(s)?e.throw_error(i.error.instantiation(t.indicator)):l.length===0&&i.type.is_compound(t.args[1].args[0])?e.throw_error(i.error.type("atomic",t.args[1].args[0],t.indicator)):l.length>0&&(i.type.is_compound(t.args[1].args[0])||i.type.is_number(t.args[1].args[0]))?e.throw_error(i.error.type("atom",t.args[1].args[0],t.indicator)):l.length===0?e.prepend([new V(n.goal.replace(new o("=",[t.args[1].args[0],t.args[0]],n)),n.substitution,n)]):e.prepend([new V(n.goal.replace(new o("=",[new o(t.args[1].args[0].id,l),t.args[0]])),n.substitution,n)])}}else{if(i.type.is_atomic(t.args[0]))s=new o(".",[t.args[0],new o("[]")]);else{s=new o("[]");for(var a=t.args[0].args.length-1;a>=0;a--)s=new o(".",[t.args[0].args[a],s]);s=new o(".",[new o(t.args[0].id),s])}e.prepend([new V(n.goal.replace(new o("=",[s,t.args[1]])),n.substitution,n)])}},"copy_term/2":function(e,n,t){var s=t.args[0].rename(e);e.prepend([new V(n.goal.replace(new o("=",[s,t.args[1]])),n.substitution,n.parent)])},"term_variables/2":function(e,n,t){var s=t.args[0],a=t.args[1];if(!i.type.is_fully_list(a))e.throw_error(i.error.type("list",a,t.indicator));else{var l=he(c(yr(s.variables()),function(f){return new O(f)}));e.prepend([new V(n.goal.replace(new o("=",[a,l])),n.substitution,n)])}},"clause/2":function(e,n,t){if(i.type.is_variable(t.args[0]))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_callable(t.args[0]))e.throw_error(i.error.type("callable",t.args[0],t.indicator));else if(!i.type.is_variable(t.args[1])&&!i.type.is_callable(t.args[1]))e.throw_error(i.error.type("callable",t.args[1],t.indicator));else if(e.session.rules[t.args[0].indicator]!==void 0)if(e.is_public_predicate(t.args[0].indicator)){var s=[];for(var a in e.session.rules[t.args[0].indicator])if(!!e.session.rules[t.args[0].indicator].hasOwnProperty(a)){var l=e.session.rules[t.args[0].indicator][a];e.session.renamed_variables={},l=l.rename(e),l.body===null&&(l.body=new o("true"));var f=new o(",",[new o("=",[l.head,t.args[0]]),new o("=",[l.body,t.args[1]])]);s.push(new V(n.goal.replace(f),n.substitution,n))}e.prepend(s)}else e.throw_error(i.error.permission("access","private_procedure",t.args[0].indicator,t.indicator))},"current_predicate/1":function(e,n,t){var s=t.args[0];if(!i.type.is_variable(s)&&(!i.type.is_compound(s)||s.indicator!=="//2"))e.throw_error(i.error.type("predicate_indicator",s,t.indicator));else if(!i.type.is_variable(s)&&!i.type.is_variable(s.args[0])&&!i.type.is_atom(s.args[0]))e.throw_error(i.error.type("atom",s.args[0],t.indicator));else if(!i.type.is_variable(s)&&!i.type.is_variable(s.args[1])&&!i.type.is_integer(s.args[1]))e.throw_error(i.error.type("integer",s.args[1],t.indicator));else{var a=[];for(var l in e.session.rules)if(!!e.session.rules.hasOwnProperty(l)){var f=l.lastIndexOf("/"),y=l.substr(0,f),d=parseInt(l.substr(f+1,l.length-(f+1))),m=new o("/",[new o(y),new E(d,!1)]),S=new o("=",[m,s]);a.push(new V(n.goal.replace(S),n.substitution,n))}e.prepend(a)}},"asserta/1":function(e,n,t){if(i.type.is_variable(t.args[0]))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_callable(t.args[0]))e.throw_error(i.error.type("callable",t.args[0],t.indicator));else{var s,a;t.args[0].indicator===":-/2"?(s=t.args[0].args[0],a=ve(t.args[0].args[1])):(s=t.args[0],a=null),i.type.is_callable(s)?a!==null&&!i.type.is_callable(a)?e.throw_error(i.error.type("callable",a,t.indicator)):e.is_public_predicate(s.indicator)?(e.session.rules[s.indicator]===void 0&&(e.session.rules[s.indicator]=[]),e.session.public_predicates[s.indicator]=!0,e.session.rules[s.indicator]=[new Q(s,a,!0)].concat(e.session.rules[s.indicator]),e.success(n)):e.throw_error(i.error.permission("modify","static_procedure",s.indicator,t.indicator)):e.throw_error(i.error.type("callable",s,t.indicator))}},"assertz/1":function(e,n,t){if(i.type.is_variable(t.args[0]))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_callable(t.args[0]))e.throw_error(i.error.type("callable",t.args[0],t.indicator));else{var s,a;t.args[0].indicator===":-/2"?(s=t.args[0].args[0],a=ve(t.args[0].args[1])):(s=t.args[0],a=null),i.type.is_callable(s)?a!==null&&!i.type.is_callable(a)?e.throw_error(i.error.type("callable",a,t.indicator)):e.is_public_predicate(s.indicator)?(e.session.rules[s.indicator]===void 0&&(e.session.rules[s.indicator]=[]),e.session.public_predicates[s.indicator]=!0,e.session.rules[s.indicator].push(new Q(s,a,!0)),e.success(n)):e.throw_error(i.error.permission("modify","static_procedure",s.indicator,t.indicator)):e.throw_error(i.error.type("callable",s,t.indicator))}},"retract/1":function(e,n,t){if(i.type.is_variable(t.args[0]))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_callable(t.args[0]))e.throw_error(i.error.type("callable",t.args[0],t.indicator));else{var s,a;if(t.args[0].indicator===":-/2"?(s=t.args[0].args[0],a=t.args[0].args[1]):(s=t.args[0],a=new o("true")),typeof n.retract=="undefined")if(e.is_public_predicate(s.indicator)){if(e.session.rules[s.indicator]!==void 0){for(var l=[],f=0;fe.get_flag("max_arity").value)e.throw_error(i.error.representation("max_arity",t.indicator));else{var s=t.args[0].args[0].id+"/"+t.args[0].args[1].value;e.is_public_predicate(s)?(delete e.session.rules[s],e.success(n)):e.throw_error(i.error.permission("modify","static_procedure",s,t.indicator))}},"atom_length/2":function(e,n,t){if(i.type.is_variable(t.args[0]))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_atom(t.args[0]))e.throw_error(i.error.type("atom",t.args[0],t.indicator));else if(!i.type.is_variable(t.args[1])&&!i.type.is_integer(t.args[1]))e.throw_error(i.error.type("integer",t.args[1],t.indicator));else if(i.type.is_integer(t.args[1])&&t.args[1].value<0)e.throw_error(i.error.domain("not_less_than_zero",t.args[1],t.indicator));else{var s=new E(t.args[0].id.length,!1);e.prepend([new V(n.goal.replace(new o("=",[s,t.args[1]])),n.substitution,n)])}},"atom_concat/3":function(e,n,t){var s,a,l=t.args[0],f=t.args[1],y=t.args[2];if(i.type.is_variable(y)&&(i.type.is_variable(l)||i.type.is_variable(f)))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_variable(l)&&!i.type.is_atom(l))e.throw_error(i.error.type("atom",l,t.indicator));else if(!i.type.is_variable(f)&&!i.type.is_atom(f))e.throw_error(i.error.type("atom",f,t.indicator));else if(!i.type.is_variable(y)&&!i.type.is_atom(y))e.throw_error(i.error.type("atom",y,t.indicator));else{var d=i.type.is_variable(l),m=i.type.is_variable(f);if(!d&&!m)a=new o("=",[y,new o(l.id+f.id)]),e.prepend([new V(n.goal.replace(a),n.substitution,n)]);else if(d&&!m)s=y.id.substr(0,y.id.length-f.id.length),s+f.id===y.id&&(a=new o("=",[l,new o(s)]),e.prepend([new V(n.goal.replace(a),n.substitution,n)]));else if(m&&!d)s=y.id.substr(l.id.length),l.id+s===y.id&&(a=new o("=",[f,new o(s)]),e.prepend([new V(n.goal.replace(a),n.substitution,n)]));else{for(var S=[],P=0;P<=y.id.length;P++){var A=new o(y.id.substr(0,P)),R=new o(y.id.substr(P));a=new o(",",[new o("=",[A,l]),new o("=",[R,f])]),S.push(new V(n.goal.replace(a),n.substitution,n))}e.prepend(S)}}},"sub_atom/5":function(e,n,t){var s,a=t.args[0],l=t.args[1],f=t.args[2],y=t.args[3],d=t.args[4];if(i.type.is_variable(a))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_variable(l)&&!i.type.is_integer(l))e.throw_error(i.error.type("integer",l,t.indicator));else if(!i.type.is_variable(f)&&!i.type.is_integer(f))e.throw_error(i.error.type("integer",f,t.indicator));else if(!i.type.is_variable(y)&&!i.type.is_integer(y))e.throw_error(i.error.type("integer",y,t.indicator));else if(i.type.is_integer(l)&&l.value<0)e.throw_error(i.error.domain("not_less_than_zero",l,t.indicator));else if(i.type.is_integer(f)&&f.value<0)e.throw_error(i.error.domain("not_less_than_zero",f,t.indicator));else if(i.type.is_integer(y)&&y.value<0)e.throw_error(i.error.domain("not_less_than_zero",y,t.indicator));else{var m=[],S=[],P=[];if(i.type.is_variable(l))for(s=0;s<=a.id.length;s++)m.push(s);else m.push(l.value);if(i.type.is_variable(f))for(s=0;s<=a.id.length;s++)S.push(s);else S.push(f.value);if(i.type.is_variable(y))for(s=0;s<=a.id.length;s++)P.push(s);else P.push(y.value);var A=[];for(var R in m)if(!!m.hasOwnProperty(R)){s=m[R];for(var k in S)if(!!S.hasOwnProperty(k)){var L=S[k],B=a.id.length-s-L;if(u(P,B)!==-1&&s+L+B===a.id.length){var q=a.id.substr(s,L);if(a.id===a.id.substr(0,s)+q+a.id.substr(s+L,B)){var F=new o("=",[new o(q),d]),H=new o("=",[l,new E(s)]),J=new o("=",[f,new E(L)]),me=new o("=",[y,new E(B)]),be=new o(",",[new o(",",[new o(",",[H,J]),me]),F]);A.push(new V(n.goal.replace(be),n.substitution,n))}}}}e.prepend(A)}},"atom_chars/2":function(e,n,t){var s=t.args[0],a=t.args[1];if(i.type.is_variable(s)&&i.type.is_variable(a))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_variable(s)&&!i.type.is_atom(s))e.throw_error(i.error.type("atom",s,t.indicator));else if(i.type.is_variable(s)){for(var y=a,d=i.type.is_variable(s),m="";y.indicator==="./2";){if(i.type.is_character(y.args[0]))m+=y.args[0].id;else if(i.type.is_variable(y.args[0])&&d){e.throw_error(i.error.instantiation(t.indicator));return}else if(!i.type.is_variable(y.args[0])){e.throw_error(i.error.type("character",y.args[0],t.indicator));return}y=y.args[1]}i.type.is_variable(y)&&d?e.throw_error(i.error.instantiation(t.indicator)):!i.type.is_empty_list(y)&&!i.type.is_variable(y)?e.throw_error(i.error.type("list",a,t.indicator)):e.prepend([new V(n.goal.replace(new o("=",[new o(m),s])),n.substitution,n)])}else{for(var l=new o("[]"),f=s.id.length-1;f>=0;f--)l=new o(".",[new o(s.id.charAt(f)),l]);e.prepend([new V(n.goal.replace(new o("=",[a,l])),n.substitution,n)])}},"atom_codes/2":function(e,n,t){var s=t.args[0],a=t.args[1];if(i.type.is_variable(s)&&i.type.is_variable(a))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_variable(s)&&!i.type.is_atom(s))e.throw_error(i.error.type("atom",s,t.indicator));else if(i.type.is_variable(s)){for(var y=a,d=i.type.is_variable(s),m="";y.indicator==="./2";){if(i.type.is_character_code(y.args[0]))m+=v(y.args[0].value);else if(i.type.is_variable(y.args[0])&&d){e.throw_error(i.error.instantiation(t.indicator));return}else if(!i.type.is_variable(y.args[0])){e.throw_error(i.error.representation("character_code",t.indicator));return}y=y.args[1]}i.type.is_variable(y)&&d?e.throw_error(i.error.instantiation(t.indicator)):!i.type.is_empty_list(y)&&!i.type.is_variable(y)?e.throw_error(i.error.type("list",a,t.indicator)):e.prepend([new V(n.goal.replace(new o("=",[new o(m),s])),n.substitution,n)])}else{for(var l=new o("[]"),f=s.id.length-1;f>=0;f--)l=new o(".",[new E(_(s.id,f),!1),l]);e.prepend([new V(n.goal.replace(new o("=",[a,l])),n.substitution,n)])}},"char_code/2":function(e,n,t){var s=t.args[0],a=t.args[1];if(i.type.is_variable(s)&&i.type.is_variable(a))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_variable(s)&&!i.type.is_character(s))e.throw_error(i.error.type("character",s,t.indicator));else if(!i.type.is_variable(a)&&!i.type.is_integer(a))e.throw_error(i.error.type("integer",a,t.indicator));else if(!i.type.is_variable(a)&&!i.type.is_character_code(a))e.throw_error(i.error.representation("character_code",t.indicator));else if(i.type.is_variable(a)){var l=new E(_(s.id,0),!1);e.prepend([new V(n.goal.replace(new o("=",[l,a])),n.substitution,n)])}else{var f=new o(v(a.value));e.prepend([new V(n.goal.replace(new o("=",[f,s])),n.substitution,n)])}},"number_chars/2":function(e,n,t){var s,a=t.args[0],l=t.args[1];if(i.type.is_variable(a)&&i.type.is_variable(l))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_variable(a)&&!i.type.is_number(a))e.throw_error(i.error.type("number",a,t.indicator));else if(!i.type.is_variable(l)&&!i.type.is_list(l))e.throw_error(i.error.type("list",l,t.indicator));else{var f=i.type.is_variable(a);if(!i.type.is_variable(l)){var y=l,d=!0;for(s="";y.indicator==="./2";){if(i.type.is_character(y.args[0]))s+=y.args[0].id;else if(i.type.is_variable(y.args[0]))d=!1;else if(!i.type.is_variable(y.args[0])){e.throw_error(i.error.type("character",y.args[0],t.indicator));return}y=y.args[1]}if(d=d&&i.type.is_empty_list(y),!i.type.is_empty_list(y)&&!i.type.is_variable(y)){e.throw_error(i.error.type("list",l,t.indicator));return}if(!d&&f){e.throw_error(i.error.instantiation(t.indicator));return}else if(d)if(i.type.is_variable(y)&&f){e.throw_error(i.error.instantiation(t.indicator));return}else{var m=e.parse(s),S=m.value;!i.type.is_number(S)||m.tokens[m.tokens.length-1].space?e.throw_error(i.error.syntax_by_predicate("parseable_number",t.indicator)):e.prepend([new V(n.goal.replace(new o("=",[a,S])),n.substitution,n)]);return}}if(!f){s=a.toString();for(var P=new o("[]"),A=s.length-1;A>=0;A--)P=new o(".",[new o(s.charAt(A)),P]);e.prepend([new V(n.goal.replace(new o("=",[l,P])),n.substitution,n)])}}},"number_codes/2":function(e,n,t){var s,a=t.args[0],l=t.args[1];if(i.type.is_variable(a)&&i.type.is_variable(l))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_variable(a)&&!i.type.is_number(a))e.throw_error(i.error.type("number",a,t.indicator));else if(!i.type.is_variable(l)&&!i.type.is_list(l))e.throw_error(i.error.type("list",l,t.indicator));else{var f=i.type.is_variable(a);if(!i.type.is_variable(l)){var y=l,d=!0;for(s="";y.indicator==="./2";){if(i.type.is_character_code(y.args[0]))s+=v(y.args[0].value);else if(i.type.is_variable(y.args[0]))d=!1;else if(!i.type.is_variable(y.args[0])){e.throw_error(i.error.type("character_code",y.args[0],t.indicator));return}y=y.args[1]}if(d=d&&i.type.is_empty_list(y),!i.type.is_empty_list(y)&&!i.type.is_variable(y)){e.throw_error(i.error.type("list",l,t.indicator));return}if(!d&&f){e.throw_error(i.error.instantiation(t.indicator));return}else if(d)if(i.type.is_variable(y)&&f){e.throw_error(i.error.instantiation(t.indicator));return}else{var m=e.parse(s),S=m.value;!i.type.is_number(S)||m.tokens[m.tokens.length-1].space?e.throw_error(i.error.syntax_by_predicate("parseable_number",t.indicator)):e.prepend([new V(n.goal.replace(new o("=",[a,S])),n.substitution,n)]);return}}if(!f){s=a.toString();for(var P=new o("[]"),A=s.length-1;A>=0;A--)P=new o(".",[new E(_(s,A),!1),P]);e.prepend([new V(n.goal.replace(new o("=",[l,P])),n.substitution,n)])}}},"upcase_atom/2":function(e,n,t){var s=t.args[0],a=t.args[1];i.type.is_variable(s)?e.throw_error(i.error.instantiation(t.indicator)):i.type.is_atom(s)?!i.type.is_variable(a)&&!i.type.is_atom(a)?e.throw_error(i.error.type("atom",a,t.indicator)):e.prepend([new V(n.goal.replace(new o("=",[a,new o(s.id.toUpperCase(),[])])),n.substitution,n)]):e.throw_error(i.error.type("atom",s,t.indicator))},"downcase_atom/2":function(e,n,t){var s=t.args[0],a=t.args[1];i.type.is_variable(s)?e.throw_error(i.error.instantiation(t.indicator)):i.type.is_atom(s)?!i.type.is_variable(a)&&!i.type.is_atom(a)?e.throw_error(i.error.type("atom",a,t.indicator)):e.prepend([new V(n.goal.replace(new o("=",[a,new o(s.id.toLowerCase(),[])])),n.substitution,n)]):e.throw_error(i.error.type("atom",s,t.indicator))},"atomic_list_concat/2":function(e,n,t){var s=t.args[0],a=t.args[1];e.prepend([new V(n.goal.replace(new o("atomic_list_concat",[s,new o("",[]),a])),n.substitution,n)])},"atomic_list_concat/3":function(e,n,t){var s=t.args[0],a=t.args[1],l=t.args[2];if(i.type.is_variable(a)||i.type.is_variable(s)&&i.type.is_variable(l))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_variable(s)&&!i.type.is_list(s))e.throw_error(i.error.type("list",s,t.indicator));else if(!i.type.is_variable(l)&&!i.type.is_atom(l))e.throw_error(i.error.type("atom",l,t.indicator));else if(i.type.is_variable(l)){for(var y="",d=s;i.type.is_term(d)&&d.indicator==="./2";){if(!i.type.is_atom(d.args[0])&&!i.type.is_number(d.args[0])){e.throw_error(i.error.type("atomic",d.args[0],t.indicator));return}y!==""&&(y+=a.id),i.type.is_atom(d.args[0])?y+=d.args[0].id:y+=""+d.args[0].value,d=d.args[1]}y=new o(y,[]),i.type.is_variable(d)?e.throw_error(i.error.instantiation(t.indicator)):!i.type.is_term(d)||d.indicator!=="[]/0"?e.throw_error(i.error.type("list",s,t.indicator)):e.prepend([new V(n.goal.replace(new o("=",[y,l])),n.substitution,n)])}else{var f=he(c(l.id.split(a.id),function(m){return new o(m,[])}));e.prepend([new V(n.goal.replace(new o("=",[f,s])),n.substitution,n)])}},"@=/2":function(e,n,t){i.compare(t.args[0],t.args[1])>0&&e.success(n)},"@>=/2":function(e,n,t){i.compare(t.args[0],t.args[1])>=0&&e.success(n)},"compare/3":function(e,n,t){var s=t.args[0],a=t.args[1],l=t.args[2];if(!i.type.is_variable(s)&&!i.type.is_atom(s))e.throw_error(i.error.type("atom",s,t.indicator));else if(i.type.is_atom(s)&&["<",">","="].indexOf(s.id)===-1)e.throw_error(i.type.domain("order",s,t.indicator));else{var f=i.compare(a,l);f=f===0?"=":f===-1?"<":">",e.prepend([new V(n.goal.replace(new o("=",[s,new o(f,[])])),n.substitution,n)])}},"is/2":function(e,n,t){var s=t.args[1].interpret(e);i.type.is_number(s)?e.prepend([new V(n.goal.replace(new o("=",[t.args[0],s],e.level)),n.substitution,n)]):e.throw_error(s)},"between/3":function(e,n,t){var s=t.args[0],a=t.args[1],l=t.args[2];if(i.type.is_variable(s)||i.type.is_variable(a))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_integer(s))e.throw_error(i.error.type("integer",s,t.indicator));else if(!i.type.is_integer(a))e.throw_error(i.error.type("integer",a,t.indicator));else if(!i.type.is_variable(l)&&!i.type.is_integer(l))e.throw_error(i.error.type("integer",l,t.indicator));else if(i.type.is_variable(l)){var f=[new V(n.goal.replace(new o("=",[l,s])),n.substitution,n)];s.value=l.value&&e.success(n)},"succ/2":function(e,n,t){var s=t.args[0],a=t.args[1];i.type.is_variable(s)&&i.type.is_variable(a)?e.throw_error(i.error.instantiation(t.indicator)):!i.type.is_variable(s)&&!i.type.is_integer(s)?e.throw_error(i.error.type("integer",s,t.indicator)):!i.type.is_variable(a)&&!i.type.is_integer(a)?e.throw_error(i.error.type("integer",a,t.indicator)):!i.type.is_variable(s)&&s.value<0?e.throw_error(i.error.domain("not_less_than_zero",s,t.indicator)):!i.type.is_variable(a)&&a.value<0?e.throw_error(i.error.domain("not_less_than_zero",a,t.indicator)):(i.type.is_variable(a)||a.value>0)&&(i.type.is_variable(s)?e.prepend([new V(n.goal.replace(new o("=",[s,new E(a.value-1,!1)])),n.substitution,n)]):e.prepend([new V(n.goal.replace(new o("=",[a,new E(s.value+1,!1)])),n.substitution,n)]))},"=:=/2":function(e,n,t){var s=i.arithmetic_compare(e,t.args[0],t.args[1]);i.type.is_term(s)?e.throw_error(s):s===0&&e.success(n)},"=\\=/2":function(e,n,t){var s=i.arithmetic_compare(e,t.args[0],t.args[1]);i.type.is_term(s)?e.throw_error(s):s!==0&&e.success(n)},"/2":function(e,n,t){var s=i.arithmetic_compare(e,t.args[0],t.args[1]);i.type.is_term(s)?e.throw_error(s):s>0&&e.success(n)},">=/2":function(e,n,t){var s=i.arithmetic_compare(e,t.args[0],t.args[1]);i.type.is_term(s)?e.throw_error(s):s>=0&&e.success(n)},"var/1":function(e,n,t){i.type.is_variable(t.args[0])&&e.success(n)},"atom/1":function(e,n,t){i.type.is_atom(t.args[0])&&e.success(n)},"atomic/1":function(e,n,t){i.type.is_atomic(t.args[0])&&e.success(n)},"compound/1":function(e,n,t){i.type.is_compound(t.args[0])&&e.success(n)},"integer/1":function(e,n,t){i.type.is_integer(t.args[0])&&e.success(n)},"float/1":function(e,n,t){i.type.is_float(t.args[0])&&e.success(n)},"number/1":function(e,n,t){i.type.is_number(t.args[0])&&e.success(n)},"nonvar/1":function(e,n,t){i.type.is_variable(t.args[0])||e.success(n)},"ground/1":function(e,n,t){t.variables().length===0&&e.success(n)},"acyclic_term/1":function(e,n,t){for(var s=n.substitution.apply(n.substitution),a=t.args[0].variables(),l=0;l0?k[k.length-1]:null,k!==null&&(A=U(e,k,0,e.__get_max_priority(),!1))}if(A.type===h&&A.len===k.length-1&&L.value==="."){A=A.value.rename(e);var B=new o("=",[a,A]);if(y.variables){var q=he(c(yr(A.variables()),function(F){return new O(F)}));B=new o(",",[B,new o("=",[y.variables,q])])}if(y.variable_names){var q=he(c(yr(A.variables()),function(H){var J;for(J in e.session.renamed_variables)if(e.session.renamed_variables.hasOwnProperty(J)&&e.session.renamed_variables[J]===H)break;return new o("=",[new o(J,[]),new O(H)])}));B=new o(",",[B,new o("=",[y.variable_names,q])])}if(y.singletons){var q=he(c(new Q(A,null).singleton_variables(),function(H){var J;for(J in e.session.renamed_variables)if(e.session.renamed_variables.hasOwnProperty(J)&&e.session.renamed_variables[J]===H)break;return new o("=",[new o(J,[]),new O(H)])}));B=new o(",",[B,new o("=",[y.singletons,q])])}e.prepend([new V(n.goal.replace(B),n.substitution,n)])}else A.type===h?e.throw_error(i.error.syntax(k[A.len],"unexpected token",!1)):e.throw_error(A.value)}}},"write/1":function(e,n,t){var s=t.args[0];e.prepend([new V(n.goal.replace(new o(",",[new o("current_output",[new O("S")]),new o("write",[new O("S"),s])])),n.substitution,n)])},"write/2":function(e,n,t){var s=t.args[0],a=t.args[1];e.prepend([new V(n.goal.replace(new o("write_term",[s,a,new o(".",[new o("quoted",[new o("false",[])]),new o(".",[new o("ignore_ops",[new o("false")]),new o(".",[new o("numbervars",[new o("true")]),new o("[]",[])])])])])),n.substitution,n)])},"writeq/1":function(e,n,t){var s=t.args[0];e.prepend([new V(n.goal.replace(new o(",",[new o("current_output",[new O("S")]),new o("writeq",[new O("S"),s])])),n.substitution,n)])},"writeq/2":function(e,n,t){var s=t.args[0],a=t.args[1];e.prepend([new V(n.goal.replace(new o("write_term",[s,a,new o(".",[new o("quoted",[new o("true",[])]),new o(".",[new o("ignore_ops",[new o("false")]),new o(".",[new o("numbervars",[new o("true")]),new o("[]",[])])])])])),n.substitution,n)])},"write_canonical/1":function(e,n,t){var s=t.args[0];e.prepend([new V(n.goal.replace(new o(",",[new o("current_output",[new O("S")]),new o("write_canonical",[new O("S"),s])])),n.substitution,n)])},"write_canonical/2":function(e,n,t){var s=t.args[0],a=t.args[1];e.prepend([new V(n.goal.replace(new o("write_term",[s,a,new o(".",[new o("quoted",[new o("true",[])]),new o(".",[new o("ignore_ops",[new o("true")]),new o(".",[new o("numbervars",[new o("false")]),new o("[]",[])])])])])),n.substitution,n)])},"write_term/2":function(e,n,t){var s=t.args[0],a=t.args[1];e.prepend([new V(n.goal.replace(new o(",",[new o("current_output",[new O("S")]),new o("write_term",[new O("S"),s,a])])),n.substitution,n)])},"write_term/3":function(e,n,t){var s=t.args[0],a=t.args[1],l=t.args[2],f=i.type.is_stream(s)?s:e.get_stream_by_alias(s.id);if(i.type.is_variable(s)||i.type.is_variable(l))e.throw_error(i.error.instantiation(t.indicator));else if(!i.type.is_list(l))e.throw_error(i.error.type("list",l,t.indicator));else if(!i.type.is_stream(s)&&!i.type.is_atom(s))e.throw_error(i.error.domain("stream_or_alias",s,t.indicator));else if(!i.type.is_stream(f)||f.stream===null)e.throw_error(i.error.existence("stream",s,t.indicator));else if(f.input)e.throw_error(i.error.permission("output","stream",s,t.indicator));else if(f.type==="binary")e.throw_error(i.error.permission("output","binary_stream",s,t.indicator));else if(f.position==="past_end_of_stream"&&f.eof_action==="error")e.throw_error(i.error.permission("output","past_end_of_stream",s,t.indicator));else{for(var y={},d=l,m;i.type.is_term(d)&&d.indicator==="./2";){if(m=d.args[0],i.type.is_variable(m)){e.throw_error(i.error.instantiation(t.indicator));return}else if(!i.type.is_write_option(m)){e.throw_error(i.error.domain("write_option",m,t.indicator));return}y[m.id]=m.args[0].id==="true",d=d.args[1]}if(d.indicator!=="[]/0"){i.type.is_variable(d)?e.throw_error(i.error.instantiation(t.indicator)):e.throw_error(i.error.type("list",l,t.indicator));return}else{y.session=e.session;var S=a.toString(y);f.stream.put(S,f.position),typeof f.position=="number"&&(f.position+=S.length),e.success(n)}}},"halt/0":function(e,n,t){e.points=[]},"halt/1":function(e,n,t){var s=t.args[0];i.type.is_variable(s)?e.throw_error(i.error.instantiation(t.indicator)):i.type.is_integer(s)?e.points=[]:e.throw_error(i.error.type("integer",s,t.indicator))},"current_prolog_flag/2":function(e,n,t){var s=t.args[0],a=t.args[1];if(!i.type.is_variable(s)&&!i.type.is_atom(s))e.throw_error(i.error.type("atom",s,t.indicator));else if(!i.type.is_variable(s)&&!i.type.is_flag(s))e.throw_error(i.error.domain("prolog_flag",s,t.indicator));else{var l=[];for(var f in i.flag)if(!!i.flag.hasOwnProperty(f)){var y=new o(",",[new o("=",[new o(f),s]),new o("=",[e.get_flag(f),a])]);l.push(new V(n.goal.replace(y),n.substitution,n))}e.prepend(l)}},"set_prolog_flag/2":function(e,n,t){var s=t.args[0],a=t.args[1];i.type.is_variable(s)||i.type.is_variable(a)?e.throw_error(i.error.instantiation(t.indicator)):i.type.is_atom(s)?i.type.is_flag(s)?i.type.is_value_flag(s,a)?i.type.is_modifiable_flag(s)?(e.session.flag[s.id]=a,e.success(n)):e.throw_error(i.error.permission("modify","flag",s)):e.throw_error(i.error.domain("flag_value",new o("+",[s,a]),t.indicator)):e.throw_error(i.error.domain("prolog_flag",s,t.indicator)):e.throw_error(i.error.type("atom",s,t.indicator))}},flag:{bounded:{allowed:[new o("true"),new o("false")],value:new o("true"),changeable:!1},max_integer:{allowed:[new E(Number.MAX_SAFE_INTEGER)],value:new E(Number.MAX_SAFE_INTEGER),changeable:!1},min_integer:{allowed:[new E(Number.MIN_SAFE_INTEGER)],value:new E(Number.MIN_SAFE_INTEGER),changeable:!1},integer_rounding_function:{allowed:[new o("down"),new o("toward_zero")],value:new o("toward_zero"),changeable:!1},char_conversion:{allowed:[new o("on"),new o("off")],value:new o("on"),changeable:!0},debug:{allowed:[new o("on"),new o("off")],value:new o("off"),changeable:!0},max_arity:{allowed:[new o("unbounded")],value:new o("unbounded"),changeable:!1},unknown:{allowed:[new o("error"),new o("fail"),new o("warning")],value:new o("error"),changeable:!0},double_quotes:{allowed:[new o("chars"),new o("codes"),new o("atom")],value:new o("codes"),changeable:!0},occurs_check:{allowed:[new o("false"),new o("true")],value:new o("false"),changeable:!0},dialect:{allowed:[new o("tau")],value:new o("tau"),changeable:!1},version_data:{allowed:[new o("tau",[new E(r.major,!1),new E(r.minor,!1),new E(r.patch,!1),new o(r.status)])],value:new o("tau",[new E(r.major,!1),new E(r.minor,!1),new E(r.patch,!1),new o(r.status)]),changeable:!1},nodejs:{allowed:[new o("yes"),new o("no")],value:new o(typeof ie!="undefined"&&ie.exports?"yes":"no"),changeable:!1}},unify:function(e,n,t){t=t===void 0?!1:t;for(var s=[{left:e,right:n}],a={};s.length!==0;){var l=s.pop();if(e=l.left,n=l.right,i.type.is_term(e)&&i.type.is_term(n)){if(e.indicator!==n.indicator)return null;for(var f=0;fa.value?1:0:a}else return s},operate:function(e,n){if(i.type.is_operator(n)){for(var t=i.type.is_operator(n),s=[],a,l=!1,f=0;fe.get_flag("max_integer").value||a0?e.start+e.matches[0].length:e.start,a=t?new o("token_not_found"):new o("found",[new o(e.value.toString())]),l=new o(".",[new o("line",[new E(e.line+1)]),new o(".",[new o("column",[new E(s+1)]),new o(".",[a,new o("[]",[])])])]);return new o("error",[new o("syntax_error",[new o(n)]),l])},syntax_by_predicate:function(e,n){return new o("error",[new o("syntax_error",[new o(e)]),ae(n)])}},warning:{singleton:function(e,n,t){for(var s=new o("[]"),a=e.length-1;a>=0;a--)s=new o(".",[new O(e[a]),s]);return new o("warning",[new o("singleton_variables",[s,ae(n)]),new o(".",[new o("line",[new E(t,!1)]),new o("[]")])])},failed_goal:function(e,n){return new o("warning",[new o("failed_goal",[e]),new o(".",[new o("line",[new E(n,!1)]),new o("[]")])])}},format_variable:function(e){return"_"+e},format_answer:function(e,n,t){n instanceof D&&(n=n.thread);var t=t||{};if(t.session=n?n.session:void 0,i.type.is_error(e))return"uncaught exception: "+e.args[0].toString();if(e===!1)return"false.";if(e===null)return"limit exceeded ;";var s=0,a="";if(i.type.is_substitution(e)){var l=e.domain(!0);e=e.filter(function(d,m){return!i.type.is_variable(m)||l.indexOf(m.id)!==-1&&d!==m.id})}for(var f in e.links)!e.links.hasOwnProperty(f)||(s++,a!==""&&(a+=", "),a+=f.toString(t)+" = "+e.links[f].toString(t));var y=typeof n=="undefined"||n.points.length>0?" ;":".";return s===0?"true"+y:a+y},flatten_error:function(e){if(!i.type.is_error(e))return null;e=e.args[0];var n={};return n.type=e.args[0].id,n.thrown=n.type==="syntax_error"?null:e.args[1].id,n.expected=null,n.found=null,n.representation=null,n.existence=null,n.existence_type=null,n.line=null,n.column=null,n.permission_operation=null,n.permission_type=null,n.evaluation_type=null,n.type==="type_error"||n.type==="domain_error"?(n.expected=e.args[0].args[0].id,n.found=e.args[0].args[1].toString()):n.type==="syntax_error"?e.args[1].indicator==="./2"?(n.expected=e.args[0].args[0].id,n.found=e.args[1].args[1].args[1].args[0],n.found=n.found.id==="token_not_found"?n.found.id:n.found.args[0].id,n.line=e.args[1].args[0].args[0].value,n.column=e.args[1].args[1].args[0].args[0].value):n.thrown=e.args[1].id:n.type==="permission_error"?(n.found=e.args[0].args[2].toString(),n.permission_operation=e.args[0].args[0].id,n.permission_type=e.args[0].args[1].id):n.type==="evaluation_error"?n.evaluation_type=e.args[0].args[0].id:n.type==="representation_error"?n.representation=e.args[0].args[0].id:n.type==="existence_error"&&(n.existence=e.args[0].args[1].toString(),n.existence_type=e.args[0].args[0].id),n},create:function(e){return new i.type.Session(e)}};typeof ie!="undefined"?ie.exports=i:window.pl=i})()});var er=I((qu,rt)=>{var is=Array.isArray;rt.exports=is});var nt=I(($u,tt)=>{var ss=typeof global=="object"&&global&&global.Object===Object&&global;tt.exports=ss});var rr=I((Du,it)=>{var as=nt(),os=typeof self=="object"&&self&&self.Object===Object&&self,us=as||os||Function("return this")();it.exports=us});var tr=I((Xu,st)=>{var ls=rr(),cs=ls.Symbol;st.exports=cs});var lt=I((Bu,at)=>{var ot=tr(),ut=Object.prototype,fs=ut.hasOwnProperty,ps=ut.toString,Xe=ot?ot.toStringTag:void 0;function ys(r){var u=fs.call(r,Xe),p=r[Xe];try{r[Xe]=void 0;var c=!0}catch(_){}var w=ps.call(r);return c&&(u?r[Xe]=p:delete r[Xe]),w}at.exports=ys});var ft=I((Fu,ct)=>{var _s=Object.prototype,ws=_s.toString;function gs(r){return ws.call(r)}ct.exports=gs});var Pr=I((zu,pt)=>{var yt=tr(),ds=lt(),vs=ft(),hs="[object Null]",ms="[object Undefined]",_t=yt?yt.toStringTag:void 0;function bs(r){return r==null?r===void 0?ms:hs:_t&&_t in Object(r)?ds(r):vs(r)}pt.exports=bs});var gt=I((Wu,wt)=>{function Ts(r){return r!=null&&typeof r=="object"}wt.exports=Ts});var nr=I((Lu,dt)=>{var xs=Pr(),Vs=gt(),Ss="[object Symbol]";function ks(r){return typeof r=="symbol"||Vs(r)&&xs(r)==Ss}dt.exports=ks});var ht=I((Hu,vt)=>{var Ps=er(),Cs=nr(),Os=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Is=/^\w*$/;function Es(r,u){if(Ps(r))return!1;var p=typeof r;return p=="number"||p=="symbol"||p=="boolean"||r==null||Cs(r)?!0:Is.test(r)||!Os.test(r)||u!=null&&r in Object(u)}vt.exports=Es});var ir=I((Gu,mt)=>{function As(r){var u=typeof r;return r!=null&&(u=="object"||u=="function")}mt.exports=As});var Tt=I((Yu,bt)=>{var Ns=Pr(),Rs=ir(),Ms="[object AsyncFunction]",qs="[object Function]",$s="[object GeneratorFunction]",Ds="[object Proxy]";function Xs(r){if(!Rs(r))return!1;var u=Ns(r);return u==qs||u==$s||u==Ms||u==Ds}bt.exports=Xs});var Vt=I((Uu,xt)=>{var Bs=rr(),Fs=Bs["__core-js_shared__"];xt.exports=Fs});var Pt=I((Zu,St)=>{var Cr=Vt(),kt=function(){var r=/[^.]+$/.exec(Cr&&Cr.keys&&Cr.keys.IE_PROTO||"");return r?"Symbol(src)_1."+r:""}();function zs(r){return!!kt&&kt in r}St.exports=zs});var Ot=I((Qu,Ct)=>{var Ws=Function.prototype,Ls=Ws.toString;function Hs(r){if(r!=null){try{return Ls.call(r)}catch(u){}try{return r+""}catch(u){}}return""}Ct.exports=Hs});var Et=I((Ju,It)=>{var Gs=Tt(),Ys=Pt(),Us=ir(),Zs=Ot(),Qs=/[\\^$.*+?()[\]{}|]/g,Js=/^\[object .+?Constructor\]$/,Ks=Function.prototype,js=Object.prototype,ea=Ks.toString,ra=js.hasOwnProperty,ta=RegExp("^"+ea.call(ra).replace(Qs,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function na(r){if(!Us(r)||Ys(r))return!1;var u=Gs(r)?ta:Js;return u.test(Zs(r))}It.exports=na});var Nt=I((Ku,At)=>{function ia(r,u){return r==null?void 0:r[u]}At.exports=ia});var sr=I((ju,Rt)=>{var sa=Et(),aa=Nt();function oa(r,u){var p=aa(r,u);return sa(p)?p:void 0}Rt.exports=oa});var Be=I((el,Mt)=>{var ua=sr(),la=ua(Object,"create");Mt.exports=la});var Dt=I((rl,qt)=>{var $t=Be();function ca(){this.__data__=$t?$t(null):{},this.size=0}qt.exports=ca});var Bt=I((tl,Xt)=>{function fa(r){var u=this.has(r)&&delete this.__data__[r];return this.size-=u?1:0,u}Xt.exports=fa});var zt=I((nl,Ft)=>{var pa=Be(),ya="__lodash_hash_undefined__",_a=Object.prototype,wa=_a.hasOwnProperty;function ga(r){var u=this.__data__;if(pa){var p=u[r];return p===ya?void 0:p}return wa.call(u,r)?u[r]:void 0}Ft.exports=ga});var Lt=I((il,Wt)=>{var da=Be(),va=Object.prototype,ha=va.hasOwnProperty;function ma(r){var u=this.__data__;return da?u[r]!==void 0:ha.call(u,r)}Wt.exports=ma});var Gt=I((sl,Ht)=>{var ba=Be(),Ta="__lodash_hash_undefined__";function xa(r,u){var p=this.__data__;return this.size+=this.has(r)?0:1,p[r]=ba&&u===void 0?Ta:u,this}Ht.exports=xa});var Ut=I((al,Yt)=>{var Va=Dt(),Sa=Bt(),ka=zt(),Pa=Lt(),Ca=Gt();function Ie(r){var u=-1,p=r==null?0:r.length;for(this.clear();++u{function Oa(){this.__data__=[],this.size=0}Zt.exports=Oa});var Or=I((ul,Jt)=>{function Ia(r,u){return r===u||r!==r&&u!==u}Jt.exports=Ia});var Fe=I((ll,Kt)=>{var Ea=Or();function Aa(r,u){for(var p=r.length;p--;)if(Ea(r[p][0],u))return p;return-1}Kt.exports=Aa});var en=I((cl,jt)=>{var Na=Fe(),Ra=Array.prototype,Ma=Ra.splice;function qa(r){var u=this.__data__,p=Na(u,r);if(p<0)return!1;var c=u.length-1;return p==c?u.pop():Ma.call(u,p,1),--this.size,!0}jt.exports=qa});var tn=I((fl,rn)=>{var $a=Fe();function Da(r){var u=this.__data__,p=$a(u,r);return p<0?void 0:u[p][1]}rn.exports=Da});var sn=I((pl,nn)=>{var Xa=Fe();function Ba(r){return Xa(this.__data__,r)>-1}nn.exports=Ba});var on=I((yl,an)=>{var Fa=Fe();function za(r,u){var p=this.__data__,c=Fa(p,r);return c<0?(++this.size,p.push([r,u])):p[c][1]=u,this}an.exports=za});var ln=I((_l,un)=>{var Wa=Qt(),La=en(),Ha=tn(),Ga=sn(),Ya=on();function Ee(r){var u=-1,p=r==null?0:r.length;for(this.clear();++u{var Ua=sr(),Za=rr(),Qa=Ua(Za,"Map");cn.exports=Qa});var _n=I((gl,pn)=>{var yn=Ut(),Ja=ln(),Ka=fn();function ja(){this.size=0,this.__data__={hash:new yn,map:new(Ka||Ja),string:new yn}}pn.exports=ja});var gn=I((dl,wn)=>{function eo(r){var u=typeof r;return u=="string"||u=="number"||u=="symbol"||u=="boolean"?r!=="__proto__":r===null}wn.exports=eo});var ze=I((vl,dn)=>{var ro=gn();function to(r,u){var p=r.__data__;return ro(u)?p[typeof u=="string"?"string":"hash"]:p.map}dn.exports=to});var hn=I((hl,vn)=>{var no=ze();function io(r){var u=no(this,r).delete(r);return this.size-=u?1:0,u}vn.exports=io});var bn=I((ml,mn)=>{var so=ze();function ao(r){return so(this,r).get(r)}mn.exports=ao});var xn=I((bl,Tn)=>{var oo=ze();function uo(r){return oo(this,r).has(r)}Tn.exports=uo});var Sn=I((Tl,Vn)=>{var lo=ze();function co(r,u){var p=lo(this,r),c=p.size;return p.set(r,u),this.size+=p.size==c?0:1,this}Vn.exports=co});var Pn=I((xl,kn)=>{var fo=_n(),po=hn(),yo=bn(),_o=xn(),wo=Sn();function Ae(r){var u=-1,p=r==null?0:r.length;for(this.clear();++u{var On=Pn(),go="Expected a function";function Ir(r,u){if(typeof r!="function"||u!=null&&typeof u!="function")throw new TypeError(go);var p=function(){var c=arguments,w=u?u.apply(this,c):c[0],_=p.cache;if(_.has(w))return _.get(w);var v=r.apply(this,c);return p.cache=_.set(w,v)||_,v};return p.cache=new(Ir.Cache||On),p}Ir.Cache=On;Cn.exports=Ir});var An=I((Sl,En)=>{var vo=In(),ho=500;function mo(r){var u=vo(r,function(c){return p.size===ho&&p.clear(),c}),p=u.cache;return u}En.exports=mo});var Rn=I((kl,Nn)=>{var bo=An(),To=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,xo=/\\(\\)?/g,Vo=bo(function(r){var u=[];return r.charCodeAt(0)===46&&u.push(""),r.replace(To,function(p,c,w,_){u.push(w?_.replace(xo,"$1"):c||p)}),u});Nn.exports=Vo});var qn=I((Pl,Mn)=>{function So(r,u){for(var p=-1,c=r==null?0:r.length,w=Array(c);++p{var Dn=tr(),ko=qn(),Po=er(),Co=nr(),Oo=1/0,Xn=Dn?Dn.prototype:void 0,Bn=Xn?Xn.toString:void 0;function Fn(r){if(typeof r=="string")return r;if(Po(r))return ko(r,Fn)+"";if(Co(r))return Bn?Bn.call(r):"";var u=r+"";return u=="0"&&1/r==-Oo?"-0":u}$n.exports=Fn});var Ln=I((Ol,Wn)=>{var Io=zn();function Eo(r){return r==null?"":Io(r)}Wn.exports=Eo});var ar=I((Il,Hn)=>{var Ao=er(),No=ht(),Ro=Rn(),Mo=Ln();function qo(r,u){return Ao(r)?r:No(r,u)?[r]:Ro(Mo(r))}Hn.exports=qo});var or=I((El,Gn)=>{var $o=nr(),Do=1/0;function Xo(r){if(typeof r=="string"||$o(r))return r;var u=r+"";return u=="0"&&1/r==-Do?"-0":u}Gn.exports=Xo});var Er=I((Al,Yn)=>{var Bo=ar(),Fo=or();function zo(r,u){u=Bo(u,r);for(var p=0,c=u.length;r!=null&&p{var Wo=Er();function Lo(r,u,p){var c=r==null?void 0:Wo(r,u);return c===void 0?p:c}Un.exports=Lo});var li=I((Ul,ui)=>{var Jo=sr(),Ko=function(){try{var r=Jo(Object,"defineProperty");return r({},"",{}),r}catch(u){}}();ui.exports=Ko});var pi=I((Zl,ci)=>{var fi=li();function jo(r,u,p){u=="__proto__"&&fi?fi(r,u,{configurable:!0,enumerable:!0,value:p,writable:!0}):r[u]=p}ci.exports=jo});var _i=I((Ql,yi)=>{var eu=pi(),ru=Or(),tu=Object.prototype,nu=tu.hasOwnProperty;function iu(r,u,p){var c=r[u];(!(nu.call(r,u)&&ru(c,p))||p===void 0&&!(u in r))&&eu(r,u,p)}yi.exports=iu});var gi=I((Jl,wi)=>{var su=9007199254740991,au=/^(?:0|[1-9]\d*)$/;function ou(r,u){var p=typeof r;return u=u==null?su:u,!!u&&(p=="number"||p!="symbol"&&au.test(r))&&r>-1&&r%1==0&&r{var uu=_i(),lu=ar(),cu=gi(),vi=ir(),fu=or();function pu(r,u,p,c){if(!vi(r))return r;u=lu(u,r);for(var w=-1,_=u.length,v=_-1,g=r;g!=null&&++w<_;){var h=fu(u[w]),x=p;if(h==="__proto__"||h==="constructor"||h==="prototype")return r;if(w!=v){var T=g[h];x=c?c(T,h,g):void 0,x===void 0&&(x=vi(T)?T:cu(u[w+1])?[]:{})}uu(g,h,x),g=g[h]}return r}di.exports=pu});var bi=I((jl,mi)=>{var yu=hi();function _u(r,u,p){return r==null?r:yu(r,u,p)}mi.exports=_u});var xi=I((ec,Ti)=>{function wu(r){var u=r==null?0:r.length;return u?r[u-1]:void 0}Ti.exports=wu});var Si=I((rc,Vi)=>{function gu(r,u,p){var c=-1,w=r.length;u<0&&(u=-u>w?0:w+u),p=p>w?w:p,p<0&&(p+=w),w=u>p?0:p-u>>>0,u>>>=0;for(var _=Array(w);++c{var du=Er(),vu=Si();function hu(r,u){return u.length<2?r:du(r,vu(u,0,-1))}ki.exports=hu});var Oi=I((nc,Ci)=>{var mu=ar(),bu=xi(),Tu=Pi(),xu=or();function Vu(r,u){return u=mu(u,r),r=Tu(r,u),r==null||delete r[xu(bu(u))]}Ci.exports=Vu});var Ei=I((ic,Ii)=>{var Su=Oi();function ku(r,u){return r==null?!0:Su(r,u)}Ii.exports=ku});var Ou={};Qi(Ou,{default:()=>Eu});var $i=G(require("@yarnpkg/core"));var ni=G(require("@yarnpkg/cli")),ur=G(require("@yarnpkg/core")),ii=G(require("@yarnpkg/core")),Le=G(require("clipanion"));var ue=G(require("@yarnpkg/core")),le=G(require("@yarnpkg/core")),Ne=G(require("@yarnpkg/fslib")),jn=G(Xr()),Re=G(kr());var Nr=G(require("@yarnpkg/core")),Rr=G(Ar()),re=G(kr()),Zn=G(require("vm")),{is_atom:ge,is_variable:Ho,is_instantiated_list:Go}=re.default.type;function Qn(r,u,p){r.prepend(p.map(c=>new re.default.type.State(u.goal.replace(c),u.substitution,u)))}var Jn=new WeakMap;function Mr(r){let u=Jn.get(r.session);if(u==null)throw new Error("Assertion failed: A project should have been registered for the active session");return u}var Yo=new re.default.type.Module("constraints",{["project_workspaces_by_descriptor/3"]:(r,u,p)=>{let[c,w,_]=p.args;if(!ge(c)||!ge(w)){r.throw_error(re.default.error.instantiation(p.indicator));return}let v=Nr.structUtils.parseIdent(c.id),g=Nr.structUtils.makeDescriptor(v,w.id),x=Mr(r).tryWorkspaceByDescriptor(g);Ho(_)&&x!==null&&Qn(r,u,[new re.default.type.Term("=",[_,new re.default.type.Term(String(x.relativeCwd))])]),ge(_)&&x!==null&&x.relativeCwd===_.id&&r.success(u)},["workspace_field/3"]:(r,u,p)=>{let[c,w,_]=p.args;if(!ge(c)||!ge(w)){r.throw_error(re.default.error.instantiation(p.indicator));return}let g=Mr(r).tryWorkspaceByCwd(c.id);if(g==null)return;let h=(0,Rr.default)(g.manifest.raw,w.id);typeof h!="undefined"&&Qn(r,u,[new re.default.type.Term("=",[_,new re.default.type.Term(typeof h=="object"?JSON.stringify(h):h)])])},["workspace_field_test/3"]:(r,u,p)=>{let[c,w,_]=p.args;r.prepend([new re.default.type.State(u.goal.replace(new re.default.type.Term("workspace_field_test",[c,w,_,new re.default.type.Term("[]",[])])),u.substitution,u)])},["workspace_field_test/4"]:(r,u,p)=>{let[c,w,_,v]=p.args;if(!ge(c)||!ge(w)||!ge(_)||!Go(v)){r.throw_error(re.default.error.instantiation(p.indicator));return}let h=Mr(r).tryWorkspaceByCwd(c.id);if(h==null)return;let x=(0,Rr.default)(h.manifest.raw,w.id);if(typeof x=="undefined")return;let T={$$:x};for(let[C,N]of v.toJavaScript().entries())T[`$${C}`]=N;Zn.default.runInNewContext(_.id,T)&&r.success(u)}},["project_workspaces_by_descriptor/3","workspace_field/3","workspace_field_test/3","workspace_field_test/4"]);function Kn(r,u){Jn.set(r,u),r.consult(`:- use_module(library(${Yo.id})).`)}(0,jn.default)(Re.default);var We;(function(c){c.Dependencies="dependencies",c.DevDependencies="devDependencies",c.PeerDependencies="peerDependencies"})(We||(We={}));var ei=[We.Dependencies,We.DevDependencies,We.PeerDependencies];function K(r){if(r instanceof Re.default.type.Num)return r.value;if(r instanceof Re.default.type.Term)switch(r.indicator){case"throw/1":return K(r.args[0]);case"error/1":return K(r.args[0]);case"error/2":if(r.args[0]instanceof Re.default.type.Term&&r.args[0].indicator==="syntax_error/1")return Object.assign(K(r.args[0]),...K(r.args[1]));{let u=K(r.args[0]);return u.message+=` (in ${K(r.args[1])})`,u}case"syntax_error/1":return new ue.ReportError(ue.MessageName.PROLOG_SYNTAX_ERROR,`Syntax error: ${K(r.args[0])}`);case"existence_error/2":return new ue.ReportError(ue.MessageName.PROLOG_EXISTENCE_ERROR,`Existence error: ${K(r.args[0])} ${K(r.args[1])} not found`);case"instantiation_error/0":return new ue.ReportError(ue.MessageName.PROLOG_INSTANTIATION_ERROR,"Instantiation error: an argument is variable when an instantiated argument was expected");case"line/1":return{line:K(r.args[0])};case"column/1":return{column:K(r.args[0])};case"found/1":return{found:K(r.args[0])};case"./2":return[K(r.args[0])].concat(K(r.args[1]));case"//2":return`${K(r.args[0])}/${K(r.args[1])}`;default:return r.id}throw`couldn't pretty print because of unsupported node ${r}`}function ri(r){let u;try{u=K(r)}catch(p){throw typeof p=="string"?new ue.ReportError(ue.MessageName.PROLOG_UNKNOWN_ERROR,`Unknown error: ${r} (note: ${p})`):p}return typeof u.line!="undefined"&&typeof u.column!="undefined"&&(u.message+=` at line ${u.line}, column ${u.column}`),u}var ti=class{constructor(u,p){this.session=Re.default.create(),Kn(this.session,u),this.session.consult(":- use_module(library(lists))."),this.session.consult(p)}fetchNextAnswer(){return new Promise(u=>{this.session.answer(p=>{u(p)})})}async*makeQuery(u){let p=this.session.query(u);if(p!==!0)throw ri(p);for(;;){let c=await this.fetchNextAnswer();if(!c)break;if(c.id==="throw")throw ri(c);yield c}}};function ke(r){return r.id==="null"?null:`${r.toJavaScript()}`}function Uo(r){if(r.id==="null")return null;{let u=r.toJavaScript();if(typeof u!="string")return JSON.stringify(u);try{return JSON.stringify(JSON.parse(u))}catch{return JSON.stringify(u)}}}var pe=class{constructor(u){this.source="";this.project=u;let p=u.configuration.get("constraintsPath");Ne.xfs.existsSync(p)&&(this.source=Ne.xfs.readFileSync(p,"utf8"))}static async find(u){return new pe(u)}getProjectDatabase(){let u="";for(let p of ei)u+=`dependency_type(${p}). +`;for(let p of this.project.workspacesByCwd.values()){let c=p.relativeCwd;u+=`workspace(${de(c)}). +`,u+=`workspace_ident(${de(c)}, ${de(le.structUtils.stringifyIdent(p.locator))}). +`,u+=`workspace_version(${de(c)}, ${de(p.manifest.version)}). +`;for(let w of ei)for(let _ of p.manifest[w].values())u+=`workspace_has_dependency(${de(c)}, ${de(le.structUtils.stringifyIdent(_))}, ${de(_.range)}, ${w}). +`}return u+=`workspace(_) :- false. +`,u+=`workspace_ident(_, _) :- false. +`,u+=`workspace_version(_, _) :- false. +`,u+=`workspace_has_dependency(_, _, _, _) :- false. +`,u}getDeclarations(){let u="";return u+=`gen_enforced_dependency(_, _, _, _) :- false. +`,u+=`gen_enforced_field(_, _, _) :- false. +`,u}get fullSource(){return`${this.getProjectDatabase()} +${this.source} +${this.getDeclarations()}`}createSession(){return new ti(this.project,this.fullSource)}async process(){let u=this.createSession();return{enforcedDependencies:await this.genEnforcedDependencies(u),enforcedFields:await this.genEnforcedFields(u)}}async genEnforcedDependencies(u){let p=[];for await(let c of u.makeQuery("workspace(WorkspaceCwd), dependency_type(DependencyType), gen_enforced_dependency(WorkspaceCwd, DependencyIdent, DependencyRange, DependencyType).")){let w=Ne.ppath.resolve(this.project.cwd,ke(c.links.WorkspaceCwd)),_=ke(c.links.DependencyIdent),v=ke(c.links.DependencyRange),g=ke(c.links.DependencyType);if(w===null||_===null)throw new Error("Invalid rule");let h=this.project.getWorkspaceByCwd(w),x=le.structUtils.parseIdent(_);p.push({workspace:h,dependencyIdent:x,dependencyRange:v,dependencyType:g})}return le.miscUtils.sortMap(p,[({dependencyRange:c})=>c!==null?"0":"1",({workspace:c})=>le.structUtils.stringifyIdent(c.locator),({dependencyIdent:c})=>le.structUtils.stringifyIdent(c)])}async genEnforcedFields(u){let p=[];for await(let c of u.makeQuery("workspace(WorkspaceCwd), gen_enforced_field(WorkspaceCwd, FieldPath, FieldValue).")){let w=Ne.ppath.resolve(this.project.cwd,ke(c.links.WorkspaceCwd)),_=ke(c.links.FieldPath),v=Uo(c.links.FieldValue);if(w===null||_===null)throw new Error("Invalid rule");let g=this.project.getWorkspaceByCwd(w);p.push({workspace:g,fieldPath:_,fieldValue:v})}return le.miscUtils.sortMap(p,[({workspace:c})=>le.structUtils.stringifyIdent(c.locator),({fieldPath:c})=>c])}async*query(u){let p=this.createSession();for await(let c of p.makeQuery(u)){let w={};for(let[_,v]of Object.entries(c.links))_!=="_"&&(w[_]=ke(v));yield w}}};function de(r){return typeof r=="string"?`'${r}'`:"[]"}var He=class extends ni.BaseCommand{constructor(){super(...arguments);this.json=Le.Option.Boolean("--json",!1,{description:"Format the output as an NDJSON stream"});this.query=Le.Option.String()}async execute(){let u=await ur.Configuration.find(this.context.cwd,this.context.plugins),{project:p}=await ur.Project.find(u,this.context.cwd),c=await pe.find(p),w=this.query;return w.endsWith(".")||(w=`${w}.`),(await ii.StreamReport.start({configuration:u,json:this.json,stdout:this.context.stdout},async v=>{for await(let g of c.query(w)){let h=Array.from(Object.entries(g)),x=h.length,T=h.reduce((b,[C])=>Math.max(b,C.length),0);for(let b=0;b{let v=new Set,g=[];for(let h=0,x=this.fix?10:1;h{await h.persistManifest()}));for(let[h,x]of g)_.reportError(h,x)});return w.hasErrors()?w.exitCode():0}};Ye.paths=[["constraints"]],Ye.usage=fr.Command.Usage({category:"Constraints-related commands",description:"check that the project constraints are met",details:` + This command will run constraints on your project and emit errors for each one that is found but isn't met. If any error is emitted the process will exit with a non-zero exit code. + + If the \`--fix\` flag is used, Yarn will attempt to automatically fix the issues the best it can, following a multi-pass process (with a maximum of 10 iterations). Some ambiguous patterns cannot be autofixed, in which case you'll have to manually specify the right resolution. + + For more information as to how to write constraints, please consult our dedicated page on our website: https://yarnpkg.com/features/constraints. + `,examples:[["Check that all constraints are satisfied","yarn constraints"],["Autofix all unmet constraints","yarn constraints --fix"]]});var qi=Ye;async function Pu(r,u,p,{configuration:c,fix:w}){let _=new Map,v=new Map;for(let{workspace:g,dependencyIdent:h,dependencyRange:x,dependencyType:T}of p){let b=v.get(g);typeof b=="undefined"&&v.set(g,b=new Map);let C=b.get(h.identHash);typeof C=="undefined"&&b.set(h.identHash,C=new Map);let N=C.get(T);typeof N=="undefined"&&C.set(T,N=new Set),_.set(h.identHash,h),N.add(x)}for(let[g,h]of v)for(let[x,T]of h){let b=_.get(x);if(typeof b=="undefined")throw new Error("Assertion failed: The ident should have been registered");for(let[C,N]of T){let W=N.has(null)?[null]:[...N];if(W.length>2)u.push([se.MessageName.CONSTRAINTS_AMBIGUITY,`${$.structUtils.prettyWorkspace(c,g)} must depend on ${$.structUtils.prettyIdent(c,b)} via conflicting ranges ${W.slice(0,-1).map(ee=>$.structUtils.prettyRange(c,String(ee))).join(", ")}, and ${$.structUtils.prettyRange(c,String(W[W.length-1]))} (in ${C})`]);else if(W.length>1)u.push([se.MessageName.CONSTRAINTS_AMBIGUITY,`${$.structUtils.prettyWorkspace(c,g)} must depend on ${$.structUtils.prettyIdent(c,b)} via conflicting ranges ${$.structUtils.prettyRange(c,String(W[0]))} and ${$.structUtils.prettyRange(c,String(W[1]))} (in ${C})`]);else{let ee=g.manifest[C].get(b.identHash),[te]=W;te!==null?ee?ee.range!==te&&(w?(g.manifest[C].set(b.identHash,$.structUtils.makeDescriptor(b,te)),r.add(g)):u.push([se.MessageName.CONSTRAINTS_INCOMPATIBLE_DEPENDENCY,`${$.structUtils.prettyWorkspace(c,g)} must depend on ${$.structUtils.prettyIdent(c,b)} via ${$.structUtils.prettyRange(c,te)}, but uses ${$.structUtils.prettyRange(c,ee.range)} instead (in ${C})`])):w?(g.manifest[C].set(b.identHash,$.structUtils.makeDescriptor(b,te)),r.add(g)):u.push([se.MessageName.CONSTRAINTS_MISSING_DEPENDENCY,`${$.structUtils.prettyWorkspace(c,g)} must depend on ${$.structUtils.prettyIdent(c,b)} (via ${$.structUtils.prettyRange(c,te)}), but doesn't (in ${C})`]):ee&&(w?(g.manifest[C].delete(b.identHash),r.add(g)):u.push([se.MessageName.CONSTRAINTS_EXTRANEOUS_DEPENDENCY,`${$.structUtils.prettyWorkspace(c,g)} has an extraneous dependency on ${$.structUtils.prettyIdent(c,b)} (in ${C})`]))}}}}async function Cu(r,u,p,{configuration:c,fix:w}){let _=new Map;for(let{workspace:v,fieldPath:g,fieldValue:h}of p){let x=Pe.miscUtils.getMapWithDefault(_,v);Pe.miscUtils.getSetWithDefault(x,g).add(h)}for(let[v,g]of _)for(let[h,x]of g){let T=[...x];if(T.length>2)u.push([se.MessageName.CONSTRAINTS_AMBIGUITY,`${$.structUtils.prettyWorkspace(c,v)} must have a field ${$.formatUtils.pretty(c,h,"cyan")} set to conflicting values ${T.slice(0,-1).map(b=>$.formatUtils.pretty(c,String(b),"magenta")).join(", ")}, or ${$.formatUtils.pretty(c,String(T[T.length-1]),"magenta")}`]);else if(T.length>1)u.push([se.MessageName.CONSTRAINTS_AMBIGUITY,`${$.structUtils.prettyWorkspace(c,v)} must have a field ${$.formatUtils.pretty(c,h,"cyan")} set to conflicting values ${$.formatUtils.pretty(c,String(T[0]),"magenta")} or ${$.formatUtils.pretty(c,String(T[1]),"magenta")}`]);else{let b=(0,Ni.default)(v.manifest.raw,h),[C]=T;C!==null?b===void 0?w?(await qr(v,h,C),r.add(v)):u.push([se.MessageName.CONSTRAINTS_MISSING_FIELD,`${$.structUtils.prettyWorkspace(c,v)} must have a field ${$.formatUtils.pretty(c,h,"cyan")} set to ${$.formatUtils.pretty(c,String(C),"magenta")}, but doesn't`]):JSON.stringify(b)!==C&&(w?(await qr(v,h,C),r.add(v)):u.push([se.MessageName.CONSTRAINTS_INCOMPATIBLE_FIELD,`${$.structUtils.prettyWorkspace(c,v)} must have a field ${$.formatUtils.pretty(c,h,"cyan")} set to ${$.formatUtils.pretty(c,String(C),"magenta")}, but is set to ${$.formatUtils.pretty(c,JSON.stringify(b),"magenta")} instead`])):b!=null&&(w?(await qr(v,h,null),r.add(v)):u.push([se.MessageName.CONSTRAINTS_EXTRANEOUS_FIELD,`${$.structUtils.prettyWorkspace(c,v)} has an extraneous field ${$.formatUtils.pretty(c,h,"cyan")} set to ${$.formatUtils.pretty(c,JSON.stringify(b),"magenta")}`]))}}}async function qr(r,u,p){p===null?(0,Mi.default)(r.manifest.raw,u):(0,Ri.default)(r.manifest.raw,u,JSON.parse(p))}var Iu={configuration:{constraintsPath:{description:"The path of the constraints file.",type:$i.SettingsType.ABSOLUTE_PATH,default:"./constraints.pro"}},commands:[si,oi,qi]},Eu=Iu;return Ou;})(); +return plugin; +} +}; diff --git a/.yarnrc.yml b/.yarnrc.yml index 64407cf3b66e..9c4331b485df 100644 --- a/.yarnrc.yml +++ b/.yarnrc.yml @@ -27,6 +27,8 @@ packageExtensions: "@babel/preset-env": ^7.1.6 plugins: + - path: .yarn/plugins/@yarnpkg/plugin-constraints.cjs + spec: "@yarnpkg/plugin-constraints" - path: .yarn/plugins/@yarnpkg/plugin-interactive-tools.cjs spec: "@yarnpkg/plugin-interactive-tools" - path: .yarn/plugins/@yarnpkg/plugin-workspace-tools.cjs diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 712dee11e9b8..bdb96e0c6bfd 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -129,6 +129,18 @@ Time: 0.232 s, estimated 1 s Ran all test suites. ``` +## Checking Constraints + +We use [Yarn Constraints](https://yarnpkg.com/features/constraints) to enforce various rules across the repository. They are declared inside the [`constraints.pro` file](https://github.com/facebook/jest/blob/main/constraints.pro) and their purposes are documented with comments. + +Constraints can be checked with `yarn constraints`, and fixed with `yarn constraints --fix`. Generally speaking: + +- Workspaces must not depend on conflicting ranges of dependencies. Use the `-i,--interactive` flag and select "Reuse" when installing dependencies and you shouldn't ever have to deal with this rule. + +- A dependency doesn't appear in both `dependencies` and `devDependencies` of the same workspace. + +- Workspaces must point our repository through the `repository` field. + ##### Using jest-circus There may be cases where you want to run jest using `jest-circus` instead of `jest-jasmine2` (which is the default runner) for integration testing. In situations like this, set the environment variable `JEST_CIRCUS` to 1. That will configure jest to use `jest-circus`. So something like this. diff --git a/constraints.pro b/constraints.pro new file mode 100644 index 000000000000..2d6fb89342c0 --- /dev/null +++ b/constraints.pro @@ -0,0 +1,82 @@ +constraints_min_version(1). + +% This file is written in Prolog +% It contains rules that the project must respect. +% Check with "yarn constraints" (fix w/ "yarn constraints --fix") +% Yarn Constraints https://yarnpkg.com/features/constraints +% Reference for other constraints: +% https://github.com/babel/babel/blob/main/constraints.pro +% https://github.com/yarnpkg/berry/blob/master/constraints.pro + +% This rule will enforce that a workspace MUST depend on the same version of a dependency as the one used by the other workspaces +gen_enforced_dependency(WorkspaceCwd, DependencyIdent, DependencyRange2, DependencyType) :- + % Iterates over all dependencies from all workspaces + workspace_has_dependency(WorkspaceCwd, DependencyIdent, DependencyRange, DependencyType), + % Iterates over similarly-named dependencies from all workspaces (again) + workspace_has_dependency(OtherWorkspaceCwd, DependencyIdent, DependencyRange2, DependencyType2), + % Ignore peer dependencies + DependencyType \= 'peerDependencies', + DependencyType2 \= 'peerDependencies', + % Ignore workspace:*: we use both `workspace:*` and real version such as `^28.0.0-alpha.8` to reference package in monorepo + % TODO: in the future we should make it consistent and remove this ignore + DependencyRange \= 'workspace:*', + DependencyRange2 \= 'workspace:*', + % Get the workspace name + workspace_ident(WorkspaceCwd, WorkspaceIdent), + workspace_ident(OtherWorkspaceCwd, OtherWorkspaceIdent), + % @types/node in the root need to stay on ~12.12.0 + ( + (WorkspaceIdent = '@jest/monorepo'; OtherWorkspaceIdent = '@jest/monorepo') -> + DependencyIdent \= '@types/node' + ; + true + ), + % Allow enzyme example workspace use a older version react and react-dom, because enzyme don't support react 17 + ( + (WorkspaceIdent = 'example-enzyme'; OtherWorkspaceIdent = 'example-enzyme') -> + \+ member(DependencyIdent, ['react', 'react-dom']) + ; + true + ). + +% Enforces that a dependency doesn't appear in both `dependencies` and `devDependencies` +gen_enforced_dependency(WorkspaceCwd, DependencyIdent, null, 'devDependencies') :- + workspace_has_dependency(WorkspaceCwd, DependencyIdent, _, 'devDependencies'), + workspace_has_dependency(WorkspaceCwd, DependencyIdent, _, 'dependencies'). + +% Enforces the license in all public workspaces while removing it from private workspaces +gen_enforced_field(WorkspaceCwd, 'license', 'MIT') :- + \+ workspace_field(WorkspaceCwd, 'private', true). +gen_enforced_field(WorkspaceCwd, 'license', null) :- + workspace_field(WorkspaceCwd, 'private', true). + +% Enforces the repository field for all public workspaces while removing it from private workspaces +gen_enforced_field(WorkspaceCwd, 'repository.type', 'git') :- + \+ workspace_field(WorkspaceCwd, 'private', true). +gen_enforced_field(WorkspaceCwd, 'repository.url', 'https://github.com/facebook/jest.git') :- + \+ workspace_field(WorkspaceCwd, 'private', true). +gen_enforced_field(WorkspaceCwd, 'repository.directory', WorkspaceCwd) :- + \+ workspace_field(WorkspaceCwd, 'private', true). +gen_enforced_field(WorkspaceCwd, 'repository', null) :- + workspace_field(WorkspaceCwd, 'private', true). + +% Enforces 'publishConfig.access' is set to public for public workspaces while removing it from private workspaces +gen_enforced_field(WorkspaceCwd, 'publishConfig.access', 'public') :- + \+ workspace_field(WorkspaceCwd, 'private', true). +gen_enforced_field(WorkspaceCwd, 'publishConfig.access', null) :- + workspace_field(WorkspaceCwd, 'private', true). + +% Enforces the engines.node field for public workspace +gen_enforced_field(WorkspaceCwd, 'engines.node', '^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0') :- + \+ workspace_field(WorkspaceCwd, 'private', true). + +% Enforces the main and types field to start with ./ +gen_enforced_field(WorkspaceCwd, FieldName, ExpectedValue) :- + % Fields the rule applies to + member(FieldName, ['main', 'types']), + % Get current value + workspace_field(WorkspaceCwd, FieldName, CurrentValue), + % Must not start with ./ already + \+ atom_concat('./', _, CurrentValue), + % Store './' + CurrentValue in ExpectedValue + atom_concat('./', CurrentValue, ExpectedValue). diff --git a/e2e/__tests__/__snapshots__/stackTraceSourceMapsWithCoverage.test.ts.snap b/e2e/__tests__/__snapshots__/stackTraceSourceMapsWithCoverage.test.ts.snap index 8ea50879d980..ced47e9dad26 100644 --- a/e2e/__tests__/__snapshots__/stackTraceSourceMapsWithCoverage.test.ts.snap +++ b/e2e/__tests__/__snapshots__/stackTraceSourceMapsWithCoverage.test.ts.snap @@ -15,6 +15,6 @@ exports[`processes stack traces and code frames with source maps with coverage 1 15 | } 16 | - at Object.error (lib.ts:14:9) - at Object. (__tests__/fails.ts:10:3)" + at error (lib.ts:14:9) + at Object. (__tests__/fails.ts:10:8)" `; diff --git a/e2e/babel-plugin-jest-hoist/package.json b/e2e/babel-plugin-jest-hoist/package.json index f8c92b090b70..b55189deec84 100644 --- a/e2e/babel-plugin-jest-hoist/package.json +++ b/e2e/babel-plugin-jest-hoist/package.json @@ -3,7 +3,7 @@ "@babel/preset-env": "^7.0.0", "@babel/preset-flow": "^7.0.0", "@babel/preset-typescript": "^7.0.0", - "react": "*" + "react": "17.0.2" }, "jest": { "automock": true, diff --git a/e2e/babel-plugin-jest-hoist/yarn.lock b/e2e/babel-plugin-jest-hoist/yarn.lock index 8e19431564b8..27bdf2e3a8d7 100644 --- a/e2e/babel-plugin-jest-hoist/yarn.lock +++ b/e2e/babel-plugin-jest-hoist/yarn.lock @@ -1596,7 +1596,7 @@ __metadata: languageName: node linkType: hard -"react@npm:*": +"react@npm:17.0.2": version: 17.0.2 resolution: "react@npm:17.0.2" dependencies: @@ -1703,7 +1703,7 @@ __metadata: "@babel/preset-env": ^7.0.0 "@babel/preset-flow": ^7.0.0 "@babel/preset-typescript": ^7.0.0 - react: "*" + react: 17.0.2 languageName: unknown linkType: soft diff --git a/e2e/coverage-remapping/package.json b/e2e/coverage-remapping/package.json index ff2715e71f98..b7b9342d8f56 100644 --- a/e2e/coverage-remapping/package.json +++ b/e2e/coverage-remapping/package.json @@ -7,6 +7,6 @@ "testEnvironment": "node" }, "dependencies": { - "typescript": "^3.7.4" + "typescript": "^4.6.2" } } diff --git a/e2e/coverage-remapping/yarn.lock b/e2e/coverage-remapping/yarn.lock index 98dbf8ec233b..68121efe22b0 100644 --- a/e2e/coverage-remapping/yarn.lock +++ b/e2e/coverage-remapping/yarn.lock @@ -9,26 +9,26 @@ __metadata: version: 0.0.0-use.local resolution: "root-workspace-0b6124@workspace:." dependencies: - typescript: ^3.7.4 + typescript: ^4.6.2 languageName: unknown linkType: soft -"typescript@npm:^3.7.4": - version: 3.9.10 - resolution: "typescript@npm:3.9.10" +"typescript@npm:^4.6.2": + version: 4.6.3 + resolution: "typescript@npm:4.6.3" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: 46c842e2cd4797b88b66ef06c9c41dd21da48b95787072ccf39d5f2aa3124361bc4c966aa1c7f709fae0509614d76751455b5231b12dbb72eb97a31369e1ff92 + checksum: 255bb26c8cb846ca689dd1c3a56587af4f69055907aa2c154796ea28ee0dea871535b1c78f85a6212c77f2657843a269c3a742d09d81495b97b914bf7920415b languageName: node linkType: hard -"typescript@patch:typescript@^3.7.4#~builtin": - version: 3.9.10 - resolution: "typescript@patch:typescript@npm%3A3.9.10#~builtin::version=3.9.10&hash=bda367" +"typescript@patch:typescript@^4.6.2#~builtin": + version: 4.6.3 + resolution: "typescript@patch:typescript@npm%3A4.6.3#~builtin::version=4.6.3&hash=bda367" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: dc7141ab555b23a8650a6787f98845fc11692063d02b75ff49433091b3af2fe3d773650dea18389d7c21f47d620fb3b110ea363dab4ab039417a6ccbbaf96fc2 + checksum: 6bf45caf847062420592e711bc9c28bf5f9a9a7fa8245343b81493e4ededae33f1774009d1234d911422d1646a2c839f44e1a23ecb111b40a60ac2ea4c1482a8 languageName: node linkType: hard diff --git a/e2e/stack-trace-source-maps-with-coverage/package.json b/e2e/stack-trace-source-maps-with-coverage/package.json index 56d2defe8c95..60a023465a34 100644 --- a/e2e/stack-trace-source-maps-with-coverage/package.json +++ b/e2e/stack-trace-source-maps-with-coverage/package.json @@ -8,6 +8,6 @@ "testRegex": "fails" }, "dependencies": { - "typescript": "^3.7.4" + "typescript": "^4.6.2" } } diff --git a/e2e/stack-trace-source-maps-with-coverage/yarn.lock b/e2e/stack-trace-source-maps-with-coverage/yarn.lock index 98dbf8ec233b..68121efe22b0 100644 --- a/e2e/stack-trace-source-maps-with-coverage/yarn.lock +++ b/e2e/stack-trace-source-maps-with-coverage/yarn.lock @@ -9,26 +9,26 @@ __metadata: version: 0.0.0-use.local resolution: "root-workspace-0b6124@workspace:." dependencies: - typescript: ^3.7.4 + typescript: ^4.6.2 languageName: unknown linkType: soft -"typescript@npm:^3.7.4": - version: 3.9.10 - resolution: "typescript@npm:3.9.10" +"typescript@npm:^4.6.2": + version: 4.6.3 + resolution: "typescript@npm:4.6.3" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: 46c842e2cd4797b88b66ef06c9c41dd21da48b95787072ccf39d5f2aa3124361bc4c966aa1c7f709fae0509614d76751455b5231b12dbb72eb97a31369e1ff92 + checksum: 255bb26c8cb846ca689dd1c3a56587af4f69055907aa2c154796ea28ee0dea871535b1c78f85a6212c77f2657843a269c3a742d09d81495b97b914bf7920415b languageName: node linkType: hard -"typescript@patch:typescript@^3.7.4#~builtin": - version: 3.9.10 - resolution: "typescript@patch:typescript@npm%3A3.9.10#~builtin::version=3.9.10&hash=bda367" +"typescript@patch:typescript@^4.6.2#~builtin": + version: 4.6.3 + resolution: "typescript@patch:typescript@npm%3A4.6.3#~builtin::version=4.6.3&hash=bda367" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: dc7141ab555b23a8650a6787f98845fc11692063d02b75ff49433091b3af2fe3d773650dea18389d7c21f47d620fb3b110ea363dab4ab039417a6ccbbaf96fc2 + checksum: 6bf45caf847062420592e711bc9c28bf5f9a9a7fa8245343b81493e4ededae33f1774009d1234d911422d1646a2c839f44e1a23ecb111b40a60ac2ea4c1482a8 languageName: node linkType: hard diff --git a/e2e/stack-trace-source-maps/package.json b/e2e/stack-trace-source-maps/package.json index 56d2defe8c95..60a023465a34 100644 --- a/e2e/stack-trace-source-maps/package.json +++ b/e2e/stack-trace-source-maps/package.json @@ -8,6 +8,6 @@ "testRegex": "fails" }, "dependencies": { - "typescript": "^3.7.4" + "typescript": "^4.6.2" } } diff --git a/e2e/stack-trace-source-maps/yarn.lock b/e2e/stack-trace-source-maps/yarn.lock index 98dbf8ec233b..68121efe22b0 100644 --- a/e2e/stack-trace-source-maps/yarn.lock +++ b/e2e/stack-trace-source-maps/yarn.lock @@ -9,26 +9,26 @@ __metadata: version: 0.0.0-use.local resolution: "root-workspace-0b6124@workspace:." dependencies: - typescript: ^3.7.4 + typescript: ^4.6.2 languageName: unknown linkType: soft -"typescript@npm:^3.7.4": - version: 3.9.10 - resolution: "typescript@npm:3.9.10" +"typescript@npm:^4.6.2": + version: 4.6.3 + resolution: "typescript@npm:4.6.3" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: 46c842e2cd4797b88b66ef06c9c41dd21da48b95787072ccf39d5f2aa3124361bc4c966aa1c7f709fae0509614d76751455b5231b12dbb72eb97a31369e1ff92 + checksum: 255bb26c8cb846ca689dd1c3a56587af4f69055907aa2c154796ea28ee0dea871535b1c78f85a6212c77f2657843a269c3a742d09d81495b97b914bf7920415b languageName: node linkType: hard -"typescript@patch:typescript@^3.7.4#~builtin": - version: 3.9.10 - resolution: "typescript@patch:typescript@npm%3A3.9.10#~builtin::version=3.9.10&hash=bda367" +"typescript@patch:typescript@^4.6.2#~builtin": + version: 4.6.3 + resolution: "typescript@patch:typescript@npm%3A4.6.3#~builtin::version=4.6.3&hash=bda367" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: dc7141ab555b23a8650a6787f98845fc11692063d02b75ff49433091b3af2fe3d773650dea18389d7c21f47d620fb3b110ea363dab4ab039417a6ccbbaf96fc2 + checksum: 6bf45caf847062420592e711bc9c28bf5f9a9a7fa8245343b81493e4ededae33f1774009d1234d911422d1646a2c839f44e1a23ecb111b40a60ac2ea4c1482a8 languageName: node linkType: hard diff --git a/e2e/transform/multiple-transformers/package.json b/e2e/transform/multiple-transformers/package.json index fb6fec0c6fff..f0f60dd9cba5 100644 --- a/e2e/transform/multiple-transformers/package.json +++ b/e2e/transform/multiple-transformers/package.json @@ -17,8 +17,8 @@ "@babel/core": "^7.0.0", "@babel/preset-env": "^7.0.0", "@babel/preset-react": "^7.0.0", - "react": "*", - "react-dom": "*", - "react-test-renderer": "*" + "react": "17.0.2", + "react-dom": "^17.0.1", + "react-test-renderer": "17.0.2" } } diff --git a/e2e/transform/multiple-transformers/yarn.lock b/e2e/transform/multiple-transformers/yarn.lock index 045c4016ff28..c5d158a23f24 100644 --- a/e2e/transform/multiple-transformers/yarn.lock +++ b/e2e/transform/multiple-transformers/yarn.lock @@ -1700,7 +1700,7 @@ __metadata: languageName: node linkType: hard -"react-dom@npm:*": +"react-dom@npm:^17.0.1": version: 17.0.2 resolution: "react-dom@npm:17.0.2" dependencies: @@ -1732,7 +1732,7 @@ __metadata: languageName: node linkType: hard -"react-test-renderer@npm:*": +"react-test-renderer@npm:17.0.2": version: 17.0.2 resolution: "react-test-renderer@npm:17.0.2" dependencies: @@ -1746,7 +1746,7 @@ __metadata: languageName: node linkType: hard -"react@npm:*": +"react@npm:17.0.2": version: 17.0.2 resolution: "react@npm:17.0.2" dependencies: @@ -1853,9 +1853,9 @@ __metadata: "@babel/core": ^7.0.0 "@babel/preset-env": ^7.0.0 "@babel/preset-react": ^7.0.0 - react: "*" - react-dom: "*" - react-test-renderer: "*" + react: 17.0.2 + react-dom: ^17.0.1 + react-test-renderer: 17.0.2 languageName: unknown linkType: soft diff --git a/e2e/typescript-coverage/package.json b/e2e/typescript-coverage/package.json index 24255a467dd7..b7b9342d8f56 100644 --- a/e2e/typescript-coverage/package.json +++ b/e2e/typescript-coverage/package.json @@ -7,6 +7,6 @@ "testEnvironment": "node" }, "dependencies": { - "typescript": "^3.3.1" + "typescript": "^4.6.2" } } diff --git a/e2e/typescript-coverage/yarn.lock b/e2e/typescript-coverage/yarn.lock index 077ddea218e3..68121efe22b0 100644 --- a/e2e/typescript-coverage/yarn.lock +++ b/e2e/typescript-coverage/yarn.lock @@ -9,26 +9,26 @@ __metadata: version: 0.0.0-use.local resolution: "root-workspace-0b6124@workspace:." dependencies: - typescript: ^3.3.1 + typescript: ^4.6.2 languageName: unknown linkType: soft -"typescript@npm:^3.3.1": - version: 3.9.10 - resolution: "typescript@npm:3.9.10" +"typescript@npm:^4.6.2": + version: 4.6.3 + resolution: "typescript@npm:4.6.3" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: 46c842e2cd4797b88b66ef06c9c41dd21da48b95787072ccf39d5f2aa3124361bc4c966aa1c7f709fae0509614d76751455b5231b12dbb72eb97a31369e1ff92 + checksum: 255bb26c8cb846ca689dd1c3a56587af4f69055907aa2c154796ea28ee0dea871535b1c78f85a6212c77f2657843a269c3a742d09d81495b97b914bf7920415b languageName: node linkType: hard -"typescript@patch:typescript@^3.3.1#~builtin": - version: 3.9.10 - resolution: "typescript@patch:typescript@npm%3A3.9.10#~builtin::version=3.9.10&hash=bda367" +"typescript@patch:typescript@^4.6.2#~builtin": + version: 4.6.3 + resolution: "typescript@patch:typescript@npm%3A4.6.3#~builtin::version=4.6.3&hash=bda367" bin: tsc: bin/tsc tsserver: bin/tsserver - checksum: dc7141ab555b23a8650a6787f98845fc11692063d02b75ff49433091b3af2fe3d773650dea18389d7c21f47d620fb3b110ea363dab4ab039417a6ccbbaf96fc2 + checksum: 6bf45caf847062420592e711bc9c28bf5f9a9a7fa8245343b81493e4ededae33f1774009d1234d911422d1646a2c839f44e1a23ecb111b40a60ac2ea4c1482a8 languageName: node linkType: hard diff --git a/examples/angular/package.json b/examples/angular/package.json index 077edb2aae2e..08a4887857c3 100644 --- a/examples/angular/package.json +++ b/examples/angular/package.json @@ -15,18 +15,18 @@ "core-js": "^3.2.1", "rxjs": "^7.5.5", "tslib": "^2.0.0", - "typescript": "*", + "typescript": "^4.6.2", "zone.js": "~0.11.3" }, "devDependencies": { - "@babel/core": "*", + "@babel/core": "^7.11.6", "@babel/plugin-proposal-decorators": "*", - "@babel/preset-env": "*", - "@babel/preset-typescript": "*", - "@types/jest": "*", - "babel-jest": "*", + "@babel/preset-env": "^7.1.0", + "@babel/preset-typescript": "^7.0.0", + "@types/jest": "^27.4.0", + "babel-jest": "workspace:*", "babel-plugin-transform-typescript-metadata": "*", - "jest": "*", + "jest": "workspace:*", "jest-zone-patch": "*" } } diff --git a/examples/async/package.json b/examples/async/package.json index 9a4169870dea..0aad9aa5f6a5 100644 --- a/examples/async/package.json +++ b/examples/async/package.json @@ -3,10 +3,10 @@ "version": "0.0.0", "name": "example-async", "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/automatic-mocks/package.json b/examples/automatic-mocks/package.json index aefcce3021ea..4289a81e4597 100644 --- a/examples/automatic-mocks/package.json +++ b/examples/automatic-mocks/package.json @@ -3,10 +3,10 @@ "version": "0.0.0", "name": "example-automatic-mocks", "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/enzyme/package.json b/examples/enzyme/package.json index 4474451b81a8..41ba3928b558 100644 --- a/examples/enzyme/package.json +++ b/examples/enzyme/package.json @@ -7,13 +7,13 @@ "react-dom": "^16.14.0" }, "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "@babel/preset-react": "*", - "babel-jest": "*", + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "@babel/preset-react": "^7.12.1", + "babel-jest": "workspace:*", "enzyme": "*", "enzyme-adapter-react-16": "*", - "jest": "*" + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/expect-extend/package.json b/examples/expect-extend/package.json index 7ffa1f92b773..161c3c2b5b3b 100644 --- a/examples/expect-extend/package.json +++ b/examples/expect-extend/package.json @@ -3,9 +3,9 @@ "version": "0.0.0", "name": "example-expect-extend", "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "@babel/preset-typescript": "*", + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "@babel/preset-typescript": "^7.0.0", "@jest/globals": "workspace:*", "babel-jest": "workspace:*", "expect": "workspace:*", diff --git a/examples/getting-started/package.json b/examples/getting-started/package.json index 2c430deeb0d3..ede124a1f08e 100644 --- a/examples/getting-started/package.json +++ b/examples/getting-started/package.json @@ -3,10 +3,10 @@ "version": "0.0.0", "name": "example-getting-started", "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/jquery/package.json b/examples/jquery/package.json index 87a6963ee511..6b125a32579e 100644 --- a/examples/jquery/package.json +++ b/examples/jquery/package.json @@ -3,13 +3,13 @@ "version": "0.0.0", "name": "example-jquery", "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "dependencies": { - "jquery": "*" + "jquery": "^3.2.1" }, "scripts": { "test": "jest" diff --git a/examples/manual-mocks/package.json b/examples/manual-mocks/package.json index 2f256f4d34d9..5c55909d7389 100644 --- a/examples/manual-mocks/package.json +++ b/examples/manual-mocks/package.json @@ -3,10 +3,10 @@ "version": "0.0.0", "name": "example-manual-mocks", "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/module-mock/package.json b/examples/module-mock/package.json index fa5b980256af..d0eb838c5c88 100644 --- a/examples/module-mock/package.json +++ b/examples/module-mock/package.json @@ -3,10 +3,10 @@ "version": "0.0.0", "name": "example-manual-mock", "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/mongodb/package.json b/examples/mongodb/package.json index d7bca6c768f3..6a552bdb71c6 100644 --- a/examples/mongodb/package.json +++ b/examples/mongodb/package.json @@ -1,19 +1,18 @@ { "name": "example-mongodb", "version": "0.0.0", - "main": "index.js", - "license": "MIT", + "main": "./index.js", "private": true, "dependencies": { - "jest-environment-node": "*", + "jest-environment-node": "workspace:*", "mongodb": "^4.3.1", "mongodb-memory-server": "^8.3.0" }, "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/react-native/package.json b/examples/react-native/package.json index 40fd30d4eca4..2a50f9accd33 100644 --- a/examples/react-native/package.json +++ b/examples/react-native/package.json @@ -11,10 +11,10 @@ "react-native": "0.68.0" }, "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "babel-jest": "*", - "jest": "*", + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "babel-jest": "workspace:*", + "jest": "workspace:*", "metro-react-native-babel-preset": "0.67.0", "react-test-renderer": "17.0.2" } diff --git a/examples/react-testing-library/package.json b/examples/react-testing-library/package.json index f18927368449..e6aa06186295 100644 --- a/examples/react-testing-library/package.json +++ b/examples/react-testing-library/package.json @@ -3,16 +3,16 @@ "version": "0.0.0", "name": "example-react-testing-library", "dependencies": { - "react": "*", - "react-dom": "*" + "react": "17.0.2", + "react-dom": "^17.0.1" }, "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "@babel/preset-react": "*", + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "@babel/preset-react": "^7.12.1", "@testing-library/react": "*", - "babel-jest": "*", - "jest": "*" + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/react/package.json b/examples/react/package.json index 61bcaa0188ff..5d24a3b06a8d 100644 --- a/examples/react/package.json +++ b/examples/react/package.json @@ -3,15 +3,15 @@ "version": "0.0.0", "name": "example-react", "dependencies": { - "react": "*", - "react-dom": "*" + "react": "17.0.2", + "react-dom": "^17.0.1" }, "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "@babel/preset-react": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "@babel/preset-react": "^7.12.1", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/snapshot/package.json b/examples/snapshot/package.json index 9d11dbcce92b..cb49aba118ea 100644 --- a/examples/snapshot/package.json +++ b/examples/snapshot/package.json @@ -3,15 +3,15 @@ "version": "0.0.0", "name": "example-snapshot", "dependencies": { - "react": "*" + "react": "17.0.2" }, "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "@babel/preset-react": "*", - "babel-jest": "*", - "jest": "*", - "react-test-renderer": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "@babel/preset-react": "^7.12.1", + "babel-jest": "workspace:*", + "jest": "workspace:*", + "react-test-renderer": "17.0.2" }, "scripts": { "test": "jest" diff --git a/examples/timer/package.json b/examples/timer/package.json index cf1b13617e94..b6540587b1f2 100644 --- a/examples/timer/package.json +++ b/examples/timer/package.json @@ -3,10 +3,10 @@ "version": "0.0.0", "name": "example-timer", "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/examples/typescript/package.json b/examples/typescript/package.json index 8a2c828a89de..7effcd539ec6 100644 --- a/examples/typescript/package.json +++ b/examples/typescript/package.json @@ -3,18 +3,18 @@ "version": "0.0.0", "name": "example-typescript", "dependencies": { - "react": "*", - "react-dom": "*", - "typescript": "*" + "react": "17.0.2", + "react-dom": "^17.0.1", + "typescript": "^4.6.2" }, "devDependencies": { - "@babel/core": "*", - "@babel/preset-env": "*", - "@babel/preset-react": "*", - "@babel/preset-typescript": "*", - "@types/jest": "*", - "babel-jest": "*", - "jest": "*" + "@babel/core": "^7.11.6", + "@babel/preset-env": "^7.1.0", + "@babel/preset-react": "^7.12.1", + "@babel/preset-typescript": "^7.0.0", + "@types/jest": "^27.4.0", + "babel-jest": "workspace:*", + "jest": "workspace:*" }, "scripts": { "test": "jest" diff --git a/package.json b/package.json index 765fec82eb3f..935c9d81e42e 100644 --- a/package.json +++ b/package.json @@ -81,7 +81,7 @@ "throat": "^6.0.1", "ts-node": "^10.5.0", "type-fest": "^2.11.2", - "typescript": "^4.2.4", + "typescript": "^4.6.2", "which": "^2.0.1" }, "scripts": { diff --git a/packages/jest-cli/package.json b/packages/jest-cli/package.json index 044cc532c4b4..ebc5fc2fa94d 100644 --- a/packages/jest-cli/package.json +++ b/packages/jest-cli/package.json @@ -48,7 +48,7 @@ }, "repository": { "type": "git", - "url": "https://github.com/facebook/jest", + "url": "https://github.com/facebook/jest.git", "directory": "packages/jest-cli" }, "bugs": { diff --git a/packages/jest-cli/src/init/__tests__/fixtures/typescript-in-dependencies/package.json b/packages/jest-cli/src/init/__tests__/fixtures/typescript-in-dependencies/package.json index 100738a1126c..45d694a634cc 100644 --- a/packages/jest-cli/src/init/__tests__/fixtures/typescript-in-dependencies/package.json +++ b/packages/jest-cli/src/init/__tests__/fixtures/typescript-in-dependencies/package.json @@ -1,6 +1,6 @@ { "name": "typescript_in_dev_dependencies", "devDependencies": { - "typescript": "*" + "typescript": "^4.6.2" } } diff --git a/packages/jest-cli/src/init/__tests__/fixtures/typescript-in-dev-dependencies/package.json b/packages/jest-cli/src/init/__tests__/fixtures/typescript-in-dev-dependencies/package.json index c6578ac6d5e9..90688f161ebf 100644 --- a/packages/jest-cli/src/init/__tests__/fixtures/typescript-in-dev-dependencies/package.json +++ b/packages/jest-cli/src/init/__tests__/fixtures/typescript-in-dev-dependencies/package.json @@ -1,6 +1,6 @@ { "name": "only-package-json", "dependencies": { - "typescript": "*" + "typescript": "^4.6.2" } } diff --git a/packages/jest-config/package.json b/packages/jest-config/package.json index 13534e8ccc7b..611a9c064e1f 100644 --- a/packages/jest-config/package.json +++ b/packages/jest-config/package.json @@ -58,7 +58,7 @@ "@types/micromatch": "^4.0.1", "semver": "^7.3.5", "ts-node": "^10.5.0", - "typescript": "^4.2.4" + "typescript": "^4.6.2" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-console/package.json b/packages/jest-console/package.json index 1d958cec5e19..dbedb42b36d8 100644 --- a/packages/jest-console/package.json +++ b/packages/jest-console/package.json @@ -25,8 +25,7 @@ "slash": "^3.0.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", - "@types/node": "*" + "@jest/test-utils": "^28.0.0-alpha.8" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-core/package.json b/packages/jest-core/package.json index 9c5071862154..fc2f73eff86d 100644 --- a/packages/jest-core/package.json +++ b/packages/jest-core/package.json @@ -63,7 +63,7 @@ }, "repository": { "type": "git", - "url": "https://github.com/facebook/jest", + "url": "https://github.com/facebook/jest.git", "directory": "packages/jest-core" }, "bugs": { diff --git a/packages/jest-reporters/package.json b/packages/jest-reporters/package.json index f85dc29e942b..c5dcc7464083 100644 --- a/packages/jest-reporters/package.json +++ b/packages/jest-reporters/package.json @@ -64,7 +64,7 @@ }, "repository": { "type": "git", - "url": "https://github.com/facebook/jest", + "url": "https://github.com/facebook/jest.git", "directory": "packages/jest-reporters" }, "bugs": { diff --git a/packages/jest-runtime/package.json b/packages/jest-runtime/package.json index 203dc44050ff..ddf360901263 100644 --- a/packages/jest-runtime/package.json +++ b/packages/jest-runtime/package.json @@ -44,7 +44,7 @@ "@jest/test-utils": "^28.0.0-alpha.8", "@types/glob": "^7.1.1", "@types/graceful-fs": "^4.1.3", - "@types/node": "^14.0.27", + "@types/node": "*", "jest-environment-node": "^28.0.0-alpha.8" }, "engines": { diff --git a/packages/jest-watcher/package.json b/packages/jest-watcher/package.json index 027af5857016..29dd32d11e0b 100644 --- a/packages/jest-watcher/package.json +++ b/packages/jest-watcher/package.json @@ -23,7 +23,7 @@ }, "repository": { "type": "git", - "url": "https://github.com/facebook/jest", + "url": "https://github.com/facebook/jest.git", "directory": "packages/jest-watcher" }, "bugs": { diff --git a/packages/jest/package.json b/packages/jest/package.json index 5fc40a9d42e4..31b201c1b840 100644 --- a/packages/jest/package.json +++ b/packages/jest/package.json @@ -31,7 +31,8 @@ }, "repository": { "type": "git", - "url": "https://github.com/facebook/jest" + "url": "https://github.com/facebook/jest.git", + "directory": "packages/jest" }, "homepage": "https://jestjs.io/", "license": "MIT", diff --git a/packages/pretty-format/package.json b/packages/pretty-format/package.json index 690af3ce4e36..a118f9674cd5 100644 --- a/packages/pretty-format/package.json +++ b/packages/pretty-format/package.json @@ -26,15 +26,15 @@ "react-is": "^18.0.0" }, "devDependencies": { - "@types/react": "*", + "@types/react": "^17.0.3", "@types/react-is": "^17.0.0", - "@types/react-test-renderer": "*", + "@types/react-test-renderer": "17.0.2", "expect": "^28.0.0-alpha.8", "immutable": "^4.0.0", "jest-util": "^28.0.0-alpha.8", - "react": "*", - "react-dom": "*", - "react-test-renderer": "*" + "react": "17.0.2", + "react-dom": "^17.0.1", + "react-test-renderer": "17.0.2" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/test-utils/package.json b/packages/test-utils/package.json index ddeaeec7b285..7b4fea7f3203 100644 --- a/packages/test-utils/package.json +++ b/packages/test-utils/package.json @@ -2,7 +2,6 @@ "name": "@jest/test-utils", "version": "28.0.0-alpha.8", "private": true, - "license": "MIT", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { diff --git a/scripts/checkCopyrightHeaders.mjs b/scripts/checkCopyrightHeaders.mjs index 78467692b227..19d9549a5093 100755 --- a/scripts/checkCopyrightHeaders.mjs +++ b/scripts/checkCopyrightHeaders.mjs @@ -71,6 +71,7 @@ const GENERIC_IGNORED_EXTENSIONS = [ 'ipynb', 'htm', 'toml', + 'pro', ].map(extension => createRegExp(`\.${extension}$`)); const GENERIC_IGNORED_PATTERNS = [ diff --git a/website/package.json b/website/package.json index 5c52084fe002..a64446b8fdce 100644 --- a/website/package.json +++ b/website/package.json @@ -36,7 +36,7 @@ "@docusaurus/remark-plugin-npm2yarn": "^2.0.0-beta.17", "clsx": "^1.1.1", "globby": "^11.0.1", - "react": "^17.0.1", + "react": "17.0.2", "react-dom": "^17.0.1", "react-github-btn": "^1.2.0", "react-lite-youtube-embed": "^2.2.1-a", diff --git a/yarn.lock b/yarn.lock index e1456f4c1e05..ea24da0647df 100644 --- a/yarn.lock +++ b/yarn.lock @@ -287,29 +287,6 @@ __metadata: languageName: node linkType: hard -"@babel/core@npm:*, @babel/core@npm:^7.11.1, @babel/core@npm:^7.11.6, @babel/core@npm:^7.12.3, @babel/core@npm:^7.13.16, @babel/core@npm:^7.14.0, @babel/core@npm:^7.15.5, @babel/core@npm:^7.17.8": - version: 7.17.9 - resolution: "@babel/core@npm:7.17.9" - dependencies: - "@ampproject/remapping": ^2.1.0 - "@babel/code-frame": ^7.16.7 - "@babel/generator": ^7.17.9 - "@babel/helper-compilation-targets": ^7.17.7 - "@babel/helper-module-transforms": ^7.17.7 - "@babel/helpers": ^7.17.9 - "@babel/parser": ^7.17.9 - "@babel/template": ^7.16.7 - "@babel/traverse": ^7.17.9 - "@babel/types": ^7.17.0 - convert-source-map: ^1.7.0 - debug: ^4.1.0 - gensync: ^1.0.0-beta.2 - json5: ^2.2.1 - semver: ^6.3.0 - checksum: 2d301e4561a170bb584a735ec412de8fdc40b2052e12380d4a5e36781be5af1fd2a60552e7f0764b0a491a242f20105265bd2a10ff57b30c2842684f02dbb5a2 - languageName: node - linkType: hard - "@babel/core@npm:7.12.9": version: 7.12.9 resolution: "@babel/core@npm:7.12.9" @@ -334,6 +311,29 @@ __metadata: languageName: node linkType: hard +"@babel/core@npm:^7.11.1, @babel/core@npm:^7.11.6, @babel/core@npm:^7.12.3, @babel/core@npm:^7.13.16, @babel/core@npm:^7.14.0, @babel/core@npm:^7.15.5, @babel/core@npm:^7.17.8": + version: 7.17.9 + resolution: "@babel/core@npm:7.17.9" + dependencies: + "@ampproject/remapping": ^2.1.0 + "@babel/code-frame": ^7.16.7 + "@babel/generator": ^7.17.9 + "@babel/helper-compilation-targets": ^7.17.7 + "@babel/helper-module-transforms": ^7.17.7 + "@babel/helpers": ^7.17.9 + "@babel/parser": ^7.17.9 + "@babel/template": ^7.16.7 + "@babel/traverse": ^7.17.9 + "@babel/types": ^7.17.0 + convert-source-map: ^1.7.0 + debug: ^4.1.0 + gensync: ^1.0.0-beta.2 + json5: ^2.2.1 + semver: ^6.3.0 + checksum: 2d301e4561a170bb584a735ec412de8fdc40b2052e12380d4a5e36781be5af1fd2a60552e7f0764b0a491a242f20105265bd2a10ff57b30c2842684f02dbb5a2 + languageName: node + linkType: hard + "@babel/generator@npm:^7.12.5, @babel/generator@npm:^7.14.0, @babel/generator@npm:^7.17.7, @babel/generator@npm:^7.17.9, @babel/generator@npm:^7.7.2": version: 7.17.9 resolution: "@babel/generator@npm:7.17.9" @@ -1634,7 +1634,7 @@ __metadata: languageName: node linkType: hard -"@babel/preset-env@npm:*, @babel/preset-env@npm:^7.1.0, @babel/preset-env@npm:^7.11.0, @babel/preset-env@npm:^7.15.6, @babel/preset-env@npm:^7.16.11": +"@babel/preset-env@npm:^7.1.0, @babel/preset-env@npm:^7.11.0, @babel/preset-env@npm:^7.15.6, @babel/preset-env@npm:^7.16.11": version: 7.16.11 resolution: "@babel/preset-env@npm:7.16.11" dependencies: @@ -1746,7 +1746,7 @@ __metadata: languageName: node linkType: hard -"@babel/preset-react@npm:*, @babel/preset-react@npm:^7.12.1, @babel/preset-react@npm:^7.14.5, @babel/preset-react@npm:^7.16.7": +"@babel/preset-react@npm:^7.12.1, @babel/preset-react@npm:^7.14.5, @babel/preset-react@npm:^7.16.7": version: 7.16.7 resolution: "@babel/preset-react@npm:7.16.7" dependencies: @@ -1762,7 +1762,7 @@ __metadata: languageName: node linkType: hard -"@babel/preset-typescript@npm:*, @babel/preset-typescript@npm:^7.0.0, @babel/preset-typescript@npm:^7.13.0, @babel/preset-typescript@npm:^7.15.0, @babel/preset-typescript@npm:^7.16.7": +"@babel/preset-typescript@npm:^7.0.0, @babel/preset-typescript@npm:^7.13.0, @babel/preset-typescript@npm:^7.15.0, @babel/preset-typescript@npm:^7.16.7": version: 7.16.7 resolution: "@babel/preset-typescript@npm:7.16.7" dependencies: @@ -2743,7 +2743,7 @@ __metadata: throat: ^6.0.1 ts-node: ^10.5.0 type-fest: ^2.11.2 - typescript: ^4.2.4 + typescript: ^4.6.2 which: ^2.0.1 languageName: unknown linkType: soft @@ -5081,7 +5081,7 @@ __metadata: languageName: node linkType: hard -"@types/jest@npm:*, @types/jest@npm:^27.4.0": +"@types/jest@npm:^27.4.0": version: 27.4.1 resolution: "@types/jest@npm:27.4.1" dependencies: @@ -5217,13 +5217,6 @@ __metadata: languageName: node linkType: hard -"@types/node@npm:^14.0.27": - version: 14.18.12 - resolution: "@types/node@npm:14.18.12" - checksum: 8a0273caa0584020adb8802784fc7d4f18f05e6c205335b7f3818a91d6b0c22736b9f51da3428d5bc54076ad47f1a4d6d57990a3ce8489a520ac66b2b3ff24bc - languageName: node - linkType: hard - "@types/node@npm:^17.0.5": version: 17.0.23 resolution: "@types/node@npm:17.0.23" @@ -5351,12 +5344,12 @@ __metadata: languageName: node linkType: hard -"@types/react-test-renderer@npm:*": - version: 17.0.1 - resolution: "@types/react-test-renderer@npm:17.0.1" +"@types/react-test-renderer@npm:17.0.2": + version: 17.0.2 + resolution: "@types/react-test-renderer@npm:17.0.2" dependencies: - "@types/react": "*" - checksum: ecaae8df36cd8cfeb89080d52534856acc3789bad9a6e369ff5119426377c827b4e5b5daa638507f2c1c2fd6c994bf45de288a698143178cd4049c2cd8b77b35 + "@types/react": ^17 + checksum: 0be325798b6b38cc31fbb11f2f1e1a5578cc3b23eddf1ddd1ab58ccf50966e8f779383084d8bc3a7db3108ad815af8fbae5c0f54329a88d52200e01547d85c33 languageName: node linkType: hard @@ -6165,19 +6158,19 @@ __metadata: "@angular/forms": ^12.0.0 "@angular/platform-browser": ^12.0.0 "@angular/platform-browser-dynamic": ^12.0.0 - "@babel/core": "*" + "@babel/core": ^7.11.6 "@babel/plugin-proposal-decorators": "*" - "@babel/preset-env": "*" - "@babel/preset-typescript": "*" - "@types/jest": "*" - babel-jest: "*" + "@babel/preset-env": ^7.1.0 + "@babel/preset-typescript": ^7.0.0 + "@types/jest": ^27.4.0 + babel-jest: "workspace:*" babel-plugin-transform-typescript-metadata: "*" core-js: ^3.2.1 - jest: "*" + jest: "workspace:*" jest-zone-patch: "*" rxjs: ^7.5.5 tslib: ^2.0.0 - typescript: "*" + typescript: ^4.6.2 zone.js: ~0.11.3 languageName: unknown linkType: soft @@ -10034,10 +10027,10 @@ __metadata: version: 0.0.0-use.local resolution: "example-async@workspace:examples/async" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - babel-jest: "*" - jest: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + babel-jest: "workspace:*" + jest: "workspace:*" languageName: unknown linkType: soft @@ -10045,10 +10038,10 @@ __metadata: version: 0.0.0-use.local resolution: "example-automatic-mocks@workspace:examples/automatic-mocks" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - babel-jest: "*" - jest: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + babel-jest: "workspace:*" + jest: "workspace:*" languageName: unknown linkType: soft @@ -10056,13 +10049,13 @@ __metadata: version: 0.0.0-use.local resolution: "example-enzyme@workspace:examples/enzyme" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - "@babel/preset-react": "*" - babel-jest: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + "@babel/preset-react": ^7.12.1 + babel-jest: "workspace:*" enzyme: "*" enzyme-adapter-react-16: "*" - jest: "*" + jest: "workspace:*" react: ^16.14.0 react-dom: ^16.14.0 languageName: unknown @@ -10072,9 +10065,9 @@ __metadata: version: 0.0.0-use.local resolution: "example-expect-extend@workspace:examples/expect-extend" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - "@babel/preset-typescript": "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + "@babel/preset-typescript": ^7.0.0 "@jest/globals": "workspace:*" babel-jest: "workspace:*" expect: "workspace:*" @@ -10086,10 +10079,10 @@ __metadata: version: 0.0.0-use.local resolution: "example-getting-started@workspace:examples/getting-started" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - babel-jest: "*" - jest: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + babel-jest: "workspace:*" + jest: "workspace:*" languageName: unknown linkType: soft @@ -10097,11 +10090,11 @@ __metadata: version: 0.0.0-use.local resolution: "example-jquery@workspace:examples/jquery" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - babel-jest: "*" - jest: "*" - jquery: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + babel-jest: "workspace:*" + jest: "workspace:*" + jquery: ^3.2.1 languageName: unknown linkType: soft @@ -10109,10 +10102,10 @@ __metadata: version: 0.0.0-use.local resolution: "example-manual-mock@workspace:examples/module-mock" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - babel-jest: "*" - jest: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + babel-jest: "workspace:*" + jest: "workspace:*" languageName: unknown linkType: soft @@ -10120,10 +10113,10 @@ __metadata: version: 0.0.0-use.local resolution: "example-manual-mocks@workspace:examples/manual-mocks" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - babel-jest: "*" - jest: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + babel-jest: "workspace:*" + jest: "workspace:*" lodash: ^4.17.19 languageName: unknown linkType: soft @@ -10132,11 +10125,11 @@ __metadata: version: 0.0.0-use.local resolution: "example-mongodb@workspace:examples/mongodb" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - babel-jest: "*" - jest: "*" - jest-environment-node: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + babel-jest: "workspace:*" + jest: "workspace:*" + jest-environment-node: "workspace:*" mongodb: ^4.3.1 mongodb-memory-server: ^8.3.0 languageName: unknown @@ -10146,10 +10139,10 @@ __metadata: version: 0.0.0-use.local resolution: "example-react-native@workspace:examples/react-native" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - babel-jest: "*" - jest: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + babel-jest: "workspace:*" + jest: "workspace:*" metro-react-native-babel-preset: 0.67.0 react: 17.0.2 react-native: 0.68.0 @@ -10161,14 +10154,14 @@ __metadata: version: 0.0.0-use.local resolution: "example-react-testing-library@workspace:examples/react-testing-library" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - "@babel/preset-react": "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + "@babel/preset-react": ^7.12.1 "@testing-library/react": "*" - babel-jest: "*" - jest: "*" - react: "*" - react-dom: "*" + babel-jest: "workspace:*" + jest: "workspace:*" + react: 17.0.2 + react-dom: ^17.0.1 languageName: unknown linkType: soft @@ -10176,13 +10169,13 @@ __metadata: version: 0.0.0-use.local resolution: "example-react@workspace:examples/react" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - "@babel/preset-react": "*" - babel-jest: "*" - jest: "*" - react: "*" - react-dom: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + "@babel/preset-react": ^7.12.1 + babel-jest: "workspace:*" + jest: "workspace:*" + react: 17.0.2 + react-dom: ^17.0.1 languageName: unknown linkType: soft @@ -10190,13 +10183,13 @@ __metadata: version: 0.0.0-use.local resolution: "example-snapshot@workspace:examples/snapshot" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - "@babel/preset-react": "*" - babel-jest: "*" - jest: "*" - react: "*" - react-test-renderer: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + "@babel/preset-react": ^7.12.1 + babel-jest: "workspace:*" + jest: "workspace:*" + react: 17.0.2 + react-test-renderer: 17.0.2 languageName: unknown linkType: soft @@ -10204,10 +10197,10 @@ __metadata: version: 0.0.0-use.local resolution: "example-timer@workspace:examples/timer" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - babel-jest: "*" - jest: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + babel-jest: "workspace:*" + jest: "workspace:*" languageName: unknown linkType: soft @@ -10215,16 +10208,16 @@ __metadata: version: 0.0.0-use.local resolution: "example-typescript@workspace:examples/typescript" dependencies: - "@babel/core": "*" - "@babel/preset-env": "*" - "@babel/preset-react": "*" - "@babel/preset-typescript": "*" - "@types/jest": "*" - babel-jest: "*" - jest: "*" - react: "*" - react-dom: "*" - typescript: "*" + "@babel/core": ^7.11.6 + "@babel/preset-env": ^7.1.0 + "@babel/preset-react": ^7.12.1 + "@babel/preset-typescript": ^7.0.0 + "@types/jest": ^27.4.0 + babel-jest: "workspace:*" + jest: "workspace:*" + react: 17.0.2 + react-dom: ^17.0.1 + typescript: ^4.6.2 languageName: unknown linkType: soft @@ -13104,7 +13097,7 @@ __metadata: slash: ^3.0.0 strip-json-comments: ^3.1.1 ts-node: ^10.5.0 - typescript: ^4.2.4 + typescript: ^4.6.2 peerDependencies: "@types/node": "*" ts-node: ">=9.0.0" @@ -13534,7 +13527,7 @@ __metadata: "@jest/types": ^28.0.0-alpha.8 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 - "@types/node": ^14.0.27 + "@types/node": "*" chalk: ^4.0.0 cjs-module-lexer: ^1.0.0 collect-v8-coverage: ^1.0.0 @@ -13758,7 +13751,7 @@ __metadata: graphql: ^16.3.0 graphql-request: ^4.0.0 js-yaml: ^4.1.0 - react: ^17.0.1 + react: 17.0.2 react-dom: ^17.0.1 react-github-btn: ^1.2.0 react-lite-youtube-embed: ^2.2.1-a @@ -13860,7 +13853,7 @@ __metadata: languageName: node linkType: hard -"jquery@npm:*, jquery@npm:^3.2.1": +"jquery@npm:^3.2.1": version: 3.6.0 resolution: "jquery@npm:3.6.0" checksum: 8fd5fef4aa48fd374ec716dd1c1df1af407814a228e15c1260ca140de3a697c2a77c30c54ff1d238b6a3ab4ddc445ddeef9adce6c6d28e4869d85eb9d3951c0e @@ -17968,18 +17961,18 @@ __metadata: resolution: "pretty-format@workspace:packages/pretty-format" dependencies: "@jest/schemas": ^28.0.0-alpha.3 - "@types/react": "*" + "@types/react": ^17.0.3 "@types/react-is": ^17.0.0 - "@types/react-test-renderer": "*" + "@types/react-test-renderer": 17.0.2 ansi-regex: ^5.0.1 ansi-styles: ^5.0.0 expect: ^28.0.0-alpha.8 immutable: ^4.0.0 jest-util: ^28.0.0-alpha.8 - react: "*" - react-dom: "*" + react: 17.0.2 + react-dom: ^17.0.1 react-is: ^18.0.0 - react-test-renderer: "*" + react-test-renderer: 17.0.2 languageName: unknown linkType: soft @@ -18414,19 +18407,6 @@ __metadata: languageName: node linkType: hard -"react-dom@npm:*, react-dom@npm:^17.0.1": - version: 17.0.2 - resolution: "react-dom@npm:17.0.2" - dependencies: - loose-envify: ^1.1.0 - object-assign: ^4.1.1 - scheduler: ^0.20.2 - peerDependencies: - react: 17.0.2 - checksum: 1c1eaa3bca7c7228d24b70932e3d7c99e70d1d04e13bb0843bbf321582bc25d7961d6b8a6978a58a598af2af496d1cedcfb1bf65f6b0960a0a8161cb8dab743c - languageName: node - linkType: hard - "react-dom@npm:^16.14.0": version: 16.14.0 resolution: "react-dom@npm:16.14.0" @@ -18441,6 +18421,19 @@ __metadata: languageName: node linkType: hard +"react-dom@npm:^17.0.1": + version: 17.0.2 + resolution: "react-dom@npm:17.0.2" + dependencies: + loose-envify: ^1.1.0 + object-assign: ^4.1.1 + scheduler: ^0.20.2 + peerDependencies: + react: 17.0.2 + checksum: 1c1eaa3bca7c7228d24b70932e3d7c99e70d1d04e13bb0843bbf321582bc25d7961d6b8a6978a58a598af2af496d1cedcfb1bf65f6b0960a0a8161cb8dab743c + languageName: node + linkType: hard + "react-error-overlay@npm:^6.0.10": version: 6.0.10 resolution: "react-error-overlay@npm:6.0.10" @@ -18760,7 +18753,7 @@ __metadata: languageName: node linkType: hard -"react-test-renderer@npm:*, react-test-renderer@npm:17.0.2": +"react-test-renderer@npm:17.0.2": version: 17.0.2 resolution: "react-test-renderer@npm:17.0.2" dependencies: @@ -18801,7 +18794,7 @@ __metadata: languageName: node linkType: hard -"react@npm:*, react@npm:17.0.2, react@npm:^17.0.1": +"react@npm:17.0.2": version: 17.0.2 resolution: "react@npm:17.0.2" dependencies: @@ -21650,7 +21643,7 @@ __metadata: languageName: node linkType: hard -"typescript@npm:*, typescript@npm:^4.2.4": +"typescript@npm:^4.6.2": version: 4.6.3 resolution: "typescript@npm:4.6.3" bin: @@ -21670,7 +21663,7 @@ __metadata: languageName: node linkType: hard -"typescript@patch:typescript@*#~builtin, typescript@patch:typescript@^4.2.4#~builtin": +"typescript@patch:typescript@^4.6.2#~builtin": version: 4.6.3 resolution: "typescript@patch:typescript@npm%3A4.6.3#~builtin::version=4.6.3&hash=bda367" bin: From 7c63f5981eb20d4b89a4c04f3675e0050d8d7887 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Tue, 19 Apr 2022 12:59:06 +0200 Subject: [PATCH 063/128] v28.0.0-alpha.9 --- lerna.json | 2 +- packages/babel-jest/package.json | 8 ++-- packages/babel-plugin-jest-hoist/package.json | 2 +- packages/babel-preset-jest/package.json | 4 +- packages/diff-sequences/package.json | 2 +- packages/expect-utils/package.json | 4 +- packages/expect/package.json | 10 ++--- packages/jest-circus/package.json | 24 +++++------ packages/jest-cli/package.json | 14 +++---- packages/jest-config/package.json | 22 +++++----- packages/jest-console/package.json | 10 ++--- packages/jest-core/package.json | 40 +++++++++---------- .../package.json | 6 +-- packages/jest-diff/package.json | 8 ++-- packages/jest-each/package.json | 8 ++-- packages/jest-environment-jsdom/package.json | 14 +++---- packages/jest-environment-node/package.json | 14 +++---- packages/jest-environment/package.json | 8 ++-- packages/jest-expect/package.json | 6 +-- packages/jest-fake-timers/package.json | 12 +++--- packages/jest-globals/package.json | 8 ++-- packages/jest-haste-map/package.json | 10 ++--- packages/jest-jasmine2/package.json | 26 ++++++------ packages/jest-leak-detector/package.json | 4 +- packages/jest-matcher-utils/package.json | 8 ++-- packages/jest-message-util/package.json | 6 +-- packages/jest-mock/package.json | 4 +- packages/jest-phabricator/package.json | 4 +- packages/jest-repl/package.json | 18 ++++----- packages/jest-reporters/package.json | 18 ++++----- .../jest-resolve-dependencies/package.json | 14 +++---- packages/jest-resolve/package.json | 8 ++-- packages/jest-runner/package.json | 32 +++++++-------- packages/jest-runtime/package.json | 32 +++++++-------- packages/jest-snapshot/package.json | 24 +++++------ packages/jest-source-map/package.json | 2 +- packages/jest-test-result/package.json | 6 +-- packages/jest-test-sequencer/package.json | 8 ++-- packages/jest-transform/package.json | 10 ++--- packages/jest-types/package.json | 2 +- packages/jest-util/package.json | 4 +- packages/jest-validate/package.json | 6 +-- packages/jest-watcher/package.json | 8 ++-- packages/jest-worker/package.json | 4 +- packages/jest/package.json | 6 +-- packages/pretty-format/package.json | 6 +-- packages/test-utils/package.json | 6 +-- 47 files changed, 251 insertions(+), 251 deletions(-) diff --git a/lerna.json b/lerna.json index e21772fafa37..23ea308570fa 100644 --- a/lerna.json +++ b/lerna.json @@ -3,5 +3,5 @@ "packages/*" ], "npmClient": "yarn", - "version": "28.0.0-alpha.8" + "version": "28.0.0-alpha.9" } diff --git a/packages/babel-jest/package.json b/packages/babel-jest/package.json index 9569215554fc..2b7c26f25ad8 100644 --- a/packages/babel-jest/package.json +++ b/packages/babel-jest/package.json @@ -1,7 +1,7 @@ { "name": "babel-jest", "description": "Jest plugin to use babel for transformation.", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,17 +18,17 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/transform": "^28.0.0-alpha.8", + "@jest/transform": "^28.0.0-alpha.9", "@types/babel__core": "^7.1.14", "babel-plugin-istanbul": "^6.1.1", - "babel-preset-jest": "^28.0.0-alpha.6", + "babel-preset-jest": "^28.0.0-alpha.9", "chalk": "^4.0.0", "graceful-fs": "^4.2.9", "slash": "^3.0.0" }, "devDependencies": { "@babel/core": "^7.11.6", - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/graceful-fs": "^4.1.3" }, "peerDependencies": { diff --git a/packages/babel-plugin-jest-hoist/package.json b/packages/babel-plugin-jest-hoist/package.json index 4d098a389a54..2edd9e59a955 100644 --- a/packages/babel-plugin-jest-hoist/package.json +++ b/packages/babel-plugin-jest-hoist/package.json @@ -1,6 +1,6 @@ { "name": "babel-plugin-jest-hoist", - "version": "28.0.0-alpha.6", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/babel-preset-jest/package.json b/packages/babel-preset-jest/package.json index 93db3751fa04..67abf64ea156 100644 --- a/packages/babel-preset-jest/package.json +++ b/packages/babel-preset-jest/package.json @@ -1,6 +1,6 @@ { "name": "babel-preset-jest", - "version": "28.0.0-alpha.6", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -13,7 +13,7 @@ "./package.json": "./package.json" }, "dependencies": { - "babel-plugin-jest-hoist": "^28.0.0-alpha.6", + "babel-plugin-jest-hoist": "^28.0.0-alpha.9", "babel-preset-current-node-syntax": "^1.0.0" }, "peerDependencies": { diff --git a/packages/diff-sequences/package.json b/packages/diff-sequences/package.json index 813282810b5b..35b29a321400 100644 --- a/packages/diff-sequences/package.json +++ b/packages/diff-sequences/package.json @@ -1,6 +1,6 @@ { "name": "diff-sequences", - "version": "28.0.0-alpha.6", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/expect-utils/package.json b/packages/expect-utils/package.json index 5d27746dbdac..dbe7893f3c7f 100644 --- a/packages/expect-utils/package.json +++ b/packages/expect-utils/package.json @@ -1,6 +1,6 @@ { "name": "@jest/expect-utils", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -20,7 +20,7 @@ "jest-get-type": "^28.0.0-alpha.3" }, "devDependencies": { - "jest-matcher-utils": "^28.0.0-alpha.8" + "jest-matcher-utils": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/expect/package.json b/packages/expect/package.json index d2c688d7b5cc..a46e3f021fe2 100644 --- a/packages/expect/package.json +++ b/packages/expect/package.json @@ -1,6 +1,6 @@ { "name": "expect", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,13 +18,13 @@ "./build/matchers": "./build/matchers.js" }, "dependencies": { - "@jest/expect-utils": "^28.0.0-alpha.8", + "@jest/expect-utils": "^28.0.0-alpha.9", "jest-get-type": "^28.0.0-alpha.3", - "jest-matcher-utils": "^28.0.0-alpha.8", - "jest-message-util": "^28.0.0-alpha.8" + "jest-matcher-utils": "^28.0.0-alpha.9", + "jest-message-util": "^28.0.0-alpha.9" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@tsd/typescript": "~4.6.2", "chalk": "^4.0.0", "fast-check": "^2.0.0", diff --git a/packages/jest-circus/package.json b/packages/jest-circus/package.json index e16e8e5df6ef..c84ffcad737b 100644 --- a/packages/jest-circus/package.json +++ b/packages/jest-circus/package.json @@ -1,6 +1,6 @@ { "name": "jest-circus", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,22 +18,22 @@ "./runner": "./runner.js" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.8", - "@jest/expect": "^28.0.0-alpha.8", - "@jest/test-result": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/environment": "^28.0.0-alpha.9", + "@jest/expect": "^28.0.0-alpha.9", + "@jest/test-result": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "chalk": "^4.0.0", "co": "^4.6.0", "dedent": "^0.7.0", "is-generator-fn": "^2.0.0", - "jest-each": "^28.0.0-alpha.8", - "jest-matcher-utils": "^28.0.0-alpha.8", - "jest-message-util": "^28.0.0-alpha.8", - "jest-runtime": "^28.0.0-alpha.8", - "jest-snapshot": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", - "pretty-format": "^28.0.0-alpha.8", + "jest-each": "^28.0.0-alpha.9", + "jest-matcher-utils": "^28.0.0-alpha.9", + "jest-message-util": "^28.0.0-alpha.9", + "jest-runtime": "^28.0.0-alpha.9", + "jest-snapshot": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", + "pretty-format": "^28.0.0-alpha.9", "slash": "^3.0.0", "stack-utils": "^2.0.3", "throat": "^6.0.1" diff --git a/packages/jest-cli/package.json b/packages/jest-cli/package.json index ebc5fc2fa94d..27150b8f2ce1 100644 --- a/packages/jest-cli/package.json +++ b/packages/jest-cli/package.json @@ -1,7 +1,7 @@ { "name": "jest-cli", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,16 +13,16 @@ "./bin/jest": "./bin/jest.js" }, "dependencies": { - "@jest/core": "^28.0.0-alpha.8", - "@jest/test-result": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/core": "^28.0.0-alpha.9", + "@jest/test-result": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", "exit": "^0.1.2", "graceful-fs": "^4.2.9", "import-local": "^3.0.2", - "jest-config": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", - "jest-validate": "^28.0.0-alpha.8", + "jest-config": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", + "jest-validate": "^28.0.0-alpha.9", "prompts": "^2.0.1", "yargs": "^17.3.1" }, diff --git a/packages/jest-config/package.json b/packages/jest-config/package.json index 611a9c064e1f..b2912d9d80dd 100644 --- a/packages/jest-config/package.json +++ b/packages/jest-config/package.json @@ -1,6 +1,6 @@ { "name": "jest-config", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -30,25 +30,25 @@ }, "dependencies": { "@babel/core": "^7.11.6", - "@jest/test-sequencer": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", - "babel-jest": "^28.0.0-alpha.8", + "@jest/test-sequencer": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", + "babel-jest": "^28.0.0-alpha.9", "chalk": "^4.0.0", "ci-info": "^3.2.0", "deepmerge": "^4.2.2", "glob": "^7.1.3", "graceful-fs": "^4.2.9", - "jest-circus": "^28.0.0-alpha.8", - "jest-environment-node": "^28.0.0-alpha.8", + "jest-circus": "^28.0.0-alpha.9", + "jest-environment-node": "^28.0.0-alpha.9", "jest-get-type": "^28.0.0-alpha.3", "jest-regex-util": "^28.0.0-alpha.6", - "jest-resolve": "^28.0.0-alpha.8", - "jest-runner": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", - "jest-validate": "^28.0.0-alpha.8", + "jest-resolve": "^28.0.0-alpha.9", + "jest-runner": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", + "jest-validate": "^28.0.0-alpha.9", "micromatch": "^4.0.4", "parse-json": "^5.2.0", - "pretty-format": "^28.0.0-alpha.8", + "pretty-format": "^28.0.0-alpha.9", "slash": "^3.0.0", "strip-json-comments": "^3.1.1" }, diff --git a/packages/jest-console/package.json b/packages/jest-console/package.json index dbedb42b36d8..0a9de65eebee 100644 --- a/packages/jest-console/package.json +++ b/packages/jest-console/package.json @@ -1,6 +1,6 @@ { "name": "@jest/console", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,15 +17,15 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "chalk": "^4.0.0", - "jest-message-util": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", + "jest-message-util": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", "slash": "^3.0.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8" + "@jest/test-utils": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-core/package.json b/packages/jest-core/package.json index fc2f73eff86d..b77f728a9b3f 100644 --- a/packages/jest-core/package.json +++ b/packages/jest-core/package.json @@ -1,7 +1,7 @@ { "name": "@jest/core", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -12,11 +12,11 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/console": "^28.0.0-alpha.8", - "@jest/reporters": "^28.0.0-alpha.8", - "@jest/test-result": "^28.0.0-alpha.8", - "@jest/transform": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/console": "^28.0.0-alpha.9", + "@jest/reporters": "^28.0.0-alpha.9", + "@jest/test-result": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "ansi-escapes": "^4.2.1", "chalk": "^4.0.0", @@ -24,27 +24,27 @@ "exit": "^0.1.2", "graceful-fs": "^4.2.9", "jest-changed-files": "^28.0.0-alpha.3", - "jest-config": "^28.0.0-alpha.8", - "jest-haste-map": "^28.0.0-alpha.8", - "jest-message-util": "^28.0.0-alpha.8", + "jest-config": "^28.0.0-alpha.9", + "jest-haste-map": "^28.0.0-alpha.9", + "jest-message-util": "^28.0.0-alpha.9", "jest-regex-util": "^28.0.0-alpha.6", - "jest-resolve": "^28.0.0-alpha.8", - "jest-resolve-dependencies": "^28.0.0-alpha.8", - "jest-runner": "^28.0.0-alpha.8", - "jest-runtime": "^28.0.0-alpha.8", - "jest-snapshot": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", - "jest-validate": "^28.0.0-alpha.8", - "jest-watcher": "^28.0.0-alpha.8", + "jest-resolve": "^28.0.0-alpha.9", + "jest-resolve-dependencies": "^28.0.0-alpha.9", + "jest-runner": "^28.0.0-alpha.9", + "jest-runtime": "^28.0.0-alpha.9", + "jest-snapshot": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", + "jest-validate": "^28.0.0-alpha.9", + "jest-watcher": "^28.0.0-alpha.9", "micromatch": "^4.0.4", - "pretty-format": "^28.0.0-alpha.8", + "pretty-format": "^28.0.0-alpha.9", "rimraf": "^3.0.0", "slash": "^3.0.0", "strip-ansi": "^6.0.0" }, "devDependencies": { - "@jest/test-sequencer": "^28.0.0-alpha.8", - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-sequencer": "^28.0.0-alpha.9", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/exit": "^0.1.30", "@types/graceful-fs": "^4.1.3", "@types/micromatch": "^4.0.1", diff --git a/packages/jest-create-cache-key-function/package.json b/packages/jest-create-cache-key-function/package.json index cd16da4ab3cc..d4803daa6a0a 100644 --- a/packages/jest-create-cache-key-function/package.json +++ b/packages/jest-create-cache-key-function/package.json @@ -1,17 +1,17 @@ { "name": "@jest/create-cache-key-function", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", "directory": "packages/jest-create-cache-key-function" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.8" + "@jest/types": "^28.0.0-alpha.9" }, "devDependencies": { "@types/node": "*", - "jest-util": "^28.0.0-alpha.8" + "jest-util": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-diff/package.json b/packages/jest-diff/package.json index cf94c5f0a8fa..f1db6618e238 100644 --- a/packages/jest-diff/package.json +++ b/packages/jest-diff/package.json @@ -1,6 +1,6 @@ { "name": "jest-diff", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,12 +18,12 @@ }, "dependencies": { "chalk": "^4.0.0", - "diff-sequences": "^28.0.0-alpha.6", + "diff-sequences": "^28.0.0-alpha.9", "jest-get-type": "^28.0.0-alpha.3", - "pretty-format": "^28.0.0-alpha.8" + "pretty-format": "^28.0.0-alpha.9" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "strip-ansi": "^6.0.0" }, "engines": { diff --git a/packages/jest-each/package.json b/packages/jest-each/package.json index 8dae4cabb5d1..e34ce3c604e4 100644 --- a/packages/jest-each/package.json +++ b/packages/jest-each/package.json @@ -1,6 +1,6 @@ { "name": "jest-each", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "description": "Parameterised tests for Jest", "main": "./build/index.js", "types": "./build/index.d.ts", @@ -25,11 +25,11 @@ "author": "Matt Phillips (mattphillips)", "license": "MIT", "dependencies": { - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", "jest-get-type": "^28.0.0-alpha.3", - "jest-util": "^28.0.0-alpha.8", - "pretty-format": "^28.0.0-alpha.8" + "jest-util": "^28.0.0-alpha.9", + "pretty-format": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-environment-jsdom/package.json b/packages/jest-environment-jsdom/package.json index d5e29636b9db..d53cba5498f3 100644 --- a/packages/jest-environment-jsdom/package.json +++ b/packages/jest-environment-jsdom/package.json @@ -1,6 +1,6 @@ { "name": "jest-environment-jsdom", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,17 +17,17 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.8", - "@jest/fake-timers": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/environment": "^28.0.0-alpha.9", + "@jest/fake-timers": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/jsdom": "^16.2.4", "@types/node": "*", - "jest-mock": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", + "jest-mock": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", "jsdom": "^19.0.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8" + "@jest/test-utils": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-environment-node/package.json b/packages/jest-environment-node/package.json index 90d155384481..bbd63ed3c379 100644 --- a/packages/jest-environment-node/package.json +++ b/packages/jest-environment-node/package.json @@ -1,6 +1,6 @@ { "name": "jest-environment-node", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,15 +17,15 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.8", - "@jest/fake-timers": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/environment": "^28.0.0-alpha.9", + "@jest/fake-timers": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", - "jest-mock": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8" + "jest-mock": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8" + "@jest/test-utils": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-environment/package.json b/packages/jest-environment/package.json index 78158980bae5..4bdfe739d583 100644 --- a/packages/jest-environment/package.json +++ b/packages/jest-environment/package.json @@ -1,6 +1,6 @@ { "name": "@jest/environment", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,10 +17,10 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/fake-timers": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/fake-timers": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", - "jest-mock": "^28.0.0-alpha.8" + "jest-mock": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-expect/package.json b/packages/jest-expect/package.json index 79e909ed9d9c..422c49d767ed 100644 --- a/packages/jest-expect/package.json +++ b/packages/jest-expect/package.json @@ -1,6 +1,6 @@ { "name": "@jest/expect", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,8 +17,8 @@ "./package.json": "./package.json" }, "dependencies": { - "expect": "^28.0.0-alpha.8", - "jest-snapshot": "^28.0.0-alpha.8" + "expect": "^28.0.0-alpha.9", + "jest-snapshot": "^28.0.0-alpha.9" }, "devDependencies": { "@tsd/typescript": "~4.6.2", diff --git a/packages/jest-fake-timers/package.json b/packages/jest-fake-timers/package.json index 1f2c80dec533..ea8ad0b0cfba 100644 --- a/packages/jest-fake-timers/package.json +++ b/packages/jest-fake-timers/package.json @@ -1,6 +1,6 @@ { "name": "@jest/fake-timers", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,15 +17,15 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "@sinonjs/fake-timers": "^9.1.1", "@types/node": "*", - "jest-message-util": "^28.0.0-alpha.8", - "jest-mock": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8" + "jest-message-util": "^28.0.0-alpha.9", + "jest-mock": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/sinonjs__fake-timers": "^8.1.2" }, "engines": { diff --git a/packages/jest-globals/package.json b/packages/jest-globals/package.json index 7cf73b85cc3d..effeab2924fb 100644 --- a/packages/jest-globals/package.json +++ b/packages/jest-globals/package.json @@ -1,6 +1,6 @@ { "name": "@jest/globals", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -20,9 +20,9 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.8", - "@jest/expect": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8" + "@jest/environment": "^28.0.0-alpha.9", + "@jest/expect": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9" }, "publishConfig": { "access": "public" diff --git a/packages/jest-haste-map/package.json b/packages/jest-haste-map/package.json index b3d7dfc72f66..4230c2bdbacf 100644 --- a/packages/jest-haste-map/package.json +++ b/packages/jest-haste-map/package.json @@ -1,6 +1,6 @@ { "name": "jest-haste-map", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,20 +17,20 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "@types/graceful-fs": "^4.1.3", "@types/node": "*", "anymatch": "^3.0.3", "fb-watchman": "^2.0.0", "graceful-fs": "^4.2.9", "jest-regex-util": "^28.0.0-alpha.6", - "jest-util": "^28.0.0-alpha.8", - "jest-worker": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.9", + "jest-worker": "^28.0.0-alpha.9", "micromatch": "^4.0.4", "walker": "^1.0.7" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/fb-watchman": "^2.0.0", "@types/micromatch": "^4.0.1", "slash": "^3.0.0" diff --git a/packages/jest-jasmine2/package.json b/packages/jest-jasmine2/package.json index 24ae48e171fd..a156dd5f9e4e 100644 --- a/packages/jest-jasmine2/package.json +++ b/packages/jest-jasmine2/package.json @@ -1,6 +1,6 @@ { "name": "jest-jasmine2", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,22 +17,22 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.8", - "@jest/expect": "^28.0.0-alpha.8", - "@jest/source-map": "^28.0.0-alpha.6", - "@jest/test-result": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/environment": "^28.0.0-alpha.9", + "@jest/expect": "^28.0.0-alpha.9", + "@jest/source-map": "^28.0.0-alpha.9", + "@jest/test-result": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "chalk": "^4.0.0", "co": "^4.6.0", "is-generator-fn": "^2.0.0", - "jest-each": "^28.0.0-alpha.8", - "jest-matcher-utils": "^28.0.0-alpha.8", - "jest-message-util": "^28.0.0-alpha.8", - "jest-runtime": "^28.0.0-alpha.8", - "jest-snapshot": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", - "pretty-format": "^28.0.0-alpha.8", + "jest-each": "^28.0.0-alpha.9", + "jest-matcher-utils": "^28.0.0-alpha.9", + "jest-message-util": "^28.0.0-alpha.9", + "jest-runtime": "^28.0.0-alpha.9", + "jest-snapshot": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", + "pretty-format": "^28.0.0-alpha.9", "throat": "^6.0.1" }, "devDependencies": { diff --git a/packages/jest-leak-detector/package.json b/packages/jest-leak-detector/package.json index 8763a0ceb5af..7e2cb596c652 100644 --- a/packages/jest-leak-detector/package.json +++ b/packages/jest-leak-detector/package.json @@ -1,6 +1,6 @@ { "name": "jest-leak-detector", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,7 +18,7 @@ }, "dependencies": { "jest-get-type": "^28.0.0-alpha.3", - "pretty-format": "^28.0.0-alpha.8" + "pretty-format": "^28.0.0-alpha.9" }, "devDependencies": { "@types/weak-napi": "^2.0.0", diff --git a/packages/jest-matcher-utils/package.json b/packages/jest-matcher-utils/package.json index ff34ef3bd8a2..8b888b11dc73 100644 --- a/packages/jest-matcher-utils/package.json +++ b/packages/jest-matcher-utils/package.json @@ -1,7 +1,7 @@ { "name": "jest-matcher-utils", "description": "A set of utility functions for expect and related packages", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -22,12 +22,12 @@ }, "dependencies": { "chalk": "^4.0.0", - "jest-diff": "^28.0.0-alpha.8", + "jest-diff": "^28.0.0-alpha.9", "jest-get-type": "^28.0.0-alpha.3", - "pretty-format": "^28.0.0-alpha.8" + "pretty-format": "^28.0.0-alpha.9" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/node": "*" }, "publishConfig": { diff --git a/packages/jest-message-util/package.json b/packages/jest-message-util/package.json index 4ba9f7f236cd..74113fa9cbc9 100644 --- a/packages/jest-message-util/package.json +++ b/packages/jest-message-util/package.json @@ -1,6 +1,6 @@ { "name": "jest-message-util", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -21,12 +21,12 @@ }, "dependencies": { "@babel/code-frame": "^7.12.13", - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "@types/stack-utils": "^2.0.0", "chalk": "^4.0.0", "graceful-fs": "^4.2.9", "micromatch": "^4.0.4", - "pretty-format": "^28.0.0-alpha.8", + "pretty-format": "^28.0.0-alpha.9", "slash": "^3.0.0", "stack-utils": "^2.0.3" }, diff --git a/packages/jest-mock/package.json b/packages/jest-mock/package.json index bdb0c0afcf6f..388dfe478cc6 100644 --- a/packages/jest-mock/package.json +++ b/packages/jest-mock/package.json @@ -1,6 +1,6 @@ { "name": "jest-mock", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,7 +17,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*" }, "devDependencies": { diff --git a/packages/jest-phabricator/package.json b/packages/jest-phabricator/package.json index 231a1893a5b0..6309c48a944c 100644 --- a/packages/jest-phabricator/package.json +++ b/packages/jest-phabricator/package.json @@ -1,6 +1,6 @@ { "name": "jest-phabricator", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -15,7 +15,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/test-result": "^28.0.0-alpha.8" + "@jest/test-result": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-repl/package.json b/packages/jest-repl/package.json index c223965d108a..9e17f9a70a5b 100644 --- a/packages/jest-repl/package.json +++ b/packages/jest-repl/package.json @@ -1,6 +1,6 @@ { "name": "jest-repl", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -19,15 +19,15 @@ "./bin/jest-runtime-cli": "./bin/jest-runtime-cli.js" }, "dependencies": { - "@jest/console": "^28.0.0-alpha.8", - "@jest/environment": "^28.0.0-alpha.8", - "@jest/transform": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/console": "^28.0.0-alpha.9", + "@jest/environment": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", - "jest-config": "^28.0.0-alpha.8", - "jest-runtime": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", - "jest-validate": "^28.0.0-alpha.8", + "jest-config": "^28.0.0-alpha.9", + "jest-runtime": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", + "jest-validate": "^28.0.0-alpha.9", "repl": "^0.1.3", "yargs": "^17.3.1" }, diff --git a/packages/jest-reporters/package.json b/packages/jest-reporters/package.json index c5dcc7464083..a79b91382150 100644 --- a/packages/jest-reporters/package.json +++ b/packages/jest-reporters/package.json @@ -1,7 +1,7 @@ { "name": "@jest/reporters", "description": "Jest's reporters", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,10 +13,10 @@ }, "dependencies": { "@bcoe/v8-coverage": "^0.2.3", - "@jest/console": "^28.0.0-alpha.8", - "@jest/test-result": "^28.0.0-alpha.8", - "@jest/transform": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/console": "^28.0.0-alpha.9", + "@jest/test-result": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "chalk": "^4.0.0", "collect-v8-coverage": "^1.0.0", @@ -28,8 +28,8 @@ "istanbul-lib-report": "^3.0.0", "istanbul-lib-source-maps": "^4.0.0", "istanbul-reports": "^3.1.3", - "jest-util": "^28.0.0-alpha.8", - "jest-worker": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.9", + "jest-worker": "^28.0.0-alpha.9", "slash": "^3.0.0", "source-map": "^0.6.1", "string-length": "^4.0.1", @@ -37,7 +37,7 @@ "v8-to-istanbul": "^8.1.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/exit": "^0.1.30", "@types/glob": "^7.1.1", "@types/graceful-fs": "^4.1.3", @@ -47,7 +47,7 @@ "@types/istanbul-lib-source-maps": "^4.0.0", "@types/istanbul-reports": "^3.0.0", "@types/node-notifier": "^8.0.0", - "jest-resolve": "^28.0.0-alpha.8", + "jest-resolve": "^28.0.0-alpha.9", "mock-fs": "^5.1.2", "strip-ansi": "^6.0.0" }, diff --git a/packages/jest-resolve-dependencies/package.json b/packages/jest-resolve-dependencies/package.json index b17dd116adfc..d1fb54158692 100644 --- a/packages/jest-resolve-dependencies/package.json +++ b/packages/jest-resolve-dependencies/package.json @@ -1,6 +1,6 @@ { "name": "jest-resolve-dependencies", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,14 +18,14 @@ }, "dependencies": { "jest-regex-util": "^28.0.0-alpha.6", - "jest-snapshot": "^28.0.0-alpha.8" + "jest-snapshot": "^28.0.0-alpha.9" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", - "jest-haste-map": "^28.0.0-alpha.8", - "jest-resolve": "^28.0.0-alpha.8", - "jest-runtime": "^28.0.0-alpha.8" + "@jest/test-utils": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", + "jest-haste-map": "^28.0.0-alpha.9", + "jest-resolve": "^28.0.0-alpha.9", + "jest-runtime": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-resolve/package.json b/packages/jest-resolve/package.json index 2affa9109365..0f4dae47588c 100644 --- a/packages/jest-resolve/package.json +++ b/packages/jest-resolve/package.json @@ -1,6 +1,6 @@ { "name": "jest-resolve", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -19,10 +19,10 @@ "dependencies": { "chalk": "^4.0.0", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.8", + "jest-haste-map": "^28.0.0-alpha.9", "jest-pnp-resolver": "^1.2.2", - "jest-util": "^28.0.0-alpha.8", - "jest-validate": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.9", + "jest-validate": "^28.0.0-alpha.9", "resolve": "^1.20.0", "resolve.exports": "^1.1.0", "slash": "^3.0.0" diff --git a/packages/jest-runner/package.json b/packages/jest-runner/package.json index e3de29991744..b0f7a269641b 100644 --- a/packages/jest-runner/package.json +++ b/packages/jest-runner/package.json @@ -1,6 +1,6 @@ { "name": "jest-runner", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,25 +17,25 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/console": "^28.0.0-alpha.8", - "@jest/environment": "^28.0.0-alpha.8", - "@jest/test-result": "^28.0.0-alpha.8", - "@jest/transform": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/console": "^28.0.0-alpha.9", + "@jest/environment": "^28.0.0-alpha.9", + "@jest/test-result": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "chalk": "^4.0.0", "emittery": "^0.10.2", "graceful-fs": "^4.2.9", "jest-docblock": "^28.0.0-alpha.6", - "jest-environment-node": "^28.0.0-alpha.8", - "jest-haste-map": "^28.0.0-alpha.8", - "jest-leak-detector": "^28.0.0-alpha.8", - "jest-message-util": "^28.0.0-alpha.8", - "jest-resolve": "^28.0.0-alpha.8", - "jest-runtime": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", - "jest-watcher": "^28.0.0-alpha.8", - "jest-worker": "^28.0.0-alpha.8", + "jest-environment-node": "^28.0.0-alpha.9", + "jest-haste-map": "^28.0.0-alpha.9", + "jest-leak-detector": "^28.0.0-alpha.9", + "jest-message-util": "^28.0.0-alpha.9", + "jest-resolve": "^28.0.0-alpha.9", + "jest-runtime": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", + "jest-watcher": "^28.0.0-alpha.9", + "jest-worker": "^28.0.0-alpha.9", "source-map-support": "^0.5.6", "throat": "^6.0.1" }, @@ -44,7 +44,7 @@ "@types/exit": "^0.1.30", "@types/graceful-fs": "^4.1.3", "@types/source-map-support": "^0.5.0", - "jest-jasmine2": "^28.0.0-alpha.8", + "jest-jasmine2": "^28.0.0-alpha.9", "tsd-lite": "^0.5.1" }, "engines": { diff --git a/packages/jest-runtime/package.json b/packages/jest-runtime/package.json index ddf360901263..3f062fc2accc 100644 --- a/packages/jest-runtime/package.json +++ b/packages/jest-runtime/package.json @@ -1,6 +1,6 @@ { "name": "jest-runtime", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,35 +17,35 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.8", - "@jest/fake-timers": "^28.0.0-alpha.8", - "@jest/globals": "^28.0.0-alpha.8", - "@jest/source-map": "^28.0.0-alpha.6", - "@jest/test-result": "^28.0.0-alpha.8", - "@jest/transform": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/environment": "^28.0.0-alpha.9", + "@jest/fake-timers": "^28.0.0-alpha.9", + "@jest/globals": "^28.0.0-alpha.9", + "@jest/source-map": "^28.0.0-alpha.9", + "@jest/test-result": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", "cjs-module-lexer": "^1.0.0", "collect-v8-coverage": "^1.0.0", "execa": "^5.0.0", "glob": "^7.1.3", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.8", - "jest-message-util": "^28.0.0-alpha.8", - "jest-mock": "^28.0.0-alpha.8", + "jest-haste-map": "^28.0.0-alpha.9", + "jest-message-util": "^28.0.0-alpha.9", + "jest-mock": "^28.0.0-alpha.9", "jest-regex-util": "^28.0.0-alpha.6", - "jest-resolve": "^28.0.0-alpha.8", - "jest-snapshot": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", + "jest-resolve": "^28.0.0-alpha.9", + "jest-snapshot": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", "slash": "^3.0.0", "strip-bom": "^4.0.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/glob": "^7.1.1", "@types/graceful-fs": "^4.1.3", "@types/node": "*", - "jest-environment-node": "^28.0.0-alpha.8" + "jest-environment-node": "^28.0.0-alpha.9" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-snapshot/package.json b/packages/jest-snapshot/package.json index e7a723585dc8..de10164f7079 100644 --- a/packages/jest-snapshot/package.json +++ b/packages/jest-snapshot/package.json @@ -1,6 +1,6 @@ { "name": "jest-snapshot", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -22,29 +22,29 @@ "@babel/plugin-syntax-typescript": "^7.7.2", "@babel/traverse": "^7.7.2", "@babel/types": "^7.3.3", - "@jest/expect-utils": "^28.0.0-alpha.8", - "@jest/transform": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/expect-utils": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/babel__traverse": "^7.0.6", "@types/prettier": "^2.1.5", "babel-preset-current-node-syntax": "^1.0.0", "chalk": "^4.0.0", - "expect": "^28.0.0-alpha.8", + "expect": "^28.0.0-alpha.9", "graceful-fs": "^4.2.9", - "jest-diff": "^28.0.0-alpha.8", + "jest-diff": "^28.0.0-alpha.9", "jest-get-type": "^28.0.0-alpha.3", - "jest-haste-map": "^28.0.0-alpha.8", - "jest-matcher-utils": "^28.0.0-alpha.8", - "jest-message-util": "^28.0.0-alpha.8", - "jest-util": "^28.0.0-alpha.8", + "jest-haste-map": "^28.0.0-alpha.9", + "jest-matcher-utils": "^28.0.0-alpha.9", + "jest-message-util": "^28.0.0-alpha.9", + "jest-util": "^28.0.0-alpha.9", "natural-compare": "^1.4.0", - "pretty-format": "^28.0.0-alpha.8", + "pretty-format": "^28.0.0-alpha.9", "semver": "^7.3.5" }, "devDependencies": { "@babel/preset-flow": "^7.7.2", "@babel/preset-react": "^7.12.1", - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/graceful-fs": "^4.1.3", "@types/natural-compare": "^1.4.0", "@types/semver": "^7.1.0", diff --git a/packages/jest-source-map/package.json b/packages/jest-source-map/package.json index f26f1d26ad40..b57ea028f33b 100644 --- a/packages/jest-source-map/package.json +++ b/packages/jest-source-map/package.json @@ -1,6 +1,6 @@ { "name": "@jest/source-map", - "version": "28.0.0-alpha.6", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/jest-test-result/package.json b/packages/jest-test-result/package.json index ed707e86e1ca..6648d6353b02 100644 --- a/packages/jest-test-result/package.json +++ b/packages/jest-test-result/package.json @@ -1,6 +1,6 @@ { "name": "@jest/test-result", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,8 +17,8 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/console": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/console": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/istanbul-lib-coverage": "^2.0.0", "collect-v8-coverage": "^1.0.0" }, diff --git a/packages/jest-test-sequencer/package.json b/packages/jest-test-sequencer/package.json index 468c5360f8a0..cdac32b85ff9 100644 --- a/packages/jest-test-sequencer/package.json +++ b/packages/jest-test-sequencer/package.json @@ -1,6 +1,6 @@ { "name": "@jest/test-sequencer", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,13 +17,13 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/test-result": "^28.0.0-alpha.8", + "@jest/test-result": "^28.0.0-alpha.9", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.8", + "jest-haste-map": "^28.0.0-alpha.9", "slash": "^3.0.0" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/graceful-fs": "^4.1.3" }, "engines": { diff --git a/packages/jest-transform/package.json b/packages/jest-transform/package.json index 7731c6c7f242..fc42a0eabb8b 100644 --- a/packages/jest-transform/package.json +++ b/packages/jest-transform/package.json @@ -1,6 +1,6 @@ { "name": "@jest/transform", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,15 +18,15 @@ }, "dependencies": { "@babel/core": "^7.11.6", - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "babel-plugin-istanbul": "^6.1.1", "chalk": "^4.0.0", "convert-source-map": "^1.4.0", "fast-json-stable-stringify": "^2.0.0", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.8", + "jest-haste-map": "^28.0.0-alpha.9", "jest-regex-util": "^28.0.0-alpha.6", - "jest-util": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.9", "micromatch": "^4.0.4", "pirates": "^4.0.4", "slash": "^3.0.0", @@ -34,7 +34,7 @@ "write-file-atomic": "^4.0.1" }, "devDependencies": { - "@jest/test-utils": "^28.0.0-alpha.8", + "@jest/test-utils": "^28.0.0-alpha.9", "@types/babel__core": "^7.1.14", "@types/convert-source-map": "^1.5.1", "@types/fast-json-stable-stringify": "^2.0.0", diff --git a/packages/jest-types/package.json b/packages/jest-types/package.json index ce7eb1d1fc55..7ba428dcdc1b 100644 --- a/packages/jest-types/package.json +++ b/packages/jest-types/package.json @@ -1,6 +1,6 @@ { "name": "@jest/types", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/jest-util/package.json b/packages/jest-util/package.json index 91e53cc5f20c..c38aa17a977e 100644 --- a/packages/jest-util/package.json +++ b/packages/jest-util/package.json @@ -1,6 +1,6 @@ { "name": "jest-util", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,7 +17,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "chalk": "^4.0.0", "ci-info": "^3.2.0", diff --git a/packages/jest-validate/package.json b/packages/jest-validate/package.json index 39e66e80b1bc..c3905194e398 100644 --- a/packages/jest-validate/package.json +++ b/packages/jest-validate/package.json @@ -1,6 +1,6 @@ { "name": "jest-validate", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,12 +17,12 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "camelcase": "^6.2.0", "chalk": "^4.0.0", "jest-get-type": "^28.0.0-alpha.3", "leven": "^3.1.0", - "pretty-format": "^28.0.0-alpha.8" + "pretty-format": "^28.0.0-alpha.9" }, "devDependencies": { "@types/yargs": "^17.0.8" diff --git a/packages/jest-watcher/package.json b/packages/jest-watcher/package.json index 29dd32d11e0b..013e9d24d868 100644 --- a/packages/jest-watcher/package.json +++ b/packages/jest-watcher/package.json @@ -1,7 +1,7 @@ { "name": "jest-watcher", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -12,13 +12,13 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/test-result": "^28.0.0-alpha.8", - "@jest/types": "^28.0.0-alpha.8", + "@jest/test-result": "^28.0.0-alpha.9", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "ansi-escapes": "^4.2.1", "chalk": "^4.0.0", "emittery": "^0.10.2", - "jest-util": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.9", "string-length": "^4.0.1" }, "repository": { diff --git a/packages/jest-worker/package.json b/packages/jest-worker/package.json index 2172efdf53e9..622fa22e0171 100644 --- a/packages/jest-worker/package.json +++ b/packages/jest-worker/package.json @@ -1,6 +1,6 @@ { "name": "jest-worker", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -25,7 +25,7 @@ "@types/merge-stream": "^1.1.2", "@types/supports-color": "^8.1.0", "get-stream": "^6.0.0", - "jest-leak-detector": "^28.0.0-alpha.8", + "jest-leak-detector": "^28.0.0-alpha.9", "worker-farm": "^1.6.0" }, "engines": { diff --git a/packages/jest/package.json b/packages/jest/package.json index 31b201c1b840..bf608678338d 100644 --- a/packages/jest/package.json +++ b/packages/jest/package.json @@ -1,7 +1,7 @@ { "name": "jest", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,9 +13,9 @@ "./bin/jest": "./bin/jest.js" }, "dependencies": { - "@jest/core": "^28.0.0-alpha.8", + "@jest/core": "^28.0.0-alpha.9", "import-local": "^3.0.2", - "jest-cli": "^28.0.0-alpha.8" + "jest-cli": "^28.0.0-alpha.9" }, "peerDependencies": { "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" diff --git a/packages/pretty-format/package.json b/packages/pretty-format/package.json index a118f9674cd5..cea85a9d0583 100644 --- a/packages/pretty-format/package.json +++ b/packages/pretty-format/package.json @@ -1,6 +1,6 @@ { "name": "pretty-format", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -29,9 +29,9 @@ "@types/react": "^17.0.3", "@types/react-is": "^17.0.0", "@types/react-test-renderer": "17.0.2", - "expect": "^28.0.0-alpha.8", + "expect": "^28.0.0-alpha.9", "immutable": "^4.0.0", - "jest-util": "^28.0.0-alpha.8", + "jest-util": "^28.0.0-alpha.9", "react": "17.0.2", "react-dom": "^17.0.1", "react-test-renderer": "17.0.2" diff --git a/packages/test-utils/package.json b/packages/test-utils/package.json index 7b4fea7f3203..b6bb226b1492 100644 --- a/packages/test-utils/package.json +++ b/packages/test-utils/package.json @@ -1,6 +1,6 @@ { "name": "@jest/test-utils", - "version": "28.0.0-alpha.8", + "version": "28.0.0-alpha.9", "private": true, "main": "./build/index.js", "types": "./build/index.d.ts", @@ -12,11 +12,11 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/types": "^28.0.0-alpha.8", + "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "ansi-regex": "^5.0.1", "ansi-styles": "^5.0.0", - "pretty-format": "^28.0.0-alpha.8", + "pretty-format": "^28.0.0-alpha.9", "semver": "^7.3.5" }, "devDependencies": { From e7ccfbfffafd94dc9a23d28ff1e0ac71c853cb05 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Tue, 19 Apr 2022 13:00:20 +0200 Subject: [PATCH 064/128] chore: update lockfile after release --- yarn.lock | 486 +++++++++++++++++++++++++++--------------------------- 1 file changed, 243 insertions(+), 243 deletions(-) diff --git a/yarn.lock b/yarn.lock index ea24da0647df..8384ffd1e1ca 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2511,16 +2511,16 @@ __metadata: languageName: node linkType: hard -"@jest/console@^28.0.0-alpha.8, @jest/console@workspace:packages/jest-console": +"@jest/console@^28.0.0-alpha.9, @jest/console@workspace:packages/jest-console": version: 0.0.0-use.local resolution: "@jest/console@workspace:packages/jest-console" dependencies: - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/node": "*" chalk: ^4.0.0 - jest-message-util: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 + jest-message-util: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 slash: ^3.0.0 languageName: unknown linkType: soft @@ -2539,17 +2539,17 @@ __metadata: languageName: node linkType: hard -"@jest/core@^28.0.0-alpha.8, @jest/core@workspace:packages/jest-core": +"@jest/core@^28.0.0-alpha.9, @jest/core@workspace:packages/jest-core": version: 0.0.0-use.local resolution: "@jest/core@workspace:packages/jest-core" dependencies: - "@jest/console": ^28.0.0-alpha.8 - "@jest/reporters": ^28.0.0-alpha.8 - "@jest/test-result": ^28.0.0-alpha.8 - "@jest/test-sequencer": ^28.0.0-alpha.8 - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/transform": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/console": ^28.0.0-alpha.9 + "@jest/reporters": ^28.0.0-alpha.9 + "@jest/test-result": ^28.0.0-alpha.9 + "@jest/test-sequencer": ^28.0.0-alpha.9 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/exit": ^0.1.30 "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 @@ -2561,20 +2561,20 @@ __metadata: exit: ^0.1.2 graceful-fs: ^4.2.9 jest-changed-files: ^28.0.0-alpha.3 - jest-config: ^28.0.0-alpha.8 - jest-haste-map: ^28.0.0-alpha.8 - jest-message-util: ^28.0.0-alpha.8 + jest-config: ^28.0.0-alpha.9 + jest-haste-map: ^28.0.0-alpha.9 + jest-message-util: ^28.0.0-alpha.9 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.8 - jest-resolve-dependencies: ^28.0.0-alpha.8 - jest-runner: ^28.0.0-alpha.8 - jest-runtime: ^28.0.0-alpha.8 - jest-snapshot: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 - jest-validate: ^28.0.0-alpha.8 - jest-watcher: ^28.0.0-alpha.8 + jest-resolve: ^28.0.0-alpha.9 + jest-resolve-dependencies: ^28.0.0-alpha.9 + jest-runner: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.9 + jest-snapshot: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 + jest-validate: ^28.0.0-alpha.9 + jest-watcher: ^28.0.0-alpha.9 micromatch: ^4.0.4 - pretty-format: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.9 rimraf: ^3.0.0 slash: ^3.0.0 strip-ansi: ^6.0.0 @@ -2599,65 +2599,65 @@ __metadata: version: 0.0.0-use.local resolution: "@jest/create-cache-key-function@workspace:packages/jest-create-cache-key-function" dependencies: - "@jest/types": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.9 "@types/node": "*" - jest-util: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.9 languageName: unknown linkType: soft -"@jest/environment@^28.0.0-alpha.8, @jest/environment@workspace:packages/jest-environment": +"@jest/environment@^28.0.0-alpha.9, @jest/environment@workspace:packages/jest-environment": version: 0.0.0-use.local resolution: "@jest/environment@workspace:packages/jest-environment" dependencies: - "@jest/fake-timers": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/fake-timers": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/node": "*" - jest-mock: ^28.0.0-alpha.8 + jest-mock: ^28.0.0-alpha.9 languageName: unknown linkType: soft -"@jest/expect-utils@^28.0.0-alpha.8, @jest/expect-utils@workspace:packages/expect-utils": +"@jest/expect-utils@^28.0.0-alpha.9, @jest/expect-utils@workspace:packages/expect-utils": version: 0.0.0-use.local resolution: "@jest/expect-utils@workspace:packages/expect-utils" dependencies: jest-get-type: ^28.0.0-alpha.3 - jest-matcher-utils: ^28.0.0-alpha.8 + jest-matcher-utils: ^28.0.0-alpha.9 languageName: unknown linkType: soft -"@jest/expect@^28.0.0-alpha.8, @jest/expect@workspace:packages/jest-expect": +"@jest/expect@^28.0.0-alpha.9, @jest/expect@workspace:packages/jest-expect": version: 0.0.0-use.local resolution: "@jest/expect@workspace:packages/jest-expect" dependencies: "@tsd/typescript": ~4.6.2 - expect: ^28.0.0-alpha.8 - jest-snapshot: ^28.0.0-alpha.8 + expect: ^28.0.0-alpha.9 + jest-snapshot: ^28.0.0-alpha.9 tsd-lite: ^0.5.1 languageName: unknown linkType: soft -"@jest/fake-timers@^28.0.0-alpha.8, @jest/fake-timers@workspace:packages/jest-fake-timers": +"@jest/fake-timers@^28.0.0-alpha.9, @jest/fake-timers@workspace:packages/jest-fake-timers": version: 0.0.0-use.local resolution: "@jest/fake-timers@workspace:packages/jest-fake-timers" dependencies: - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@sinonjs/fake-timers": ^9.1.1 "@types/node": "*" "@types/sinonjs__fake-timers": ^8.1.2 - jest-message-util: ^28.0.0-alpha.8 - jest-mock: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 + jest-message-util: ^28.0.0-alpha.9 + jest-mock: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 languageName: unknown linkType: soft -"@jest/globals@^28.0.0-alpha.8, @jest/globals@workspace:*, @jest/globals@workspace:packages/jest-globals": +"@jest/globals@^28.0.0-alpha.9, @jest/globals@workspace:*, @jest/globals@workspace:packages/jest-globals": version: 0.0.0-use.local resolution: "@jest/globals@workspace:packages/jest-globals" dependencies: - "@jest/environment": ^28.0.0-alpha.8 - "@jest/expect": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/environment": ^28.0.0-alpha.9 + "@jest/expect": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 languageName: unknown linkType: soft @@ -2748,16 +2748,16 @@ __metadata: languageName: unknown linkType: soft -"@jest/reporters@^28.0.0-alpha.8, @jest/reporters@workspace:packages/jest-reporters": +"@jest/reporters@^28.0.0-alpha.9, @jest/reporters@workspace:packages/jest-reporters": version: 0.0.0-use.local resolution: "@jest/reporters@workspace:packages/jest-reporters" dependencies: "@bcoe/v8-coverage": ^0.2.3 - "@jest/console": ^28.0.0-alpha.8 - "@jest/test-result": ^28.0.0-alpha.8 - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/transform": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/console": ^28.0.0-alpha.9 + "@jest/test-result": ^28.0.0-alpha.9 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/exit": ^0.1.30 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 @@ -2778,9 +2778,9 @@ __metadata: istanbul-lib-report: ^3.0.0 istanbul-lib-source-maps: ^4.0.0 istanbul-reports: ^3.1.3 - jest-resolve: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 - jest-worker: ^28.0.0-alpha.8 + jest-resolve: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 + jest-worker: ^28.0.0-alpha.9 mock-fs: ^5.1.2 slash: ^3.0.0 source-map: ^0.6.1 @@ -2804,7 +2804,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/source-map@^28.0.0-alpha.6, @jest/source-map@workspace:packages/jest-source-map": +"@jest/source-map@^28.0.0-alpha.9, @jest/source-map@workspace:packages/jest-source-map": version: 0.0.0-use.local resolution: "@jest/source-map@workspace:packages/jest-source-map" dependencies: @@ -2815,12 +2815,12 @@ __metadata: languageName: unknown linkType: soft -"@jest/test-result@^28.0.0-alpha.8, @jest/test-result@workspace:packages/jest-test-result": +"@jest/test-result@^28.0.0-alpha.9, @jest/test-result@workspace:packages/jest-test-result": version: 0.0.0-use.local resolution: "@jest/test-result@workspace:packages/jest-test-result" dependencies: - "@jest/console": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/console": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/istanbul-lib-coverage": ^2.0.0 collect-v8-coverage: ^1.0.0 languageName: unknown @@ -2838,40 +2838,40 @@ __metadata: languageName: node linkType: hard -"@jest/test-sequencer@^28.0.0-alpha.8, @jest/test-sequencer@workspace:packages/jest-test-sequencer": +"@jest/test-sequencer@^28.0.0-alpha.9, @jest/test-sequencer@workspace:packages/jest-test-sequencer": version: 0.0.0-use.local resolution: "@jest/test-sequencer@workspace:packages/jest-test-sequencer" dependencies: - "@jest/test-result": ^28.0.0-alpha.8 - "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/test-result": ^28.0.0-alpha.9 + "@jest/test-utils": ^28.0.0-alpha.9 "@types/graceful-fs": ^4.1.3 graceful-fs: ^4.2.9 - jest-haste-map: ^28.0.0-alpha.8 + jest-haste-map: ^28.0.0-alpha.9 slash: ^3.0.0 languageName: unknown linkType: soft -"@jest/test-utils@^28.0.0-alpha.8, @jest/test-utils@workspace:*, @jest/test-utils@workspace:packages/test-utils": +"@jest/test-utils@^28.0.0-alpha.9, @jest/test-utils@workspace:*, @jest/test-utils@workspace:packages/test-utils": version: 0.0.0-use.local resolution: "@jest/test-utils@workspace:packages/test-utils" dependencies: - "@jest/types": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.9 "@types/node": "*" "@types/semver": ^7.1.0 ansi-regex: ^5.0.1 ansi-styles: ^5.0.0 - pretty-format: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.9 semver: ^7.3.5 languageName: unknown linkType: soft -"@jest/transform@^28.0.0-alpha.8, @jest/transform@workspace:packages/jest-transform": +"@jest/transform@^28.0.0-alpha.9, @jest/transform@workspace:packages/jest-transform": version: 0.0.0-use.local resolution: "@jest/transform@workspace:packages/jest-transform" dependencies: "@babel/core": ^7.11.6 - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/babel__core": ^7.1.14 "@types/convert-source-map": ^1.5.1 "@types/fast-json-stable-stringify": ^2.0.0 @@ -2884,9 +2884,9 @@ __metadata: dedent: ^0.7.0 fast-json-stable-stringify: ^2.0.0 graceful-fs: ^4.2.9 - jest-haste-map: ^28.0.0-alpha.8 + jest-haste-map: ^28.0.0-alpha.9 jest-regex-util: ^28.0.0-alpha.6 - jest-util: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.9 micromatch: ^4.0.4 pirates: ^4.0.4 slash: ^3.0.0 @@ -2895,7 +2895,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/types@^28.0.0-alpha.8, @jest/types@workspace:packages/jest-types": +"@jest/types@^28.0.0-alpha.9, @jest/types@workspace:packages/jest-types": version: 0.0.0-use.local resolution: "@jest/types@workspace:packages/jest-types" dependencies: @@ -6677,12 +6677,12 @@ __metadata: resolution: "babel-jest@workspace:packages/babel-jest" dependencies: "@babel/core": ^7.11.6 - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/transform": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.9 "@types/babel__core": ^7.1.14 "@types/graceful-fs": ^4.1.3 babel-plugin-istanbul: ^6.1.1 - babel-preset-jest: ^28.0.0-alpha.6 + babel-preset-jest: ^28.0.0-alpha.9 chalk: ^4.0.0 graceful-fs: ^4.2.9 slash: ^3.0.0 @@ -6758,7 +6758,7 @@ __metadata: languageName: node linkType: hard -"babel-plugin-jest-hoist@^28.0.0-alpha.6, babel-plugin-jest-hoist@workspace:packages/babel-plugin-jest-hoist": +"babel-plugin-jest-hoist@^28.0.0-alpha.9, babel-plugin-jest-hoist@workspace:packages/babel-plugin-jest-hoist": version: 0.0.0-use.local resolution: "babel-plugin-jest-hoist@workspace:packages/babel-plugin-jest-hoist" dependencies: @@ -6908,11 +6908,11 @@ __metadata: languageName: node linkType: hard -"babel-preset-jest@^28.0.0-alpha.6, babel-preset-jest@workspace:packages/babel-preset-jest": +"babel-preset-jest@^28.0.0-alpha.9, babel-preset-jest@workspace:packages/babel-preset-jest": version: 0.0.0-use.local resolution: "babel-preset-jest@workspace:packages/babel-preset-jest" dependencies: - babel-plugin-jest-hoist: ^28.0.0-alpha.6 + babel-plugin-jest-hoist: ^28.0.0-alpha.9 babel-preset-current-node-syntax: ^1.0.0 peerDependencies: "@babel/core": ^7.0.0 @@ -9060,7 +9060,7 @@ __metadata: languageName: node linkType: hard -"diff-sequences@^28.0.0-alpha.6, diff-sequences@workspace:packages/diff-sequences": +"diff-sequences@^28.0.0-alpha.9, diff-sequences@workspace:packages/diff-sequences": version: 0.0.0-use.local resolution: "diff-sequences@workspace:packages/diff-sequences" dependencies: @@ -10275,19 +10275,19 @@ __metadata: languageName: node linkType: hard -"expect@^28.0.0-alpha.8, expect@workspace:*, expect@workspace:packages/expect": +"expect@^28.0.0-alpha.9, expect@workspace:*, expect@workspace:packages/expect": version: 0.0.0-use.local resolution: "expect@workspace:packages/expect" dependencies: - "@jest/expect-utils": ^28.0.0-alpha.8 - "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/expect-utils": ^28.0.0-alpha.9 + "@jest/test-utils": ^28.0.0-alpha.9 "@tsd/typescript": ~4.6.2 chalk: ^4.0.0 fast-check: ^2.0.0 immutable: ^4.0.0 jest-get-type: ^28.0.0-alpha.3 - jest-matcher-utils: ^28.0.0-alpha.8 - jest-message-util: ^28.0.0-alpha.8 + jest-matcher-utils: ^28.0.0-alpha.9 + jest-message-util: ^28.0.0-alpha.9 tsd-lite: ^0.5.1 languageName: unknown linkType: soft @@ -13002,16 +13002,16 @@ __metadata: languageName: unknown linkType: soft -"jest-circus@^28.0.0-alpha.8, jest-circus@workspace:packages/jest-circus": +"jest-circus@^28.0.0-alpha.9, jest-circus@workspace:packages/jest-circus": version: 0.0.0-use.local resolution: "jest-circus@workspace:packages/jest-circus" dependencies: "@babel/core": ^7.11.6 "@babel/register": ^7.0.0 - "@jest/environment": ^28.0.0-alpha.8 - "@jest/expect": ^28.0.0-alpha.8 - "@jest/test-result": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/environment": ^28.0.0-alpha.9 + "@jest/expect": ^28.0.0-alpha.9 + "@jest/test-result": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/co": ^4.6.2 "@types/dedent": ^0.7.0 "@types/graceful-fs": ^4.1.3 @@ -13023,26 +13023,26 @@ __metadata: execa: ^5.0.0 graceful-fs: ^4.2.9 is-generator-fn: ^2.0.0 - jest-each: ^28.0.0-alpha.8 - jest-matcher-utils: ^28.0.0-alpha.8 - jest-message-util: ^28.0.0-alpha.8 - jest-runtime: ^28.0.0-alpha.8 - jest-snapshot: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 - pretty-format: ^28.0.0-alpha.8 + jest-each: ^28.0.0-alpha.9 + jest-matcher-utils: ^28.0.0-alpha.9 + jest-message-util: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.9 + jest-snapshot: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 + pretty-format: ^28.0.0-alpha.9 slash: ^3.0.0 stack-utils: ^2.0.3 throat: ^6.0.1 languageName: unknown linkType: soft -"jest-cli@^28.0.0-alpha.8, jest-cli@workspace:packages/jest-cli": +"jest-cli@^28.0.0-alpha.9, jest-cli@workspace:packages/jest-cli": version: 0.0.0-use.local resolution: "jest-cli@workspace:packages/jest-cli" dependencies: - "@jest/core": ^28.0.0-alpha.8 - "@jest/test-result": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/core": ^28.0.0-alpha.9 + "@jest/test-result": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/exit": ^0.1.30 "@types/graceful-fs": ^4.1.3 "@types/prompts": ^2.0.1 @@ -13051,9 +13051,9 @@ __metadata: exit: ^0.1.2 graceful-fs: ^4.2.9 import-local: ^3.0.2 - jest-config: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 - jest-validate: ^28.0.0-alpha.8 + jest-config: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 + jest-validate: ^28.0.0-alpha.9 prompts: ^2.0.1 yargs: ^17.3.1 peerDependencies: @@ -13066,33 +13066,33 @@ __metadata: languageName: unknown linkType: soft -"jest-config@^28.0.0-alpha.8, jest-config@workspace:packages/jest-config": +"jest-config@^28.0.0-alpha.9, jest-config@workspace:packages/jest-config": version: 0.0.0-use.local resolution: "jest-config@workspace:packages/jest-config" dependencies: "@babel/core": ^7.11.6 - "@jest/test-sequencer": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/test-sequencer": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 - babel-jest: ^28.0.0-alpha.8 + babel-jest: ^28.0.0-alpha.9 chalk: ^4.0.0 ci-info: ^3.2.0 deepmerge: ^4.2.2 glob: ^7.1.3 graceful-fs: ^4.2.9 - jest-circus: ^28.0.0-alpha.8 - jest-environment-node: ^28.0.0-alpha.8 + jest-circus: ^28.0.0-alpha.9 + jest-environment-node: ^28.0.0-alpha.9 jest-get-type: ^28.0.0-alpha.3 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.8 - jest-runner: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 - jest-validate: ^28.0.0-alpha.8 + jest-resolve: ^28.0.0-alpha.9 + jest-runner: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 + jest-validate: ^28.0.0-alpha.9 micromatch: ^4.0.4 parse-json: ^5.2.0 - pretty-format: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.9 semver: ^7.3.5 slash: ^3.0.0 strip-json-comments: ^3.1.1 @@ -13109,15 +13109,15 @@ __metadata: languageName: unknown linkType: soft -"jest-diff@^28.0.0-alpha.8, jest-diff@workspace:packages/jest-diff": +"jest-diff@^28.0.0-alpha.9, jest-diff@workspace:packages/jest-diff": version: 0.0.0-use.local resolution: "jest-diff@workspace:packages/jest-diff" dependencies: - "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.9 chalk: ^4.0.0 - diff-sequences: ^28.0.0-alpha.6 + diff-sequences: ^28.0.0-alpha.9 jest-get-type: ^28.0.0-alpha.3 - pretty-format: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.9 strip-ansi: ^6.0.0 languageName: unknown linkType: soft @@ -13143,15 +13143,15 @@ __metadata: languageName: unknown linkType: soft -"jest-each@^28.0.0-alpha.8, jest-each@workspace:packages/jest-each": +"jest-each@^28.0.0-alpha.9, jest-each@workspace:packages/jest-each": version: 0.0.0-use.local resolution: "jest-each@workspace:packages/jest-each" dependencies: - "@jest/types": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.9 chalk: ^4.0.0 jest-get-type: ^28.0.0-alpha.3 - jest-util: ^28.0.0-alpha.8 - pretty-format: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.9 + pretty-format: ^28.0.0-alpha.9 languageName: unknown linkType: soft @@ -13159,14 +13159,14 @@ __metadata: version: 0.0.0-use.local resolution: "jest-environment-jsdom@workspace:packages/jest-environment-jsdom" dependencies: - "@jest/environment": ^28.0.0-alpha.8 - "@jest/fake-timers": ^28.0.0-alpha.8 - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/environment": ^28.0.0-alpha.9 + "@jest/fake-timers": ^28.0.0-alpha.9 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/jsdom": ^16.2.4 "@types/node": "*" - jest-mock: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 + jest-mock: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 jsdom: ^19.0.0 languageName: unknown linkType: soft @@ -13175,13 +13175,13 @@ __metadata: version: 0.0.0-use.local resolution: "jest-environment-node@workspace:packages/jest-environment-node" dependencies: - "@jest/environment": ^28.0.0-alpha.8 - "@jest/fake-timers": ^28.0.0-alpha.8 - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/environment": ^28.0.0-alpha.9 + "@jest/fake-timers": ^28.0.0-alpha.9 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/node": "*" - jest-mock: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 + jest-mock: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 languageName: unknown linkType: soft @@ -13205,12 +13205,12 @@ __metadata: languageName: node linkType: hard -"jest-haste-map@^28.0.0-alpha.8, jest-haste-map@workspace:packages/jest-haste-map": +"jest-haste-map@^28.0.0-alpha.9, jest-haste-map@workspace:packages/jest-haste-map": version: 0.0.0-use.local resolution: "jest-haste-map@workspace:packages/jest-haste-map" dependencies: - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/fb-watchman": ^2.0.0 "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 @@ -13220,8 +13220,8 @@ __metadata: fsevents: ^2.3.2 graceful-fs: ^4.2.9 jest-regex-util: ^28.0.0-alpha.6 - jest-util: ^28.0.0-alpha.8 - jest-worker: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.9 + jest-worker: ^28.0.0-alpha.9 micromatch: ^4.0.4 slash: ^3.0.0 walker: ^1.0.7 @@ -13255,27 +13255,27 @@ __metadata: languageName: node linkType: hard -"jest-jasmine2@^28.0.0-alpha.8, jest-jasmine2@workspace:packages/jest-jasmine2": +"jest-jasmine2@^28.0.0-alpha.9, jest-jasmine2@workspace:packages/jest-jasmine2": version: 0.0.0-use.local resolution: "jest-jasmine2@workspace:packages/jest-jasmine2" dependencies: - "@jest/environment": ^28.0.0-alpha.8 - "@jest/expect": ^28.0.0-alpha.8 - "@jest/source-map": ^28.0.0-alpha.6 - "@jest/test-result": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/environment": ^28.0.0-alpha.9 + "@jest/expect": ^28.0.0-alpha.9 + "@jest/source-map": ^28.0.0-alpha.9 + "@jest/test-result": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/co": ^4.6.2 "@types/node": "*" chalk: ^4.0.0 co: ^4.6.0 is-generator-fn: ^2.0.0 - jest-each: ^28.0.0-alpha.8 - jest-matcher-utils: ^28.0.0-alpha.8 - jest-message-util: ^28.0.0-alpha.8 - jest-runtime: ^28.0.0-alpha.8 - jest-snapshot: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 - pretty-format: ^28.0.0-alpha.8 + jest-each: ^28.0.0-alpha.9 + jest-matcher-utils: ^28.0.0-alpha.9 + jest-message-util: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.9 + jest-snapshot: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 + pretty-format: ^28.0.0-alpha.9 throat: ^6.0.1 languageName: unknown linkType: soft @@ -13292,27 +13292,27 @@ __metadata: languageName: node linkType: hard -"jest-leak-detector@^28.0.0-alpha.8, jest-leak-detector@workspace:packages/jest-leak-detector": +"jest-leak-detector@^28.0.0-alpha.9, jest-leak-detector@workspace:packages/jest-leak-detector": version: 0.0.0-use.local resolution: "jest-leak-detector@workspace:packages/jest-leak-detector" dependencies: "@types/weak-napi": ^2.0.0 jest-get-type: ^28.0.0-alpha.3 - pretty-format: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.9 weak-napi: ^2.0.1 languageName: unknown linkType: soft -"jest-matcher-utils@^28.0.0-alpha.8, jest-matcher-utils@workspace:packages/jest-matcher-utils": +"jest-matcher-utils@^28.0.0-alpha.9, jest-matcher-utils@workspace:packages/jest-matcher-utils": version: 0.0.0-use.local resolution: "jest-matcher-utils@workspace:packages/jest-matcher-utils" dependencies: - "@jest/test-utils": ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.9 "@types/node": "*" chalk: ^4.0.0 - jest-diff: ^28.0.0-alpha.8 + jest-diff: ^28.0.0-alpha.9 jest-get-type: ^28.0.0-alpha.3 - pretty-format: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.9 languageName: unknown linkType: soft @@ -13328,12 +13328,12 @@ __metadata: languageName: node linkType: hard -"jest-message-util@^28.0.0-alpha.8, jest-message-util@workspace:packages/jest-message-util": +"jest-message-util@^28.0.0-alpha.9, jest-message-util@workspace:packages/jest-message-util": version: 0.0.0-use.local resolution: "jest-message-util@workspace:packages/jest-message-util" dependencies: "@babel/code-frame": ^7.12.13 - "@jest/types": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.9 "@types/babel__code-frame": ^7.0.0 "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 @@ -13341,7 +13341,7 @@ __metadata: chalk: ^4.0.0 graceful-fs: ^4.2.9 micromatch: ^4.0.4 - pretty-format: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.9 slash: ^3.0.0 stack-utils: ^2.0.3 languageName: unknown @@ -13364,11 +13364,11 @@ __metadata: languageName: node linkType: hard -"jest-mock@^28.0.0-alpha.8, jest-mock@workspace:*, jest-mock@workspace:packages/jest-mock": +"jest-mock@^28.0.0-alpha.9, jest-mock@workspace:*, jest-mock@workspace:packages/jest-mock": version: 0.0.0-use.local resolution: "jest-mock@workspace:packages/jest-mock" dependencies: - "@jest/types": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.9 "@tsd/typescript": ~4.6.2 "@types/node": "*" tsd-lite: ^0.5.1 @@ -13379,7 +13379,7 @@ __metadata: version: 0.0.0-use.local resolution: "jest-phabricator@workspace:packages/jest-phabricator" dependencies: - "@jest/test-result": ^28.0.0-alpha.8 + "@jest/test-result": ^28.0.0-alpha.9 languageName: unknown linkType: soft @@ -13414,17 +13414,17 @@ __metadata: version: 0.0.0-use.local resolution: "jest-repl@workspace:packages/jest-repl" dependencies: - "@jest/console": ^28.0.0-alpha.8 - "@jest/environment": ^28.0.0-alpha.8 - "@jest/transform": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/console": ^28.0.0-alpha.9 + "@jest/environment": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/yargs": ^17.0.8 chalk: ^4.0.0 execa: ^5.0.0 - jest-config: ^28.0.0-alpha.8 - jest-runtime: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 - jest-validate: ^28.0.0-alpha.8 + jest-config: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 + jest-validate: ^28.0.0-alpha.9 repl: ^0.1.3 yargs: ^17.3.1 bin: @@ -13433,21 +13433,21 @@ __metadata: languageName: unknown linkType: soft -"jest-resolve-dependencies@^28.0.0-alpha.8, jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies": +"jest-resolve-dependencies@^28.0.0-alpha.9, jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies": version: 0.0.0-use.local resolution: "jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies" dependencies: - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 - jest-haste-map: ^28.0.0-alpha.8 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 + jest-haste-map: ^28.0.0-alpha.9 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.8 - jest-runtime: ^28.0.0-alpha.8 - jest-snapshot: ^28.0.0-alpha.8 + jest-resolve: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.9 + jest-snapshot: ^28.0.0-alpha.9 languageName: unknown linkType: soft -"jest-resolve@^28.0.0-alpha.8, jest-resolve@workspace:packages/jest-resolve": +"jest-resolve@^28.0.0-alpha.9, jest-resolve@workspace:packages/jest-resolve": version: 0.0.0-use.local resolution: "jest-resolve@workspace:packages/jest-resolve" dependencies: @@ -13455,10 +13455,10 @@ __metadata: "@types/resolve": ^1.20.0 chalk: ^4.0.0 graceful-fs: ^4.2.9 - jest-haste-map: ^28.0.0-alpha.8 + jest-haste-map: ^28.0.0-alpha.9 jest-pnp-resolver: ^1.2.2 - jest-util: ^28.0.0-alpha.8 - jest-validate: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.9 + jest-validate: ^28.0.0-alpha.9 resolve: ^1.20.0 resolve.exports: ^1.1.0 slash: ^3.0.0 @@ -13479,15 +13479,15 @@ __metadata: languageName: node linkType: hard -"jest-runner@^28.0.0-alpha.8, jest-runner@workspace:packages/jest-runner": +"jest-runner@^28.0.0-alpha.9, jest-runner@workspace:packages/jest-runner": version: 0.0.0-use.local resolution: "jest-runner@workspace:packages/jest-runner" dependencies: - "@jest/console": ^28.0.0-alpha.8 - "@jest/environment": ^28.0.0-alpha.8 - "@jest/test-result": ^28.0.0-alpha.8 - "@jest/transform": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/console": ^28.0.0-alpha.9 + "@jest/environment": ^28.0.0-alpha.9 + "@jest/test-result": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@tsd/typescript": ~4.6.2 "@types/exit": ^0.1.30 "@types/graceful-fs": ^4.1.3 @@ -13497,34 +13497,34 @@ __metadata: emittery: ^0.10.2 graceful-fs: ^4.2.9 jest-docblock: ^28.0.0-alpha.6 - jest-environment-node: ^28.0.0-alpha.8 - jest-haste-map: ^28.0.0-alpha.8 - jest-jasmine2: ^28.0.0-alpha.8 - jest-leak-detector: ^28.0.0-alpha.8 - jest-message-util: ^28.0.0-alpha.8 - jest-resolve: ^28.0.0-alpha.8 - jest-runtime: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 - jest-watcher: ^28.0.0-alpha.8 - jest-worker: ^28.0.0-alpha.8 + jest-environment-node: ^28.0.0-alpha.9 + jest-haste-map: ^28.0.0-alpha.9 + jest-jasmine2: ^28.0.0-alpha.9 + jest-leak-detector: ^28.0.0-alpha.9 + jest-message-util: ^28.0.0-alpha.9 + jest-resolve: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 + jest-watcher: ^28.0.0-alpha.9 + jest-worker: ^28.0.0-alpha.9 source-map-support: ^0.5.6 throat: ^6.0.1 tsd-lite: ^0.5.1 languageName: unknown linkType: soft -"jest-runtime@^28.0.0-alpha.8, jest-runtime@workspace:packages/jest-runtime": +"jest-runtime@^28.0.0-alpha.9, jest-runtime@workspace:packages/jest-runtime": version: 0.0.0-use.local resolution: "jest-runtime@workspace:packages/jest-runtime" dependencies: - "@jest/environment": ^28.0.0-alpha.8 - "@jest/fake-timers": ^28.0.0-alpha.8 - "@jest/globals": ^28.0.0-alpha.8 - "@jest/source-map": ^28.0.0-alpha.6 - "@jest/test-result": ^28.0.0-alpha.8 - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/transform": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/environment": ^28.0.0-alpha.9 + "@jest/fake-timers": ^28.0.0-alpha.9 + "@jest/globals": ^28.0.0-alpha.9 + "@jest/source-map": ^28.0.0-alpha.9 + "@jest/test-result": ^28.0.0-alpha.9 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 "@types/node": "*" @@ -13534,14 +13534,14 @@ __metadata: execa: ^5.0.0 glob: ^7.1.3 graceful-fs: ^4.2.9 - jest-environment-node: ^28.0.0-alpha.8 - jest-haste-map: ^28.0.0-alpha.8 - jest-message-util: ^28.0.0-alpha.8 - jest-mock: ^28.0.0-alpha.8 + jest-environment-node: ^28.0.0-alpha.9 + jest-haste-map: ^28.0.0-alpha.9 + jest-message-util: ^28.0.0-alpha.9 + jest-mock: ^28.0.0-alpha.9 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.8 - jest-snapshot: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 + jest-resolve: ^28.0.0-alpha.9 + jest-snapshot: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 slash: ^3.0.0 strip-bom: ^4.0.0 languageName: unknown @@ -13577,7 +13577,7 @@ __metadata: languageName: node linkType: hard -"jest-snapshot@^28.0.0-alpha.8, jest-snapshot@workspace:*, jest-snapshot@workspace:packages/jest-snapshot": +"jest-snapshot@^28.0.0-alpha.9, jest-snapshot@workspace:*, jest-snapshot@workspace:packages/jest-snapshot": version: 0.0.0-use.local resolution: "jest-snapshot@workspace:packages/jest-snapshot" dependencies: @@ -13588,10 +13588,10 @@ __metadata: "@babel/preset-react": ^7.12.1 "@babel/traverse": ^7.7.2 "@babel/types": ^7.3.3 - "@jest/expect-utils": ^28.0.0-alpha.8 - "@jest/test-utils": ^28.0.0-alpha.8 - "@jest/transform": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/expect-utils": ^28.0.0-alpha.9 + "@jest/test-utils": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/babel__traverse": ^7.0.6 "@types/graceful-fs": ^4.1.3 "@types/natural-compare": ^1.4.0 @@ -13601,26 +13601,26 @@ __metadata: ansi-styles: ^5.0.0 babel-preset-current-node-syntax: ^1.0.0 chalk: ^4.0.0 - expect: ^28.0.0-alpha.8 + expect: ^28.0.0-alpha.9 graceful-fs: ^4.2.9 - jest-diff: ^28.0.0-alpha.8 + jest-diff: ^28.0.0-alpha.9 jest-get-type: ^28.0.0-alpha.3 - jest-haste-map: ^28.0.0-alpha.8 - jest-matcher-utils: ^28.0.0-alpha.8 - jest-message-util: ^28.0.0-alpha.8 - jest-util: ^28.0.0-alpha.8 + jest-haste-map: ^28.0.0-alpha.9 + jest-matcher-utils: ^28.0.0-alpha.9 + jest-message-util: ^28.0.0-alpha.9 + jest-util: ^28.0.0-alpha.9 natural-compare: ^1.4.0 prettier: ^2.1.1 - pretty-format: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.9 semver: ^7.3.5 languageName: unknown linkType: soft -"jest-util@^28.0.0-alpha.8, jest-util@workspace:packages/jest-util": +"jest-util@^28.0.0-alpha.9, jest-util@workspace:packages/jest-util": version: 0.0.0-use.local resolution: "jest-util@workspace:packages/jest-util" dependencies: - "@jest/types": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.9 "@types/graceful-fs": ^4.1.3 "@types/node": "*" "@types/picomatch": ^2.2.2 @@ -13659,17 +13659,17 @@ __metadata: languageName: node linkType: hard -"jest-validate@^28.0.0-alpha.8, jest-validate@workspace:packages/jest-validate": +"jest-validate@^28.0.0-alpha.9, jest-validate@workspace:packages/jest-validate": version: 0.0.0-use.local resolution: "jest-validate@workspace:packages/jest-validate" dependencies: - "@jest/types": ^28.0.0-alpha.8 + "@jest/types": ^28.0.0-alpha.9 "@types/yargs": ^17.0.8 camelcase: ^6.2.0 chalk: ^4.0.0 jest-get-type: ^28.0.0-alpha.3 leven: ^3.1.0 - pretty-format: ^28.0.0-alpha.8 + pretty-format: ^28.0.0-alpha.9 languageName: unknown linkType: soft @@ -13704,17 +13704,17 @@ __metadata: languageName: node linkType: hard -"jest-watcher@^28.0.0-alpha.8, jest-watcher@workspace:packages/jest-watcher": +"jest-watcher@^28.0.0-alpha.9, jest-watcher@workspace:packages/jest-watcher": version: 0.0.0-use.local resolution: "jest-watcher@workspace:packages/jest-watcher" dependencies: - "@jest/test-result": ^28.0.0-alpha.8 - "@jest/types": ^28.0.0-alpha.8 + "@jest/test-result": ^28.0.0-alpha.9 + "@jest/types": ^28.0.0-alpha.9 "@types/node": "*" ansi-escapes: ^4.2.1 chalk: ^4.0.0 emittery: ^0.10.2 - jest-util: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.9 string-length: ^4.0.1 languageName: unknown linkType: soft @@ -13759,7 +13759,7 @@ __metadata: languageName: unknown linkType: soft -"jest-worker@^28.0.0-alpha.8, jest-worker@workspace:packages/jest-worker": +"jest-worker@^28.0.0-alpha.9, jest-worker@workspace:packages/jest-worker": version: 0.0.0-use.local resolution: "jest-worker@workspace:packages/jest-worker" dependencies: @@ -13767,7 +13767,7 @@ __metadata: "@types/node": "*" "@types/supports-color": ^8.1.0 get-stream: ^6.0.0 - jest-leak-detector: ^28.0.0-alpha.8 + jest-leak-detector: ^28.0.0-alpha.9 merge-stream: ^2.0.0 supports-color: ^8.0.0 worker-farm: ^1.6.0 @@ -13809,9 +13809,9 @@ __metadata: version: 0.0.0-use.local resolution: "jest@workspace:packages/jest" dependencies: - "@jest/core": ^28.0.0-alpha.8 + "@jest/core": ^28.0.0-alpha.9 import-local: ^3.0.2 - jest-cli: ^28.0.0-alpha.8 + jest-cli: ^28.0.0-alpha.9 peerDependencies: node-notifier: ^8.0.1 || ^9.0.0 || ^10.0.0 peerDependenciesMeta: @@ -17956,7 +17956,7 @@ __metadata: languageName: node linkType: hard -"pretty-format@^28.0.0-alpha.8, pretty-format@workspace:packages/pretty-format": +"pretty-format@^28.0.0-alpha.9, pretty-format@workspace:packages/pretty-format": version: 0.0.0-use.local resolution: "pretty-format@workspace:packages/pretty-format" dependencies: @@ -17966,9 +17966,9 @@ __metadata: "@types/react-test-renderer": 17.0.2 ansi-regex: ^5.0.1 ansi-styles: ^5.0.0 - expect: ^28.0.0-alpha.8 + expect: ^28.0.0-alpha.9 immutable: ^4.0.0 - jest-util: ^28.0.0-alpha.8 + jest-util: ^28.0.0-alpha.9 react: 17.0.2 react-dom: ^17.0.1 react-is: ^18.0.0 From 49a5eca02fbbf83ab5de9cca9007052896916a5e Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Tue, 19 Apr 2022 13:11:44 +0200 Subject: [PATCH 065/128] chore: correct package name in changelog --- CHANGELOG.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a098459a0efd..72ea00c8ecb2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -38,8 +38,8 @@ - `[jest-mock]` [**BREAKING**] Improve the usage of `jest.fn` generic type argument ([#12489](https://github.com/facebook/jest/pull/12489)) - `[jest-mock]` Add support for auto-mocking async generator functions ([#11080](https://github.com/facebook/jest/pull/11080)) - `[jest-mock]` Add `contexts` member to mock functions ([#12601](https://github.com/facebook/jest/pull/12601)) -- `[jest-reporters]` Add GitHub Actions reporter ([#11320](https://github.com/facebook/jest/pull/11320), [#12658](https://github.com/facebook/jest/pull/12658) -- `[jest-reporters]` Pass `reporterContext` to custom reporter constructors as third argument ([#12657](https://github.com/facebook/jest/pull/12657)) +- `[@jest/reporters]` Add GitHub Actions reporter ([#11320](https://github.com/facebook/jest/pull/11320), [#12658](https://github.com/facebook/jest/pull/12658) +- `[@jest/reporters]` Pass `reporterContext` to custom reporter constructors as third argument ([#12657](https://github.com/facebook/jest/pull/12657)) - `[jest-resolve]` [**BREAKING**] Add support for `package.json` `exports` ([#11961](https://github.com/facebook/jest/pull/11961), [#12373](https://github.com/facebook/jest/pull/12373)) - `[jest-resolve]` Support package self-reference ([#12682](https://github.com/facebook/jest/pull/12682)) - `[jest-resolve, jest-runtime]` Add support for `data:` URI import and mock ([#12392](https://github.com/facebook/jest/pull/12392)) @@ -83,7 +83,7 @@ - `[jest-matcher-utils]` Pass maxWidth to `pretty-format` to avoid printing every element in arrays by default ([#12402](https://github.com/facebook/jest/pull/12402)) - `[jest-mock]` Fix function overloads for `spyOn` to allow more correct type inference in complex object ([#12442](https://github.com/facebook/jest/pull/12442)) - `[jest-mock]` Handle overridden `Function.name` property ([#12674](https://github.com/facebook/jest/pull/12674)) -- `[jest-reporters]` Notifications generated by the `--notify` flag are no longer persistent in GNOME Shell. ([#11733](https://github.com/facebook/jest/pull/11733)) +- `[@jest/reporters]` Notifications generated by the `--notify` flag are no longer persistent in GNOME Shell. ([#11733](https://github.com/facebook/jest/pull/11733)) - `[@jest/reporters]` Move missing icon file which is needed for `NotifyReporter` class. ([#12593](https://github.com/facebook/jest/pull/12593)) - `[jest-resolver]` Call custom resolver with core node.js modules ([#12654](https://github.com/facebook/jest/pull/12654)) - `[jest-worker]` Fix `Farm` execution results memory leak ([#12497](https://github.com/facebook/jest/pull/12497)) From ea8dc8a82c26520dc7679c2496d6470a3bc35272 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Tue, 19 Apr 2022 14:24:08 +0200 Subject: [PATCH 066/128] chore: update react-native (#12690) --- .yarnrc.yml | 3 -- examples/react-native/package.json | 2 +- package.json | 2 +- yarn.lock | 50 +++++++++++------------------- 4 files changed, 20 insertions(+), 37 deletions(-) diff --git a/.yarnrc.yml b/.yarnrc.yml index 9c4331b485df..38f6137f7562 100644 --- a/.yarnrc.yml +++ b/.yarnrc.yml @@ -17,9 +17,6 @@ packageExtensions: react-native-codegen@*: peerDependencies: "@babel/preset-env": ^7.1.6 - react-native-gradle-plugin@*: - peerDependencies: - "@babel/preset-env": ^7.1.6 react-native@*: dependencies: metro-babel-register: 0.67.0 diff --git a/examples/react-native/package.json b/examples/react-native/package.json index 2a50f9accd33..3f19aae39f42 100644 --- a/examples/react-native/package.json +++ b/examples/react-native/package.json @@ -8,7 +8,7 @@ }, "dependencies": { "react": "17.0.2", - "react-native": "0.68.0" + "react-native": "0.68.1" }, "devDependencies": { "@babel/core": "^7.11.6", diff --git a/package.json b/package.json index 935c9d81e42e..9d406a9f6d7b 100644 --- a/package.json +++ b/package.json @@ -166,7 +166,7 @@ "babel-jest": "workspace:*", "jest": "workspace:*", "jest-environment-node": "workspace:*", - "react-native": "patch:react-native@npm:0.68.0#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch" + "react-native": "patch:react-native@npm:0.68.1#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch" }, "packageManager": "yarn@3.2.0" } diff --git a/yarn.lock b/yarn.lock index 8384ffd1e1ca..7eaa8f033d71 100644 --- a/yarn.lock +++ b/yarn.lock @@ -10145,7 +10145,7 @@ __metadata: jest: "workspace:*" metro-react-native-babel-preset: 0.67.0 react: 17.0.2 - react-native: 0.68.0 + react-native: 0.68.1 react-test-renderer: 17.0.2 languageName: unknown linkType: soft @@ -18564,18 +18564,6 @@ __metadata: languageName: node linkType: hard -"react-native-codegen@npm:*": - version: 0.0.14 - resolution: "react-native-codegen@npm:0.0.14" - dependencies: - "@babel/parser": ^7.14.0 - flow-parser: ^0.121.0 - jscodeshift: ^0.13.1 - nullthrows: ^1.1.1 - checksum: 2e22f472e504b035a032fcb4c13412ecd60971cb2f11a161c674219f379afcc8098103503dc5f394ac92e8f6cbd2dce68ad3d8b7eb5cb1cd01a4e548063cf97c - languageName: node - linkType: hard - "react-native-codegen@npm:^0.0.13": version: 0.0.13 resolution: "react-native-codegen@npm:0.0.13" @@ -18588,18 +18576,16 @@ __metadata: languageName: node linkType: hard -"react-native-gradle-plugin@npm:^0.0.5": - version: 0.0.5 - resolution: "react-native-gradle-plugin@npm:0.0.5" - dependencies: - react-native-codegen: "*" - checksum: ee14e5abc692fadb66527334e00ce57bfb7371fae82711f3a1c658c8896e93daee17019e533b1eb0323606f812fa5c645e67348f4169ecc0cb9fa3de3706b5e6 +"react-native-gradle-plugin@npm:^0.0.6": + version: 0.0.6 + resolution: "react-native-gradle-plugin@npm:0.0.6" + checksum: 185ad348931ef4f58065b50bbf80558af668b1ef11c31067aab7f1cd85b18809a62fcf0b7a18444726dacd098042771a570c0ac76bb8976c3ccbe7c86cff0e11 languageName: node linkType: hard -"react-native@npm:0.68.0": - version: 0.68.0 - resolution: "react-native@npm:0.68.0" +"react-native@npm:0.68.1": + version: 0.68.1 + resolution: "react-native@npm:0.68.1" dependencies: "@jest/create-cache-key-function": ^27.0.1 "@react-native-community/cli": ^7.0.3 @@ -18624,26 +18610,26 @@ __metadata: promise: ^8.0.3 react-devtools-core: ^4.23.0 react-native-codegen: ^0.0.13 - react-native-gradle-plugin: ^0.0.5 + react-native-gradle-plugin: ^0.0.6 react-refresh: ^0.4.0 react-shallow-renderer: 16.14.1 regenerator-runtime: ^0.13.2 scheduler: ^0.20.2 stacktrace-parser: ^0.1.3 - use-subscription: ^1.0.0 + use-subscription: ">=1.0.0 <1.6.0" whatwg-fetch: ^3.0.0 ws: ^6.1.4 peerDependencies: react: 17.0.2 bin: react-native: cli.js - checksum: 2232376ac65e63c8b2895b6fcb84299dd42ef6502b0d2d26a64758f4de871c64f261e116b6a0930a0e6b3320a68d46cbbe4daa5eb50fd517d90aa0eb451b189c + checksum: 72916e7ac092ca68702254d2a80db80b340e735f1ea654d5146e54037cf20410c182477d1c7f59dd4c6d854472a67b5ed6c279640d515235998717ba12757a39 languageName: node linkType: hard -"react-native@patch:react-native@npm:0.68.0#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch::locator=%40jest%2Fmonorepo%40workspace%3A.": - version: 0.68.0 - resolution: "react-native@patch:react-native@npm%3A0.68.0#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch::version=0.68.0&hash=c5a757&locator=%40jest%2Fmonorepo%40workspace%3A." +"react-native@patch:react-native@npm:0.68.1#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch::locator=%40jest%2Fmonorepo%40workspace%3A.": + version: 0.68.1 + resolution: "react-native@patch:react-native@npm%3A0.68.1#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch::version=0.68.1&hash=c5a757&locator=%40jest%2Fmonorepo%40workspace%3A." dependencies: "@jest/create-cache-key-function": ^27.0.1 "@react-native-community/cli": ^7.0.3 @@ -18668,20 +18654,20 @@ __metadata: promise: ^8.0.3 react-devtools-core: ^4.23.0 react-native-codegen: ^0.0.13 - react-native-gradle-plugin: ^0.0.5 + react-native-gradle-plugin: ^0.0.6 react-refresh: ^0.4.0 react-shallow-renderer: 16.14.1 regenerator-runtime: ^0.13.2 scheduler: ^0.20.2 stacktrace-parser: ^0.1.3 - use-subscription: ^1.0.0 + use-subscription: ">=1.0.0 <1.6.0" whatwg-fetch: ^3.0.0 ws: ^6.1.4 peerDependencies: react: 17.0.2 bin: react-native: cli.js - checksum: 14f503f007e6372c9c31c397df1cc6ecc581a597a8752009721402c132905aa9381d1bb5459da8862dde498348eb0c18a9e93ce1ee911a4947ff01cc5df9928d + checksum: a1d1ab50269a9b83eb2bcae2b5889cf657a48d9b42f1ea9bc05ae575fca10b1c34e226affbc792e336b2a4b1fc4299030ee7e6b9cdcc25e12990379b18d0bed6 languageName: node linkType: hard @@ -22169,7 +22155,7 @@ __metadata: languageName: node linkType: hard -"use-subscription@npm:^1.0.0": +"use-subscription@npm:>=1.0.0 <1.6.0": version: 1.5.1 resolution: "use-subscription@npm:1.5.1" dependencies: From 5183c15a8e14089351d6403f4fdb72a6705aa379 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Tue, 19 Apr 2022 15:59:29 +0200 Subject: [PATCH 067/128] fix: pass `root` in babel config (#12689) Co-authored-by: Bradford Lemley --- .../react-native-npm-0.68.0-9eb3ecb60a.patch | 31 --------- .yarnrc.yml | 2 - CHANGELOG.md | 1 + e2e/__tests__/multiProjectRunner.test.ts | 38 ++++++++++ e2e/global-setup/projects.jest.config.js | 6 ++ e2e/multi-project-babel/package.json | 15 ++++ e2e/multi-project-babel/prj-1/babel.config.js | 10 +++ e2e/multi-project-babel/prj-1/index.js | 8 +++ e2e/multi-project-babel/prj-1/index.test.js | 12 ++++ e2e/multi-project-babel/prj-1/package.json | 1 + e2e/multi-project-babel/prj-2/.babelrc.js | 10 +++ e2e/multi-project-babel/prj-2/index.js | 8 +++ e2e/multi-project-babel/prj-2/index.test.js | 12 ++++ e2e/multi-project-babel/prj-2/package.json | 1 + e2e/multi-project-babel/prj-3/package.json | 5 ++ .../prj-3/src/babel.config.js | 10 +++ e2e/multi-project-babel/prj-3/src/index.js | 8 +++ .../prj-3/src/index.test.js | 12 ++++ e2e/multi-project-babel/prj-4/.babelrc.js | 10 +++ e2e/multi-project-babel/prj-4/package.json | 5 ++ e2e/multi-project-babel/prj-4/src/index.js | 8 +++ .../prj-4/src/index.test.js | 12 ++++ e2e/multi-project-babel/prj-5/.babelrc.js | 10 +++ e2e/multi-project-babel/prj-5/package.json | 5 ++ e2e/multi-project-babel/prj-5/src/index.js | 8 +++ .../prj-5/src/index.test.js | 12 ++++ examples/react-native/jest.config.js | 3 - jest.config.mjs | 1 + package.json | 3 +- packages/babel-jest/src/index.ts | 5 +- .../src/__mocks__/createRuntime.js | 20 ++---- yarn.lock | 69 ------------------- 32 files changed, 239 insertions(+), 122 deletions(-) delete mode 100644 .yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch create mode 100644 e2e/multi-project-babel/package.json create mode 100644 e2e/multi-project-babel/prj-1/babel.config.js create mode 100644 e2e/multi-project-babel/prj-1/index.js create mode 100644 e2e/multi-project-babel/prj-1/index.test.js create mode 100644 e2e/multi-project-babel/prj-1/package.json create mode 100644 e2e/multi-project-babel/prj-2/.babelrc.js create mode 100644 e2e/multi-project-babel/prj-2/index.js create mode 100644 e2e/multi-project-babel/prj-2/index.test.js create mode 100644 e2e/multi-project-babel/prj-2/package.json create mode 100644 e2e/multi-project-babel/prj-3/package.json create mode 100644 e2e/multi-project-babel/prj-3/src/babel.config.js create mode 100644 e2e/multi-project-babel/prj-3/src/index.js create mode 100644 e2e/multi-project-babel/prj-3/src/index.test.js create mode 100644 e2e/multi-project-babel/prj-4/.babelrc.js create mode 100644 e2e/multi-project-babel/prj-4/package.json create mode 100644 e2e/multi-project-babel/prj-4/src/index.js create mode 100644 e2e/multi-project-babel/prj-4/src/index.test.js create mode 100644 e2e/multi-project-babel/prj-5/.babelrc.js create mode 100644 e2e/multi-project-babel/prj-5/package.json create mode 100644 e2e/multi-project-babel/prj-5/src/index.js create mode 100644 e2e/multi-project-babel/prj-5/src/index.test.js diff --git a/.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch b/.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch deleted file mode 100644 index bb6b711f1e52..000000000000 --- a/.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch +++ /dev/null @@ -1,31 +0,0 @@ -diff --git a/jest/preprocessor.js b/jest/preprocessor.js -index f5e34763d840193e243a974e448b619f8f635095..cc6e05ab4c9c25a3d257379a1bf19c21fb9ef5ca 100644 ---- a/jest/preprocessor.js -+++ b/jest/preprocessor.js -@@ -38,7 +38,7 @@ module.exports = { - sourceType: 'script', - ...nodeOptions, - ast: false, -- }).code; -+ }); - } - - const {ast} = transformer.transform({ -@@ -66,8 +66,6 @@ module.exports = { - [require('@babel/plugin-transform-flow-strip-types')], - [ - require('@babel/plugin-proposal-class-properties'), -- // use `this.foo = bar` instead of `this.defineProperty('foo', ...)` -- {loose: true}, - ], - [require('@babel/plugin-transform-computed-properties')], - [require('@babel/plugin-transform-destructuring')], -@@ -112,7 +110,7 @@ module.exports = { - sourceMaps: true, - }, - src, -- ).code; -+ ); - }, - - getCacheKey: (createCacheKeyFunction([ diff --git a/.yarnrc.yml b/.yarnrc.yml index 38f6137f7562..172a2ce7ddc9 100644 --- a/.yarnrc.yml +++ b/.yarnrc.yml @@ -18,8 +18,6 @@ packageExtensions: peerDependencies: "@babel/preset-env": ^7.1.6 react-native@*: - dependencies: - metro-babel-register: 0.67.0 peerDependencies: "@babel/preset-env": ^7.1.6 diff --git a/CHANGELOG.md b/CHANGELOG.md index 72ea00c8ecb2..0fc8df52ae20 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -59,6 +59,7 @@ ### Fixes +- `[babel-jest]` [**BREAKING**] Pass `rootDir` as `root` in Babel's options ([#12689](https://github.com/facebook/jest/pull/12689)) - `[expect]` Move typings of `.not`, `.rejects` and `.resolves` modifiers outside of `Matchers` interface ([#12346](https://github.com/facebook/jest/pull/12346)) - `[expect]` Throw useful error if `expect.extend` is called with invalid matchers ([#12488](https://github.com/facebook/jest/pull/12488)) - `[expect]` Fix `iterableEquality` ignores other properties ([#8359](https://github.com/facebook/jest/pull/8359)) diff --git a/e2e/__tests__/multiProjectRunner.test.ts b/e2e/__tests__/multiProjectRunner.test.ts index c9ad5b0bf811..50dd3d04af21 100644 --- a/e2e/__tests__/multiProjectRunner.test.ts +++ b/e2e/__tests__/multiProjectRunner.test.ts @@ -572,3 +572,41 @@ describe("doesn't bleed module file extensions resolution with multiple workers" expect(stderr).toMatch('PASS project2/__tests__/project2.test.js'); }); }); + +describe('Babel config in individual project works in multi-project', () => { + it('Prj-1 works individually', () => { + const result = runJest('multi-project-babel/prj-1'); + expect(result.stderr).toMatch('PASS ./index.test.js'); + expect(result.exitCode).toBe(0); + }); + it('Prj-2 works individually', () => { + const result = runJest('multi-project-babel/prj-2'); + expect(result.stderr).toMatch('PASS ./index.test.js'); + expect(result.exitCode).toBe(0); + }); + it('Prj-3 works individually', () => { + const result = runJest('multi-project-babel/prj-3'); + expect(result.stderr).toMatch('PASS src/index.test.js'); + expect(result.exitCode).toBe(0); + }); + it('Prj-4 works individually', () => { + const result = runJest('multi-project-babel/prj-4'); + expect(result.stderr).toMatch('PASS src/index.test.js'); + expect(result.exitCode).toBe(0); + }); + it('Prj-5 works individually', () => { + const result = runJest('multi-project-babel/prj-5'); + expect(result.stderr).toMatch('PASS src/index.test.js'); + expect(result.exitCode).toBe(0); + }); + it('All project work when running from multiproject', () => { + const result = runJest('multi-project-babel'); + expect(result.stderr).toMatch('PASS prj-1/index.test.js'); + expect(result.stderr).toMatch('PASS prj-2/index.test.js'); + expect(result.stderr).toMatch('PASS prj-3/src/index.test.js'); + expect(result.stderr).toMatch('PASS prj-4/src/index.test.js'); + expect(result.stderr).toMatch('PASS prj-5/src/index.test.js'); + expect(result.stderr).toMatch('PASS prj-3/src/index.test.js'); + expect(result.exitCode).toBe(0); + }); +}); diff --git a/e2e/global-setup/projects.jest.config.js b/e2e/global-setup/projects.jest.config.js index 9d008ac5cd06..08da804c2003 100644 --- a/e2e/global-setup/projects.jest.config.js +++ b/e2e/global-setup/projects.jest.config.js @@ -15,6 +15,9 @@ module.exports = { globalSetup: '/setup.js', rootDir: path.resolve(__dirname, './project-1'), testMatch: ['/**/*.test.js'], + transform: { + '\\.[jt]sx?$': [require.resolve('babel-jest'), {root: __dirname}], + }, transformIgnorePatterns: ['/node_modules/', '/packages/'], }, { @@ -22,6 +25,9 @@ module.exports = { globalSetup: '/setup.js', rootDir: path.resolve(__dirname, './project-2'), testMatch: ['/**/*.test.js'], + transform: { + '\\.[jt]sx?$': [require.resolve('babel-jest'), {root: __dirname}], + }, transformIgnorePatterns: ['/node_modules/', '/packages/'], }, ], diff --git a/e2e/multi-project-babel/package.json b/e2e/multi-project-babel/package.json new file mode 100644 index 000000000000..c51f8db5ccfa --- /dev/null +++ b/e2e/multi-project-babel/package.json @@ -0,0 +1,15 @@ +{ + "jest": { + "projects": [ + { + "rootDir": "/prj-1" + }, + { + "rootDir": "/prj-2" + }, + "/prj-3", + "/prj-4", + "/prj-5" + ] + } +} diff --git a/e2e/multi-project-babel/prj-1/babel.config.js b/e2e/multi-project-babel/prj-1/babel.config.js new file mode 100644 index 000000000000..186d686670e3 --- /dev/null +++ b/e2e/multi-project-babel/prj-1/babel.config.js @@ -0,0 +1,10 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = { + presets: ['@babel/preset-flow'], +}; diff --git a/e2e/multi-project-babel/prj-1/index.js b/e2e/multi-project-babel/prj-1/index.js new file mode 100644 index 000000000000..881ff4073178 --- /dev/null +++ b/e2e/multi-project-babel/prj-1/index.js @@ -0,0 +1,8 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = (text: string) => text; diff --git a/e2e/multi-project-babel/prj-1/index.test.js b/e2e/multi-project-babel/prj-1/index.test.js new file mode 100644 index 000000000000..f0f19c2e9ab9 --- /dev/null +++ b/e2e/multi-project-babel/prj-1/index.test.js @@ -0,0 +1,12 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +const f = require('./'); + +it('Transpiles', () => { + expect(f('test')).toBe('test'); +}); diff --git a/e2e/multi-project-babel/prj-1/package.json b/e2e/multi-project-babel/prj-1/package.json new file mode 100644 index 000000000000..0967ef424bce --- /dev/null +++ b/e2e/multi-project-babel/prj-1/package.json @@ -0,0 +1 @@ +{} diff --git a/e2e/multi-project-babel/prj-2/.babelrc.js b/e2e/multi-project-babel/prj-2/.babelrc.js new file mode 100644 index 000000000000..186d686670e3 --- /dev/null +++ b/e2e/multi-project-babel/prj-2/.babelrc.js @@ -0,0 +1,10 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = { + presets: ['@babel/preset-flow'], +}; diff --git a/e2e/multi-project-babel/prj-2/index.js b/e2e/multi-project-babel/prj-2/index.js new file mode 100644 index 000000000000..881ff4073178 --- /dev/null +++ b/e2e/multi-project-babel/prj-2/index.js @@ -0,0 +1,8 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = (text: string) => text; diff --git a/e2e/multi-project-babel/prj-2/index.test.js b/e2e/multi-project-babel/prj-2/index.test.js new file mode 100644 index 000000000000..f0f19c2e9ab9 --- /dev/null +++ b/e2e/multi-project-babel/prj-2/index.test.js @@ -0,0 +1,12 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +const f = require('./'); + +it('Transpiles', () => { + expect(f('test')).toBe('test'); +}); diff --git a/e2e/multi-project-babel/prj-2/package.json b/e2e/multi-project-babel/prj-2/package.json new file mode 100644 index 000000000000..0967ef424bce --- /dev/null +++ b/e2e/multi-project-babel/prj-2/package.json @@ -0,0 +1 @@ +{} diff --git a/e2e/multi-project-babel/prj-3/package.json b/e2e/multi-project-babel/prj-3/package.json new file mode 100644 index 000000000000..2b9231f5dcc3 --- /dev/null +++ b/e2e/multi-project-babel/prj-3/package.json @@ -0,0 +1,5 @@ +{ + "jest": { + "rootDir": "src" + } +} diff --git a/e2e/multi-project-babel/prj-3/src/babel.config.js b/e2e/multi-project-babel/prj-3/src/babel.config.js new file mode 100644 index 000000000000..186d686670e3 --- /dev/null +++ b/e2e/multi-project-babel/prj-3/src/babel.config.js @@ -0,0 +1,10 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = { + presets: ['@babel/preset-flow'], +}; diff --git a/e2e/multi-project-babel/prj-3/src/index.js b/e2e/multi-project-babel/prj-3/src/index.js new file mode 100644 index 000000000000..881ff4073178 --- /dev/null +++ b/e2e/multi-project-babel/prj-3/src/index.js @@ -0,0 +1,8 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = (text: string) => text; diff --git a/e2e/multi-project-babel/prj-3/src/index.test.js b/e2e/multi-project-babel/prj-3/src/index.test.js new file mode 100644 index 000000000000..f0f19c2e9ab9 --- /dev/null +++ b/e2e/multi-project-babel/prj-3/src/index.test.js @@ -0,0 +1,12 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +const f = require('./'); + +it('Transpiles', () => { + expect(f('test')).toBe('test'); +}); diff --git a/e2e/multi-project-babel/prj-4/.babelrc.js b/e2e/multi-project-babel/prj-4/.babelrc.js new file mode 100644 index 000000000000..186d686670e3 --- /dev/null +++ b/e2e/multi-project-babel/prj-4/.babelrc.js @@ -0,0 +1,10 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = { + presets: ['@babel/preset-flow'], +}; diff --git a/e2e/multi-project-babel/prj-4/package.json b/e2e/multi-project-babel/prj-4/package.json new file mode 100644 index 000000000000..2b9231f5dcc3 --- /dev/null +++ b/e2e/multi-project-babel/prj-4/package.json @@ -0,0 +1,5 @@ +{ + "jest": { + "rootDir": "src" + } +} diff --git a/e2e/multi-project-babel/prj-4/src/index.js b/e2e/multi-project-babel/prj-4/src/index.js new file mode 100644 index 000000000000..881ff4073178 --- /dev/null +++ b/e2e/multi-project-babel/prj-4/src/index.js @@ -0,0 +1,8 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = (text: string) => text; diff --git a/e2e/multi-project-babel/prj-4/src/index.test.js b/e2e/multi-project-babel/prj-4/src/index.test.js new file mode 100644 index 000000000000..f0f19c2e9ab9 --- /dev/null +++ b/e2e/multi-project-babel/prj-4/src/index.test.js @@ -0,0 +1,12 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +const f = require('./'); + +it('Transpiles', () => { + expect(f('test')).toBe('test'); +}); diff --git a/e2e/multi-project-babel/prj-5/.babelrc.js b/e2e/multi-project-babel/prj-5/.babelrc.js new file mode 100644 index 000000000000..186d686670e3 --- /dev/null +++ b/e2e/multi-project-babel/prj-5/.babelrc.js @@ -0,0 +1,10 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = { + presets: ['@babel/preset-flow'], +}; diff --git a/e2e/multi-project-babel/prj-5/package.json b/e2e/multi-project-babel/prj-5/package.json new file mode 100644 index 000000000000..2b9231f5dcc3 --- /dev/null +++ b/e2e/multi-project-babel/prj-5/package.json @@ -0,0 +1,5 @@ +{ + "jest": { + "rootDir": "src" + } +} diff --git a/e2e/multi-project-babel/prj-5/src/index.js b/e2e/multi-project-babel/prj-5/src/index.js new file mode 100644 index 000000000000..881ff4073178 --- /dev/null +++ b/e2e/multi-project-babel/prj-5/src/index.js @@ -0,0 +1,8 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +module.exports = (text: string) => text; diff --git a/e2e/multi-project-babel/prj-5/src/index.test.js b/e2e/multi-project-babel/prj-5/src/index.test.js new file mode 100644 index 000000000000..f0f19c2e9ab9 --- /dev/null +++ b/e2e/multi-project-babel/prj-5/src/index.test.js @@ -0,0 +1,12 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +const f = require('./'); + +it('Transpiles', () => { + expect(f('test')).toBe('test'); +}); diff --git a/examples/react-native/jest.config.js b/examples/react-native/jest.config.js index 4ea28b54a72f..5e3d4871ef83 100644 --- a/examples/react-native/jest.config.js +++ b/examples/react-native/jest.config.js @@ -3,9 +3,6 @@ const {resolve} = require('path'); module.exports = { preset: 'react-native', testEnvironment: 'jsdom', - transform: { - '\\.(js|ts|tsx)$': require.resolve('react-native/jest/preprocessor.js'), - }, // this is specific to the Jest repo, not generally needed (the files we ignore will be in node_modules which is ignored by default) transformIgnorePatterns: [resolve(__dirname, '../../packages')], }; diff --git a/jest.config.mjs b/jest.config.mjs index 6084cf82b9d3..3d5bb0fcddcd 100644 --- a/jest.config.mjs +++ b/jest.config.mjs @@ -48,6 +48,7 @@ export default { '/e2e/custom-*', '/e2e/test-in-root', '/e2e/run-programmatically-multiple-projects', + '/e2e/multi-project-babel', '\\.snap$', '/packages/.*/build', '/packages/.*/src/__tests__/setPrettyPrint.ts', diff --git a/package.json b/package.json index 9d406a9f6d7b..6cc88e839cbd 100644 --- a/package.json +++ b/package.json @@ -165,8 +165,7 @@ "resolutions": { "babel-jest": "workspace:*", "jest": "workspace:*", - "jest-environment-node": "workspace:*", - "react-native": "patch:react-native@npm:0.68.1#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch" + "jest-environment-node": "workspace:*" }, "packageManager": "yarn@3.2.0" } diff --git a/packages/babel-jest/src/index.ts b/packages/babel-jest/src/index.ts index b48ebe71a40c..e4ac550eaf14 100644 --- a/packages/babel-jest/src/index.ts +++ b/packages/babel-jest/src/index.ts @@ -173,10 +173,11 @@ export const createTransformer: TransformerCreator< filename: string, transformOptions: JestTransformOptions, ): TransformOptions { - const {cwd} = transformOptions.config; - // `cwd` first to allow incoming options to override it + const {cwd, rootDir} = transformOptions.config; + // `cwd` and `root` first to allow incoming options to override it return { cwd, + root: rootDir, ...options, caller: { ...options.caller, diff --git a/packages/jest-runtime/src/__mocks__/createRuntime.js b/packages/jest-runtime/src/__mocks__/createRuntime.js index c562ee7a74fe..b22afc6154bf 100644 --- a/packages/jest-runtime/src/__mocks__/createRuntime.js +++ b/packages/jest-runtime/src/__mocks__/createRuntime.js @@ -37,7 +37,7 @@ const setupModuleNameMapper = (config, rootDir) => { return []; }; -const setupTransform = (config, rootDir) => { +const setupTransform = (config, rootDir, cwd) => { if (config?.transform) { const transform = config.transform; return Object.keys(transform).map(regex => [ @@ -45,28 +45,22 @@ const setupTransform = (config, rootDir) => { path.resolve(rootDir, transform[regex]), ]); } - return [['^.+\\.[jt]sx?$', require.resolve('babel-jest')]]; + return [['^.+\\.[jt]sx?$', require.resolve('babel-jest'), {root: cwd}]]; }; module.exports = async function createRuntime(filename, projectConfig) { const rootDir = path.resolve(path.dirname(filename), 'test_root'); + const cwd = path.resolve(__dirname, '../../../..'); const moduleNameMapper = setupModuleNameMapper(projectConfig, rootDir); - const transform = setupTransform(projectConfig, rootDir); + const transform = setupTransform(projectConfig, rootDir, cwd); projectConfig = makeProjectConfig({ cacheDirectory: getCacheDirectory(), - cwd: path.resolve(__dirname, '..', '..', '..', '..'), + cwd, haste: { - hasteImplModulePath: path.resolve( - __dirname, - '..', - '..', - '..', - 'jest-haste-map', - 'src', - '__tests__', - 'haste_impl.js', + hasteImplModulePath: require.resolve( + '../../../jest-haste-map/src/__tests__/haste_impl.js', ), }, id: `Runtime-${filename.replace(/\W/, '-')}.tests`, diff --git a/yarn.lock b/yarn.lock index 7eaa8f033d71..875b2c9d58df 100644 --- a/yarn.lock +++ b/yarn.lock @@ -6812,13 +6812,6 @@ __metadata: languageName: node linkType: hard -"babel-plugin-replace-ts-export-assignment@npm:^0.0.2": - version: 0.0.2 - resolution: "babel-plugin-replace-ts-export-assignment@npm:0.0.2" - checksum: da749130fe0479cd9da73f8b3aafc62e05885b12732ce0e25976a7138dad1688a03366791b12633afdd8a702e2018ec01764c4ddb0ed0dbc3783b7e75b1b148a - languageName: node - linkType: hard - "babel-plugin-syntax-trailing-function-commas@npm:^7.0.0-beta.0": version: 7.0.0-beta.0 resolution: "babel-plugin-syntax-trailing-function-commas@npm:7.0.0-beta.0" @@ -15033,24 +15026,6 @@ __metadata: languageName: node linkType: hard -"metro-babel-register@npm:0.67.0": - version: 0.67.0 - resolution: "metro-babel-register@npm:0.67.0" - dependencies: - "@babel/core": ^7.14.0 - "@babel/plugin-proposal-nullish-coalescing-operator": ^7.0.0 - "@babel/plugin-proposal-optional-chaining": ^7.0.0 - "@babel/plugin-syntax-class-properties": ^7.0.0 - "@babel/plugin-transform-flow-strip-types": ^7.0.0 - "@babel/plugin-transform-modules-commonjs": ^7.0.0 - "@babel/preset-typescript": ^7.15.0 - "@babel/register": ^7.0.0 - babel-plugin-replace-ts-export-assignment: ^0.0.2 - escape-string-regexp: ^1.0.5 - checksum: 4aabb6884db027326ca97e8c9f3943e9af9f455439fa7e361002e3c5b5c3600e9f4aae141018bebec7a242f6950f822945fd464fa6f14c134f893d6542afc081 - languageName: node - linkType: hard - "metro-babel-transformer@npm:0.67.0": version: 0.67.0 resolution: "metro-babel-transformer@npm:0.67.0" @@ -18627,50 +18602,6 @@ __metadata: languageName: node linkType: hard -"react-native@patch:react-native@npm:0.68.1#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch::locator=%40jest%2Fmonorepo%40workspace%3A.": - version: 0.68.1 - resolution: "react-native@patch:react-native@npm%3A0.68.1#.yarn/patches/react-native-npm-0.68.0-9eb3ecb60a.patch::version=0.68.1&hash=c5a757&locator=%40jest%2Fmonorepo%40workspace%3A." - dependencies: - "@jest/create-cache-key-function": ^27.0.1 - "@react-native-community/cli": ^7.0.3 - "@react-native-community/cli-platform-android": ^7.0.1 - "@react-native-community/cli-platform-ios": ^7.0.1 - "@react-native/assets": 1.0.0 - "@react-native/normalize-color": 2.0.0 - "@react-native/polyfills": 2.0.0 - abort-controller: ^3.0.0 - anser: ^1.4.9 - base64-js: ^1.1.2 - deprecated-react-native-prop-types: ^2.3.0 - event-target-shim: ^5.0.1 - hermes-engine: ~0.11.0 - invariant: ^2.2.4 - jsc-android: ^250230.2.1 - metro-react-native-babel-transformer: 0.67.0 - metro-runtime: 0.67.0 - metro-source-map: 0.67.0 - nullthrows: ^1.1.1 - pretty-format: ^26.5.2 - promise: ^8.0.3 - react-devtools-core: ^4.23.0 - react-native-codegen: ^0.0.13 - react-native-gradle-plugin: ^0.0.6 - react-refresh: ^0.4.0 - react-shallow-renderer: 16.14.1 - regenerator-runtime: ^0.13.2 - scheduler: ^0.20.2 - stacktrace-parser: ^0.1.3 - use-subscription: ">=1.0.0 <1.6.0" - whatwg-fetch: ^3.0.0 - ws: ^6.1.4 - peerDependencies: - react: 17.0.2 - bin: - react-native: cli.js - checksum: a1d1ab50269a9b83eb2bcae2b5889cf657a48d9b42f1ea9bc05ae575fca10b1c34e226affbc792e336b2a4b1fc4299030ee7e6b9cdcc25e12990379b18d0bed6 - languageName: node - linkType: hard - "react-refresh@npm:^0.4.0": version: 0.4.3 resolution: "react-refresh@npm:0.4.3" From 58af3c13a83e18f9f149e71df8dfdf09ee1607e3 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 07:30:36 +0200 Subject: [PATCH 068/128] feat: migrate from `source-map` to `@jridgewell/trace-mapping` (#12692) --- packages/jest-reporters/package.json | 2 +- .../jest-reporters/src/CoverageReporter.ts | 13 ++---- packages/jest-source-map/package.json | 4 +- .../src/__tests__/getCallsite.test.ts | 43 ++++++++++++------- packages/jest-source-map/src/getCallsite.ts | 11 +++-- packages/jest-transform/package.json | 2 +- packages/jest-transform/src/types.ts | 6 +-- yarn.lock | 8 ++-- 8 files changed, 48 insertions(+), 41 deletions(-) diff --git a/packages/jest-reporters/package.json b/packages/jest-reporters/package.json index a79b91382150..82fe47a62706 100644 --- a/packages/jest-reporters/package.json +++ b/packages/jest-reporters/package.json @@ -17,6 +17,7 @@ "@jest/test-result": "^28.0.0-alpha.9", "@jest/transform": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", + "@jridgewell/trace-mapping": "^0.3.4", "@types/node": "*", "chalk": "^4.0.0", "collect-v8-coverage": "^1.0.0", @@ -31,7 +32,6 @@ "jest-util": "^28.0.0-alpha.9", "jest-worker": "^28.0.0-alpha.9", "slash": "^3.0.0", - "source-map": "^0.6.1", "string-length": "^4.0.1", "terminal-link": "^2.0.0", "v8-to-istanbul": "^8.1.0" diff --git a/packages/jest-reporters/src/CoverageReporter.ts b/packages/jest-reporters/src/CoverageReporter.ts index 2aa808d97e75..dc4d87daa6c1 100644 --- a/packages/jest-reporters/src/CoverageReporter.ts +++ b/packages/jest-reporters/src/CoverageReporter.ts @@ -7,6 +7,7 @@ import * as path from 'path'; import {mergeProcessCovs} from '@bcoe/v8-coverage'; +import type {EncodedSourceMap} from '@jridgewell/trace-mapping'; import chalk = require('chalk'); import glob = require('glob'); import * as fs from 'graceful-fs'; @@ -14,7 +15,6 @@ import istanbulCoverage = require('istanbul-lib-coverage'); import istanbulReport = require('istanbul-lib-report'); import libSourceMaps = require('istanbul-lib-source-maps'); import istanbulReports = require('istanbul-reports'); -import type {RawSourceMap} from 'source-map'; import v8toIstanbul = require('v8-to-istanbul'); import type { AggregatedResult, @@ -31,12 +31,6 @@ import BaseReporter from './BaseReporter'; import getWatermarks from './getWatermarks'; import type {CoverageWorker, ReporterContext} from './types'; -// This is fixed in a newer versions of source-map, but our dependencies are still stuck on old versions -interface FixedRawSourceMap extends Omit { - version: number; - file?: string; -} - const FAIL_COLOR = chalk.bold.red; const RUNNING_TEST_COLOR = chalk.bold.dim; @@ -437,7 +431,7 @@ export default class CoverageReporter extends BaseReporter { mergedCoverages.result.map(async res => { const fileTransform = fileTransforms.get(res.url); - let sourcemapContent: FixedRawSourceMap | undefined = undefined; + let sourcemapContent: EncodedSourceMap | undefined = undefined; if ( fileTransform?.sourceMapPath && @@ -456,7 +450,8 @@ export default class CoverageReporter extends BaseReporter { originalSource: fileTransform.originalCode, source: fileTransform.code, sourceMap: { - sourcemap: {file: res.url, ...sourcemapContent}, + // remove `as any` after https://github.com/istanbuljs/v8-to-istanbul/pull/186 is released + sourcemap: {file: res.url, ...sourcemapContent} as any, }, } : {source: fs.readFileSync(res.url, 'utf8')}, diff --git a/packages/jest-source-map/package.json b/packages/jest-source-map/package.json index b57ea028f33b..477f6ebe8667 100644 --- a/packages/jest-source-map/package.json +++ b/packages/jest-source-map/package.json @@ -17,9 +17,9 @@ "./package.json": "./package.json" }, "dependencies": { + "@jridgewell/trace-mapping": "^0.3.4", "callsites": "^3.0.0", - "graceful-fs": "^4.2.9", - "source-map": "^0.6.1" + "graceful-fs": "^4.2.9" }, "devDependencies": { "@types/graceful-fs": "^4.1.3" diff --git a/packages/jest-source-map/src/__tests__/getCallsite.test.ts b/packages/jest-source-map/src/__tests__/getCallsite.test.ts index 00f265f9b2d9..0482b12f7323 100644 --- a/packages/jest-source-map/src/__tests__/getCallsite.test.ts +++ b/packages/jest-source-map/src/__tests__/getCallsite.test.ts @@ -5,11 +5,19 @@ * LICENSE file in the root directory of this source tree. */ +import {originalPositionFor} from '@jridgewell/trace-mapping'; import * as fs from 'graceful-fs'; -import SourceMap from 'source-map'; import getCallsite from '../getCallsite'; jest.mock('graceful-fs'); +jest.mock('@jridgewell/trace-mapping', () => { + const actual = jest.requireActual('@jridgewell/trace-mapping'); + + return { + ...actual, + originalPositionFor: jest.fn(actual.originalPositionFor), + }; +}); describe('getCallsite', () => { test('without source map', () => { @@ -35,30 +43,35 @@ describe('getCallsite', () => { }); test('reads source map file to determine line and column', () => { - (fs.readFileSync as jest.Mock).mockImplementation(() => 'file data'); + (fs.readFileSync as jest.Mock).mockImplementation(() => + JSON.stringify({ + file: 'file.js', + mappings: 'AAAA,OAAO,MAAM,KAAK,GAAG,QAAd', + names: [], + sources: ['file.js'], + sourcesContent: ["export const hello = 'foobar';\\n"], + version: 3, + }), + ); const sourceMapColumn = 1; const sourceMapLine = 2; - SourceMap.SourceMapConsumer = class { - originalPositionFor(params: Record) { - expect(params).toMatchObject({ - column: expect.any(Number), - line: expect.any(Number), - }); - - return { - column: sourceMapColumn, - line: sourceMapLine, - }; - } - }; + jest.mocked(originalPositionFor).mockImplementation(() => ({ + column: sourceMapColumn, + line: sourceMapLine, + })); const site = getCallsite(0, new Map([[__filename, 'mockedSourceMapFile']])); expect(site.getFileName()).toEqual(__filename); expect(site.getColumnNumber()).toEqual(sourceMapColumn); expect(site.getLineNumber()).toEqual(sourceMapLine); + expect(originalPositionFor).toHaveBeenCalledTimes(1); + expect(originalPositionFor).toHaveBeenCalledWith(expect.anything(), { + column: expect.any(Number), + line: expect.any(Number), + }); expect(fs.readFileSync).toHaveBeenCalledWith('mockedSourceMapFile', 'utf8'); }); }); diff --git a/packages/jest-source-map/src/getCallsite.ts b/packages/jest-source-map/src/getCallsite.ts index 44d4420fb201..930e5c1eb5bb 100644 --- a/packages/jest-source-map/src/getCallsite.ts +++ b/packages/jest-source-map/src/getCallsite.ts @@ -5,23 +5,23 @@ * LICENSE file in the root directory of this source tree. */ +import {TraceMap, originalPositionFor} from '@jridgewell/trace-mapping'; import callsites = require('callsites'); import {readFileSync} from 'graceful-fs'; -import {SourceMapConsumer} from 'source-map'; import type {SourceMapRegistry} from './types'; // Copied from https://github.com/rexxars/sourcemap-decorate-callsites/blob/5b9735a156964973a75dc62fd2c7f0c1975458e8/lib/index.js#L113-L158 const addSourceMapConsumer = ( callsite: callsites.CallSite, - consumer: SourceMapConsumer, + tracer: TraceMap, ) => { const getLineNumber = callsite.getLineNumber; const getColumnNumber = callsite.getColumnNumber; - let position: ReturnType | null = null; + let position: ReturnType | null = null; function getPosition() { if (!position) { - position = consumer.originalPositionFor({ + position = originalPositionFor(tracer, { column: getColumnNumber.call(callsite) || -1, line: getLineNumber.call(callsite) || -1, }); @@ -57,8 +57,7 @@ export default function getCallsite( if (sourceMapFileName) { try { const sourceMap = readFileSync(sourceMapFileName, 'utf8'); - // @ts-expect-error: Not allowed to pass string - addSourceMapConsumer(stack, new SourceMapConsumer(sourceMap)); + addSourceMapConsumer(stack, new TraceMap(sourceMap)); } catch { // ignore } diff --git a/packages/jest-transform/package.json b/packages/jest-transform/package.json index fc42a0eabb8b..ebb34e5f963b 100644 --- a/packages/jest-transform/package.json +++ b/packages/jest-transform/package.json @@ -19,6 +19,7 @@ "dependencies": { "@babel/core": "^7.11.6", "@jest/types": "^28.0.0-alpha.9", + "@jridgewell/trace-mapping": "^0.3.4", "babel-plugin-istanbul": "^6.1.1", "chalk": "^4.0.0", "convert-source-map": "^1.4.0", @@ -30,7 +31,6 @@ "micromatch": "^4.0.4", "pirates": "^4.0.4", "slash": "^3.0.0", - "source-map": "^0.6.1", "write-file-atomic": "^4.0.1" }, "devDependencies": { diff --git a/packages/jest-transform/src/types.ts b/packages/jest-transform/src/types.ts index 543583477a6a..27308b5403f8 100644 --- a/packages/jest-transform/src/types.ts +++ b/packages/jest-transform/src/types.ts @@ -5,7 +5,7 @@ * LICENSE file in the root directory of this source tree. */ -import type {RawSourceMap} from 'source-map'; +import type {EncodedSourceMap} from '@jridgewell/trace-mapping'; import type {Config, TransformTypes} from '@jest/types'; export interface ShouldInstrumentOptions @@ -26,8 +26,8 @@ export interface Options isInternalModule?: boolean; } -// This is fixed in source-map@0.7.x, but we can't upgrade yet since it's async -interface FixedRawSourceMap extends Omit { +// `babel` and `@jridgewell/trace-mapping` disagrees - `number` vs `3` +interface FixedRawSourceMap extends Omit { version: number; } diff --git a/yarn.lock b/yarn.lock index 875b2c9d58df..428a3a0a9ec5 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2758,6 +2758,7 @@ __metadata: "@jest/test-utils": ^28.0.0-alpha.9 "@jest/transform": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 + "@jridgewell/trace-mapping": ^0.3.4 "@types/exit": ^0.1.30 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 @@ -2783,7 +2784,6 @@ __metadata: jest-worker: ^28.0.0-alpha.9 mock-fs: ^5.1.2 slash: ^3.0.0 - source-map: ^0.6.1 string-length: ^4.0.1 strip-ansi: ^6.0.0 terminal-link: ^2.0.0 @@ -2808,10 +2808,10 @@ __metadata: version: 0.0.0-use.local resolution: "@jest/source-map@workspace:packages/jest-source-map" dependencies: + "@jridgewell/trace-mapping": ^0.3.4 "@types/graceful-fs": ^4.1.3 callsites: ^3.0.0 graceful-fs: ^4.2.9 - source-map: ^0.6.1 languageName: unknown linkType: soft @@ -2872,6 +2872,7 @@ __metadata: "@babel/core": ^7.11.6 "@jest/test-utils": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 + "@jridgewell/trace-mapping": ^0.3.4 "@types/babel__core": ^7.1.14 "@types/convert-source-map": ^1.5.1 "@types/fast-json-stable-stringify": ^2.0.0 @@ -2890,7 +2891,6 @@ __metadata: micromatch: ^4.0.4 pirates: ^4.0.4 slash: ^3.0.0 - source-map: ^0.6.1 write-file-atomic: ^4.0.1 languageName: unknown linkType: soft @@ -2950,7 +2950,7 @@ __metadata: languageName: node linkType: hard -"@jridgewell/trace-mapping@npm:^0.3.0": +"@jridgewell/trace-mapping@npm:^0.3.0, @jridgewell/trace-mapping@npm:^0.3.4": version: 0.3.4 resolution: "@jridgewell/trace-mapping@npm:0.3.4" dependencies: From 78d4088ea53c4e89915ac30d55f432be5dc83832 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 08:59:03 +0200 Subject: [PATCH 069/128] fix: lazily define node env globals (#12696) --- CHANGELOG.md | 2 +- packages/jest-environment-node/src/index.ts | 53 ++++++++++++++++++--- 2 files changed, 47 insertions(+), 8 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 0fc8df52ae20..6225ec6c0fc5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -26,7 +26,7 @@ - `[jest-environment-node]` [**BREAKING**] Add default `node` and `node-addon` conditions to `exportConditions` for `node` environment ([#11924](https://github.com/facebook/jest/pull/11924)) - `[jest-environment-node]` [**BREAKING**] Pass global config to Jest environment constructor for `node` environment ([#12461](https://github.com/facebook/jest/pull/12461)) - `[jest-environment-node]` [**BREAKING**] Second argument `context` to constructor is mandatory ([#12469](https://github.com/facebook/jest/pull/12469)) -- `[jest-environment-node]` Add all available globals to test globals, not just explicit ones ([#12642](https://github.com/facebook/jest/pull/12642)) +- `[jest-environment-node]` Add all available globals to test globals, not just explicit ones ([#12642](https://github.com/facebook/jest/pull/12642), [#12696](https://github.com/facebook/jest/pull/12696)) - `[@jest/expect]` New module which extends `expect` with `jest-snapshot` matchers ([#12404](https://github.com/facebook/jest/pull/12404), [#12410](https://github.com/facebook/jest/pull/12410), [#12418](https://github.com/facebook/jest/pull/12418)) - `[@jest/expect-utils]` New module exporting utils for `expect` ([#12323](https://github.com/facebook/jest/pull/12323)) - `[@jest/fake-timers]` [**BREAKING**] Rename `timers` configuration option to `fakeTimers` ([#12572](https://github.com/facebook/jest/pull/12572)) diff --git a/packages/jest-environment-node/src/index.ts b/packages/jest-environment-node/src/index.ts index b6bdd65d895e..ec2b61f09ac0 100644 --- a/packages/jest-environment-node/src/index.ts +++ b/packages/jest-environment-node/src/index.ts @@ -30,12 +30,27 @@ const denyList = new Set([ 'Buffer', 'ArrayBuffer', 'Uint8Array', + // if env is loaded within a jest test + 'jest-symbol-do-not-touch', ]); -const nodeGlobals = new Set( - Object.getOwnPropertyNames(globalThis).filter( - global => !denyList.has(global), - ), +const nodeGlobals = new Map( + Object.getOwnPropertyNames(globalThis) + .filter(global => !denyList.has(global)) + .map(nodeGlobalsKey => { + const descriptor = Object.getOwnPropertyDescriptor( + globalThis, + nodeGlobalsKey, + ); + + if (!descriptor) { + throw new Error( + `No property descriptor for ${nodeGlobalsKey}, this is a bug in Jest.`, + ); + } + + return [nodeGlobalsKey, descriptor]; + }), ); export default class NodeEnvironment implements JestEnvironment { @@ -55,10 +70,34 @@ export default class NodeEnvironment implements JestEnvironment { )); const contextGlobals = new Set(Object.getOwnPropertyNames(global)); - for (const nodeGlobalsKey of nodeGlobals) { + for (const [nodeGlobalsKey, descriptor] of nodeGlobals) { if (!contextGlobals.has(nodeGlobalsKey)) { - // @ts-expect-error - global[nodeGlobalsKey] = globalThis[nodeGlobalsKey]; + Object.defineProperty(global, nodeGlobalsKey, { + configurable: descriptor.configurable, + enumerable: descriptor.enumerable, + get() { + // @ts-expect-error + const val = globalThis[nodeGlobalsKey]; + + // override lazy getter + Object.defineProperty(global, nodeGlobalsKey, { + configurable: descriptor.configurable, + enumerable: descriptor.enumerable, + value: val, + writable: descriptor.writable, + }); + return val; + }, + set(val) { + // override lazy getter + Object.defineProperty(global, nodeGlobalsKey, { + configurable: descriptor.configurable, + enumerable: descriptor.enumerable, + value: val, + writable: true, + }); + }, + }); } } From 4d5e58a847dbcda1b414c58399cc5d4ae8d2782c Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 09:23:06 +0200 Subject: [PATCH 070/128] chore: test node 18 on CI (#12694) --- .circleci/config.yml | 2 +- .github/workflows/nodejs.yml | 2 +- .../react-native-npm-0.68.1-8830b7be0d.patch | 18 ++++++++ package.json | 3 +- yarn.lock | 44 +++++++++++++++++++ 5 files changed, 66 insertions(+), 3 deletions(-) create mode 100644 .yarn/patches/react-native-npm-0.68.1-8830b7be0d.patch diff --git a/.circleci/config.yml b/.circleci/config.yml index f6614bab3220..b28f93ee3a3c 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -54,5 +54,5 @@ workflows: name: test-node-partial-<< matrix.node-version >> matrix: parameters: - node-version: ['12', '14', '16', '17'] + node-version: ['12', '14', '16', '17', '18'] - test-jest-jasmine diff --git a/.github/workflows/nodejs.yml b/.github/workflows/nodejs.yml index e69d8c36226f..ec67774a5153 100644 --- a/.github/workflows/nodejs.yml +++ b/.github/workflows/nodejs.yml @@ -101,7 +101,7 @@ jobs: strategy: fail-fast: false matrix: - node-version: [12.x, 14.x, 16.x, 17.x] + node-version: [12.x, 14.x, 16.x, 17.x, 18.x] os: [ubuntu-latest, macOS-latest, windows-latest] shard: ['1/4', '2/4', '3/4', '4/4'] runs-on: ${{ matrix.os }} diff --git a/.yarn/patches/react-native-npm-0.68.1-8830b7be0d.patch b/.yarn/patches/react-native-npm-0.68.1-8830b7be0d.patch new file mode 100644 index 000000000000..28b1e00527da --- /dev/null +++ b/.yarn/patches/react-native-npm-0.68.1-8830b7be0d.patch @@ -0,0 +1,18 @@ +diff --git a/jest/setup.js b/jest/setup.js +index 5bc65447594091c2da6dadb4be6bc1c6da43c7a0..356e7ff3eb55947e084db5d1df9b2d9f0544a15b 100644 +--- a/jest/setup.js ++++ b/jest/setup.js +@@ -17,13 +17,8 @@ jest.requireActual('@react-native/polyfills/error-guard'); + + global.__DEV__ = true; + +-global.performance = { +- now: jest.fn(Date.now), +-}; +- + global.Promise = jest.requireActual('promise'); + global.regeneratorRuntime = jest.requireActual('regenerator-runtime/runtime'); +-global.window = global; + + global.requestAnimationFrame = function (callback) { + return setTimeout(callback, 0); diff --git a/package.json b/package.json index 6cc88e839cbd..ff0747191f4b 100644 --- a/package.json +++ b/package.json @@ -165,7 +165,8 @@ "resolutions": { "babel-jest": "workspace:*", "jest": "workspace:*", - "jest-environment-node": "workspace:*" + "jest-environment-node": "workspace:*", + "react-native@0.68.1": "patch:react-native@npm:0.68.1#.yarn/patches/react-native-npm-0.68.1-8830b7be0d.patch" }, "packageManager": "yarn@3.2.0" } diff --git a/yarn.lock b/yarn.lock index 428a3a0a9ec5..698966324eb6 100644 --- a/yarn.lock +++ b/yarn.lock @@ -18602,6 +18602,50 @@ __metadata: languageName: node linkType: hard +"react-native@patch:react-native@npm:0.68.1#.yarn/patches/react-native-npm-0.68.1-8830b7be0d.patch::locator=%40jest%2Fmonorepo%40workspace%3A.": + version: 0.68.1 + resolution: "react-native@patch:react-native@npm%3A0.68.1#.yarn/patches/react-native-npm-0.68.1-8830b7be0d.patch::version=0.68.1&hash=b59fc5&locator=%40jest%2Fmonorepo%40workspace%3A." + dependencies: + "@jest/create-cache-key-function": ^27.0.1 + "@react-native-community/cli": ^7.0.3 + "@react-native-community/cli-platform-android": ^7.0.1 + "@react-native-community/cli-platform-ios": ^7.0.1 + "@react-native/assets": 1.0.0 + "@react-native/normalize-color": 2.0.0 + "@react-native/polyfills": 2.0.0 + abort-controller: ^3.0.0 + anser: ^1.4.9 + base64-js: ^1.1.2 + deprecated-react-native-prop-types: ^2.3.0 + event-target-shim: ^5.0.1 + hermes-engine: ~0.11.0 + invariant: ^2.2.4 + jsc-android: ^250230.2.1 + metro-react-native-babel-transformer: 0.67.0 + metro-runtime: 0.67.0 + metro-source-map: 0.67.0 + nullthrows: ^1.1.1 + pretty-format: ^26.5.2 + promise: ^8.0.3 + react-devtools-core: ^4.23.0 + react-native-codegen: ^0.0.13 + react-native-gradle-plugin: ^0.0.6 + react-refresh: ^0.4.0 + react-shallow-renderer: 16.14.1 + regenerator-runtime: ^0.13.2 + scheduler: ^0.20.2 + stacktrace-parser: ^0.1.3 + use-subscription: ">=1.0.0 <1.6.0" + whatwg-fetch: ^3.0.0 + ws: ^6.1.4 + peerDependencies: + react: 17.0.2 + bin: + react-native: cli.js + checksum: 9cde185dcf581af0ec53a79f73d74b5d5d7437b4d78f5b5cf562717b7dae2d967aa9ce274b05f5803a52f3c549a9bcc586fc53a40ca02d154257ce31916f8d61 + languageName: node + linkType: hard + "react-refresh@npm:^0.4.0": version: 0.4.3 resolution: "react-refresh@npm:0.4.3" From d5eda7f23571081cea24760261d209ff3e01a084 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 09:37:26 +0200 Subject: [PATCH 071/128] v28.0.0-alpha.10 --- lerna.json | 2 +- packages/babel-jest/package.json | 4 ++-- packages/jest-circus/package.json | 8 ++++---- packages/jest-cli/package.json | 6 +++--- packages/jest-config/package.json | 10 +++++----- packages/jest-core/package.json | 16 ++++++++-------- packages/jest-environment-node/package.json | 2 +- packages/jest-expect/package.json | 4 ++-- packages/jest-globals/package.json | 4 ++-- packages/jest-jasmine2/package.json | 10 +++++----- packages/jest-repl/package.json | 8 ++++---- packages/jest-reporters/package.json | 4 ++-- packages/jest-resolve-dependencies/package.json | 6 +++--- packages/jest-runner/package.json | 10 +++++----- packages/jest-runtime/package.json | 12 ++++++------ packages/jest-snapshot/package.json | 4 ++-- packages/jest-source-map/package.json | 2 +- packages/jest-transform/package.json | 2 +- packages/jest/package.json | 6 +++--- 19 files changed, 60 insertions(+), 60 deletions(-) diff --git a/lerna.json b/lerna.json index 23ea308570fa..9e3cc5d8701f 100644 --- a/lerna.json +++ b/lerna.json @@ -3,5 +3,5 @@ "packages/*" ], "npmClient": "yarn", - "version": "28.0.0-alpha.9" + "version": "28.0.0-alpha.10" } diff --git a/packages/babel-jest/package.json b/packages/babel-jest/package.json index 2b7c26f25ad8..deb70a595b3e 100644 --- a/packages/babel-jest/package.json +++ b/packages/babel-jest/package.json @@ -1,7 +1,7 @@ { "name": "babel-jest", "description": "Jest plugin to use babel for transformation.", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,7 +18,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/transform": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.10", "@types/babel__core": "^7.1.14", "babel-plugin-istanbul": "^6.1.1", "babel-preset-jest": "^28.0.0-alpha.9", diff --git a/packages/jest-circus/package.json b/packages/jest-circus/package.json index c84ffcad737b..8a09d685239b 100644 --- a/packages/jest-circus/package.json +++ b/packages/jest-circus/package.json @@ -1,6 +1,6 @@ { "name": "jest-circus", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -19,7 +19,7 @@ }, "dependencies": { "@jest/environment": "^28.0.0-alpha.9", - "@jest/expect": "^28.0.0-alpha.9", + "@jest/expect": "^28.0.0-alpha.10", "@jest/test-result": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", @@ -30,8 +30,8 @@ "jest-each": "^28.0.0-alpha.9", "jest-matcher-utils": "^28.0.0-alpha.9", "jest-message-util": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.9", - "jest-snapshot": "^28.0.0-alpha.9", + "jest-runtime": "^28.0.0-alpha.10", + "jest-snapshot": "^28.0.0-alpha.10", "jest-util": "^28.0.0-alpha.9", "pretty-format": "^28.0.0-alpha.9", "slash": "^3.0.0", diff --git a/packages/jest-cli/package.json b/packages/jest-cli/package.json index 27150b8f2ce1..eb7544128b29 100644 --- a/packages/jest-cli/package.json +++ b/packages/jest-cli/package.json @@ -1,7 +1,7 @@ { "name": "jest-cli", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,14 +13,14 @@ "./bin/jest": "./bin/jest.js" }, "dependencies": { - "@jest/core": "^28.0.0-alpha.9", + "@jest/core": "^28.0.0-alpha.10", "@jest/test-result": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", "exit": "^0.1.2", "graceful-fs": "^4.2.9", "import-local": "^3.0.2", - "jest-config": "^28.0.0-alpha.9", + "jest-config": "^28.0.0-alpha.10", "jest-util": "^28.0.0-alpha.9", "jest-validate": "^28.0.0-alpha.9", "prompts": "^2.0.1", diff --git a/packages/jest-config/package.json b/packages/jest-config/package.json index b2912d9d80dd..dcbc41d9e1e4 100644 --- a/packages/jest-config/package.json +++ b/packages/jest-config/package.json @@ -1,6 +1,6 @@ { "name": "jest-config", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -32,18 +32,18 @@ "@babel/core": "^7.11.6", "@jest/test-sequencer": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", - "babel-jest": "^28.0.0-alpha.9", + "babel-jest": "^28.0.0-alpha.10", "chalk": "^4.0.0", "ci-info": "^3.2.0", "deepmerge": "^4.2.2", "glob": "^7.1.3", "graceful-fs": "^4.2.9", - "jest-circus": "^28.0.0-alpha.9", - "jest-environment-node": "^28.0.0-alpha.9", + "jest-circus": "^28.0.0-alpha.10", + "jest-environment-node": "^28.0.0-alpha.10", "jest-get-type": "^28.0.0-alpha.3", "jest-regex-util": "^28.0.0-alpha.6", "jest-resolve": "^28.0.0-alpha.9", - "jest-runner": "^28.0.0-alpha.9", + "jest-runner": "^28.0.0-alpha.10", "jest-util": "^28.0.0-alpha.9", "jest-validate": "^28.0.0-alpha.9", "micromatch": "^4.0.4", diff --git a/packages/jest-core/package.json b/packages/jest-core/package.json index b77f728a9b3f..aae17154d36c 100644 --- a/packages/jest-core/package.json +++ b/packages/jest-core/package.json @@ -1,7 +1,7 @@ { "name": "@jest/core", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,9 +13,9 @@ }, "dependencies": { "@jest/console": "^28.0.0-alpha.9", - "@jest/reporters": "^28.0.0-alpha.9", + "@jest/reporters": "^28.0.0-alpha.10", "@jest/test-result": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.10", "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "ansi-escapes": "^4.2.1", @@ -24,15 +24,15 @@ "exit": "^0.1.2", "graceful-fs": "^4.2.9", "jest-changed-files": "^28.0.0-alpha.3", - "jest-config": "^28.0.0-alpha.9", + "jest-config": "^28.0.0-alpha.10", "jest-haste-map": "^28.0.0-alpha.9", "jest-message-util": "^28.0.0-alpha.9", "jest-regex-util": "^28.0.0-alpha.6", "jest-resolve": "^28.0.0-alpha.9", - "jest-resolve-dependencies": "^28.0.0-alpha.9", - "jest-runner": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.9", - "jest-snapshot": "^28.0.0-alpha.9", + "jest-resolve-dependencies": "^28.0.0-alpha.10", + "jest-runner": "^28.0.0-alpha.10", + "jest-runtime": "^28.0.0-alpha.10", + "jest-snapshot": "^28.0.0-alpha.10", "jest-util": "^28.0.0-alpha.9", "jest-validate": "^28.0.0-alpha.9", "jest-watcher": "^28.0.0-alpha.9", diff --git a/packages/jest-environment-node/package.json b/packages/jest-environment-node/package.json index bbd63ed3c379..02f9a64602cf 100644 --- a/packages/jest-environment-node/package.json +++ b/packages/jest-environment-node/package.json @@ -1,6 +1,6 @@ { "name": "jest-environment-node", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/jest-expect/package.json b/packages/jest-expect/package.json index 422c49d767ed..d92964a604ff 100644 --- a/packages/jest-expect/package.json +++ b/packages/jest-expect/package.json @@ -1,6 +1,6 @@ { "name": "@jest/expect", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,7 +18,7 @@ }, "dependencies": { "expect": "^28.0.0-alpha.9", - "jest-snapshot": "^28.0.0-alpha.9" + "jest-snapshot": "^28.0.0-alpha.10" }, "devDependencies": { "@tsd/typescript": "~4.6.2", diff --git a/packages/jest-globals/package.json b/packages/jest-globals/package.json index effeab2924fb..acf78156ed55 100644 --- a/packages/jest-globals/package.json +++ b/packages/jest-globals/package.json @@ -1,6 +1,6 @@ { "name": "@jest/globals", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -21,7 +21,7 @@ }, "dependencies": { "@jest/environment": "^28.0.0-alpha.9", - "@jest/expect": "^28.0.0-alpha.9", + "@jest/expect": "^28.0.0-alpha.10", "@jest/types": "^28.0.0-alpha.9" }, "publishConfig": { diff --git a/packages/jest-jasmine2/package.json b/packages/jest-jasmine2/package.json index a156dd5f9e4e..1351a0240a21 100644 --- a/packages/jest-jasmine2/package.json +++ b/packages/jest-jasmine2/package.json @@ -1,6 +1,6 @@ { "name": "jest-jasmine2", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,8 +18,8 @@ }, "dependencies": { "@jest/environment": "^28.0.0-alpha.9", - "@jest/expect": "^28.0.0-alpha.9", - "@jest/source-map": "^28.0.0-alpha.9", + "@jest/expect": "^28.0.0-alpha.10", + "@jest/source-map": "^28.0.0-alpha.10", "@jest/test-result": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", @@ -29,8 +29,8 @@ "jest-each": "^28.0.0-alpha.9", "jest-matcher-utils": "^28.0.0-alpha.9", "jest-message-util": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.9", - "jest-snapshot": "^28.0.0-alpha.9", + "jest-runtime": "^28.0.0-alpha.10", + "jest-snapshot": "^28.0.0-alpha.10", "jest-util": "^28.0.0-alpha.9", "pretty-format": "^28.0.0-alpha.9", "throat": "^6.0.1" diff --git a/packages/jest-repl/package.json b/packages/jest-repl/package.json index 9e17f9a70a5b..dc3797c735fc 100644 --- a/packages/jest-repl/package.json +++ b/packages/jest-repl/package.json @@ -1,6 +1,6 @@ { "name": "jest-repl", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -21,11 +21,11 @@ "dependencies": { "@jest/console": "^28.0.0-alpha.9", "@jest/environment": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.10", "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", - "jest-config": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.9", + "jest-config": "^28.0.0-alpha.10", + "jest-runtime": "^28.0.0-alpha.10", "jest-util": "^28.0.0-alpha.9", "jest-validate": "^28.0.0-alpha.9", "repl": "^0.1.3", diff --git a/packages/jest-reporters/package.json b/packages/jest-reporters/package.json index 82fe47a62706..ed1d2c6b38db 100644 --- a/packages/jest-reporters/package.json +++ b/packages/jest-reporters/package.json @@ -1,7 +1,7 @@ { "name": "@jest/reporters", "description": "Jest's reporters", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -15,7 +15,7 @@ "@bcoe/v8-coverage": "^0.2.3", "@jest/console": "^28.0.0-alpha.9", "@jest/test-result": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.10", "@jest/types": "^28.0.0-alpha.9", "@jridgewell/trace-mapping": "^0.3.4", "@types/node": "*", diff --git a/packages/jest-resolve-dependencies/package.json b/packages/jest-resolve-dependencies/package.json index d1fb54158692..b98cf1f9cc58 100644 --- a/packages/jest-resolve-dependencies/package.json +++ b/packages/jest-resolve-dependencies/package.json @@ -1,6 +1,6 @@ { "name": "jest-resolve-dependencies", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,14 +18,14 @@ }, "dependencies": { "jest-regex-util": "^28.0.0-alpha.6", - "jest-snapshot": "^28.0.0-alpha.9" + "jest-snapshot": "^28.0.0-alpha.10" }, "devDependencies": { "@jest/test-utils": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", "jest-haste-map": "^28.0.0-alpha.9", "jest-resolve": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.9" + "jest-runtime": "^28.0.0-alpha.10" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-runner/package.json b/packages/jest-runner/package.json index b0f7a269641b..e51b82617886 100644 --- a/packages/jest-runner/package.json +++ b/packages/jest-runner/package.json @@ -1,6 +1,6 @@ { "name": "jest-runner", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -20,19 +20,19 @@ "@jest/console": "^28.0.0-alpha.9", "@jest/environment": "^28.0.0-alpha.9", "@jest/test-result": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.10", "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "chalk": "^4.0.0", "emittery": "^0.10.2", "graceful-fs": "^4.2.9", "jest-docblock": "^28.0.0-alpha.6", - "jest-environment-node": "^28.0.0-alpha.9", + "jest-environment-node": "^28.0.0-alpha.10", "jest-haste-map": "^28.0.0-alpha.9", "jest-leak-detector": "^28.0.0-alpha.9", "jest-message-util": "^28.0.0-alpha.9", "jest-resolve": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.9", + "jest-runtime": "^28.0.0-alpha.10", "jest-util": "^28.0.0-alpha.9", "jest-watcher": "^28.0.0-alpha.9", "jest-worker": "^28.0.0-alpha.9", @@ -44,7 +44,7 @@ "@types/exit": "^0.1.30", "@types/graceful-fs": "^4.1.3", "@types/source-map-support": "^0.5.0", - "jest-jasmine2": "^28.0.0-alpha.9", + "jest-jasmine2": "^28.0.0-alpha.10", "tsd-lite": "^0.5.1" }, "engines": { diff --git a/packages/jest-runtime/package.json b/packages/jest-runtime/package.json index 3f062fc2accc..d73a442e5595 100644 --- a/packages/jest-runtime/package.json +++ b/packages/jest-runtime/package.json @@ -1,6 +1,6 @@ { "name": "jest-runtime", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -19,10 +19,10 @@ "dependencies": { "@jest/environment": "^28.0.0-alpha.9", "@jest/fake-timers": "^28.0.0-alpha.9", - "@jest/globals": "^28.0.0-alpha.9", - "@jest/source-map": "^28.0.0-alpha.9", + "@jest/globals": "^28.0.0-alpha.10", + "@jest/source-map": "^28.0.0-alpha.10", "@jest/test-result": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.10", "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", "cjs-module-lexer": "^1.0.0", @@ -35,7 +35,7 @@ "jest-mock": "^28.0.0-alpha.9", "jest-regex-util": "^28.0.0-alpha.6", "jest-resolve": "^28.0.0-alpha.9", - "jest-snapshot": "^28.0.0-alpha.9", + "jest-snapshot": "^28.0.0-alpha.10", "jest-util": "^28.0.0-alpha.9", "slash": "^3.0.0", "strip-bom": "^4.0.0" @@ -45,7 +45,7 @@ "@types/glob": "^7.1.1", "@types/graceful-fs": "^4.1.3", "@types/node": "*", - "jest-environment-node": "^28.0.0-alpha.9" + "jest-environment-node": "^28.0.0-alpha.10" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-snapshot/package.json b/packages/jest-snapshot/package.json index de10164f7079..22c07087419e 100644 --- a/packages/jest-snapshot/package.json +++ b/packages/jest-snapshot/package.json @@ -1,6 +1,6 @@ { "name": "jest-snapshot", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -23,7 +23,7 @@ "@babel/traverse": "^7.7.2", "@babel/types": "^7.3.3", "@jest/expect-utils": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.9", + "@jest/transform": "^28.0.0-alpha.10", "@jest/types": "^28.0.0-alpha.9", "@types/babel__traverse": "^7.0.6", "@types/prettier": "^2.1.5", diff --git a/packages/jest-source-map/package.json b/packages/jest-source-map/package.json index 477f6ebe8667..87d4ad08423b 100644 --- a/packages/jest-source-map/package.json +++ b/packages/jest-source-map/package.json @@ -1,6 +1,6 @@ { "name": "@jest/source-map", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/jest-transform/package.json b/packages/jest-transform/package.json index ebb34e5f963b..1dcc9333a908 100644 --- a/packages/jest-transform/package.json +++ b/packages/jest-transform/package.json @@ -1,6 +1,6 @@ { "name": "@jest/transform", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/jest/package.json b/packages/jest/package.json index bf608678338d..2f8f92962ee6 100644 --- a/packages/jest/package.json +++ b/packages/jest/package.json @@ -1,7 +1,7 @@ { "name": "jest", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.10", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,9 +13,9 @@ "./bin/jest": "./bin/jest.js" }, "dependencies": { - "@jest/core": "^28.0.0-alpha.9", + "@jest/core": "^28.0.0-alpha.10", "import-local": "^3.0.2", - "jest-cli": "^28.0.0-alpha.9" + "jest-cli": "^28.0.0-alpha.10" }, "peerDependencies": { "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" From 92acb873e351a8dfdac05eba4c34ffae076d88c1 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 09:38:14 +0200 Subject: [PATCH 072/128] chore: update lockfile after release --- yarn.lock | 110 +++++++++++++++++++++++++++--------------------------- 1 file changed, 55 insertions(+), 55 deletions(-) diff --git a/yarn.lock b/yarn.lock index 698966324eb6..266df664152c 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2539,16 +2539,16 @@ __metadata: languageName: node linkType: hard -"@jest/core@^28.0.0-alpha.9, @jest/core@workspace:packages/jest-core": +"@jest/core@^28.0.0-alpha.10, @jest/core@workspace:packages/jest-core": version: 0.0.0-use.local resolution: "@jest/core@workspace:packages/jest-core" dependencies: "@jest/console": ^28.0.0-alpha.9 - "@jest/reporters": ^28.0.0-alpha.9 + "@jest/reporters": ^28.0.0-alpha.10 "@jest/test-result": ^28.0.0-alpha.9 "@jest/test-sequencer": ^28.0.0-alpha.9 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.10 "@jest/types": ^28.0.0-alpha.9 "@types/exit": ^0.1.30 "@types/graceful-fs": ^4.1.3 @@ -2561,15 +2561,15 @@ __metadata: exit: ^0.1.2 graceful-fs: ^4.2.9 jest-changed-files: ^28.0.0-alpha.3 - jest-config: ^28.0.0-alpha.9 + jest-config: ^28.0.0-alpha.10 jest-haste-map: ^28.0.0-alpha.9 jest-message-util: ^28.0.0-alpha.9 jest-regex-util: ^28.0.0-alpha.6 jest-resolve: ^28.0.0-alpha.9 - jest-resolve-dependencies: ^28.0.0-alpha.9 - jest-runner: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.9 - jest-snapshot: ^28.0.0-alpha.9 + jest-resolve-dependencies: ^28.0.0-alpha.10 + jest-runner: ^28.0.0-alpha.10 + jest-runtime: ^28.0.0-alpha.10 + jest-snapshot: ^28.0.0-alpha.10 jest-util: ^28.0.0-alpha.9 jest-validate: ^28.0.0-alpha.9 jest-watcher: ^28.0.0-alpha.9 @@ -2625,13 +2625,13 @@ __metadata: languageName: unknown linkType: soft -"@jest/expect@^28.0.0-alpha.9, @jest/expect@workspace:packages/jest-expect": +"@jest/expect@^28.0.0-alpha.10, @jest/expect@workspace:packages/jest-expect": version: 0.0.0-use.local resolution: "@jest/expect@workspace:packages/jest-expect" dependencies: "@tsd/typescript": ~4.6.2 expect: ^28.0.0-alpha.9 - jest-snapshot: ^28.0.0-alpha.9 + jest-snapshot: ^28.0.0-alpha.10 tsd-lite: ^0.5.1 languageName: unknown linkType: soft @@ -2651,12 +2651,12 @@ __metadata: languageName: unknown linkType: soft -"@jest/globals@^28.0.0-alpha.9, @jest/globals@workspace:*, @jest/globals@workspace:packages/jest-globals": +"@jest/globals@^28.0.0-alpha.10, @jest/globals@workspace:*, @jest/globals@workspace:packages/jest-globals": version: 0.0.0-use.local resolution: "@jest/globals@workspace:packages/jest-globals" dependencies: "@jest/environment": ^28.0.0-alpha.9 - "@jest/expect": ^28.0.0-alpha.9 + "@jest/expect": ^28.0.0-alpha.10 "@jest/types": ^28.0.0-alpha.9 languageName: unknown linkType: soft @@ -2748,7 +2748,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/reporters@^28.0.0-alpha.9, @jest/reporters@workspace:packages/jest-reporters": +"@jest/reporters@^28.0.0-alpha.10, @jest/reporters@workspace:packages/jest-reporters": version: 0.0.0-use.local resolution: "@jest/reporters@workspace:packages/jest-reporters" dependencies: @@ -2756,7 +2756,7 @@ __metadata: "@jest/console": ^28.0.0-alpha.9 "@jest/test-result": ^28.0.0-alpha.9 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.10 "@jest/types": ^28.0.0-alpha.9 "@jridgewell/trace-mapping": ^0.3.4 "@types/exit": ^0.1.30 @@ -2804,7 +2804,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/source-map@^28.0.0-alpha.9, @jest/source-map@workspace:packages/jest-source-map": +"@jest/source-map@^28.0.0-alpha.10, @jest/source-map@workspace:packages/jest-source-map": version: 0.0.0-use.local resolution: "@jest/source-map@workspace:packages/jest-source-map" dependencies: @@ -2865,7 +2865,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/transform@^28.0.0-alpha.9, @jest/transform@workspace:packages/jest-transform": +"@jest/transform@^28.0.0-alpha.10, @jest/transform@workspace:packages/jest-transform": version: 0.0.0-use.local resolution: "@jest/transform@workspace:packages/jest-transform" dependencies: @@ -6678,7 +6678,7 @@ __metadata: dependencies: "@babel/core": ^7.11.6 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.10 "@types/babel__core": ^7.1.14 "@types/graceful-fs": ^4.1.3 babel-plugin-istanbul: ^6.1.1 @@ -12995,14 +12995,14 @@ __metadata: languageName: unknown linkType: soft -"jest-circus@^28.0.0-alpha.9, jest-circus@workspace:packages/jest-circus": +"jest-circus@^28.0.0-alpha.10, jest-circus@workspace:packages/jest-circus": version: 0.0.0-use.local resolution: "jest-circus@workspace:packages/jest-circus" dependencies: "@babel/core": ^7.11.6 "@babel/register": ^7.0.0 "@jest/environment": ^28.0.0-alpha.9 - "@jest/expect": ^28.0.0-alpha.9 + "@jest/expect": ^28.0.0-alpha.10 "@jest/test-result": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 "@types/co": ^4.6.2 @@ -13019,8 +13019,8 @@ __metadata: jest-each: ^28.0.0-alpha.9 jest-matcher-utils: ^28.0.0-alpha.9 jest-message-util: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.9 - jest-snapshot: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.10 + jest-snapshot: ^28.0.0-alpha.10 jest-util: ^28.0.0-alpha.9 pretty-format: ^28.0.0-alpha.9 slash: ^3.0.0 @@ -13029,11 +13029,11 @@ __metadata: languageName: unknown linkType: soft -"jest-cli@^28.0.0-alpha.9, jest-cli@workspace:packages/jest-cli": +"jest-cli@^28.0.0-alpha.10, jest-cli@workspace:packages/jest-cli": version: 0.0.0-use.local resolution: "jest-cli@workspace:packages/jest-cli" dependencies: - "@jest/core": ^28.0.0-alpha.9 + "@jest/core": ^28.0.0-alpha.10 "@jest/test-result": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 "@types/exit": ^0.1.30 @@ -13044,7 +13044,7 @@ __metadata: exit: ^0.1.2 graceful-fs: ^4.2.9 import-local: ^3.0.2 - jest-config: ^28.0.0-alpha.9 + jest-config: ^28.0.0-alpha.10 jest-util: ^28.0.0-alpha.9 jest-validate: ^28.0.0-alpha.9 prompts: ^2.0.1 @@ -13059,7 +13059,7 @@ __metadata: languageName: unknown linkType: soft -"jest-config@^28.0.0-alpha.9, jest-config@workspace:packages/jest-config": +"jest-config@^28.0.0-alpha.10, jest-config@workspace:packages/jest-config": version: 0.0.0-use.local resolution: "jest-config@workspace:packages/jest-config" dependencies: @@ -13069,18 +13069,18 @@ __metadata: "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 - babel-jest: ^28.0.0-alpha.9 + babel-jest: ^28.0.0-alpha.10 chalk: ^4.0.0 ci-info: ^3.2.0 deepmerge: ^4.2.2 glob: ^7.1.3 graceful-fs: ^4.2.9 - jest-circus: ^28.0.0-alpha.9 - jest-environment-node: ^28.0.0-alpha.9 + jest-circus: ^28.0.0-alpha.10 + jest-environment-node: ^28.0.0-alpha.10 jest-get-type: ^28.0.0-alpha.3 jest-regex-util: ^28.0.0-alpha.6 jest-resolve: ^28.0.0-alpha.9 - jest-runner: ^28.0.0-alpha.9 + jest-runner: ^28.0.0-alpha.10 jest-util: ^28.0.0-alpha.9 jest-validate: ^28.0.0-alpha.9 micromatch: ^4.0.4 @@ -13248,13 +13248,13 @@ __metadata: languageName: node linkType: hard -"jest-jasmine2@^28.0.0-alpha.9, jest-jasmine2@workspace:packages/jest-jasmine2": +"jest-jasmine2@^28.0.0-alpha.10, jest-jasmine2@workspace:packages/jest-jasmine2": version: 0.0.0-use.local resolution: "jest-jasmine2@workspace:packages/jest-jasmine2" dependencies: "@jest/environment": ^28.0.0-alpha.9 - "@jest/expect": ^28.0.0-alpha.9 - "@jest/source-map": ^28.0.0-alpha.9 + "@jest/expect": ^28.0.0-alpha.10 + "@jest/source-map": ^28.0.0-alpha.10 "@jest/test-result": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 "@types/co": ^4.6.2 @@ -13265,8 +13265,8 @@ __metadata: jest-each: ^28.0.0-alpha.9 jest-matcher-utils: ^28.0.0-alpha.9 jest-message-util: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.9 - jest-snapshot: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.10 + jest-snapshot: ^28.0.0-alpha.10 jest-util: ^28.0.0-alpha.9 pretty-format: ^28.0.0-alpha.9 throat: ^6.0.1 @@ -13409,13 +13409,13 @@ __metadata: dependencies: "@jest/console": ^28.0.0-alpha.9 "@jest/environment": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.10 "@jest/types": ^28.0.0-alpha.9 "@types/yargs": ^17.0.8 chalk: ^4.0.0 execa: ^5.0.0 - jest-config: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.9 + jest-config: ^28.0.0-alpha.10 + jest-runtime: ^28.0.0-alpha.10 jest-util: ^28.0.0-alpha.9 jest-validate: ^28.0.0-alpha.9 repl: ^0.1.3 @@ -13426,7 +13426,7 @@ __metadata: languageName: unknown linkType: soft -"jest-resolve-dependencies@^28.0.0-alpha.9, jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies": +"jest-resolve-dependencies@^28.0.0-alpha.10, jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies": version: 0.0.0-use.local resolution: "jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies" dependencies: @@ -13435,8 +13435,8 @@ __metadata: jest-haste-map: ^28.0.0-alpha.9 jest-regex-util: ^28.0.0-alpha.6 jest-resolve: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.9 - jest-snapshot: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.10 + jest-snapshot: ^28.0.0-alpha.10 languageName: unknown linkType: soft @@ -13472,14 +13472,14 @@ __metadata: languageName: node linkType: hard -"jest-runner@^28.0.0-alpha.9, jest-runner@workspace:packages/jest-runner": +"jest-runner@^28.0.0-alpha.10, jest-runner@workspace:packages/jest-runner": version: 0.0.0-use.local resolution: "jest-runner@workspace:packages/jest-runner" dependencies: "@jest/console": ^28.0.0-alpha.9 "@jest/environment": ^28.0.0-alpha.9 "@jest/test-result": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.10 "@jest/types": ^28.0.0-alpha.9 "@tsd/typescript": ~4.6.2 "@types/exit": ^0.1.30 @@ -13490,13 +13490,13 @@ __metadata: emittery: ^0.10.2 graceful-fs: ^4.2.9 jest-docblock: ^28.0.0-alpha.6 - jest-environment-node: ^28.0.0-alpha.9 + jest-environment-node: ^28.0.0-alpha.10 jest-haste-map: ^28.0.0-alpha.9 - jest-jasmine2: ^28.0.0-alpha.9 + jest-jasmine2: ^28.0.0-alpha.10 jest-leak-detector: ^28.0.0-alpha.9 jest-message-util: ^28.0.0-alpha.9 jest-resolve: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.9 + jest-runtime: ^28.0.0-alpha.10 jest-util: ^28.0.0-alpha.9 jest-watcher: ^28.0.0-alpha.9 jest-worker: ^28.0.0-alpha.9 @@ -13506,17 +13506,17 @@ __metadata: languageName: unknown linkType: soft -"jest-runtime@^28.0.0-alpha.9, jest-runtime@workspace:packages/jest-runtime": +"jest-runtime@^28.0.0-alpha.10, jest-runtime@workspace:packages/jest-runtime": version: 0.0.0-use.local resolution: "jest-runtime@workspace:packages/jest-runtime" dependencies: "@jest/environment": ^28.0.0-alpha.9 "@jest/fake-timers": ^28.0.0-alpha.9 - "@jest/globals": ^28.0.0-alpha.9 - "@jest/source-map": ^28.0.0-alpha.9 + "@jest/globals": ^28.0.0-alpha.10 + "@jest/source-map": ^28.0.0-alpha.10 "@jest/test-result": ^28.0.0-alpha.9 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.10 "@jest/types": ^28.0.0-alpha.9 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 @@ -13527,13 +13527,13 @@ __metadata: execa: ^5.0.0 glob: ^7.1.3 graceful-fs: ^4.2.9 - jest-environment-node: ^28.0.0-alpha.9 + jest-environment-node: ^28.0.0-alpha.10 jest-haste-map: ^28.0.0-alpha.9 jest-message-util: ^28.0.0-alpha.9 jest-mock: ^28.0.0-alpha.9 jest-regex-util: ^28.0.0-alpha.6 jest-resolve: ^28.0.0-alpha.9 - jest-snapshot: ^28.0.0-alpha.9 + jest-snapshot: ^28.0.0-alpha.10 jest-util: ^28.0.0-alpha.9 slash: ^3.0.0 strip-bom: ^4.0.0 @@ -13570,7 +13570,7 @@ __metadata: languageName: node linkType: hard -"jest-snapshot@^28.0.0-alpha.9, jest-snapshot@workspace:*, jest-snapshot@workspace:packages/jest-snapshot": +"jest-snapshot@^28.0.0-alpha.10, jest-snapshot@workspace:*, jest-snapshot@workspace:packages/jest-snapshot": version: 0.0.0-use.local resolution: "jest-snapshot@workspace:packages/jest-snapshot" dependencies: @@ -13583,7 +13583,7 @@ __metadata: "@babel/types": ^7.3.3 "@jest/expect-utils": ^28.0.0-alpha.9 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.9 + "@jest/transform": ^28.0.0-alpha.10 "@jest/types": ^28.0.0-alpha.9 "@types/babel__traverse": ^7.0.6 "@types/graceful-fs": ^4.1.3 @@ -13802,9 +13802,9 @@ __metadata: version: 0.0.0-use.local resolution: "jest@workspace:packages/jest" dependencies: - "@jest/core": ^28.0.0-alpha.9 + "@jest/core": ^28.0.0-alpha.10 import-local: ^3.0.2 - jest-cli: ^28.0.0-alpha.9 + jest-cli: ^28.0.0-alpha.10 peerDependencies: node-notifier: ^8.0.1 || ^9.0.0 || ^10.0.0 peerDependenciesMeta: From 588cc35f59046f6ee0eeb25ccf34cf83dac65f86 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 09:39:33 +0200 Subject: [PATCH 073/128] chore: add missing changelog entry --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6225ec6c0fc5..af72967aaa80 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -51,6 +51,7 @@ - `[jest-runtime]` Calling `jest.resetModules` function will clear FS and transform cache ([#12531](https://github.com/facebook/jest/pull/12531)) - `[jest-runtime]` [**BREAKING**] Remove `Context` type export, it must be imported from `@jest/test-result` ([#12685](https://github.com/facebook/jest/pull/12685)) - `[@jest/schemas]` New module for JSON schemas for Jest's config ([#12384](https://github.com/facebook/jest/pull/12384)) +- `[@jest/source-map]` Migrate from `source-map` to `@jridgewell/trace-mapping` ([#12692](https://github.com/facebook/jest/pull/12692)) - `[jest-transform]` [**BREAKING**] Make it required for `process()` and `processAsync()` methods to always return structured data ([#12638](https://github.com/facebook/jest/pull/12638)) - `[jest-test-result]` Add duration property to JSON test output ([#12518](https://github.com/facebook/jest/pull/12518)) - `[jest-watcher]` [**BREAKING**] Make `PatternPrompt` class to take `entityName` as third constructor parameter instead of `this._entityName` ([#12591](https://github.com/facebook/jest/pull/12591)) From 6c068ff6a98f8ead59bfc9a71a989a7c5c929351 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 12:41:55 +0200 Subject: [PATCH 074/128] chore: retry flaky test --- e2e/__tests__/jestChangedFiles.test.ts | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/e2e/__tests__/jestChangedFiles.test.ts b/e2e/__tests__/jestChangedFiles.test.ts index 44251db4acf9..ccb4b682ac53 100644 --- a/e2e/__tests__/jestChangedFiles.test.ts +++ b/e2e/__tests__/jestChangedFiles.test.ts @@ -47,6 +47,10 @@ function gitCreateBranch(branchName: string, dir: string) { run(`git branch ${branchName}`, dir); } +beforeAll(() => { + jest.retryTimes(3); +}); + beforeEach(() => cleanup(DIR)); afterEach(() => cleanup(DIR)); From d67f7831a9eaee215acc019e918a0e6223f66635 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 12:43:02 +0200 Subject: [PATCH 075/128] feat: add `import.meta.jest` (#12698) --- CHANGELOG.md | 1 + docs/ECMAScriptModules.md | 7 ++++++- e2e/native-esm/__tests__/native-esm.test.js | 2 ++ packages/jest-environment/src/index.ts | 4 ++++ packages/jest-runtime/src/index.ts | 14 +++++++++++++- 5 files changed, 26 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index af72967aaa80..68d80297ca28 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -50,6 +50,7 @@ - `[jest-runtime]` [**BREAKING**] `Runtime.createHasteMap` now returns a promise ([#12008](https://github.com/facebook/jest/pull/12008)) - `[jest-runtime]` Calling `jest.resetModules` function will clear FS and transform cache ([#12531](https://github.com/facebook/jest/pull/12531)) - `[jest-runtime]` [**BREAKING**] Remove `Context` type export, it must be imported from `@jest/test-result` ([#12685](https://github.com/facebook/jest/pull/12685)) +- `[jest-runtime]` Add `import.meta.jest` ([#12698](https://github.com/facebook/jest/pull/12698)) - `[@jest/schemas]` New module for JSON schemas for Jest's config ([#12384](https://github.com/facebook/jest/pull/12384)) - `[@jest/source-map]` Migrate from `source-map` to `@jridgewell/trace-mapping` ([#12692](https://github.com/facebook/jest/pull/12692)) - `[jest-transform]` [**BREAKING**] Make it required for `process()` and `processAsync()` methods to always return structured data ([#12638](https://github.com/facebook/jest/pull/12638)) diff --git a/docs/ECMAScriptModules.md b/docs/ECMAScriptModules.md index b4ad17d411b4..199b7ff61b8c 100644 --- a/docs/ECMAScriptModules.md +++ b/docs/ECMAScriptModules.md @@ -23,7 +23,7 @@ With the warnings out of the way, this is how you activate ESM support in your t ## Differences between ESM and CommonJS -Most of the differences are explained in [Node's documentation](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs), but in addition to the things mentioned there, Jest injects a special variable into all executed files - the [`jest` object](JestObjectAPI.md). To access this object in ESM, you need to import it from the `@jest/globals` module. +Most of the differences are explained in [Node's documentation](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs), but in addition to the things mentioned there, Jest injects a special variable into all executed files - the [`jest` object](JestObjectAPI.md). To access this object in ESM, you need to import it from the `@jest/globals` module or use `import.meta`. ```js import {jest} from '@jest/globals'; @@ -31,6 +31,11 @@ import {jest} from '@jest/globals'; jest.useFakeTimers(); // etc. + +// alternatively +import.meta.jest.useFakeTimers(); + +// jest === import.meta.jest => true ``` Please note that we currently don't support `jest.mock` in a clean way in ESM, but that is something we intend to add proper support for in the future. Follow [this issue](https://github.com/facebook/jest/issues/10025) for updates. diff --git a/e2e/native-esm/__tests__/native-esm.test.js b/e2e/native-esm/__tests__/native-esm.test.js index 73a652bdac5e..4a4088a7c2c2 100644 --- a/e2e/native-esm/__tests__/native-esm.test.js +++ b/e2e/native-esm/__tests__/native-esm.test.js @@ -28,8 +28,10 @@ test('should have correct import.meta', () => { expect(typeof require).toBe('undefined'); expect(typeof jest).toBe('undefined'); expect(import.meta).toEqual({ + jest: expect.anything(), url: expect.any(String), }); + expect(import.meta.jest).toBe(jestObject); expect( import.meta.url.endsWith('/e2e/native-esm/__tests__/native-esm.test.js'), ).toBe(true); diff --git a/packages/jest-environment/src/index.ts b/packages/jest-environment/src/index.ts index 67b57c37fa03..3005b3ef9a59 100644 --- a/packages/jest-environment/src/index.ts +++ b/packages/jest-environment/src/index.ts @@ -28,6 +28,10 @@ export type ModuleWrapper = ( ...sandboxInjectedGlobals: Array ) => unknown; +export interface JestImportMeta extends ImportMeta { + jest: Jest; +} + export interface JestEnvironmentConfig { projectConfig: Config.ProjectConfig; globalConfig: Config.GlobalConfig; diff --git a/packages/jest-runtime/src/index.ts b/packages/jest-runtime/src/index.ts index 49eb7b38fe5b..c98f97f0c3a7 100644 --- a/packages/jest-runtime/src/index.ts +++ b/packages/jest-runtime/src/index.ts @@ -27,6 +27,7 @@ import stripBOM = require('strip-bom'); import type { Jest, JestEnvironment, + JestImportMeta, Module, ModuleWrapper, } from '@jest/environment'; @@ -499,8 +500,18 @@ export default class Runtime { return this.linkAndEvaluateModule(module); }, - initializeImportMeta(meta: ImportMeta) { + initializeImportMeta: (meta: JestImportMeta) => { meta.url = pathToFileURL(modulePath).href; + + let jest = this.jestObjectCaches.get(modulePath); + + if (!jest) { + jest = this._createJestObjectFor(modulePath); + + this.jestObjectCaches.set(modulePath, jest); + } + + meta.jest = jest; }, }); @@ -625,6 +636,7 @@ export default class Runtime { return this.linkAndEvaluateModule(module); }, initializeImportMeta(meta: ImportMeta) { + // no `jest` here as it's not loaded in a file meta.url = specifier; }, }); From d4b36becd8e3c1befe4576a018d2a58ed22c92b7 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Wed, 20 Apr 2022 14:18:08 +0300 Subject: [PATCH 076/128] chore: few more `name` to `id` renames in test files (#12700) --- e2e/__tests__/hasteMapMockChanged.test.ts | 2 +- e2e/__tests__/hasteMapSha1.test.ts | 2 +- e2e/__tests__/hasteMapSize.test.ts | 2 +- .../jest-haste-map/src/__tests__/includes_dotfiles.test.ts | 4 ++-- 4 files changed, 5 insertions(+), 5 deletions(-) diff --git a/e2e/__tests__/hasteMapMockChanged.test.ts b/e2e/__tests__/hasteMapMockChanged.test.ts index 435225064e27..266e24e0536c 100644 --- a/e2e/__tests__/hasteMapMockChanged.test.ts +++ b/e2e/__tests__/hasteMapMockChanged.test.ts @@ -20,10 +20,10 @@ test('should not warn when a mock file changes', async () => { computeSha1: false, extensions: ['js', 'json', 'png'], forceNodeFilesystemAPI: false, + id: `tmp_${Date.now()}`, ignorePattern: / ^/, maxWorkers: 2, mocksPattern: '__mocks__', - name: `tmp_${Date.now()}`, platforms: [], retainAllFiles: false, rootDir: DIR, diff --git a/e2e/__tests__/hasteMapSha1.test.ts b/e2e/__tests__/hasteMapSha1.test.ts index bba942943671..a11e71672e3d 100644 --- a/e2e/__tests__/hasteMapSha1.test.ts +++ b/e2e/__tests__/hasteMapSha1.test.ts @@ -30,10 +30,10 @@ test('exits the process after test are done but before timers complete', async ( computeSha1: true, extensions: ['js', 'json', 'png'], forceNodeFilesystemAPI: true, + id: 'tmp', ignorePattern: / ^/, maxWorkers: 2, mocksPattern: '', - name: 'tmp', platforms: ['ios', 'android'], retainAllFiles: true, rootDir: DIR, diff --git a/e2e/__tests__/hasteMapSize.test.ts b/e2e/__tests__/hasteMapSize.test.ts index e21246b55ad9..e88d6269000c 100644 --- a/e2e/__tests__/hasteMapSize.test.ts +++ b/e2e/__tests__/hasteMapSize.test.ts @@ -24,10 +24,10 @@ afterEach(() => cleanup(DIR)); const options = { extensions: ['js'], forceNodeFilesystemAPI: true, + id: 'tmp', ignorePattern: / ^/, maxWorkers: 2, mocksPattern: '', - name: 'tmp', platforms: [], retainAllFiles: true, rootDir: DIR, diff --git a/packages/jest-haste-map/src/__tests__/includes_dotfiles.test.ts b/packages/jest-haste-map/src/__tests__/includes_dotfiles.test.ts index ee5868c63c9e..64bf2257d0ab 100644 --- a/packages/jest-haste-map/src/__tests__/includes_dotfiles.test.ts +++ b/packages/jest-haste-map/src/__tests__/includes_dotfiles.test.ts @@ -23,13 +23,13 @@ const commonOptions = { test('watchman crawler and node crawler both include dotfiles', async () => { const hasteMapWithWatchman = await HasteMap.create({ ...commonOptions, - name: 'withWatchman', + id: 'withWatchman', useWatchman: true, }); const hasteMapWithNode = await HasteMap.create({ ...commonOptions, - name: 'withNode', + id: 'withNode', useWatchman: false, }); From 0e41755d1c941b0e4021cadd28b567880c08814b Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 14:19:43 +0200 Subject: [PATCH 077/128] chore: retry flaky test --- e2e/__tests__/detectOpenHandles.ts | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/e2e/__tests__/detectOpenHandles.ts b/e2e/__tests__/detectOpenHandles.ts index 08c6b8c96b1d..797ad18d59cb 100644 --- a/e2e/__tests__/detectOpenHandles.ts +++ b/e2e/__tests__/detectOpenHandles.ts @@ -11,6 +11,10 @@ function getTextAfterTest(stderr: string) { return (stderr.split(/Ran all test suites(.*)\n/)[2] || '').trim(); } +beforeAll(() => { + jest.retryTimes(3); +}); + it('prints message about flag on slow tests', async () => { const run = runContinuous('detect-open-handles', ['outside']); await run.waitUntil(({stderr}) => From 5e570b9d89a29e04bd3a0626c0451506ca29348e Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 14:19:57 +0200 Subject: [PATCH 078/128] fix(workers): use advanced serialization by default in child process workers (#10983) --- CHANGELOG.md | 1 + packages/jest-haste-map/src/index.ts | 2 ++ packages/jest-reporters/src/CoverageReporter.ts | 2 ++ packages/jest-runner/src/index.ts | 3 ++- packages/jest-worker/README.md | 2 +- packages/jest-worker/src/__tests__/leak-integration.test.ts | 2 ++ packages/jest-worker/src/workers/ChildProcessWorker.ts | 3 +++ .../src/workers/__tests__/ChildProcessWorker.test.js | 1 + 8 files changed, 14 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 68d80297ca28..e70000d8286f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -57,6 +57,7 @@ - `[jest-test-result]` Add duration property to JSON test output ([#12518](https://github.com/facebook/jest/pull/12518)) - `[jest-watcher]` [**BREAKING**] Make `PatternPrompt` class to take `entityName` as third constructor parameter instead of `this._entityName` ([#12591](https://github.com/facebook/jest/pull/12591)) - `[jest-worker]` [**BREAKING**] Allow only absolute `workerPath` ([#12343](https://github.com/facebook/jest/pull/12343)) +- `[jest-worker]` [**BREAKING**] Default to advanced serialization when using child process workers ([#10983] (https://github.com/facebook/jest/pull/10983)) - `[pretty-format]` New `maxWidth` parameter ([#12402](https://github.com/facebook/jest/pull/12402)) ### Fixes diff --git a/packages/jest-haste-map/src/index.ts b/packages/jest-haste-map/src/index.ts index 4254eb2c52ad..a203bea0a845 100644 --- a/packages/jest-haste-map/src/index.ts +++ b/packages/jest-haste-map/src/index.ts @@ -747,6 +747,8 @@ export default class HasteMap extends EventEmitter { // @ts-expect-error: assignment of a worker with custom properties. this._worker = new Worker(require.resolve('./worker'), { exposedMethods: ['getSha1', 'worker'], + // @ts-expect-error: option does not exist on the node 12 types + forkOptions: {serialization: 'json'}, maxRetries: 3, numWorkers: this._options.maxWorkers, }) as WorkerInterface; diff --git a/packages/jest-reporters/src/CoverageReporter.ts b/packages/jest-reporters/src/CoverageReporter.ts index dc4d87daa6c1..dd1a52b99e98 100644 --- a/packages/jest-reporters/src/CoverageReporter.ts +++ b/packages/jest-reporters/src/CoverageReporter.ts @@ -144,6 +144,8 @@ export default class CoverageReporter extends BaseReporter { } else { worker = new Worker(require.resolve('./CoverageWorker'), { exposedMethods: ['worker'], + // @ts-expect-error: option does not exist on the node 12 types + forkOptions: {serialization: 'json'}, maxRetries: 2, numWorkers: this._globalConfig.maxWorkers, }); diff --git a/packages/jest-runner/src/index.ts b/packages/jest-runner/src/index.ts index 01434c043bf8..627b446798f2 100644 --- a/packages/jest-runner/src/index.ts +++ b/packages/jest-runner/src/index.ts @@ -105,7 +105,8 @@ export default class TestRunner extends EmittingTestRunner { const worker = new Worker(TEST_WORKER_PATH, { exposedMethods: ['worker'], - forkOptions: {stdio: 'pipe'}, + // @ts-expect-error: option does not exist on the node 12 types + forkOptions: {serialization: 'json', stdio: 'pipe'}, maxRetries: 3, numWorkers: this._globalConfig.maxWorkers, setupArgs: [{serializableResolvers: Array.from(resolvers.values())}], diff --git a/packages/jest-worker/README.md b/packages/jest-worker/README.md index 302e3682bf99..c8a29401c19d 100644 --- a/packages/jest-worker/README.md +++ b/packages/jest-worker/README.md @@ -73,7 +73,7 @@ List of method names that can be called on the child processes from the parent p #### `forkOptions: ForkOptions` (optional) -Allow customizing all options passed to `child_process.fork`. By default, some values are set (`cwd`, `env` and `execArgv`), but you can override them and customize the rest. For a list of valid values, check [the Node documentation](https://nodejs.org/api/child_process.html#child_processforkmodulepath-args-options). +Allow customizing all options passed to `child_process.fork`. By default, some values are set (`cwd`, `env`, `execArgv` and `serialization`), but you can override them and customize the rest. For a list of valid values, check [the Node documentation](https://nodejs.org/api/child_process.html#child_process_child_process_fork_modulepath_args_options). #### `maxRetries: number` (optional) diff --git a/packages/jest-worker/src/__tests__/leak-integration.test.ts b/packages/jest-worker/src/__tests__/leak-integration.test.ts index af5e827bc296..ef10567fe5fc 100644 --- a/packages/jest-worker/src/__tests__/leak-integration.test.ts +++ b/packages/jest-worker/src/__tests__/leak-integration.test.ts @@ -53,6 +53,8 @@ describe('Worker leaks', () => { worker = new Worker(workerFile, { enableWorkerThreads: false, exposedMethods: ['fn'], + // @ts-expect-error: option does not exist on the node 12 types + forkOptions: {serialization: 'json'}, }); }); afterEach(async () => { diff --git a/packages/jest-worker/src/workers/ChildProcessWorker.ts b/packages/jest-worker/src/workers/ChildProcessWorker.ts index 8d07b0a12e86..c3a2f2ab4d78 100644 --- a/packages/jest-worker/src/workers/ChildProcessWorker.ts +++ b/packages/jest-worker/src/workers/ChildProcessWorker.ts @@ -92,6 +92,9 @@ export default class ChildProcessWorker implements WorkerInterface { }, // Suppress --debug / --inspect flags while preserving others (like --harmony). execArgv: process.execArgv.filter(v => !/^--(debug|inspect)/.test(v)), + // default to advanced serialization in order to match worker threads + // @ts-expect-error: option does not exist on the node 12 types + serialization: 'advanced', silent: true, ...this._options.forkOptions, }); diff --git a/packages/jest-worker/src/workers/__tests__/ChildProcessWorker.test.js b/packages/jest-worker/src/workers/__tests__/ChildProcessWorker.test.js index e5e7e1e99694..1caa8e654380 100644 --- a/packages/jest-worker/src/workers/__tests__/ChildProcessWorker.test.js +++ b/packages/jest-worker/src/workers/__tests__/ChildProcessWorker.test.js @@ -70,6 +70,7 @@ it('passes fork options down to child_process.fork, adding the defaults', () => env: {...process.env, FORCE_COLOR: supportsColor.stdout ? '1' : undefined}, // Default option. execArgv: ['-p'], // Filtered option. execPath: 'hello', // Added option. + serialization: 'advanced', // Default option. silent: true, // Default option. }); }); From 79bbcdabebb500ba3d0b88b3e6d597b57ef9fcd5 Mon Sep 17 00:00:00 2001 From: Will Slattum <20246633+wrslatz@users.noreply.github.com> Date: Wed, 20 Apr 2022 09:21:04 -0400 Subject: [PATCH 079/128] Fix typo in Jest 28 upgrade docs (#12693) --- docs/UpgradingToJest28.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/UpgradingToJest28.md b/docs/UpgradingToJest28.md index d6d682656687..f329c731343f 100644 --- a/docs/UpgradingToJest28.md +++ b/docs/UpgradingToJest28.md @@ -30,7 +30,7 @@ The `extraGlobals` option was renamed to [`sandboxInjectedGlobals`](Configuratio ### `timers` -The `timers` option was renamed to [`fakeTimers`](Configuration.md#faketimers-object). See [Fake Timers](#fake-timers) section bellow for details. +The `timers` option was renamed to [`fakeTimers`](Configuration.md#faketimers-object). See [Fake Timers](#fake-timers) section below for details. ### `testURL` From c92c21fc63ec7d39c2026638bb77daf4e4e2fb72 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 15:22:12 +0200 Subject: [PATCH 080/128] fix: use v8-to-istanbul without source-map (#12697) --- CHANGELOG.md | 1 + e2e/__tests__/coverageProviderV8.test.ts | 16 +++++------- packages/jest-reporters/package.json | 4 +-- .../jest-reporters/src/CoverageReporter.ts | 5 +--- packages/jest-source-map/package.json | 2 +- packages/jest-transform/package.json | 2 +- yarn.lock | 26 +++++++++---------- 7 files changed, 25 insertions(+), 31 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e70000d8286f..8d69b328c1e4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -89,6 +89,7 @@ - `[jest-mock]` Handle overridden `Function.name` property ([#12674](https://github.com/facebook/jest/pull/12674)) - `[@jest/reporters]` Notifications generated by the `--notify` flag are no longer persistent in GNOME Shell. ([#11733](https://github.com/facebook/jest/pull/11733)) - `[@jest/reporters]` Move missing icon file which is needed for `NotifyReporter` class. ([#12593](https://github.com/facebook/jest/pull/12593)) +- `[@jest/reporters]` Update `v8-to-istanbul` ([#12697](https://github.com/facebook/jest/pull/12697)) - `[jest-resolver]` Call custom resolver with core node.js modules ([#12654](https://github.com/facebook/jest/pull/12654)) - `[jest-worker]` Fix `Farm` execution results memory leak ([#12497](https://github.com/facebook/jest/pull/12497)) diff --git a/e2e/__tests__/coverageProviderV8.test.ts b/e2e/__tests__/coverageProviderV8.test.ts index 6071485cc61e..e0aed23d0d10 100644 --- a/e2e/__tests__/coverageProviderV8.test.ts +++ b/e2e/__tests__/coverageProviderV8.test.ts @@ -11,17 +11,13 @@ import runJest from '../runJest'; const DIR = path.resolve(__dirname, '../coverage-provider-v8'); -// https://github.com/nodejs/node/issues/42638 -const nodeOptions = - typeof fetch === 'undefined' ? '' : '--no-experimental-fetch'; - test('prints coverage with missing sourcemaps', () => { const sourcemapDir = path.join(DIR, 'no-sourcemap'); const {stdout, exitCode} = runJest( sourcemapDir, ['--coverage', '--coverage-provider', 'v8'], - {nodeOptions, stripAnsi: true}, + {stripAnsi: true}, ); expect(exitCode).toBe(0); @@ -34,7 +30,7 @@ test('prints coverage with empty sourcemaps', () => { const {stdout, exitCode} = runJest( sourcemapDir, ['--coverage', '--coverage-provider', 'v8'], - {nodeOptions, stripAnsi: true}, + {stripAnsi: true}, ); expect(exitCode).toBe(0); @@ -47,7 +43,7 @@ test('prints correct coverage report, if a CJS module is put under test without const {stdout, exitCode} = runJest( sourcemapDir, ['--coverage', '--coverage-provider', 'v8', '--no-cache'], - {nodeOptions, stripAnsi: true}, + {stripAnsi: true}, ); expect(exitCode).toBe(0); @@ -60,7 +56,7 @@ test('prints correct coverage report, if a TS module is transpiled by Babel to C const {stdout, exitCode} = runJest( sourcemapDir, ['--coverage', '--coverage-provider', 'v8', '--no-cache'], - {nodeOptions, stripAnsi: true}, + {stripAnsi: true}, ); expect(exitCode).toBe(0); @@ -76,7 +72,7 @@ onNodeVersions('>=12.16.0', () => { sourcemapDir, ['--coverage', '--coverage-provider', 'v8', '--no-cache'], { - nodeOptions: `${nodeOptions} --experimental-vm-modules --no-warnings`, + nodeOptions: '--experimental-vm-modules --no-warnings', stripAnsi: true, }, ); @@ -92,7 +88,7 @@ onNodeVersions('>=12.16.0', () => { sourcemapDir, ['--coverage', '--coverage-provider', 'v8', '--no-cache'], { - nodeOptions: `${nodeOptions} --experimental-vm-modules --no-warnings`, + nodeOptions: '--experimental-vm-modules --no-warnings', stripAnsi: true, }, ); diff --git a/packages/jest-reporters/package.json b/packages/jest-reporters/package.json index ed1d2c6b38db..0af4551a1216 100644 --- a/packages/jest-reporters/package.json +++ b/packages/jest-reporters/package.json @@ -17,7 +17,7 @@ "@jest/test-result": "^28.0.0-alpha.9", "@jest/transform": "^28.0.0-alpha.10", "@jest/types": "^28.0.0-alpha.9", - "@jridgewell/trace-mapping": "^0.3.4", + "@jridgewell/trace-mapping": "^0.3.7", "@types/node": "*", "chalk": "^4.0.0", "collect-v8-coverage": "^1.0.0", @@ -34,7 +34,7 @@ "slash": "^3.0.0", "string-length": "^4.0.1", "terminal-link": "^2.0.0", - "v8-to-istanbul": "^8.1.0" + "v8-to-istanbul": "^9.0.0" }, "devDependencies": { "@jest/test-utils": "^28.0.0-alpha.9", diff --git a/packages/jest-reporters/src/CoverageReporter.ts b/packages/jest-reporters/src/CoverageReporter.ts index dd1a52b99e98..203435f08f23 100644 --- a/packages/jest-reporters/src/CoverageReporter.ts +++ b/packages/jest-reporters/src/CoverageReporter.ts @@ -452,8 +452,7 @@ export default class CoverageReporter extends BaseReporter { originalSource: fileTransform.originalCode, source: fileTransform.code, sourceMap: { - // remove `as any` after https://github.com/istanbuljs/v8-to-istanbul/pull/186 is released - sourcemap: {file: res.url, ...sourcemapContent} as any, + sourcemap: {file: res.url, ...sourcemapContent}, }, } : {source: fs.readFileSync(res.url, 'utf8')}, @@ -465,8 +464,6 @@ export default class CoverageReporter extends BaseReporter { const istanbulData = converter.toIstanbul(); - converter.destroy(); - return istanbulData; }), ); diff --git a/packages/jest-source-map/package.json b/packages/jest-source-map/package.json index 87d4ad08423b..e310aeaff01c 100644 --- a/packages/jest-source-map/package.json +++ b/packages/jest-source-map/package.json @@ -17,7 +17,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jridgewell/trace-mapping": "^0.3.4", + "@jridgewell/trace-mapping": "^0.3.7", "callsites": "^3.0.0", "graceful-fs": "^4.2.9" }, diff --git a/packages/jest-transform/package.json b/packages/jest-transform/package.json index 1dcc9333a908..f7ce973efa84 100644 --- a/packages/jest-transform/package.json +++ b/packages/jest-transform/package.json @@ -19,7 +19,7 @@ "dependencies": { "@babel/core": "^7.11.6", "@jest/types": "^28.0.0-alpha.9", - "@jridgewell/trace-mapping": "^0.3.4", + "@jridgewell/trace-mapping": "^0.3.7", "babel-plugin-istanbul": "^6.1.1", "chalk": "^4.0.0", "convert-source-map": "^1.4.0", diff --git a/yarn.lock b/yarn.lock index 266df664152c..ab9ccb14f3c3 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2758,7 +2758,7 @@ __metadata: "@jest/test-utils": ^28.0.0-alpha.9 "@jest/transform": ^28.0.0-alpha.10 "@jest/types": ^28.0.0-alpha.9 - "@jridgewell/trace-mapping": ^0.3.4 + "@jridgewell/trace-mapping": ^0.3.7 "@types/exit": ^0.1.30 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 @@ -2787,7 +2787,7 @@ __metadata: string-length: ^4.0.1 strip-ansi: ^6.0.0 terminal-link: ^2.0.0 - v8-to-istanbul: ^8.1.0 + v8-to-istanbul: ^9.0.0 peerDependencies: node-notifier: ^8.0.1 || ^9.0.0 || ^10.0.0 peerDependenciesMeta: @@ -2808,7 +2808,7 @@ __metadata: version: 0.0.0-use.local resolution: "@jest/source-map@workspace:packages/jest-source-map" dependencies: - "@jridgewell/trace-mapping": ^0.3.4 + "@jridgewell/trace-mapping": ^0.3.7 "@types/graceful-fs": ^4.1.3 callsites: ^3.0.0 graceful-fs: ^4.2.9 @@ -2872,7 +2872,7 @@ __metadata: "@babel/core": ^7.11.6 "@jest/test-utils": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 - "@jridgewell/trace-mapping": ^0.3.4 + "@jridgewell/trace-mapping": ^0.3.7 "@types/babel__core": ^7.1.14 "@types/convert-source-map": ^1.5.1 "@types/fast-json-stable-stringify": ^2.0.0 @@ -2950,13 +2950,13 @@ __metadata: languageName: node linkType: hard -"@jridgewell/trace-mapping@npm:^0.3.0, @jridgewell/trace-mapping@npm:^0.3.4": - version: 0.3.4 - resolution: "@jridgewell/trace-mapping@npm:0.3.4" +"@jridgewell/trace-mapping@npm:^0.3.0, @jridgewell/trace-mapping@npm:^0.3.7": + version: 0.3.7 + resolution: "@jridgewell/trace-mapping@npm:0.3.7" dependencies: "@jridgewell/resolve-uri": ^3.0.3 "@jridgewell/sourcemap-codec": ^1.4.10 - checksum: ab8bce84bbbc8c34f3ba8325ed926f8f2d3098983c10442a80c55764c4eb6e47d5b92d8ff20a0dd868c3e76a3535651fd8a0138182c290dbfc8396195685c37b + checksum: c08f5344568e1396fc377c95054b126620380a87e8992d77526f73b9627e56930a1a76ee95d31266d388ed052f6f97c64911c2aa49283d37547f51c342dfc9b8 languageName: node linkType: hard @@ -22240,14 +22240,14 @@ __metadata: languageName: node linkType: hard -"v8-to-istanbul@npm:^8.1.0": - version: 8.1.1 - resolution: "v8-to-istanbul@npm:8.1.1" +"v8-to-istanbul@npm:^9.0.0": + version: 9.0.0 + resolution: "v8-to-istanbul@npm:9.0.0" dependencies: + "@jridgewell/trace-mapping": ^0.3.7 "@types/istanbul-lib-coverage": ^2.0.1 convert-source-map: ^1.6.0 - source-map: ^0.7.3 - checksum: 54ce92bec2727879626f623d02c8d193f0c7e919941fa373ec135189a8382265117f5316ea317a1e12a5f9c13d84d8449052a731fe3306fa4beaafbfa4cab229 + checksum: d8ed2c39ba657dfd851a3c7b3f2b87e5b96c9face806ecfe5b627abe53b0c86f264f51425c591e451405b739e3f8a6728da59670f081790990710e813d8d3440 languageName: node linkType: hard From 8b4b78759d255746f11e396efe7d06ac93dbd05b Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 15:30:52 +0200 Subject: [PATCH 081/128] v28.0.0-alpha.11 --- lerna.json | 2 +- packages/babel-jest/package.json | 4 ++-- packages/jest-circus/package.json | 10 ++++----- packages/jest-cli/package.json | 6 ++--- packages/jest-config/package.json | 14 ++++++------ packages/jest-core/package.json | 22 +++++++++---------- packages/jest-environment-jsdom/package.json | 4 ++-- packages/jest-environment-node/package.json | 4 ++-- packages/jest-environment/package.json | 2 +- packages/jest-expect/package.json | 4 ++-- packages/jest-globals/package.json | 6 ++--- packages/jest-haste-map/package.json | 4 ++-- packages/jest-jasmine2/package.json | 12 +++++----- packages/jest-repl/package.json | 10 ++++----- packages/jest-reporters/package.json | 8 +++---- .../jest-resolve-dependencies/package.json | 10 ++++----- packages/jest-resolve/package.json | 4 ++-- packages/jest-runner/package.json | 18 +++++++-------- packages/jest-runtime/package.json | 18 +++++++-------- packages/jest-snapshot/package.json | 6 ++--- packages/jest-source-map/package.json | 2 +- packages/jest-test-sequencer/package.json | 4 ++-- packages/jest-transform/package.json | 4 ++-- packages/jest-worker/package.json | 2 +- packages/jest/package.json | 6 ++--- 25 files changed, 93 insertions(+), 93 deletions(-) diff --git a/lerna.json b/lerna.json index 9e3cc5d8701f..44206be00e21 100644 --- a/lerna.json +++ b/lerna.json @@ -3,5 +3,5 @@ "packages/*" ], "npmClient": "yarn", - "version": "28.0.0-alpha.10" + "version": "28.0.0-alpha.11" } diff --git a/packages/babel-jest/package.json b/packages/babel-jest/package.json index deb70a595b3e..3ab55cd38b9d 100644 --- a/packages/babel-jest/package.json +++ b/packages/babel-jest/package.json @@ -1,7 +1,7 @@ { "name": "babel-jest", "description": "Jest plugin to use babel for transformation.", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,7 +18,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/transform": "^28.0.0-alpha.10", + "@jest/transform": "^28.0.0-alpha.11", "@types/babel__core": "^7.1.14", "babel-plugin-istanbul": "^6.1.1", "babel-preset-jest": "^28.0.0-alpha.9", diff --git a/packages/jest-circus/package.json b/packages/jest-circus/package.json index 8a09d685239b..262193f4d202 100644 --- a/packages/jest-circus/package.json +++ b/packages/jest-circus/package.json @@ -1,6 +1,6 @@ { "name": "jest-circus", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,8 +18,8 @@ "./runner": "./runner.js" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.9", - "@jest/expect": "^28.0.0-alpha.10", + "@jest/environment": "^28.0.0-alpha.11", + "@jest/expect": "^28.0.0-alpha.11", "@jest/test-result": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", @@ -30,8 +30,8 @@ "jest-each": "^28.0.0-alpha.9", "jest-matcher-utils": "^28.0.0-alpha.9", "jest-message-util": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.10", - "jest-snapshot": "^28.0.0-alpha.10", + "jest-runtime": "^28.0.0-alpha.11", + "jest-snapshot": "^28.0.0-alpha.11", "jest-util": "^28.0.0-alpha.9", "pretty-format": "^28.0.0-alpha.9", "slash": "^3.0.0", diff --git a/packages/jest-cli/package.json b/packages/jest-cli/package.json index eb7544128b29..403730eee963 100644 --- a/packages/jest-cli/package.json +++ b/packages/jest-cli/package.json @@ -1,7 +1,7 @@ { "name": "jest-cli", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,14 +13,14 @@ "./bin/jest": "./bin/jest.js" }, "dependencies": { - "@jest/core": "^28.0.0-alpha.10", + "@jest/core": "^28.0.0-alpha.11", "@jest/test-result": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", "exit": "^0.1.2", "graceful-fs": "^4.2.9", "import-local": "^3.0.2", - "jest-config": "^28.0.0-alpha.10", + "jest-config": "^28.0.0-alpha.11", "jest-util": "^28.0.0-alpha.9", "jest-validate": "^28.0.0-alpha.9", "prompts": "^2.0.1", diff --git a/packages/jest-config/package.json b/packages/jest-config/package.json index dcbc41d9e1e4..a3122e64a3fd 100644 --- a/packages/jest-config/package.json +++ b/packages/jest-config/package.json @@ -1,6 +1,6 @@ { "name": "jest-config", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -30,20 +30,20 @@ }, "dependencies": { "@babel/core": "^7.11.6", - "@jest/test-sequencer": "^28.0.0-alpha.9", + "@jest/test-sequencer": "^28.0.0-alpha.11", "@jest/types": "^28.0.0-alpha.9", - "babel-jest": "^28.0.0-alpha.10", + "babel-jest": "^28.0.0-alpha.11", "chalk": "^4.0.0", "ci-info": "^3.2.0", "deepmerge": "^4.2.2", "glob": "^7.1.3", "graceful-fs": "^4.2.9", - "jest-circus": "^28.0.0-alpha.10", - "jest-environment-node": "^28.0.0-alpha.10", + "jest-circus": "^28.0.0-alpha.11", + "jest-environment-node": "^28.0.0-alpha.11", "jest-get-type": "^28.0.0-alpha.3", "jest-regex-util": "^28.0.0-alpha.6", - "jest-resolve": "^28.0.0-alpha.9", - "jest-runner": "^28.0.0-alpha.10", + "jest-resolve": "^28.0.0-alpha.11", + "jest-runner": "^28.0.0-alpha.11", "jest-util": "^28.0.0-alpha.9", "jest-validate": "^28.0.0-alpha.9", "micromatch": "^4.0.4", diff --git a/packages/jest-core/package.json b/packages/jest-core/package.json index aae17154d36c..6343bca2d938 100644 --- a/packages/jest-core/package.json +++ b/packages/jest-core/package.json @@ -1,7 +1,7 @@ { "name": "@jest/core", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,9 +13,9 @@ }, "dependencies": { "@jest/console": "^28.0.0-alpha.9", - "@jest/reporters": "^28.0.0-alpha.10", + "@jest/reporters": "^28.0.0-alpha.11", "@jest/test-result": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.10", + "@jest/transform": "^28.0.0-alpha.11", "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "ansi-escapes": "^4.2.1", @@ -24,15 +24,15 @@ "exit": "^0.1.2", "graceful-fs": "^4.2.9", "jest-changed-files": "^28.0.0-alpha.3", - "jest-config": "^28.0.0-alpha.10", - "jest-haste-map": "^28.0.0-alpha.9", + "jest-config": "^28.0.0-alpha.11", + "jest-haste-map": "^28.0.0-alpha.11", "jest-message-util": "^28.0.0-alpha.9", "jest-regex-util": "^28.0.0-alpha.6", - "jest-resolve": "^28.0.0-alpha.9", - "jest-resolve-dependencies": "^28.0.0-alpha.10", - "jest-runner": "^28.0.0-alpha.10", - "jest-runtime": "^28.0.0-alpha.10", - "jest-snapshot": "^28.0.0-alpha.10", + "jest-resolve": "^28.0.0-alpha.11", + "jest-resolve-dependencies": "^28.0.0-alpha.11", + "jest-runner": "^28.0.0-alpha.11", + "jest-runtime": "^28.0.0-alpha.11", + "jest-snapshot": "^28.0.0-alpha.11", "jest-util": "^28.0.0-alpha.9", "jest-validate": "^28.0.0-alpha.9", "jest-watcher": "^28.0.0-alpha.9", @@ -43,7 +43,7 @@ "strip-ansi": "^6.0.0" }, "devDependencies": { - "@jest/test-sequencer": "^28.0.0-alpha.9", + "@jest/test-sequencer": "^28.0.0-alpha.11", "@jest/test-utils": "^28.0.0-alpha.9", "@types/exit": "^0.1.30", "@types/graceful-fs": "^4.1.3", diff --git a/packages/jest-environment-jsdom/package.json b/packages/jest-environment-jsdom/package.json index d53cba5498f3..de463504525a 100644 --- a/packages/jest-environment-jsdom/package.json +++ b/packages/jest-environment-jsdom/package.json @@ -1,6 +1,6 @@ { "name": "jest-environment-jsdom", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,7 +17,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.9", + "@jest/environment": "^28.0.0-alpha.11", "@jest/fake-timers": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", "@types/jsdom": "^16.2.4", diff --git a/packages/jest-environment-node/package.json b/packages/jest-environment-node/package.json index 02f9a64602cf..ec28d87b043e 100644 --- a/packages/jest-environment-node/package.json +++ b/packages/jest-environment-node/package.json @@ -1,6 +1,6 @@ { "name": "jest-environment-node", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,7 +17,7 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.9", + "@jest/environment": "^28.0.0-alpha.11", "@jest/fake-timers": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", diff --git a/packages/jest-environment/package.json b/packages/jest-environment/package.json index 4bdfe739d583..72e3cd9f8abb 100644 --- a/packages/jest-environment/package.json +++ b/packages/jest-environment/package.json @@ -1,6 +1,6 @@ { "name": "@jest/environment", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/jest-expect/package.json b/packages/jest-expect/package.json index d92964a604ff..eb411a96a978 100644 --- a/packages/jest-expect/package.json +++ b/packages/jest-expect/package.json @@ -1,6 +1,6 @@ { "name": "@jest/expect", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,7 +18,7 @@ }, "dependencies": { "expect": "^28.0.0-alpha.9", - "jest-snapshot": "^28.0.0-alpha.10" + "jest-snapshot": "^28.0.0-alpha.11" }, "devDependencies": { "@tsd/typescript": "~4.6.2", diff --git a/packages/jest-globals/package.json b/packages/jest-globals/package.json index acf78156ed55..79f68f4c293d 100644 --- a/packages/jest-globals/package.json +++ b/packages/jest-globals/package.json @@ -1,6 +1,6 @@ { "name": "@jest/globals", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -20,8 +20,8 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.9", - "@jest/expect": "^28.0.0-alpha.10", + "@jest/environment": "^28.0.0-alpha.11", + "@jest/expect": "^28.0.0-alpha.11", "@jest/types": "^28.0.0-alpha.9" }, "publishConfig": { diff --git a/packages/jest-haste-map/package.json b/packages/jest-haste-map/package.json index 4230c2bdbacf..1fe9be1add5d 100644 --- a/packages/jest-haste-map/package.json +++ b/packages/jest-haste-map/package.json @@ -1,6 +1,6 @@ { "name": "jest-haste-map", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -25,7 +25,7 @@ "graceful-fs": "^4.2.9", "jest-regex-util": "^28.0.0-alpha.6", "jest-util": "^28.0.0-alpha.9", - "jest-worker": "^28.0.0-alpha.9", + "jest-worker": "^28.0.0-alpha.11", "micromatch": "^4.0.4", "walker": "^1.0.7" }, diff --git a/packages/jest-jasmine2/package.json b/packages/jest-jasmine2/package.json index 1351a0240a21..41323a82250b 100644 --- a/packages/jest-jasmine2/package.json +++ b/packages/jest-jasmine2/package.json @@ -1,6 +1,6 @@ { "name": "jest-jasmine2", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,9 +17,9 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.9", - "@jest/expect": "^28.0.0-alpha.10", - "@jest/source-map": "^28.0.0-alpha.10", + "@jest/environment": "^28.0.0-alpha.11", + "@jest/expect": "^28.0.0-alpha.11", + "@jest/source-map": "^28.0.0-alpha.11", "@jest/test-result": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", @@ -29,8 +29,8 @@ "jest-each": "^28.0.0-alpha.9", "jest-matcher-utils": "^28.0.0-alpha.9", "jest-message-util": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.10", - "jest-snapshot": "^28.0.0-alpha.10", + "jest-runtime": "^28.0.0-alpha.11", + "jest-snapshot": "^28.0.0-alpha.11", "jest-util": "^28.0.0-alpha.9", "pretty-format": "^28.0.0-alpha.9", "throat": "^6.0.1" diff --git a/packages/jest-repl/package.json b/packages/jest-repl/package.json index dc3797c735fc..c07eec66187d 100644 --- a/packages/jest-repl/package.json +++ b/packages/jest-repl/package.json @@ -1,6 +1,6 @@ { "name": "jest-repl", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -20,12 +20,12 @@ }, "dependencies": { "@jest/console": "^28.0.0-alpha.9", - "@jest/environment": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.10", + "@jest/environment": "^28.0.0-alpha.11", + "@jest/transform": "^28.0.0-alpha.11", "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", - "jest-config": "^28.0.0-alpha.10", - "jest-runtime": "^28.0.0-alpha.10", + "jest-config": "^28.0.0-alpha.11", + "jest-runtime": "^28.0.0-alpha.11", "jest-util": "^28.0.0-alpha.9", "jest-validate": "^28.0.0-alpha.9", "repl": "^0.1.3", diff --git a/packages/jest-reporters/package.json b/packages/jest-reporters/package.json index 0af4551a1216..55db0bd26ce1 100644 --- a/packages/jest-reporters/package.json +++ b/packages/jest-reporters/package.json @@ -1,7 +1,7 @@ { "name": "@jest/reporters", "description": "Jest's reporters", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -15,7 +15,7 @@ "@bcoe/v8-coverage": "^0.2.3", "@jest/console": "^28.0.0-alpha.9", "@jest/test-result": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.10", + "@jest/transform": "^28.0.0-alpha.11", "@jest/types": "^28.0.0-alpha.9", "@jridgewell/trace-mapping": "^0.3.7", "@types/node": "*", @@ -30,7 +30,7 @@ "istanbul-lib-source-maps": "^4.0.0", "istanbul-reports": "^3.1.3", "jest-util": "^28.0.0-alpha.9", - "jest-worker": "^28.0.0-alpha.9", + "jest-worker": "^28.0.0-alpha.11", "slash": "^3.0.0", "string-length": "^4.0.1", "terminal-link": "^2.0.0", @@ -47,7 +47,7 @@ "@types/istanbul-lib-source-maps": "^4.0.0", "@types/istanbul-reports": "^3.0.0", "@types/node-notifier": "^8.0.0", - "jest-resolve": "^28.0.0-alpha.9", + "jest-resolve": "^28.0.0-alpha.11", "mock-fs": "^5.1.2", "strip-ansi": "^6.0.0" }, diff --git a/packages/jest-resolve-dependencies/package.json b/packages/jest-resolve-dependencies/package.json index b98cf1f9cc58..40280b29cec0 100644 --- a/packages/jest-resolve-dependencies/package.json +++ b/packages/jest-resolve-dependencies/package.json @@ -1,6 +1,6 @@ { "name": "jest-resolve-dependencies", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,14 +18,14 @@ }, "dependencies": { "jest-regex-util": "^28.0.0-alpha.6", - "jest-snapshot": "^28.0.0-alpha.10" + "jest-snapshot": "^28.0.0-alpha.11" }, "devDependencies": { "@jest/test-utils": "^28.0.0-alpha.9", "@jest/types": "^28.0.0-alpha.9", - "jest-haste-map": "^28.0.0-alpha.9", - "jest-resolve": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.10" + "jest-haste-map": "^28.0.0-alpha.11", + "jest-resolve": "^28.0.0-alpha.11", + "jest-runtime": "^28.0.0-alpha.11" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-resolve/package.json b/packages/jest-resolve/package.json index 0f4dae47588c..6d6120d83290 100644 --- a/packages/jest-resolve/package.json +++ b/packages/jest-resolve/package.json @@ -1,6 +1,6 @@ { "name": "jest-resolve", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -19,7 +19,7 @@ "dependencies": { "chalk": "^4.0.0", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.9", + "jest-haste-map": "^28.0.0-alpha.11", "jest-pnp-resolver": "^1.2.2", "jest-util": "^28.0.0-alpha.9", "jest-validate": "^28.0.0-alpha.9", diff --git a/packages/jest-runner/package.json b/packages/jest-runner/package.json index e51b82617886..89207a4651f4 100644 --- a/packages/jest-runner/package.json +++ b/packages/jest-runner/package.json @@ -1,6 +1,6 @@ { "name": "jest-runner", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -18,24 +18,24 @@ }, "dependencies": { "@jest/console": "^28.0.0-alpha.9", - "@jest/environment": "^28.0.0-alpha.9", + "@jest/environment": "^28.0.0-alpha.11", "@jest/test-result": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.10", + "@jest/transform": "^28.0.0-alpha.11", "@jest/types": "^28.0.0-alpha.9", "@types/node": "*", "chalk": "^4.0.0", "emittery": "^0.10.2", "graceful-fs": "^4.2.9", "jest-docblock": "^28.0.0-alpha.6", - "jest-environment-node": "^28.0.0-alpha.10", - "jest-haste-map": "^28.0.0-alpha.9", + "jest-environment-node": "^28.0.0-alpha.11", + "jest-haste-map": "^28.0.0-alpha.11", "jest-leak-detector": "^28.0.0-alpha.9", "jest-message-util": "^28.0.0-alpha.9", - "jest-resolve": "^28.0.0-alpha.9", - "jest-runtime": "^28.0.0-alpha.10", + "jest-resolve": "^28.0.0-alpha.11", + "jest-runtime": "^28.0.0-alpha.11", "jest-util": "^28.0.0-alpha.9", "jest-watcher": "^28.0.0-alpha.9", - "jest-worker": "^28.0.0-alpha.9", + "jest-worker": "^28.0.0-alpha.11", "source-map-support": "^0.5.6", "throat": "^6.0.1" }, @@ -44,7 +44,7 @@ "@types/exit": "^0.1.30", "@types/graceful-fs": "^4.1.3", "@types/source-map-support": "^0.5.0", - "jest-jasmine2": "^28.0.0-alpha.10", + "jest-jasmine2": "^28.0.0-alpha.11", "tsd-lite": "^0.5.1" }, "engines": { diff --git a/packages/jest-runtime/package.json b/packages/jest-runtime/package.json index d73a442e5595..0be6219f3166 100644 --- a/packages/jest-runtime/package.json +++ b/packages/jest-runtime/package.json @@ -1,6 +1,6 @@ { "name": "jest-runtime", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -17,12 +17,12 @@ "./package.json": "./package.json" }, "dependencies": { - "@jest/environment": "^28.0.0-alpha.9", + "@jest/environment": "^28.0.0-alpha.11", "@jest/fake-timers": "^28.0.0-alpha.9", - "@jest/globals": "^28.0.0-alpha.10", - "@jest/source-map": "^28.0.0-alpha.10", + "@jest/globals": "^28.0.0-alpha.11", + "@jest/source-map": "^28.0.0-alpha.11", "@jest/test-result": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.10", + "@jest/transform": "^28.0.0-alpha.11", "@jest/types": "^28.0.0-alpha.9", "chalk": "^4.0.0", "cjs-module-lexer": "^1.0.0", @@ -30,12 +30,12 @@ "execa": "^5.0.0", "glob": "^7.1.3", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.9", + "jest-haste-map": "^28.0.0-alpha.11", "jest-message-util": "^28.0.0-alpha.9", "jest-mock": "^28.0.0-alpha.9", "jest-regex-util": "^28.0.0-alpha.6", - "jest-resolve": "^28.0.0-alpha.9", - "jest-snapshot": "^28.0.0-alpha.10", + "jest-resolve": "^28.0.0-alpha.11", + "jest-snapshot": "^28.0.0-alpha.11", "jest-util": "^28.0.0-alpha.9", "slash": "^3.0.0", "strip-bom": "^4.0.0" @@ -45,7 +45,7 @@ "@types/glob": "^7.1.1", "@types/graceful-fs": "^4.1.3", "@types/node": "*", - "jest-environment-node": "^28.0.0-alpha.10" + "jest-environment-node": "^28.0.0-alpha.11" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-snapshot/package.json b/packages/jest-snapshot/package.json index 22c07087419e..06d722c311b6 100644 --- a/packages/jest-snapshot/package.json +++ b/packages/jest-snapshot/package.json @@ -1,6 +1,6 @@ { "name": "jest-snapshot", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -23,7 +23,7 @@ "@babel/traverse": "^7.7.2", "@babel/types": "^7.3.3", "@jest/expect-utils": "^28.0.0-alpha.9", - "@jest/transform": "^28.0.0-alpha.10", + "@jest/transform": "^28.0.0-alpha.11", "@jest/types": "^28.0.0-alpha.9", "@types/babel__traverse": "^7.0.6", "@types/prettier": "^2.1.5", @@ -33,7 +33,7 @@ "graceful-fs": "^4.2.9", "jest-diff": "^28.0.0-alpha.9", "jest-get-type": "^28.0.0-alpha.3", - "jest-haste-map": "^28.0.0-alpha.9", + "jest-haste-map": "^28.0.0-alpha.11", "jest-matcher-utils": "^28.0.0-alpha.9", "jest-message-util": "^28.0.0-alpha.9", "jest-util": "^28.0.0-alpha.9", diff --git a/packages/jest-source-map/package.json b/packages/jest-source-map/package.json index e310aeaff01c..78a56582d57b 100644 --- a/packages/jest-source-map/package.json +++ b/packages/jest-source-map/package.json @@ -1,6 +1,6 @@ { "name": "@jest/source-map", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/jest-test-sequencer/package.json b/packages/jest-test-sequencer/package.json index cdac32b85ff9..ce25a041ee85 100644 --- a/packages/jest-test-sequencer/package.json +++ b/packages/jest-test-sequencer/package.json @@ -1,6 +1,6 @@ { "name": "@jest/test-sequencer", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -19,7 +19,7 @@ "dependencies": { "@jest/test-result": "^28.0.0-alpha.9", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.9", + "jest-haste-map": "^28.0.0-alpha.11", "slash": "^3.0.0" }, "devDependencies": { diff --git a/packages/jest-transform/package.json b/packages/jest-transform/package.json index f7ce973efa84..0b923772fc0e 100644 --- a/packages/jest-transform/package.json +++ b/packages/jest-transform/package.json @@ -1,6 +1,6 @@ { "name": "@jest/transform", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", @@ -25,7 +25,7 @@ "convert-source-map": "^1.4.0", "fast-json-stable-stringify": "^2.0.0", "graceful-fs": "^4.2.9", - "jest-haste-map": "^28.0.0-alpha.9", + "jest-haste-map": "^28.0.0-alpha.11", "jest-regex-util": "^28.0.0-alpha.6", "jest-util": "^28.0.0-alpha.9", "micromatch": "^4.0.4", diff --git a/packages/jest-worker/package.json b/packages/jest-worker/package.json index 622fa22e0171..85650676d01c 100644 --- a/packages/jest-worker/package.json +++ b/packages/jest-worker/package.json @@ -1,6 +1,6 @@ { "name": "jest-worker", - "version": "28.0.0-alpha.9", + "version": "28.0.0-alpha.11", "repository": { "type": "git", "url": "https://github.com/facebook/jest.git", diff --git a/packages/jest/package.json b/packages/jest/package.json index 2f8f92962ee6..0d3716d98107 100644 --- a/packages/jest/package.json +++ b/packages/jest/package.json @@ -1,7 +1,7 @@ { "name": "jest", "description": "Delightful JavaScript Testing.", - "version": "28.0.0-alpha.10", + "version": "28.0.0-alpha.11", "main": "./build/index.js", "types": "./build/index.d.ts", "exports": { @@ -13,9 +13,9 @@ "./bin/jest": "./bin/jest.js" }, "dependencies": { - "@jest/core": "^28.0.0-alpha.10", + "@jest/core": "^28.0.0-alpha.11", "import-local": "^3.0.2", - "jest-cli": "^28.0.0-alpha.10" + "jest-cli": "^28.0.0-alpha.11" }, "peerDependencies": { "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" From d2f03eff4cb2bcff4d49f644a7f235879aed1bc6 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Wed, 20 Apr 2022 15:31:39 +0200 Subject: [PATCH 082/128] chore: update lockfile after release --- yarn.lock | 174 +++++++++++++++++++++++++++--------------------------- 1 file changed, 87 insertions(+), 87 deletions(-) diff --git a/yarn.lock b/yarn.lock index ab9ccb14f3c3..9f87e26b3026 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2539,16 +2539,16 @@ __metadata: languageName: node linkType: hard -"@jest/core@^28.0.0-alpha.10, @jest/core@workspace:packages/jest-core": +"@jest/core@^28.0.0-alpha.11, @jest/core@workspace:packages/jest-core": version: 0.0.0-use.local resolution: "@jest/core@workspace:packages/jest-core" dependencies: "@jest/console": ^28.0.0-alpha.9 - "@jest/reporters": ^28.0.0-alpha.10 + "@jest/reporters": ^28.0.0-alpha.11 "@jest/test-result": ^28.0.0-alpha.9 - "@jest/test-sequencer": ^28.0.0-alpha.9 + "@jest/test-sequencer": ^28.0.0-alpha.11 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.10 + "@jest/transform": ^28.0.0-alpha.11 "@jest/types": ^28.0.0-alpha.9 "@types/exit": ^0.1.30 "@types/graceful-fs": ^4.1.3 @@ -2561,15 +2561,15 @@ __metadata: exit: ^0.1.2 graceful-fs: ^4.2.9 jest-changed-files: ^28.0.0-alpha.3 - jest-config: ^28.0.0-alpha.10 - jest-haste-map: ^28.0.0-alpha.9 + jest-config: ^28.0.0-alpha.11 + jest-haste-map: ^28.0.0-alpha.11 jest-message-util: ^28.0.0-alpha.9 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.9 - jest-resolve-dependencies: ^28.0.0-alpha.10 - jest-runner: ^28.0.0-alpha.10 - jest-runtime: ^28.0.0-alpha.10 - jest-snapshot: ^28.0.0-alpha.10 + jest-resolve: ^28.0.0-alpha.11 + jest-resolve-dependencies: ^28.0.0-alpha.11 + jest-runner: ^28.0.0-alpha.11 + jest-runtime: ^28.0.0-alpha.11 + jest-snapshot: ^28.0.0-alpha.11 jest-util: ^28.0.0-alpha.9 jest-validate: ^28.0.0-alpha.9 jest-watcher: ^28.0.0-alpha.9 @@ -2605,7 +2605,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/environment@^28.0.0-alpha.9, @jest/environment@workspace:packages/jest-environment": +"@jest/environment@^28.0.0-alpha.11, @jest/environment@workspace:packages/jest-environment": version: 0.0.0-use.local resolution: "@jest/environment@workspace:packages/jest-environment" dependencies: @@ -2625,13 +2625,13 @@ __metadata: languageName: unknown linkType: soft -"@jest/expect@^28.0.0-alpha.10, @jest/expect@workspace:packages/jest-expect": +"@jest/expect@^28.0.0-alpha.11, @jest/expect@workspace:packages/jest-expect": version: 0.0.0-use.local resolution: "@jest/expect@workspace:packages/jest-expect" dependencies: "@tsd/typescript": ~4.6.2 expect: ^28.0.0-alpha.9 - jest-snapshot: ^28.0.0-alpha.10 + jest-snapshot: ^28.0.0-alpha.11 tsd-lite: ^0.5.1 languageName: unknown linkType: soft @@ -2651,12 +2651,12 @@ __metadata: languageName: unknown linkType: soft -"@jest/globals@^28.0.0-alpha.10, @jest/globals@workspace:*, @jest/globals@workspace:packages/jest-globals": +"@jest/globals@^28.0.0-alpha.11, @jest/globals@workspace:*, @jest/globals@workspace:packages/jest-globals": version: 0.0.0-use.local resolution: "@jest/globals@workspace:packages/jest-globals" dependencies: - "@jest/environment": ^28.0.0-alpha.9 - "@jest/expect": ^28.0.0-alpha.10 + "@jest/environment": ^28.0.0-alpha.11 + "@jest/expect": ^28.0.0-alpha.11 "@jest/types": ^28.0.0-alpha.9 languageName: unknown linkType: soft @@ -2748,7 +2748,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/reporters@^28.0.0-alpha.10, @jest/reporters@workspace:packages/jest-reporters": +"@jest/reporters@^28.0.0-alpha.11, @jest/reporters@workspace:packages/jest-reporters": version: 0.0.0-use.local resolution: "@jest/reporters@workspace:packages/jest-reporters" dependencies: @@ -2756,7 +2756,7 @@ __metadata: "@jest/console": ^28.0.0-alpha.9 "@jest/test-result": ^28.0.0-alpha.9 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.10 + "@jest/transform": ^28.0.0-alpha.11 "@jest/types": ^28.0.0-alpha.9 "@jridgewell/trace-mapping": ^0.3.7 "@types/exit": ^0.1.30 @@ -2779,9 +2779,9 @@ __metadata: istanbul-lib-report: ^3.0.0 istanbul-lib-source-maps: ^4.0.0 istanbul-reports: ^3.1.3 - jest-resolve: ^28.0.0-alpha.9 + jest-resolve: ^28.0.0-alpha.11 jest-util: ^28.0.0-alpha.9 - jest-worker: ^28.0.0-alpha.9 + jest-worker: ^28.0.0-alpha.11 mock-fs: ^5.1.2 slash: ^3.0.0 string-length: ^4.0.1 @@ -2804,7 +2804,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/source-map@^28.0.0-alpha.10, @jest/source-map@workspace:packages/jest-source-map": +"@jest/source-map@^28.0.0-alpha.11, @jest/source-map@workspace:packages/jest-source-map": version: 0.0.0-use.local resolution: "@jest/source-map@workspace:packages/jest-source-map" dependencies: @@ -2838,7 +2838,7 @@ __metadata: languageName: node linkType: hard -"@jest/test-sequencer@^28.0.0-alpha.9, @jest/test-sequencer@workspace:packages/jest-test-sequencer": +"@jest/test-sequencer@^28.0.0-alpha.11, @jest/test-sequencer@workspace:packages/jest-test-sequencer": version: 0.0.0-use.local resolution: "@jest/test-sequencer@workspace:packages/jest-test-sequencer" dependencies: @@ -2846,7 +2846,7 @@ __metadata: "@jest/test-utils": ^28.0.0-alpha.9 "@types/graceful-fs": ^4.1.3 graceful-fs: ^4.2.9 - jest-haste-map: ^28.0.0-alpha.9 + jest-haste-map: ^28.0.0-alpha.11 slash: ^3.0.0 languageName: unknown linkType: soft @@ -2865,7 +2865,7 @@ __metadata: languageName: unknown linkType: soft -"@jest/transform@^28.0.0-alpha.10, @jest/transform@workspace:packages/jest-transform": +"@jest/transform@^28.0.0-alpha.11, @jest/transform@workspace:packages/jest-transform": version: 0.0.0-use.local resolution: "@jest/transform@workspace:packages/jest-transform" dependencies: @@ -2885,7 +2885,7 @@ __metadata: dedent: ^0.7.0 fast-json-stable-stringify: ^2.0.0 graceful-fs: ^4.2.9 - jest-haste-map: ^28.0.0-alpha.9 + jest-haste-map: ^28.0.0-alpha.11 jest-regex-util: ^28.0.0-alpha.6 jest-util: ^28.0.0-alpha.9 micromatch: ^4.0.4 @@ -6678,7 +6678,7 @@ __metadata: dependencies: "@babel/core": ^7.11.6 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.10 + "@jest/transform": ^28.0.0-alpha.11 "@types/babel__core": ^7.1.14 "@types/graceful-fs": ^4.1.3 babel-plugin-istanbul: ^6.1.1 @@ -12995,14 +12995,14 @@ __metadata: languageName: unknown linkType: soft -"jest-circus@^28.0.0-alpha.10, jest-circus@workspace:packages/jest-circus": +"jest-circus@^28.0.0-alpha.11, jest-circus@workspace:packages/jest-circus": version: 0.0.0-use.local resolution: "jest-circus@workspace:packages/jest-circus" dependencies: "@babel/core": ^7.11.6 "@babel/register": ^7.0.0 - "@jest/environment": ^28.0.0-alpha.9 - "@jest/expect": ^28.0.0-alpha.10 + "@jest/environment": ^28.0.0-alpha.11 + "@jest/expect": ^28.0.0-alpha.11 "@jest/test-result": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 "@types/co": ^4.6.2 @@ -13019,8 +13019,8 @@ __metadata: jest-each: ^28.0.0-alpha.9 jest-matcher-utils: ^28.0.0-alpha.9 jest-message-util: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.10 - jest-snapshot: ^28.0.0-alpha.10 + jest-runtime: ^28.0.0-alpha.11 + jest-snapshot: ^28.0.0-alpha.11 jest-util: ^28.0.0-alpha.9 pretty-format: ^28.0.0-alpha.9 slash: ^3.0.0 @@ -13029,11 +13029,11 @@ __metadata: languageName: unknown linkType: soft -"jest-cli@^28.0.0-alpha.10, jest-cli@workspace:packages/jest-cli": +"jest-cli@^28.0.0-alpha.11, jest-cli@workspace:packages/jest-cli": version: 0.0.0-use.local resolution: "jest-cli@workspace:packages/jest-cli" dependencies: - "@jest/core": ^28.0.0-alpha.10 + "@jest/core": ^28.0.0-alpha.11 "@jest/test-result": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 "@types/exit": ^0.1.30 @@ -13044,7 +13044,7 @@ __metadata: exit: ^0.1.2 graceful-fs: ^4.2.9 import-local: ^3.0.2 - jest-config: ^28.0.0-alpha.10 + jest-config: ^28.0.0-alpha.11 jest-util: ^28.0.0-alpha.9 jest-validate: ^28.0.0-alpha.9 prompts: ^2.0.1 @@ -13059,28 +13059,28 @@ __metadata: languageName: unknown linkType: soft -"jest-config@^28.0.0-alpha.10, jest-config@workspace:packages/jest-config": +"jest-config@^28.0.0-alpha.11, jest-config@workspace:packages/jest-config": version: 0.0.0-use.local resolution: "jest-config@workspace:packages/jest-config" dependencies: "@babel/core": ^7.11.6 - "@jest/test-sequencer": ^28.0.0-alpha.9 + "@jest/test-sequencer": ^28.0.0-alpha.11 "@jest/types": ^28.0.0-alpha.9 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 "@types/micromatch": ^4.0.1 - babel-jest: ^28.0.0-alpha.10 + babel-jest: ^28.0.0-alpha.11 chalk: ^4.0.0 ci-info: ^3.2.0 deepmerge: ^4.2.2 glob: ^7.1.3 graceful-fs: ^4.2.9 - jest-circus: ^28.0.0-alpha.10 - jest-environment-node: ^28.0.0-alpha.10 + jest-circus: ^28.0.0-alpha.11 + jest-environment-node: ^28.0.0-alpha.11 jest-get-type: ^28.0.0-alpha.3 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.9 - jest-runner: ^28.0.0-alpha.10 + jest-resolve: ^28.0.0-alpha.11 + jest-runner: ^28.0.0-alpha.11 jest-util: ^28.0.0-alpha.9 jest-validate: ^28.0.0-alpha.9 micromatch: ^4.0.4 @@ -13152,7 +13152,7 @@ __metadata: version: 0.0.0-use.local resolution: "jest-environment-jsdom@workspace:packages/jest-environment-jsdom" dependencies: - "@jest/environment": ^28.0.0-alpha.9 + "@jest/environment": ^28.0.0-alpha.11 "@jest/fake-timers": ^28.0.0-alpha.9 "@jest/test-utils": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 @@ -13168,7 +13168,7 @@ __metadata: version: 0.0.0-use.local resolution: "jest-environment-node@workspace:packages/jest-environment-node" dependencies: - "@jest/environment": ^28.0.0-alpha.9 + "@jest/environment": ^28.0.0-alpha.11 "@jest/fake-timers": ^28.0.0-alpha.9 "@jest/test-utils": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 @@ -13198,7 +13198,7 @@ __metadata: languageName: node linkType: hard -"jest-haste-map@^28.0.0-alpha.9, jest-haste-map@workspace:packages/jest-haste-map": +"jest-haste-map@^28.0.0-alpha.11, jest-haste-map@workspace:packages/jest-haste-map": version: 0.0.0-use.local resolution: "jest-haste-map@workspace:packages/jest-haste-map" dependencies: @@ -13214,7 +13214,7 @@ __metadata: graceful-fs: ^4.2.9 jest-regex-util: ^28.0.0-alpha.6 jest-util: ^28.0.0-alpha.9 - jest-worker: ^28.0.0-alpha.9 + jest-worker: ^28.0.0-alpha.11 micromatch: ^4.0.4 slash: ^3.0.0 walker: ^1.0.7 @@ -13248,13 +13248,13 @@ __metadata: languageName: node linkType: hard -"jest-jasmine2@^28.0.0-alpha.10, jest-jasmine2@workspace:packages/jest-jasmine2": +"jest-jasmine2@^28.0.0-alpha.11, jest-jasmine2@workspace:packages/jest-jasmine2": version: 0.0.0-use.local resolution: "jest-jasmine2@workspace:packages/jest-jasmine2" dependencies: - "@jest/environment": ^28.0.0-alpha.9 - "@jest/expect": ^28.0.0-alpha.10 - "@jest/source-map": ^28.0.0-alpha.10 + "@jest/environment": ^28.0.0-alpha.11 + "@jest/expect": ^28.0.0-alpha.11 + "@jest/source-map": ^28.0.0-alpha.11 "@jest/test-result": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 "@types/co": ^4.6.2 @@ -13265,8 +13265,8 @@ __metadata: jest-each: ^28.0.0-alpha.9 jest-matcher-utils: ^28.0.0-alpha.9 jest-message-util: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.10 - jest-snapshot: ^28.0.0-alpha.10 + jest-runtime: ^28.0.0-alpha.11 + jest-snapshot: ^28.0.0-alpha.11 jest-util: ^28.0.0-alpha.9 pretty-format: ^28.0.0-alpha.9 throat: ^6.0.1 @@ -13408,14 +13408,14 @@ __metadata: resolution: "jest-repl@workspace:packages/jest-repl" dependencies: "@jest/console": ^28.0.0-alpha.9 - "@jest/environment": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.10 + "@jest/environment": ^28.0.0-alpha.11 + "@jest/transform": ^28.0.0-alpha.11 "@jest/types": ^28.0.0-alpha.9 "@types/yargs": ^17.0.8 chalk: ^4.0.0 execa: ^5.0.0 - jest-config: ^28.0.0-alpha.10 - jest-runtime: ^28.0.0-alpha.10 + jest-config: ^28.0.0-alpha.11 + jest-runtime: ^28.0.0-alpha.11 jest-util: ^28.0.0-alpha.9 jest-validate: ^28.0.0-alpha.9 repl: ^0.1.3 @@ -13426,21 +13426,21 @@ __metadata: languageName: unknown linkType: soft -"jest-resolve-dependencies@^28.0.0-alpha.10, jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies": +"jest-resolve-dependencies@^28.0.0-alpha.11, jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies": version: 0.0.0-use.local resolution: "jest-resolve-dependencies@workspace:packages/jest-resolve-dependencies" dependencies: "@jest/test-utils": ^28.0.0-alpha.9 "@jest/types": ^28.0.0-alpha.9 - jest-haste-map: ^28.0.0-alpha.9 + jest-haste-map: ^28.0.0-alpha.11 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.10 - jest-snapshot: ^28.0.0-alpha.10 + jest-resolve: ^28.0.0-alpha.11 + jest-runtime: ^28.0.0-alpha.11 + jest-snapshot: ^28.0.0-alpha.11 languageName: unknown linkType: soft -"jest-resolve@^28.0.0-alpha.9, jest-resolve@workspace:packages/jest-resolve": +"jest-resolve@^28.0.0-alpha.11, jest-resolve@workspace:packages/jest-resolve": version: 0.0.0-use.local resolution: "jest-resolve@workspace:packages/jest-resolve" dependencies: @@ -13448,7 +13448,7 @@ __metadata: "@types/resolve": ^1.20.0 chalk: ^4.0.0 graceful-fs: ^4.2.9 - jest-haste-map: ^28.0.0-alpha.9 + jest-haste-map: ^28.0.0-alpha.11 jest-pnp-resolver: ^1.2.2 jest-util: ^28.0.0-alpha.9 jest-validate: ^28.0.0-alpha.9 @@ -13472,14 +13472,14 @@ __metadata: languageName: node linkType: hard -"jest-runner@^28.0.0-alpha.10, jest-runner@workspace:packages/jest-runner": +"jest-runner@^28.0.0-alpha.11, jest-runner@workspace:packages/jest-runner": version: 0.0.0-use.local resolution: "jest-runner@workspace:packages/jest-runner" dependencies: "@jest/console": ^28.0.0-alpha.9 - "@jest/environment": ^28.0.0-alpha.9 + "@jest/environment": ^28.0.0-alpha.11 "@jest/test-result": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.10 + "@jest/transform": ^28.0.0-alpha.11 "@jest/types": ^28.0.0-alpha.9 "@tsd/typescript": ~4.6.2 "@types/exit": ^0.1.30 @@ -13490,33 +13490,33 @@ __metadata: emittery: ^0.10.2 graceful-fs: ^4.2.9 jest-docblock: ^28.0.0-alpha.6 - jest-environment-node: ^28.0.0-alpha.10 - jest-haste-map: ^28.0.0-alpha.9 - jest-jasmine2: ^28.0.0-alpha.10 + jest-environment-node: ^28.0.0-alpha.11 + jest-haste-map: ^28.0.0-alpha.11 + jest-jasmine2: ^28.0.0-alpha.11 jest-leak-detector: ^28.0.0-alpha.9 jest-message-util: ^28.0.0-alpha.9 - jest-resolve: ^28.0.0-alpha.9 - jest-runtime: ^28.0.0-alpha.10 + jest-resolve: ^28.0.0-alpha.11 + jest-runtime: ^28.0.0-alpha.11 jest-util: ^28.0.0-alpha.9 jest-watcher: ^28.0.0-alpha.9 - jest-worker: ^28.0.0-alpha.9 + jest-worker: ^28.0.0-alpha.11 source-map-support: ^0.5.6 throat: ^6.0.1 tsd-lite: ^0.5.1 languageName: unknown linkType: soft -"jest-runtime@^28.0.0-alpha.10, jest-runtime@workspace:packages/jest-runtime": +"jest-runtime@^28.0.0-alpha.11, jest-runtime@workspace:packages/jest-runtime": version: 0.0.0-use.local resolution: "jest-runtime@workspace:packages/jest-runtime" dependencies: - "@jest/environment": ^28.0.0-alpha.9 + "@jest/environment": ^28.0.0-alpha.11 "@jest/fake-timers": ^28.0.0-alpha.9 - "@jest/globals": ^28.0.0-alpha.10 - "@jest/source-map": ^28.0.0-alpha.10 + "@jest/globals": ^28.0.0-alpha.11 + "@jest/source-map": ^28.0.0-alpha.11 "@jest/test-result": ^28.0.0-alpha.9 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.10 + "@jest/transform": ^28.0.0-alpha.11 "@jest/types": ^28.0.0-alpha.9 "@types/glob": ^7.1.1 "@types/graceful-fs": ^4.1.3 @@ -13527,13 +13527,13 @@ __metadata: execa: ^5.0.0 glob: ^7.1.3 graceful-fs: ^4.2.9 - jest-environment-node: ^28.0.0-alpha.10 - jest-haste-map: ^28.0.0-alpha.9 + jest-environment-node: ^28.0.0-alpha.11 + jest-haste-map: ^28.0.0-alpha.11 jest-message-util: ^28.0.0-alpha.9 jest-mock: ^28.0.0-alpha.9 jest-regex-util: ^28.0.0-alpha.6 - jest-resolve: ^28.0.0-alpha.9 - jest-snapshot: ^28.0.0-alpha.10 + jest-resolve: ^28.0.0-alpha.11 + jest-snapshot: ^28.0.0-alpha.11 jest-util: ^28.0.0-alpha.9 slash: ^3.0.0 strip-bom: ^4.0.0 @@ -13570,7 +13570,7 @@ __metadata: languageName: node linkType: hard -"jest-snapshot@^28.0.0-alpha.10, jest-snapshot@workspace:*, jest-snapshot@workspace:packages/jest-snapshot": +"jest-snapshot@^28.0.0-alpha.11, jest-snapshot@workspace:*, jest-snapshot@workspace:packages/jest-snapshot": version: 0.0.0-use.local resolution: "jest-snapshot@workspace:packages/jest-snapshot" dependencies: @@ -13583,7 +13583,7 @@ __metadata: "@babel/types": ^7.3.3 "@jest/expect-utils": ^28.0.0-alpha.9 "@jest/test-utils": ^28.0.0-alpha.9 - "@jest/transform": ^28.0.0-alpha.10 + "@jest/transform": ^28.0.0-alpha.11 "@jest/types": ^28.0.0-alpha.9 "@types/babel__traverse": ^7.0.6 "@types/graceful-fs": ^4.1.3 @@ -13598,7 +13598,7 @@ __metadata: graceful-fs: ^4.2.9 jest-diff: ^28.0.0-alpha.9 jest-get-type: ^28.0.0-alpha.3 - jest-haste-map: ^28.0.0-alpha.9 + jest-haste-map: ^28.0.0-alpha.11 jest-matcher-utils: ^28.0.0-alpha.9 jest-message-util: ^28.0.0-alpha.9 jest-util: ^28.0.0-alpha.9 @@ -13752,7 +13752,7 @@ __metadata: languageName: unknown linkType: soft -"jest-worker@^28.0.0-alpha.9, jest-worker@workspace:packages/jest-worker": +"jest-worker@^28.0.0-alpha.11, jest-worker@workspace:packages/jest-worker": version: 0.0.0-use.local resolution: "jest-worker@workspace:packages/jest-worker" dependencies: @@ -13802,9 +13802,9 @@ __metadata: version: 0.0.0-use.local resolution: "jest@workspace:packages/jest" dependencies: - "@jest/core": ^28.0.0-alpha.10 + "@jest/core": ^28.0.0-alpha.11 import-local: ^3.0.2 - jest-cli: ^28.0.0-alpha.10 + jest-cli: ^28.0.0-alpha.11 peerDependencies: node-notifier: ^8.0.1 || ^9.0.0 || ^10.0.0 peerDependenciesMeta: From f60f84e82056bdafd785fd9a410208c631a96c37 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Wed, 20 Apr 2022 19:39:15 +0300 Subject: [PATCH 083/128] refactor(jest-config)!: do not normalize long deprecated configuration options (#12701) --- CHANGELOG.md | 3 +- docs/Configuration.md | 6 - packages/jest-config/src/Deprecated.ts | 28 +- .../__snapshots__/normalize.test.ts.snap | 259 ++++++++++++------ .../src/__tests__/normalize.test.ts | 178 +++++------- packages/jest-config/src/normalize.ts | 71 +---- packages/jest-types/src/Config.ts | 16 -- .../version-27.4/Configuration.md | 2 - .../version-27.5/Configuration.md | 2 - 9 files changed, 250 insertions(+), 315 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 8d69b328c1e4..4cdee711f967 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -14,6 +14,7 @@ - `[jest-config]` [**BREAKING**] Rename `moduleLoader` to `runtime` ([#10817](https://github.com/facebook/jest/pull/10817)) - `[jest-config]` [**BREAKING**] Rename `extraGlobals` to `sandboxInjectedGlobals` ([#10817](https://github.com/facebook/jest/pull/10817)) - `[jest-config]` [**BREAKING**] Throw an error instead of showing a warning if multiple configs are used ([#12510](https://github.com/facebook/jest/pull/12510)) +- `[jest-config]` [**BREAKING**] Do not normalize long deprecated configuration options `preprocessorIgnorePatterns`,`scriptPreprocessor`, `setupTestFrameworkScriptFile` and `testPathDirs` ([#1251270110](https://github.com/facebook/jest/pull/12701)) - `[jest-cli, jest-core]` Add `--ignoreProjects` CLI argument to ignore test suites by project name ([#12620](https://github.com/facebook/jest/pull/12620)) - `[jest-core]` Pass project config to `globalSetup`/`globalTeardown` function as second argument ([#12440](https://github.com/facebook/jest/pull/12440)) - `[jest-core]` Stabilize test runners with event emitters ([#12641](https://github.com/facebook/jest/pull/12641)) @@ -38,7 +39,7 @@ - `[jest-mock]` [**BREAKING**] Improve the usage of `jest.fn` generic type argument ([#12489](https://github.com/facebook/jest/pull/12489)) - `[jest-mock]` Add support for auto-mocking async generator functions ([#11080](https://github.com/facebook/jest/pull/11080)) - `[jest-mock]` Add `contexts` member to mock functions ([#12601](https://github.com/facebook/jest/pull/12601)) -- `[@jest/reporters]` Add GitHub Actions reporter ([#11320](https://github.com/facebook/jest/pull/11320), [#12658](https://github.com/facebook/jest/pull/12658) +- `[@jest/reporters]` Add GitHub Actions reporter ([#11320](https://github.com/facebook/jest/pull/11320), [#12658](https://github.com/facebook/jest/pull/12658)) - `[@jest/reporters]` Pass `reporterContext` to custom reporter constructors as third argument ([#12657](https://github.com/facebook/jest/pull/12657)) - `[jest-resolve]` [**BREAKING**] Add support for `package.json` `exports` ([#11961](https://github.com/facebook/jest/pull/11961), [#12373](https://github.com/facebook/jest/pull/12373)) - `[jest-resolve]` Support package self-reference ([#12682](https://github.com/facebook/jest/pull/12682)) diff --git a/docs/Configuration.md b/docs/Configuration.md index 11d60d5f4896..212e391955c1 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -1108,12 +1108,6 @@ If you want a path to be [relative to the root directory of your project](#rootd For example, Jest ships with several plug-ins to `jasmine` that work by monkey-patching the jasmine API. If you wanted to add even more jasmine plugins to the mix (or if you wanted some custom, project-wide matchers for example), you could do so in these modules. -:::info - -`setupTestFrameworkScriptFile` is deprecated in favor of `setupFilesAfterEnv`. - -::: - Example `setupFilesAfterEnv` array in a jest.config.js: ```js diff --git a/packages/jest-config/src/Deprecated.ts b/packages/jest-config/src/Deprecated.ts index 905d3ebdde5b..647dd29691d3 100644 --- a/packages/jest-config/src/Deprecated.ts +++ b/packages/jest-config/src/Deprecated.ts @@ -7,9 +7,6 @@ import chalk = require('chalk'); import type {DeprecatedOptions} from 'jest-validate'; -import {format as prettyFormat} from 'pretty-format'; - -const format = (value: unknown) => prettyFormat(value, {min: true}); const deprecatedOptions: DeprecatedOptions = { browser: () => @@ -29,7 +26,7 @@ const deprecatedOptions: DeprecatedOptions = { Please update your configuration.`, - preprocessorIgnorePatterns: (options: { + preprocessorIgnorePatterns: (_options: { preprocessorIgnorePatterns?: Array; }) => ` Option ${chalk.bold( '"preprocessorIgnorePatterns"', @@ -37,16 +34,9 @@ const deprecatedOptions: DeprecatedOptions = { '"transformIgnorePatterns"', )}, which support multiple preprocessors. - Jest now treats your current configuration as: - { - ${chalk.bold('"transformIgnorePatterns"')}: ${chalk.bold( - format(options.preprocessorIgnorePatterns), - )} - } - Please update your configuration.`, - scriptPreprocessor: (options: { + scriptPreprocessor: (_options: { scriptPreprocessor?: string; }) => ` Option ${chalk.bold( '"scriptPreprocessor"', @@ -54,13 +44,6 @@ const deprecatedOptions: DeprecatedOptions = { '"transform"', )}, which support multiple preprocessors. - Jest now treats your current configuration as: - { - ${chalk.bold('"transform"')}: ${chalk.bold( - `{".*": ${format(options.scriptPreprocessor)}}`, - )} - } - Please update your configuration.`, setupTestFrameworkScriptFile: (_options: { @@ -73,17 +56,12 @@ const deprecatedOptions: DeprecatedOptions = { Please update your configuration.`, - testPathDirs: (options: { + testPathDirs: (_options: { testPathDirs?: Array; }) => ` Option ${chalk.bold('"testPathDirs"')} was replaced by ${chalk.bold( '"roots"', )}. - Jest now treats your current configuration as: - { - ${chalk.bold('"roots"')}: ${chalk.bold(format(options.testPathDirs))} - } - Please update your configuration. `, diff --git a/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap b/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap index 284570033fc2..00386d08b28c 100644 --- a/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap +++ b/packages/jest-config/src/__tests__/__snapshots__/normalize.test.ts.snap @@ -1,22 +1,5 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`Upgrade help logs a warning when \`scriptPreprocessor\` and/or \`preprocessorIgnorePatterns\` are used 1`] = ` -" Deprecation Warning: - - Option "preprocessorIgnorePatterns" was replaced by "transformIgnorePatterns", which support multiple preprocessors. - - Jest now treats your current configuration as: - { - "transformIgnorePatterns": ["bar/baz", "qux/quux"] - } - - Please update your configuration. - - Configuration Documentation: - https://jestjs.io/docs/configuration -" -`; - exports[`displayName generates a default color for the runner jest-runner 1`] = `"yellow"`; exports[`displayName generates a default color for the runner jest-runner-eslint 1`] = `"magenta"`; @@ -132,7 +115,29 @@ exports[`extensionsToTreatAsEsm throws on .mjs 1`] = ` " `; -exports[`extraGlobals logs a deprecation warning when \`extraGlobals\` is used 1`] = ` +exports[`logs a deprecation warning when 'browser' option is passed 1`] = ` +[MockFunction] { + "calls": Array [ + Array [ + " Deprecation Warning: + + Option "browser" has been deprecated. Please install "browser-resolve" and use the "resolver" option in Jest configuration as shown in the documentation: https://jestjs.io/docs/configuration#resolver-string + + Configuration Documentation: + https://jestjs.io/docs/configuration +", + ], + ], + "results": Array [ + Object { + "type": "return", + "value": undefined, + }, + ], +} +`; + +exports[`logs a deprecation warning when 'extraGlobals' option is passed 1`] = ` [MockFunction] { "calls": Array [ Array [ @@ -156,7 +161,7 @@ exports[`extraGlobals logs a deprecation warning when \`extraGlobals\` is used 1 } `; -exports[`moduleLoader logs a deprecation warning when \`moduleLoader\` is used 1`] = ` +exports[`logs a deprecation warning when 'moduleLoader' option is passed 1`] = ` [MockFunction] { "calls": Array [ Array [ @@ -180,6 +185,151 @@ exports[`moduleLoader logs a deprecation warning when \`moduleLoader\` is used 1 } `; +exports[`logs a deprecation warning when 'preprocessorIgnorePatterns' option is passed 1`] = ` +[MockFunction] { + "calls": Array [ + Array [ + " Deprecation Warning: + + Option "preprocessorIgnorePatterns" was replaced by "transformIgnorePatterns", which support multiple preprocessors. + + Please update your configuration. + + Configuration Documentation: + https://jestjs.io/docs/configuration +", + ], + ], + "results": Array [ + Object { + "type": "return", + "value": undefined, + }, + ], +} +`; + +exports[`logs a deprecation warning when 'scriptPreprocessor' option is passed 1`] = ` +[MockFunction] { + "calls": Array [ + Array [ + " Deprecation Warning: + + Option "scriptPreprocessor" was replaced by "transform", which support multiple preprocessors. + + Please update your configuration. + + Configuration Documentation: + https://jestjs.io/docs/configuration +", + ], + ], + "results": Array [ + Object { + "type": "return", + "value": undefined, + }, + ], +} +`; + +exports[`logs a deprecation warning when 'setupTestFrameworkScriptFile' option is passed 1`] = ` +[MockFunction] { + "calls": Array [ + Array [ + " Deprecation Warning: + + Option "setupTestFrameworkScriptFile" was replaced by configuration "setupFilesAfterEnv", which supports multiple paths. + + Please update your configuration. + + Configuration Documentation: + https://jestjs.io/docs/configuration +", + ], + ], + "results": Array [ + Object { + "type": "return", + "value": undefined, + }, + ], +} +`; + +exports[`logs a deprecation warning when 'testPathDirs' option is passed 1`] = ` +[MockFunction] { + "calls": Array [ + Array [ + " Deprecation Warning: + + Option "testPathDirs" was replaced by "roots". + + Please update your configuration. + + + Configuration Documentation: + https://jestjs.io/docs/configuration +", + ], + ], + "results": Array [ + Object { + "type": "return", + "value": undefined, + }, + ], +} +`; + +exports[`logs a deprecation warning when 'testURL' option is passed 1`] = ` +[MockFunction] { + "calls": Array [ + Array [ + " Deprecation Warning: + + Option "testURL" was replaced by passing the URL via "testEnvironmentOptions.url". + + Please update your configuration. + + Configuration Documentation: + https://jestjs.io/docs/configuration +", + ], + ], + "results": Array [ + Object { + "type": "return", + "value": undefined, + }, + ], +} +`; + +exports[`logs a deprecation warning when 'timers' option is passed 1`] = ` +[MockFunction] { + "calls": Array [ + Array [ + " Deprecation Warning: + + Option "timers" was replaced by "fakeTimers". + + Please update your configuration. + + Configuration Documentation: + https://jestjs.io/docs/configuration +", + ], + ], + "results": Array [ + Object { + "type": "return", + "value": undefined, + }, + ], +} +`; + exports[`preset throws when module was found but no "jest-preset.js" or "jest-preset.json" files 1`] = ` "Validation Error: @@ -288,29 +438,6 @@ exports[`runner throw error when a runner is not found 1`] = ` " `; -exports[`setupTestFrameworkScriptFile logs a deprecation warning when \`setupTestFrameworkScriptFile\` is used 1`] = ` -" Deprecation Warning: - - Option "setupTestFrameworkScriptFile" was replaced by configuration "setupFilesAfterEnv", which supports multiple paths. - - Please update your configuration. - - Configuration Documentation: - https://jestjs.io/docs/configuration -" -`; - -exports[`setupTestFrameworkScriptFile logs an error when \`setupTestFrameworkScriptFile\` and \`setupFilesAfterEnv\` are used 1`] = ` -"Validation Error: - - Options: setupTestFrameworkScriptFile and setupFilesAfterEnv cannot be used together. - Please change your configuration to only use setupFilesAfterEnv. - - Configuration Documentation: - https://jestjs.io/docs/configuration -" -`; - exports[`testEnvironment throws on invalid environment names 1`] = ` "Validation Error: @@ -345,54 +472,6 @@ exports[`testTimeout should throw an error if timeout is a negative number 1`] = " `; -exports[`testURL logs a deprecation warning when \`testURL\` is used 1`] = ` -[MockFunction] { - "calls": Array [ - Array [ - " Deprecation Warning: - - Option "testURL" was replaced by passing the URL via "testEnvironmentOptions.url". - - Please update your configuration. - - Configuration Documentation: - https://jestjs.io/docs/configuration -", - ], - ], - "results": Array [ - Object { - "type": "return", - "value": undefined, - }, - ], -} -`; - -exports[`timers logs a deprecation warning when \`timers\` is used 1`] = ` -[MockFunction] { - "calls": Array [ - Array [ - " Deprecation Warning: - - Option "timers" was replaced by "fakeTimers". - - Please update your configuration. - - Configuration Documentation: - https://jestjs.io/docs/configuration -", - ], - ], - "results": Array [ - Object { - "type": "return", - "value": undefined, - }, - ], -} -`; - exports[`watchPlugins throw error when a watch plugin is not found 1`] = ` "Validation Error: diff --git a/packages/jest-config/src/__tests__/normalize.test.ts b/packages/jest-config/src/__tests__/normalize.test.ts index 457baef302f1..1fc435b0ecfb 100644 --- a/packages/jest-config/src/__tests__/normalize.test.ts +++ b/packages/jest-config/src/__tests__/normalize.test.ts @@ -521,45 +521,6 @@ describe('setupFilesAfterEnv', () => { }); }); -describe('setupTestFrameworkScriptFile', () => { - let Resolver; - - beforeEach(() => { - (console.warn as unknown as jest.SpyInstance).mockImplementation(() => {}); - Resolver = require('jest-resolve').default; - Resolver.findNodeModule = jest.fn(name => - name.startsWith('/') ? name : `/root/path/foo${path.sep}${name}`, - ); - }); - - it('logs a deprecation warning when `setupTestFrameworkScriptFile` is used', async () => { - await normalize( - { - rootDir: '/root/path/foo', - setupTestFrameworkScriptFile: 'bar/baz', - }, - {} as Config.Argv, - ); - - expect( - (console.warn as unknown as jest.SpyInstance).mock.calls[0][0], - ).toMatchSnapshot(); - }); - - it('logs an error when `setupTestFrameworkScriptFile` and `setupFilesAfterEnv` are used', async () => { - await expect( - normalize( - { - rootDir: '/root/path/foo', - setupFilesAfterEnv: ['bar/baz'], - setupTestFrameworkScriptFile: 'bar/baz', - }, - {} as Config.Argv, - ), - ).rejects.toThrowErrorMatchingSnapshot(); - }); -}); - describe('coveragePathIgnorePatterns', () => { it('does not normalize paths relative to rootDir', async () => { // This is a list of patterns, so we can't assume any of them are @@ -927,45 +888,6 @@ describe('babel-jest', () => { }); }); -describe('Upgrade help', () => { - beforeEach(() => { - (console.warn as unknown as jest.SpyInstance).mockImplementation(() => {}); - - const Resolver = require('jest-resolve').default; - Resolver.findNodeModule = jest.fn(name => { - if (name == 'bar/baz') { - return '/node_modules/bar/baz'; - } - return findNodeModule(name); - }); - }); - - it('logs a warning when `scriptPreprocessor` and/or `preprocessorIgnorePatterns` are used', async () => { - const {options: options, hasDeprecationWarnings} = await normalize( - { - preprocessorIgnorePatterns: ['bar/baz', 'qux/quux'], - rootDir: '/root/path/foo', - scriptPreprocessor: 'bar/baz', - }, - {} as Config.Argv, - ); - - expect(options.transform).toEqual([['.*', '/node_modules/bar/baz', {}]]); - expect(options.transformIgnorePatterns).toEqual([ - joinForPattern('bar', 'baz'), - joinForPattern('qux', 'quux'), - ]); - - expect(options).not.toHaveProperty('scriptPreprocessor'); - expect(options).not.toHaveProperty('preprocessorIgnorePatterns'); - expect(hasDeprecationWarnings).toBeTruthy(); - - expect( - (console.warn as unknown as jest.SpyInstance).mock.calls[0][0], - ).toMatchSnapshot(); - }); -}); - describe('testRegex', () => { it('testRegex empty string is mapped to empty array', async () => { const {options} = await normalize( @@ -2017,84 +1939,126 @@ describe('updateSnapshot', () => { }); }); -describe('testURL', () => { +describe('shards', () => { + it('should be object if defined', async () => { + const {options} = await normalize({rootDir: '/root/'}, { + shard: '1/2', + } as Config.Argv); + + expect(options.shard).toEqual({shardCount: 2, shardIndex: 1}); + }); +}); + +describe('logs a deprecation warning', () => { beforeEach(() => { - jest.mocked(console.warn).mockImplementation(() => {}); + (console.warn as unknown as jest.SpyInstance).mockImplementation(() => {}); }); - it('logs a deprecation warning when `testURL` is used', async () => { + test("when 'browser' option is passed", async () => { await normalize( { + browser: true, rootDir: '/root/', - testURL: 'https://jestjs.io/', }, {} as Config.Argv, ); expect(console.warn).toMatchSnapshot(); }); -}); -describe('timers', () => { - beforeEach(() => { - jest.mocked(console.warn).mockImplementation(() => {}); + test("when 'extraGlobals' option is passed", async () => { + await normalize( + { + extraGlobals: ['Math'], + rootDir: '/root/', + }, + {} as Config.Argv, + ); + + expect(console.warn).toMatchSnapshot(); }); - it('logs a deprecation warning when `timers` is used', async () => { + test("when 'moduleLoader' option is passed", async () => { await normalize( { + moduleLoader: '/runtime.js', rootDir: '/root/', - timers: 'real', }, {} as Config.Argv, ); expect(console.warn).toMatchSnapshot(); }); -}); -describe('extraGlobals', () => { - beforeEach(() => { - jest.mocked(console.warn).mockImplementation(() => {}); + test("when 'preprocessorIgnorePatterns' option is passed", async () => { + await normalize( + { + preprocessorIgnorePatterns: ['/node_modules/'], + rootDir: '/root/', + }, + {} as Config.Argv, + ); + + expect(console.warn).toMatchSnapshot(); }); - it('logs a deprecation warning when `extraGlobals` is used', async () => { + test("when 'scriptPreprocessor' option is passed", async () => { await normalize( { - extraGlobals: ['Math'], rootDir: '/root/', + scriptPreprocessor: 'preprocessor.js', }, {} as Config.Argv, ); expect(console.warn).toMatchSnapshot(); }); -}); -describe('moduleLoader', () => { - beforeEach(() => { - jest.mocked(console.warn).mockImplementation(() => {}); + test("when 'setupTestFrameworkScriptFile' option is passed", async () => { + await normalize( + { + rootDir: '/root/', + setupTestFrameworkScriptFile: 'setup.js', + }, + {} as Config.Argv, + ); + + expect(console.warn).toMatchSnapshot(); }); - it('logs a deprecation warning when `moduleLoader` is used', async () => { + test("when 'testPathDirs' option is passed", async () => { await normalize( { - moduleLoader: '/runtime.js', rootDir: '/root/', + testPathDirs: [''], }, {} as Config.Argv, ); expect(console.warn).toMatchSnapshot(); }); -}); -describe('shards', () => { - it('should be object if defined', async () => { - const {options} = await normalize({rootDir: '/root/'}, { - shard: '1/2', - } as Config.Argv); + test("when 'testURL' option is passed", async () => { + await normalize( + { + rootDir: '/root/', + testURL: 'https://jestjs.io', + }, + {} as Config.Argv, + ); - expect(options.shard).toEqual({shardCount: 2, shardIndex: 1}); + expect(console.warn).toMatchSnapshot(); + }); + + test("when 'timers' option is passed", async () => { + await normalize( + { + rootDir: '/root/', + timers: 'real', + }, + {} as Config.Argv, + ); + + expect(console.warn).toMatchSnapshot(); }); }); diff --git a/packages/jest-config/src/normalize.ts b/packages/jest-config/src/normalize.ts index 1f1fa8c65d13..d2fc5ade328e 100644 --- a/packages/jest-config/src/normalize.ts +++ b/packages/jest-config/src/normalize.ts @@ -327,44 +327,6 @@ const normalizeUnmockedModulePathPatterns = ( replacePathSepForRegex(pattern.replace(//g, options.rootDir)), ); -const normalizePreprocessor = ( - options: Config.InitialOptionsWithRootDir, -): Config.InitialOptionsWithRootDir => { - if (options.scriptPreprocessor && options.transform) { - throw createConfigError( - ` Options: ${chalk.bold('scriptPreprocessor')} and ${chalk.bold( - 'transform', - )} cannot be used together. - Please change your configuration to only use ${chalk.bold('transform')}.`, - ); - } - - if (options.preprocessorIgnorePatterns && options.transformIgnorePatterns) { - throw createConfigError( - ` Options ${chalk.bold('preprocessorIgnorePatterns')} and ${chalk.bold( - 'transformIgnorePatterns', - )} cannot be used together. - Please change your configuration to only use ${chalk.bold( - 'transformIgnorePatterns', - )}.`, - ); - } - - if (options.scriptPreprocessor) { - options.transform = { - '.*': options.scriptPreprocessor, - }; - } - - if (options.preprocessorIgnorePatterns) { - options.transformIgnorePatterns = options.preprocessorIgnorePatterns; - } - - delete options.scriptPreprocessor; - delete options.preprocessorIgnorePatterns; - return options; -}; - const normalizeMissingOptions = ( options: Config.InitialOptionsWithRootDir, configPath: string | null | undefined, @@ -573,13 +535,11 @@ export default async function normalize( ], }); - let options = normalizePreprocessor( - normalizeReporters( - normalizeMissingOptions( - normalizeRootDir(setFromArgv(initialOptions, argv)), - configPath, - projectIndex, - ), + let options = normalizeReporters( + normalizeMissingOptions( + normalizeRootDir(setFromArgv(initialOptions, argv)), + configPath, + projectIndex, ), ); @@ -591,22 +551,6 @@ export default async function normalize( options.setupFilesAfterEnv = []; } - if ( - options.setupTestFrameworkScriptFile && - options.setupFilesAfterEnv.length > 0 - ) { - throw createConfigError(` Options: ${chalk.bold( - 'setupTestFrameworkScriptFile', - )} and ${chalk.bold('setupFilesAfterEnv')} cannot be used together. - Please change your configuration to only use ${chalk.bold( - 'setupFilesAfterEnv', - )}.`); - } - - if (options.setupTestFrameworkScriptFile) { - options.setupFilesAfterEnv.push(options.setupTestFrameworkScriptFile); - } - options.testEnvironment = resolveTestEnvironment({ requireResolveFunction: require.resolve, rootDir: options.rootDir, @@ -615,11 +559,6 @@ export default async function normalize( require.resolve(DEFAULT_CONFIG.testEnvironment), }); - if (!options.roots && options.testPathDirs) { - options.roots = options.testPathDirs; - delete options.testPathDirs; - } - if (!options.roots) { options.roots = [options.rootDir]; } diff --git a/packages/jest-types/src/Config.ts b/packages/jest-types/src/Config.ts index 7cc11a5df789..1d3f19457b95 100644 --- a/packages/jest-types/src/Config.ts +++ b/packages/jest-types/src/Config.ts @@ -277,10 +277,6 @@ export type InitialOptions = Partial<{ onlyFailures: boolean; outputFile: string; passWithNoTests: boolean; - /** - * @deprecated Use `transformIgnorePatterns` options instead. - */ - preprocessorIgnorePatterns: Array; preset: string | null | undefined; prettierPath: string | null | undefined; projects: Array; @@ -295,15 +291,7 @@ export type InitialOptions = Partial<{ runTestsByPath: boolean; runtime: string; sandboxInjectedGlobals: Array; - /** - * @deprecated Use `transform` options instead. - */ - scriptPreprocessor: string; setupFiles: Array; - /** - * @deprecated Use `setupFilesAfterEnv` options instead. - */ - setupTestFrameworkScriptFile: string; setupFilesAfterEnv: Array; silent: boolean; skipFilter: boolean; @@ -319,10 +307,6 @@ export type InitialOptions = Partial<{ testLocationInResults: boolean; testMatch: Array; testNamePattern: string; - /** - * @deprecated Use `roots` options instead. - */ - testPathDirs: Array; testPathIgnorePatterns: Array; testRegex: string | Array; testResultsProcessor: string; diff --git a/website/versioned_docs/version-27.4/Configuration.md b/website/versioned_docs/version-27.4/Configuration.md index de7e3dd8d032..4f86bbd3f342 100644 --- a/website/versioned_docs/version-27.4/Configuration.md +++ b/website/versioned_docs/version-27.4/Configuration.md @@ -918,8 +918,6 @@ If you want a path to be [relative to the root directory of your project](#rootd For example, Jest ships with several plug-ins to `jasmine` that work by monkey-patching the jasmine API. If you wanted to add even more jasmine plugins to the mix (or if you wanted some custom, project-wide matchers for example), you could do so in these modules. -_Note: `setupTestFrameworkScriptFile` is deprecated in favor of `setupFilesAfterEnv`._ - Example `setupFilesAfterEnv` array in a jest.config.js: ```js diff --git a/website/versioned_docs/version-27.5/Configuration.md b/website/versioned_docs/version-27.5/Configuration.md index de7e3dd8d032..4f86bbd3f342 100644 --- a/website/versioned_docs/version-27.5/Configuration.md +++ b/website/versioned_docs/version-27.5/Configuration.md @@ -918,8 +918,6 @@ If you want a path to be [relative to the root directory of your project](#rootd For example, Jest ships with several plug-ins to `jasmine` that work by monkey-patching the jasmine API. If you wanted to add even more jasmine plugins to the mix (or if you wanted some custom, project-wide matchers for example), you could do so in these modules. -_Note: `setupTestFrameworkScriptFile` is deprecated in favor of `setupFilesAfterEnv`._ - Example `setupFilesAfterEnv` array in a jest.config.js: ```js From 49cc5d29bd8be5c87bdfd5a6417a01da02d04c42 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Thu, 21 Apr 2022 08:41:23 +0300 Subject: [PATCH 084/128] fix(jest-changed-files): improve `changedFilesWithAncestor` command pattern for Mercurial SCM (#12322) --- CHANGELOG.md | 1 + e2e/__tests__/jestChangedFiles.test.ts | 8 -------- packages/jest-changed-files/src/hg.ts | 2 +- 3 files changed, 2 insertions(+), 9 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 4cdee711f967..4013ef2dd32d 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -68,6 +68,7 @@ - `[expect]` Throw useful error if `expect.extend` is called with invalid matchers ([#12488](https://github.com/facebook/jest/pull/12488)) - `[expect]` Fix `iterableEquality` ignores other properties ([#8359](https://github.com/facebook/jest/pull/8359)) - `[expect]` Fix print for the `closeTo` matcher ([#12626](https://github.com/facebook/jest/pull/12626)) +- `[jest-changed-files]` Improve `changedFilesWithAncestor` pattern for Mercurial SCM ([#12322](https://github.com/facebook/jest/pull/12322)) - `[jest-circus, @jest/types]` Disallow undefined value in `TestContext` type ([#12507](https://github.com/facebook/jest/pull/12507)) - `[jest-config]` Correctly detect CI environment and update snapshots accordingly ([#12378](https://github.com/facebook/jest/pull/12378)) - `[jest-config]` Pass `moduleTypes` to `ts-node` to enforce CJS when transpiling ([#12397](https://github.com/facebook/jest/pull/12397)) diff --git a/e2e/__tests__/jestChangedFiles.test.ts b/e2e/__tests__/jestChangedFiles.test.ts index ccb4b682ac53..c97f1dd53bbf 100644 --- a/e2e/__tests__/jestChangedFiles.test.ts +++ b/e2e/__tests__/jestChangedFiles.test.ts @@ -362,14 +362,6 @@ test('handles a bad revision for "changedSince", for git', async () => { }); testIfHg('gets changed files for hg', async () => { - if (process.env.CI) { - // Circle and Travis have very old version of hg (v2, and current - // version is v4.2) and its API changed since then and not compatible - // any more. Changing the SCM version on CIs is not trivial, so we'll just - // skip this test and run it only locally. - return; - } - // file1.txt is used to make a multi-line commit message // with `hg commit -l file1.txt`. // This is done to ensure that `changedFiles` only returns files diff --git a/packages/jest-changed-files/src/hg.ts b/packages/jest-changed-files/src/hg.ts index 02f1ea6099cd..c9fb11b5558a 100644 --- a/packages/jest-changed-files/src/hg.ts +++ b/packages/jest-changed-files/src/hg.ts @@ -18,7 +18,7 @@ const adapter: SCMAdapter = { const args = ['status', '-amnu']; if (options.withAncestor) { - args.push('--rev', 'min((!public() & ::.)+.)^'); + args.push('--rev', 'first(min(!public() & ::.)^+.^)'); } else if (options.changedSince) { args.push('--rev', `ancestor(., ${options.changedSince})`); } else if (options.lastCommit === true) { From 54f0ded7125d7717d7587a1cdac126900c49d88c Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Thu, 21 Apr 2022 09:30:22 +0300 Subject: [PATCH 085/128] chore(CI): enable one more Mercurial test (#12704) --- e2e/__tests__/onlyChanged.test.ts | 7 ------- 1 file changed, 7 deletions(-) diff --git a/e2e/__tests__/onlyChanged.test.ts b/e2e/__tests__/onlyChanged.test.ts index 34eeee93f793..3cbbb282f039 100644 --- a/e2e/__tests__/onlyChanged.test.ts +++ b/e2e/__tests__/onlyChanged.test.ts @@ -312,13 +312,6 @@ test('onlyChanged in config is overwritten by --all or testPathPattern', () => { }); testIfHg('gets changed files for hg', async () => { - if (process.env.CI) { - // Circle and Travis have very old version of hg (v2, and current - // version is v4.2) and its API changed since then and not compatible - // any more. Changing the SCM version on CIs is not trivial, so we'll just - // skip this test and run it only locally. - return; - } writeFiles(DIR, { '.watchmanconfig': '', '__tests__/file1.test.js': "require('../file1'); test('file1', () => {});", From 4beda2dd370d734ee3ec5b87fcaac771ccbbeb77 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Thu, 21 Apr 2022 08:56:48 +0200 Subject: [PATCH 086/128] fix: do not report unref-ed subprocesses as open handles (#12705) --- CHANGELOG.md | 1 + e2e/__tests__/detectOpenHandles.ts | 11 ++++++++ .../__tests__/child_process.js | 21 ++++++++++++++++ e2e/detect-open-handles/interval-code.js | 10 ++++++++ packages/jest-core/src/collectHandles.ts | 25 ++++++++----------- 5 files changed, 53 insertions(+), 15 deletions(-) create mode 100644 e2e/detect-open-handles/__tests__/child_process.js create mode 100644 e2e/detect-open-handles/interval-code.js diff --git a/CHANGELOG.md b/CHANGELOG.md index 4013ef2dd32d..66d8e321591e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -75,6 +75,7 @@ - `[jest-config]` [**BREAKING**] Add `mjs` and `cjs` to default `moduleFileExtensions` config ([#12578](https://github.com/facebook/jest/pull/12578)) - `[jest-config, jest-haste-map]` Allow searching for tests in `node_modules` by exposing `retainAllFiles` ([#11084](https://github.com/facebook/jest/pull/11084)) - `[jest-core]` [**BREAKING**] Exit with status `1` if no tests are found with `--findRelatedTests` flag ([#12487](https://github.com/facebook/jest/pull/12487)) +- `[jest-core]` Do not report unref-ed subprocesses as open handles ([#12705](https://github.com/facebook/jest/pull/12705)) - `[jest-each]` `%#` is not replaced with index of the test case ([#12517](https://github.com/facebook/jest/pull/12517)) - `[jest-each]` Fixes error message with incorrect count of missing arguments ([#12464](https://github.com/facebook/jest/pull/12464)) - `[jest-environment-jsdom]` Make `jsdom` accessible to extending environments again ([#12232](https://github.com/facebook/jest/pull/12232)) diff --git a/e2e/__tests__/detectOpenHandles.ts b/e2e/__tests__/detectOpenHandles.ts index 797ad18d59cb..97586bbbbf16 100644 --- a/e2e/__tests__/detectOpenHandles.ts +++ b/e2e/__tests__/detectOpenHandles.ts @@ -108,6 +108,17 @@ it('does not report timeouts using unref', () => { expect(textAfterTest).toBe(''); }); +it('does not report child_process using unref', () => { + // The test here is basically that it exits cleanly without reporting anything (does not need `until`) + const {stderr} = runJest('detect-open-handles', [ + 'child_process', + '--detectOpenHandles', + ]); + const textAfterTest = getTextAfterTest(stderr); + + expect(textAfterTest).toBe(''); +}); + it('prints out info about open handlers from inside tests', async () => { const run = runContinuous('detect-open-handles', [ 'inside', diff --git a/e2e/detect-open-handles/__tests__/child_process.js b/e2e/detect-open-handles/__tests__/child_process.js new file mode 100644 index 000000000000..3440138ba757 --- /dev/null +++ b/e2e/detect-open-handles/__tests__/child_process.js @@ -0,0 +1,21 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +const {spawn} = require('child_process'); + +test('something', () => { + const subprocess = spawn( + process.argv[0], + [require.resolve('../interval-code')], + { + detached: true, + stdio: 'ignore', + }, + ); + subprocess.unref(); + expect(true).toBe(true); +}); diff --git a/e2e/detect-open-handles/interval-code.js b/e2e/detect-open-handles/interval-code.js new file mode 100644 index 000000000000..3e1309e032cf --- /dev/null +++ b/e2e/detect-open-handles/interval-code.js @@ -0,0 +1,10 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +setInterval(() => { + console.log('XX'); +}, 1000); diff --git a/packages/jest-core/src/collectHandles.ts b/packages/jest-core/src/collectHandles.ts index 88fe14a4b1de..61afcf7fd846 100644 --- a/packages/jest-core/src/collectHandles.ts +++ b/packages/jest-core/src/collectHandles.ts @@ -93,24 +93,19 @@ export default function collectHandles(): HandleCollectionResult { if (fromUser) { let isActive: () => boolean; - if (type === 'Timeout' || type === 'Immediate') { - // Timer that supports hasRef (Node v11+) - if ('hasRef' in resource) { - if (hasWeakRef) { - // @ts-expect-error: doesn't exist in v12 typings - const ref = new WeakRef(resource); - isActive = () => { - return ref.deref()?.hasRef() ?? false; - }; - } else { - isActive = resource.hasRef.bind(resource); - } + // Handle that supports hasRef + if ('hasRef' in resource) { + if (hasWeakRef) { + // @ts-expect-error: doesn't exist in v12 typings + const ref = new WeakRef(resource); + isActive = () => { + return ref.deref()?.hasRef() ?? false; + }; } else { - // Timer that doesn't support hasRef - isActive = alwaysActive; + isActive = resource.hasRef.bind(resource); } } else { - // Any other async resource + // Handle that doesn't support hasRef isActive = alwaysActive; } From 8436c06ca853060a7db56f1ae1ce56d16bf515e9 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Thu, 21 Apr 2022 11:21:34 +0200 Subject: [PATCH 087/128] fix: correctly resolve `source-map-support` (#12706) --- CHANGELOG.md | 3 ++- packages/jest-runner/src/runTest.ts | 1 - 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 66d8e321591e..7dfefd497d41 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -58,7 +58,7 @@ - `[jest-test-result]` Add duration property to JSON test output ([#12518](https://github.com/facebook/jest/pull/12518)) - `[jest-watcher]` [**BREAKING**] Make `PatternPrompt` class to take `entityName` as third constructor parameter instead of `this._entityName` ([#12591](https://github.com/facebook/jest/pull/12591)) - `[jest-worker]` [**BREAKING**] Allow only absolute `workerPath` ([#12343](https://github.com/facebook/jest/pull/12343)) -- `[jest-worker]` [**BREAKING**] Default to advanced serialization when using child process workers ([#10983] (https://github.com/facebook/jest/pull/10983)) +- `[jest-worker]` [**BREAKING**] Default to advanced serialization when using child process workers ([#10983](https://github.com/facebook/jest/pull/10983)) - `[pretty-format]` New `maxWidth` parameter ([#12402](https://github.com/facebook/jest/pull/12402)) ### Fixes @@ -94,6 +94,7 @@ - `[@jest/reporters]` Move missing icon file which is needed for `NotifyReporter` class. ([#12593](https://github.com/facebook/jest/pull/12593)) - `[@jest/reporters]` Update `v8-to-istanbul` ([#12697](https://github.com/facebook/jest/pull/12697)) - `[jest-resolver]` Call custom resolver with core node.js modules ([#12654](https://github.com/facebook/jest/pull/12654)) +- `[jest-runner]` Correctly resolve `source-map-support` ([#12706](https://github.com/facebook/jest/pull/12706)) - `[jest-worker]` Fix `Farm` execution results memory leak ([#12497](https://github.com/facebook/jest/pull/12497)) ### Chore & Maintenance diff --git a/packages/jest-runner/src/runTest.ts b/packages/jest-runner/src/runTest.ts index ecf25812b269..f6e0d40848cc 100644 --- a/packages/jest-runner/src/runTest.ts +++ b/packages/jest-runner/src/runTest.ts @@ -236,7 +236,6 @@ async function runTestInternal( runtime .requireInternalModule( require.resolve('source-map-support'), - 'source-map-support', ) .install(sourcemapOptions); From 75c7c401d4555127c9cee3e27770978a1172e392 Mon Sep 17 00:00:00 2001 From: BIKI DAS Date: Thu, 21 Apr 2022 16:14:23 +0530 Subject: [PATCH 088/128] docs: use admonitions in ExpectAPI.md (#12679) --- docs/ExpectAPI.md | 30 +++++++++++++++++++++++++----- 1 file changed, 25 insertions(+), 5 deletions(-) diff --git a/docs/ExpectAPI.md b/docs/ExpectAPI.md index da7a47365058..aa25136d861b 100644 --- a/docs/ExpectAPI.md +++ b/docs/ExpectAPI.md @@ -67,7 +67,9 @@ test('numeric ranges', () => { }); ``` -_Note_: In TypeScript, when using `@types/jest` for example, you can declare the new `toBeWithinRange` matcher in the imported module like this: +:::note + +In TypeScript, when using `@types/jest` for example, you can declare the new `toBeWithinRange` matcher in the imported module like this: ```ts interface CustomMatchers { @@ -83,6 +85,8 @@ declare global { } ``` +::: + #### Async Matchers `expect.extend` also supports async matchers. Async matchers return a Promise so you will need to await the returned value. Let's use an example matcher to illustrate the usage of them. We are going to implement a matcher called `toBeDivisibleByExternalValue`, where the divisible number is going to be pulled from an external source. @@ -800,7 +804,11 @@ test('drinkEach drinks each drink', () => { }); ``` -Note: the nth argument must be positive integer starting from 1. +:::note + +The nth argument must be positive integer starting from 1. + +::: ### `.toHaveReturned()` @@ -899,7 +907,11 @@ test('drink returns expected nth calls', () => { }); ``` -Note: the nth argument must be positive integer starting from 1. +:::note + +The nth argument must be positive integer starting from 1. + +::: ### `.toHaveLength(number)` @@ -1205,7 +1217,11 @@ describe('the La Croix cans on my desk', () => { }); ``` -> Note: `.toEqual` won't perform a _deep equality_ check for two errors. Only the `message` property of an Error is considered for equality. It is recommended to use the `.toThrow` matcher for testing against errors. +:::tip + +`.toEqual` won't perform a _deep equality_ check for two errors. Only the `message` property of an Error is considered for equality. It is recommended to use the `.toThrow` matcher for testing against errors. + +::: If differences between properties do not help you to understand why a test fails, especially if the report is large, then you might move the comparison into the `expect` function. For example, use `equals` method of `Buffer` class to assert whether or not buffers contain the same content: @@ -1340,7 +1356,11 @@ test('throws on octopus', () => { }); ``` -> Note: You must wrap the code in a function, otherwise the error will not be caught and the assertion will fail. +:::tip + +You must wrap the code in a function, otherwise the error will not be caught and the assertion will fail. + +::: You can provide an optional argument to test that a specific error is thrown: From 0208815654e54814c3a4477fb366a5f1e1d8b997 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Thu, 21 Apr 2022 14:14:25 +0300 Subject: [PATCH 089/128] feat(jest-resolve): expose `JestResolver`, `AsyncResolver` and `SyncResolver` types (#12707) --- CHANGELOG.md | 2 + docs/Configuration.md | 57 +++++++-------- .../moduleNameMapper.test.ts.snap | 4 +- .../resolveNoFileExtensions.test.ts.snap | 2 +- .../__typetests__/resolver.test.ts | 70 +++++++++++++++++++ .../jest-resolve/__typetests__/tsconfig.json | 12 ++++ packages/jest-resolve/package.json | 4 +- .../src/__tests__/resolve.test.ts | 4 -- packages/jest-resolve/src/defaultResolver.ts | 35 +++++++--- packages/jest-resolve/src/fileWalkers.ts | 8 +-- packages/jest-resolve/src/index.ts | 7 +- packages/jest-resolve/src/resolver.ts | 7 +- .../src/__tests__/fixtures/jestConfig.ts | 2 - yarn.lock | 2 + 14 files changed, 157 insertions(+), 59 deletions(-) create mode 100644 packages/jest-resolve/__typetests__/resolver.test.ts create mode 100644 packages/jest-resolve/__typetests__/tsconfig.json diff --git a/CHANGELOG.md b/CHANGELOG.md index 7dfefd497d41..6d6ffb16d57e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -45,6 +45,8 @@ - `[jest-resolve]` Support package self-reference ([#12682](https://github.com/facebook/jest/pull/12682)) - `[jest-resolve, jest-runtime]` Add support for `data:` URI import and mock ([#12392](https://github.com/facebook/jest/pull/12392)) - `[jest-resolve, jest-runtime]` Add support for async resolver ([#11540](https://github.com/facebook/jest/pull/11540)) +- `[jest-resolve]` [**BREAKING**] Remove `browser?: boolean` from resolver options, `conditions: ['browser']` should be used instead ([#12707](https://github.com/facebook/jest/pull/12707)) +- `[jest-resolve]` Expose `JestResolver`, `AsyncResolver` and `SyncResolver` types ([#12707](https://github.com/facebook/jest/pull/12707)) - `[jest-runner]` Allow `setupFiles` module to export an async function ([#12042](https://github.com/facebook/jest/pull/12042)) - `[jest-runner]` Allow passing `testEnvironmentOptions` via docblocks ([#12470](https://github.com/facebook/jest/pull/12470)) - `[jest-runner]` Exposing `CallbackTestRunner`, `EmittingTestRunner` abstract classes to help typing third party runners ([#12646](https://github.com/facebook/jest/pull/12646)) diff --git a/docs/Configuration.md b/docs/Configuration.md index 212e391955c1..8901f21b76c8 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -919,30 +919,41 @@ By default, each test file gets its own independent module registry. Enabling `r Default: `undefined` -This option allows the use of a custom resolver. This resolver must be a node module that exports _either_: +This option allows the use of a custom resolver. This resolver must be a module that exports _either_: 1. a function expecting a string as the first argument for the path to resolve and an options object as the second argument. The function should either return a path to the module that should be resolved or throw an error if the module can't be found. _or_ 2. an object containing `async` and/or `sync` properties. The `sync` property should be a function with the shape explained above, and the `async` property should also be a function that accepts the same arguments, but returns a promise which resolves with the path to the module or rejects with an error. The options object provided to resolvers has the shape: -```json -{ - "basedir": string, - "conditions": [string], - "defaultResolver": "function(request, options) -> string", - "extensions": [string], - "moduleDirectory": [string], - "paths": [string], - "packageFilter": "function(pkg, pkgdir)", - "pathFilter": "function(pkg, path, relativePath)", - "rootDir": [string] -} +```ts +type PackageJson = Record; + +type ResolverOptions = { + /** Directory to begin resolving from. */ + basedir: string; + /** List of export conditions. */ + conditions?: Array; + /** Instance of default resolver. */ + defaultResolver: (path: string, options: ResolverOptions) => string; + /** List of file extensions to search in order. */ + extensions?: Array; + /** List of directory names to be looked up for modules recursively. */ + moduleDirectory?: Array; + /** List of `require.paths` to use if nothing is found in `node_modules`. */ + paths?: Array; + /** Allows transforming parsed `package.json` contents. */ + packageFilter?: (pkg: PackageJson, file: string, dir: string) => PackageJson; + /** Allows transforms a path within a package. */ + pathFilter?: (pkg: PackageJson, path: string, relativePath: string) => string; + /** Current root directory. */ + rootDir?: string; +}; ``` :::tip -The `defaultResolver` passed as an option is the Jest default resolver which might be useful when you write your custom one. It takes the same arguments as your custom synchronous one, e.g. `(request, options)` and returns a string or throws. +The `defaultResolver` passed as an option is the Jest default resolver which might be useful when you write your custom one. It takes the same arguments as your custom synchronous one, e.g. `(path, options)` and returns a string or throws. ::: @@ -950,10 +961,7 @@ For example, if you want to respect Browserify's [`"browser"` field](https://git ```json { - ... - "jest": { - "resolver": "/resolver.js" - } + "resolver": "/resolver.js" } ``` @@ -965,19 +973,8 @@ module.exports = browserResolve.sync; By combining `defaultResolver` and `packageFilter` we can implement a `package.json` "pre-processor" that allows us to change how the default resolver will resolve modules. For example, imagine we want to use the field `"module"` if it is present, otherwise fallback to `"main"`: -```json -{ - ... - "jest": { - "resolver": "my-module-resolve" - } -} -``` - ```js -// my-module-resolve package - -module.exports = (request, options) => { +module.exports = (path, options) => { // Call the defaultResolver, so we leverage its cache, error handling, etc. return options.defaultResolver(request, { ...options, diff --git a/e2e/__tests__/__snapshots__/moduleNameMapper.test.ts.snap b/e2e/__tests__/__snapshots__/moduleNameMapper.test.ts.snap index 912914fe7348..b9c10e68936f 100644 --- a/e2e/__tests__/__snapshots__/moduleNameMapper.test.ts.snap +++ b/e2e/__tests__/__snapshots__/moduleNameMapper.test.ts.snap @@ -41,7 +41,7 @@ exports[`moduleNameMapper wrong array configuration 1`] = ` 12 | module.exports = () => 'test'; 13 | - at createNoMappedModuleFoundError (../../packages/jest-resolve/build/resolver.js:901:17) + at createNoMappedModuleFoundError (../../packages/jest-resolve/build/resolver.js:899:17) at Object.require (index.js:10:1)" `; @@ -70,6 +70,6 @@ exports[`moduleNameMapper wrong configuration 1`] = ` 12 | module.exports = () => 'test'; 13 | - at createNoMappedModuleFoundError (../../packages/jest-resolve/build/resolver.js:901:17) + at createNoMappedModuleFoundError (../../packages/jest-resolve/build/resolver.js:899:17) at Object.require (index.js:10:1)" `; diff --git a/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.ts.snap b/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.ts.snap index a457d7551b13..8ee95a4ed134 100644 --- a/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.ts.snap +++ b/e2e/__tests__/__snapshots__/resolveNoFileExtensions.test.ts.snap @@ -37,6 +37,6 @@ exports[`show error message with matching files 1`] = ` | ^ 9 | - at Resolver._throwModNotFoundError (../../packages/jest-resolve/build/resolver.js:493:11) + at Resolver._throwModNotFoundError (../../packages/jest-resolve/build/resolver.js:491:11) at Object.require (index.js:8:18)" `; diff --git a/packages/jest-resolve/__typetests__/resolver.test.ts b/packages/jest-resolve/__typetests__/resolver.test.ts new file mode 100644 index 000000000000..a9cfc7ab3603 --- /dev/null +++ b/packages/jest-resolve/__typetests__/resolver.test.ts @@ -0,0 +1,70 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + +import {expectAssignable, expectError, expectType} from 'tsd-lite'; +import type {AsyncResolver, JestResolver, SyncResolver} from 'jest-resolve'; + +type PackageJson = Record; +type PackageFilter = ( + pkg: PackageJson, + file: string, + dir: string, +) => PackageJson; +type PathFilter = ( + pkg: PackageJson, + path: string, + relativePath: string, +) => string; + +// AsyncResolver + +const asyncResolver: AsyncResolver = async (path, options) => { + expectType(path); + + expectType(options.basedir); + expectType | undefined>(options.conditions); + expectType(options.defaultResolver); + expectType | undefined>(options.extensions); + expectType | undefined>(options.moduleDirectory); + expectType(options.packageFilter); + expectType(options.pathFilter); + expectType | undefined>(options.paths); + expectType(options.rootDir); + + return path; +}; + +const notReturningAsyncResolver = async () => {}; +expectError(notReturningAsyncResolver()); + +// SyncResolver + +const syncResolver: SyncResolver = (path, options) => { + expectType(path); + + expectType(options.basedir); + expectType | undefined>(options.conditions); + expectType(options.defaultResolver); + expectType | undefined>(options.extensions); + expectType | undefined>(options.moduleDirectory); + expectType(options.packageFilter); + expectType(options.pathFilter); + expectType | undefined>(options.paths); + expectType(options.rootDir); + + return path; +}; + +const notReturningSyncResolver = () => {}; +expectError(notReturningSyncResolver()); + +// JestResolver + +expectAssignable({async: asyncResolver}); +expectAssignable({sync: syncResolver}); +expectAssignable({async: asyncResolver, sync: syncResolver}); +expectError({}); diff --git a/packages/jest-resolve/__typetests__/tsconfig.json b/packages/jest-resolve/__typetests__/tsconfig.json new file mode 100644 index 000000000000..165ba1343021 --- /dev/null +++ b/packages/jest-resolve/__typetests__/tsconfig.json @@ -0,0 +1,12 @@ +{ + "extends": "../../../tsconfig.json", + "compilerOptions": { + "composite": false, + "noUnusedLocals": false, + "noUnusedParameters": false, + "skipLibCheck": true, + + "types": [] + }, + "include": ["./**/*"] +} diff --git a/packages/jest-resolve/package.json b/packages/jest-resolve/package.json index 6d6120d83290..9bccf572115d 100644 --- a/packages/jest-resolve/package.json +++ b/packages/jest-resolve/package.json @@ -28,8 +28,10 @@ "slash": "^3.0.0" }, "devDependencies": { + "@tsd/typescript": "~4.6.2", "@types/graceful-fs": "^4.1.3", - "@types/resolve": "^1.20.0" + "@types/resolve": "^1.20.0", + "tsd-lite": "^0.5.1" }, "engines": { "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" diff --git a/packages/jest-resolve/src/__tests__/resolve.test.ts b/packages/jest-resolve/src/__tests__/resolve.test.ts index 0b4b22a0647c..3143c9c45e6c 100644 --- a/packages/jest-resolve/src/__tests__/resolve.test.ts +++ b/packages/jest-resolve/src/__tests__/resolve.test.ts @@ -108,7 +108,6 @@ describe('findNodeModule', () => { const newPath = Resolver.findNodeModule('test', { basedir: '/', - browser: true, conditions: ['conditions, woooo'], extensions: ['js'], moduleDirectory: ['node_modules'], @@ -120,7 +119,6 @@ describe('findNodeModule', () => { expect(userResolver.mock.calls[0][0]).toBe('test'); expect(userResolver.mock.calls[0][1]).toStrictEqual({ basedir: '/', - browser: true, conditions: ['conditions, woooo'], defaultResolver, extensions: ['js'], @@ -315,7 +313,6 @@ describe('findNodeModuleAsync', () => { const newPath = await Resolver.findNodeModuleAsync('test', { basedir: '/', - browser: true, conditions: ['conditions, woooo'], extensions: ['js'], moduleDirectory: ['node_modules'], @@ -327,7 +324,6 @@ describe('findNodeModuleAsync', () => { expect(userResolverAsync.async.mock.calls[0][0]).toBe('test'); expect(userResolverAsync.async.mock.calls[0][1]).toStrictEqual({ basedir: '/', - browser: true, conditions: ['conditions, woooo'], defaultResolver, extensions: ['js'], diff --git a/packages/jest-resolve/src/defaultResolver.ts b/packages/jest-resolve/src/defaultResolver.ts index b5a834b32b3a..de53b3ccd939 100644 --- a/packages/jest-resolve/src/defaultResolver.ts +++ b/packages/jest-resolve/src/defaultResolver.ts @@ -13,7 +13,7 @@ import { resolve as resolveExports, } from 'resolve.exports'; import { - PkgJson, + PackageJson, findClosestPackageJson, isDirectory, isFile, @@ -21,20 +21,36 @@ import { realpathSync, } from './fileWalkers'; -// copy from `resolve`'s types so we don't have their types in our definition -// files -interface ResolverOptions { +type ResolverOptions = { + /** Directory to begin resolving from. */ basedir: string; - browser?: boolean; + /** List of export conditions. */ conditions?: Array; + /** Instance of default resolver. */ defaultResolver: typeof defaultResolver; + /** List of file extensions to search in order. */ extensions?: Array; + /** + * List of directory names to be looked up for modules recursively. + * + * @defaultValue + * The default is `['node_modules']`. + */ moduleDirectory?: Array; + /** + * List of `require.paths` to use if nothing is found in `node_modules`. + * + * @defaultValue + * The default is `undefined`. + */ paths?: Array; + /** Allows transforming parsed `package.json` contents. */ + packageFilter?: (pkg: PackageJson, file: string, dir: string) => PackageJson; + /** Allows transforms a path within a package. */ + pathFilter?: (pkg: PackageJson, path: string, relativePath: string) => string; + /** Current root directory. */ rootDir?: string; - packageFilter?: (pkg: PkgJson, dir: string) => PkgJson; - pathFilter?: (pkg: PkgJson, path: string, relativePath: string) => string; -} +}; type UpstreamResolveOptionsWithConditions = UpstreamResolveOptions & Pick; @@ -63,6 +79,7 @@ const defaultResolver: SyncResolver = (path, options) => { return pnpResolver(path, options); } + // @ts-expect-error: TODO remove after merging https://github.com/DefinitelyTyped/DefinitelyTyped/pull/59990 const resolveOptions: UpstreamResolveOptionsWithConditions = { ...options, isDirectory, @@ -91,7 +108,7 @@ export default defaultResolver; * helper functions */ -function readPackageSync(_: unknown, file: string): PkgJson { +function readPackageSync(_: unknown, file: string): PackageJson { return readPackageCached(file); } diff --git a/packages/jest-resolve/src/fileWalkers.ts b/packages/jest-resolve/src/fileWalkers.ts index 88c2110e9f72..1e57f6fc8251 100644 --- a/packages/jest-resolve/src/fileWalkers.ts +++ b/packages/jest-resolve/src/fileWalkers.ts @@ -71,17 +71,17 @@ function realpathCached(path: string): string { return result; } -export type PkgJson = Record; +export type PackageJson = Record; -const packageContents = new Map(); -export function readPackageCached(path: string): PkgJson { +const packageContents = new Map(); +export function readPackageCached(path: string): PackageJson { let result = packageContents.get(path); if (result != null) { return result; } - result = JSON.parse(fs.readFileSync(path, 'utf8')) as PkgJson; + result = JSON.parse(fs.readFileSync(path, 'utf8')) as PackageJson; packageContents.set(path, result); diff --git a/packages/jest-resolve/src/index.ts b/packages/jest-resolve/src/index.ts index 34600936314f..af1c1f2cb9ff 100644 --- a/packages/jest-resolve/src/index.ts +++ b/packages/jest-resolve/src/index.ts @@ -7,7 +7,12 @@ import Resolver from './resolver'; -export type {ResolveModuleConfig} from './resolver'; +export type {AsyncResolver, SyncResolver} from './defaultResolver'; +export type { + FindNodeModuleConfig, + ResolveModuleConfig, + ResolverObject as JestResolver, +} from './resolver'; export * from './utils'; export default Resolver; diff --git a/packages/jest-resolve/src/resolver.ts b/packages/jest-resolve/src/resolver.ts index 1ac833d5bf55..4c9f1a93cae3 100644 --- a/packages/jest-resolve/src/resolver.ts +++ b/packages/jest-resolve/src/resolver.ts @@ -24,9 +24,8 @@ import nodeModulesPaths from './nodeModulesPaths'; import shouldLoadAsEsm, {clearCachedLookups} from './shouldLoadAsEsm'; import type {ResolverConfig} from './types'; -type FindNodeModuleConfig = { +export type FindNodeModuleConfig = { basedir: string; - browser?: boolean; conditions?: Array; extensions?: Array; moduleDirectory?: Array; @@ -124,7 +123,6 @@ export default class Resolver { try { return resolver(path, { basedir: options.basedir, - browser: options.browser, conditions: options.conditions, defaultResolver, extensions: options.extensions, @@ -167,7 +165,6 @@ export default class Resolver { try { const result = await resolver(path, { basedir: options.basedir, - browser: options.browser, conditions: options.conditions, defaultResolver, extensions: options.extensions, @@ -860,7 +857,7 @@ Please check your configuration for these entries: type ResolverSyncObject = {sync: SyncResolver; async?: AsyncResolver}; type ResolverAsyncObject = {sync?: SyncResolver; async: AsyncResolver}; -type ResolverObject = ResolverSyncObject | ResolverAsyncObject; +export type ResolverObject = ResolverSyncObject | ResolverAsyncObject; function loadResolver( resolver: string | undefined | null, diff --git a/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts b/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts index c6055b1d740e..dfcc3a5a69c5 100644 --- a/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts +++ b/packages/jest-validate/src/__tests__/fixtures/jestConfig.ts @@ -22,7 +22,6 @@ const NODE_MODULES_REGEXP = replacePathSepForRegex(NODE_MODULES); const defaultConfig = { automock: false, bail: 0, - browser: false, cacheDirectory: path.join(tmpdir(), 'jest'), clearMocks: false, coveragePathIgnorePatterns: [NODE_MODULES_REGEXP], @@ -59,7 +58,6 @@ const defaultConfig = { const validConfig = { automock: false, bail: 0, - browser: false, cache: true, cacheDirectory: '/tmp/user/jest', clearMocks: false, diff --git a/yarn.lock b/yarn.lock index 9f87e26b3026..7871974f8337 100644 --- a/yarn.lock +++ b/yarn.lock @@ -13444,6 +13444,7 @@ __metadata: version: 0.0.0-use.local resolution: "jest-resolve@workspace:packages/jest-resolve" dependencies: + "@tsd/typescript": ~4.6.2 "@types/graceful-fs": ^4.1.3 "@types/resolve": ^1.20.0 chalk: ^4.0.0 @@ -13455,6 +13456,7 @@ __metadata: resolve: ^1.20.0 resolve.exports: ^1.1.0 slash: ^3.0.0 + tsd-lite: ^0.5.1 languageName: unknown linkType: soft From 625e0bc79a7e3f900de57316d401c6dc666c3642 Mon Sep 17 00:00:00 2001 From: Kat Lim Ruiz <93484005+katlim-br@users.noreply.github.com> Date: Thu, 21 Apr 2022 08:43:16 -0500 Subject: [PATCH 090/128] show that setupFilesAfterEnv scripts can define beforeAll (#12702) --- docs/Configuration.md | 14 ++++++++++++++ .../version-27.0/Configuration.md | 14 ++++++++++++++ .../version-27.1/Configuration.md | 14 ++++++++++++++ .../version-27.2/Configuration.md | 14 ++++++++++++++ .../version-27.4/Configuration.md | 14 ++++++++++++++ .../version-27.5/Configuration.md | 17 +++++++++++++++++ 6 files changed, 87 insertions(+) diff --git a/docs/Configuration.md b/docs/Configuration.md index 8901f21b76c8..1855b0009b68 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -1117,6 +1117,20 @@ Example `jest.setup.js` file ```js jest.setTimeout(10000); // in milliseconds + +// you can even use the setup/teardown methods +beforeAll(() => { + // your code +}); +beforeEach(() => { + // your code +}); +afterEach(() => { + // your code +}); +afterAll(() => { + // your code +}); ``` ### `slowTestThreshold` \[number] diff --git a/website/versioned_docs/version-27.0/Configuration.md b/website/versioned_docs/version-27.0/Configuration.md index ab8d4eda9693..3e3c5128dcda 100644 --- a/website/versioned_docs/version-27.0/Configuration.md +++ b/website/versioned_docs/version-27.0/Configuration.md @@ -926,6 +926,20 @@ Example `jest.setup.js` file ```js jest.setTimeout(10000); // in milliseconds + +// you can even use the setup/teardown methods +beforeAll(() => { + // your code +}); +beforeEach(() => { + // your code +}); +afterEach(() => { + // your code +}); +afterAll(() => { + // your code +}); ``` ### `slowTestThreshold` \[number] diff --git a/website/versioned_docs/version-27.1/Configuration.md b/website/versioned_docs/version-27.1/Configuration.md index 59e1816d519c..3031336442e2 100644 --- a/website/versioned_docs/version-27.1/Configuration.md +++ b/website/versioned_docs/version-27.1/Configuration.md @@ -926,6 +926,20 @@ Example `jest.setup.js` file ```js jest.setTimeout(10000); // in milliseconds + +// you can even use the setup/teardown methods +beforeAll(() => { + // your code +}); +beforeEach(() => { + // your code +}); +afterEach(() => { + // your code +}); +afterAll(() => { + // your code +}); ``` ### `slowTestThreshold` \[number] diff --git a/website/versioned_docs/version-27.2/Configuration.md b/website/versioned_docs/version-27.2/Configuration.md index 82773cfbeaf6..38d56aea604c 100644 --- a/website/versioned_docs/version-27.2/Configuration.md +++ b/website/versioned_docs/version-27.2/Configuration.md @@ -930,6 +930,20 @@ Example `jest.setup.js` file ```js jest.setTimeout(10000); // in milliseconds + +// you can even use the setup/teardown methods +beforeAll(() => { + // your code +}); +beforeEach(() => { + // your code +}); +afterEach(() => { + // your code +}); +afterAll(() => { + // your code +}); ``` ### `slowTestThreshold` \[number] diff --git a/website/versioned_docs/version-27.4/Configuration.md b/website/versioned_docs/version-27.4/Configuration.md index 4f86bbd3f342..20aa3554eae0 100644 --- a/website/versioned_docs/version-27.4/Configuration.md +++ b/website/versioned_docs/version-27.4/Configuration.md @@ -930,6 +930,20 @@ Example `jest.setup.js` file ```js jest.setTimeout(10000); // in milliseconds + +// you can even use the setup/teardown methods +beforeAll(() => { + // your code +}); +beforeEach(() => { + // your code +}); +afterEach(() => { + // your code +}); +afterAll(() => { + // your code +}); ``` ### `slowTestThreshold` \[number] diff --git a/website/versioned_docs/version-27.5/Configuration.md b/website/versioned_docs/version-27.5/Configuration.md index 4f86bbd3f342..87d27057f420 100644 --- a/website/versioned_docs/version-27.5/Configuration.md +++ b/website/versioned_docs/version-27.5/Configuration.md @@ -930,6 +930,23 @@ Example `jest.setup.js` file ```js jest.setTimeout(10000); // in milliseconds + +// you can even use the setup/teardown methods +beforeAll(() => { + // your code +}); + +beforeEach(() => { + // your code +}); + +afterEach(() => { + // your code +}); + +afterAll(() => { + // your code +}); ``` ### `slowTestThreshold` \[number] From a293b75310cfc209713df1d34d243eb258995316 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Thu, 21 Apr 2022 16:44:58 +0300 Subject: [PATCH 091/128] refactor(jest-transform): rename TransformerConfig (#12708) --- docs/CodeTransformation.md | 45 ++++++++++++++-------------- packages/jest-transform/src/types.ts | 43 +++++++++++++------------- 2 files changed, 45 insertions(+), 43 deletions(-) diff --git a/docs/CodeTransformation.md b/docs/CodeTransformation.md index b94873c7eb0f..b7ceb9aaeb7a 100644 --- a/docs/CodeTransformation.md +++ b/docs/CodeTransformation.md @@ -33,19 +33,20 @@ Remember to include the default `babel-jest` transformer explicitly, if you wish You can write your own transformer. The API of a transformer is as follows: ```ts -interface TransformOptions { +interface TransformOptions { supportsDynamicImport: boolean; supportsExportNamespaceFrom: boolean; supportsStaticESM: boolean; supportsTopLevelAwait: boolean; instrument: boolean; - /** a cached file system which is used in jest-runtime - useful to improve performance */ + /** Cached file system which is used by `jest-runtime` to improve performance. */ cacheFS: Map; - config: Config.ProjectConfig; - /** A stringified version of the configuration - useful in cache busting */ + /** Jest configuration of currently running project. */ + config: ProjectConfig; + /** Stringified version of the `config` - useful in cache busting. */ configString: string; - /** the options passed through Jest's config by the user */ - transformerConfig: OptionType; + /** Transformer configuration passed through `transform` option by the user. */ + transformerConfig: TransformerConfig; } type TransformedSource = { @@ -53,70 +54,70 @@ type TransformedSource = { map?: RawSourceMap | string | null; }; -interface SyncTransformer { +interface SyncTransformer { canInstrument?: boolean; getCacheKey?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => string; getCacheKeyAsync?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => Promise; process: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => TransformedSource; processAsync?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => Promise; } -interface AsyncTransformer { +interface AsyncTransformer { canInstrument?: boolean; getCacheKey?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => string; getCacheKeyAsync?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => Promise; process?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => TransformedSource; processAsync: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => Promise; } -type Transformer = - | SyncTransformer - | AsyncTransformer; +type Transformer = + | SyncTransformer + | AsyncTransformer; type TransformerCreator< - X extends Transformer, - OptionType = unknown, -> = (options?: OptionType) => X; + X extends Transformer, + TransformerConfig = unknown, +> = (transformerConfig?: TransformerConfig) => X; type TransformerFactory = { createTransformer: TransformerCreator; diff --git a/packages/jest-transform/src/types.ts b/packages/jest-transform/src/types.ts index 27308b5403f8..a86d56e973d1 100644 --- a/packages/jest-transform/src/types.ts +++ b/packages/jest-transform/src/types.ts @@ -57,18 +57,19 @@ export interface RequireAndTranspileModuleOptions export type StringMap = Map; -export interface TransformOptions +export interface TransformOptions extends ReducedTransformOptions { - /** a cached file system which is used in jest-runtime - useful to improve performance */ + /** Cached file system which is used by `jest-runtime` to improve performance. */ cacheFS: StringMap; + /** Jest configuration of currently running project. */ config: Config.ProjectConfig; - /** A stringified version of the configuration - useful in cache busting */ + /** Stringified version of the `config` - useful in cache busting. */ configString: string; - /** the options passed through Jest's config by the user */ - transformerConfig: OptionType; + /** Transformer configuration passed through `transform` option by the user. */ + transformerConfig: TransformerConfig; } -export interface SyncTransformer { +export interface SyncTransformer { /** * Indicates if the transformer is capable of instrumenting the code for code coverage. * @@ -80,29 +81,29 @@ export interface SyncTransformer { getCacheKey?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => string; getCacheKeyAsync?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => Promise; process: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => TransformedSource; processAsync?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => Promise; } -export interface AsyncTransformer { +export interface AsyncTransformer { /** * Indicates if the transformer is capable of instrumenting the code for code coverage. * @@ -114,25 +115,25 @@ export interface AsyncTransformer { getCacheKey?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => string; getCacheKeyAsync?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => Promise; process?: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => TransformedSource; processAsync: ( sourceText: string, sourcePath: string, - options: TransformOptions, + options: TransformOptions, ) => Promise; } @@ -144,14 +145,14 @@ export interface AsyncTransformer { * * For more info on the sync vs async model, see https://jestjs.io/docs/code-transformation#writing-custom-transformers */ -export type Transformer = - | SyncTransformer - | AsyncTransformer; +export type Transformer = + | SyncTransformer + | AsyncTransformer; export type TransformerCreator< - X extends Transformer, - OptionType = unknown, -> = (options?: OptionType) => X; + X extends Transformer, + TransformerConfig = unknown, +> = (transformerConfig?: TransformerConfig) => X; /** * Instead of having your custom transformer implement the Transformer interface From 3c6f14bc51a857bb0baf8e6ff7af43aaf47951e9 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Fri, 22 Apr 2022 11:19:35 +0300 Subject: [PATCH 092/128] feat(jest-resolve): expose `PackageFilter`, `PathFilter` and `PackageJSON` types (#12712) --- CHANGELOG.md | 2 +- docs/Configuration.md | 6 +-- .../__typetests__/resolver.test.ts | 48 ++++++++++++++----- packages/jest-resolve/package.json | 2 +- packages/jest-resolve/src/defaultResolver.ts | 39 +++++++++++++-- packages/jest-resolve/src/fileWalkers.ts | 9 ++-- packages/jest-resolve/src/index.ts | 8 +++- packages/jest-resolve/src/types.ts | 8 ++++ yarn.lock | 10 ++-- 9 files changed, 97 insertions(+), 35 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6d6ffb16d57e..913b7572a4d3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -46,7 +46,7 @@ - `[jest-resolve, jest-runtime]` Add support for `data:` URI import and mock ([#12392](https://github.com/facebook/jest/pull/12392)) - `[jest-resolve, jest-runtime]` Add support for async resolver ([#11540](https://github.com/facebook/jest/pull/11540)) - `[jest-resolve]` [**BREAKING**] Remove `browser?: boolean` from resolver options, `conditions: ['browser']` should be used instead ([#12707](https://github.com/facebook/jest/pull/12707)) -- `[jest-resolve]` Expose `JestResolver`, `AsyncResolver` and `SyncResolver` types ([#12707](https://github.com/facebook/jest/pull/12707)) +- `[jest-resolve]` Expose `JestResolver`, `AsyncResolver`, `SyncResolver`, `PackageFilter`, `PathFilter` and `PackageJSON` types ([#12707](https://github.com/facebook/jest/pull/12707), ([#12712](https://github.com/facebook/jest/pull/12712)) - `[jest-runner]` Allow `setupFiles` module to export an async function ([#12042](https://github.com/facebook/jest/pull/12042)) - `[jest-runner]` Allow passing `testEnvironmentOptions` via docblocks ([#12470](https://github.com/facebook/jest/pull/12470)) - `[jest-runner]` Exposing `CallbackTestRunner`, `EmittingTestRunner` abstract classes to help typing third party runners ([#12646](https://github.com/facebook/jest/pull/12646)) diff --git a/docs/Configuration.md b/docs/Configuration.md index 1855b0009b68..a8b148154fb1 100644 --- a/docs/Configuration.md +++ b/docs/Configuration.md @@ -927,8 +927,6 @@ This option allows the use of a custom resolver. This resolver must be a module The options object provided to resolvers has the shape: ```ts -type PackageJson = Record; - type ResolverOptions = { /** Directory to begin resolving from. */ basedir: string; @@ -943,9 +941,9 @@ type ResolverOptions = { /** List of `require.paths` to use if nothing is found in `node_modules`. */ paths?: Array; /** Allows transforming parsed `package.json` contents. */ - packageFilter?: (pkg: PackageJson, file: string, dir: string) => PackageJson; + packageFilter?: (pkg: PackageJSON, file: string, dir: string) => PackageJSON; /** Allows transforms a path within a package. */ - pathFilter?: (pkg: PackageJson, path: string, relativePath: string) => string; + pathFilter?: (pkg: PackageJSON, path: string, relativePath: string) => string; /** Current root directory. */ rootDir?: string; }; diff --git a/packages/jest-resolve/__typetests__/resolver.test.ts b/packages/jest-resolve/__typetests__/resolver.test.ts index a9cfc7ab3603..b3ee2403e5f3 100644 --- a/packages/jest-resolve/__typetests__/resolver.test.ts +++ b/packages/jest-resolve/__typetests__/resolver.test.ts @@ -6,19 +6,41 @@ */ import {expectAssignable, expectError, expectType} from 'tsd-lite'; -import type {AsyncResolver, JestResolver, SyncResolver} from 'jest-resolve'; - -type PackageJson = Record; -type PackageFilter = ( - pkg: PackageJson, - file: string, - dir: string, -) => PackageJson; -type PathFilter = ( - pkg: PackageJson, - path: string, - relativePath: string, -) => string; +import type { + AsyncResolver, + JestResolver, + PackageFilter, + PackageJSON, + PathFilter, + SyncResolver, +} from 'jest-resolve'; + +// PackageJSON + +expectAssignable({ + caption: 'test', + count: 100, + isTest: true, + location: {name: 'test', start: [1, 2], valid: false, x: 10, y: 20}, + values: [0, 10, 20, {x: 1, y: 2}, true, 'test', ['a', 'b']], +}); + +expectError({ + filter: () => {}, +}); + +// PackageFilter + +const packageFilter = (pkg: PackageJSON, file: string, dir: string) => pkg; + +expectAssignable(packageFilter); + +// PathFilter + +const pathFilter = (pkg: PackageJSON, path: string, relativePath: string) => + relativePath; + +expectAssignable(pathFilter); // AsyncResolver diff --git a/packages/jest-resolve/package.json b/packages/jest-resolve/package.json index 9bccf572115d..c723ff659542 100644 --- a/packages/jest-resolve/package.json +++ b/packages/jest-resolve/package.json @@ -30,7 +30,7 @@ "devDependencies": { "@tsd/typescript": "~4.6.2", "@types/graceful-fs": "^4.1.3", - "@types/resolve": "^1.20.0", + "@types/resolve": "^1.20.2", "tsd-lite": "^0.5.1" }, "engines": { diff --git a/packages/jest-resolve/src/defaultResolver.ts b/packages/jest-resolve/src/defaultResolver.ts index de53b3ccd939..16694ad990ed 100644 --- a/packages/jest-resolve/src/defaultResolver.ts +++ b/packages/jest-resolve/src/defaultResolver.ts @@ -13,13 +13,43 @@ import { resolve as resolveExports, } from 'resolve.exports'; import { - PackageJson, findClosestPackageJson, isDirectory, isFile, readPackageCached, realpathSync, } from './fileWalkers'; +import type {PackageJSON} from './types'; + +/** + * Allows transforming parsed `package.json` contents. + * + * @param pkg - Parsed `package.json` contents. + * @param file - Path to `package.json` file. + * @param dir - Directory that contains the `package.json`. + * + * @returns Transformed `package.json` contents. + */ +export type PackageFilter = ( + pkg: PackageJSON, + file: string, + dir: string, +) => PackageJSON; + +/** + * Allows transforms a path within a package. + * + * @param pkg - Parsed `package.json` contents. + * @param path - Path being resolved. + * @param relativePath - Path relative from the `package.json` location. + * + * @returns Relative path that will be joined from the `package.json` location. + */ +export type PathFilter = ( + pkg: PackageJSON, + path: string, + relativePath: string, +) => string; type ResolverOptions = { /** Directory to begin resolving from. */ @@ -45,9 +75,9 @@ type ResolverOptions = { */ paths?: Array; /** Allows transforming parsed `package.json` contents. */ - packageFilter?: (pkg: PackageJson, file: string, dir: string) => PackageJson; + packageFilter?: PackageFilter; /** Allows transforms a path within a package. */ - pathFilter?: (pkg: PackageJson, path: string, relativePath: string) => string; + pathFilter?: PathFilter; /** Current root directory. */ rootDir?: string; }; @@ -79,7 +109,6 @@ const defaultResolver: SyncResolver = (path, options) => { return pnpResolver(path, options); } - // @ts-expect-error: TODO remove after merging https://github.com/DefinitelyTyped/DefinitelyTyped/pull/59990 const resolveOptions: UpstreamResolveOptionsWithConditions = { ...options, isDirectory, @@ -108,7 +137,7 @@ export default defaultResolver; * helper functions */ -function readPackageSync(_: unknown, file: string): PackageJson { +function readPackageSync(_: unknown, file: string): PackageJSON { return readPackageCached(file); } diff --git a/packages/jest-resolve/src/fileWalkers.ts b/packages/jest-resolve/src/fileWalkers.ts index 1e57f6fc8251..f19e6b4701ae 100644 --- a/packages/jest-resolve/src/fileWalkers.ts +++ b/packages/jest-resolve/src/fileWalkers.ts @@ -8,6 +8,7 @@ import {dirname, resolve} from 'path'; import * as fs from 'graceful-fs'; import {tryRealpath} from 'jest-util'; +import type {PackageJSON} from './types'; export function clearFsCache(): void { checkedPaths.clear(); @@ -71,17 +72,15 @@ function realpathCached(path: string): string { return result; } -export type PackageJson = Record; - -const packageContents = new Map(); -export function readPackageCached(path: string): PackageJson { +const packageContents = new Map(); +export function readPackageCached(path: string): PackageJSON { let result = packageContents.get(path); if (result != null) { return result; } - result = JSON.parse(fs.readFileSync(path, 'utf8')) as PackageJson; + result = JSON.parse(fs.readFileSync(path, 'utf8')) as PackageJSON; packageContents.set(path, result); diff --git a/packages/jest-resolve/src/index.ts b/packages/jest-resolve/src/index.ts index af1c1f2cb9ff..e32263a3a488 100644 --- a/packages/jest-resolve/src/index.ts +++ b/packages/jest-resolve/src/index.ts @@ -7,12 +7,18 @@ import Resolver from './resolver'; -export type {AsyncResolver, SyncResolver} from './defaultResolver'; +export type { + AsyncResolver, + SyncResolver, + PackageFilter, + PathFilter, +} from './defaultResolver'; export type { FindNodeModuleConfig, ResolveModuleConfig, ResolverObject as JestResolver, } from './resolver'; +export type {PackageJSON} from './types'; export * from './utils'; export default Resolver; diff --git a/packages/jest-resolve/src/types.ts b/packages/jest-resolve/src/types.ts index 8469e2b9dc3d..b7279945463f 100644 --- a/packages/jest-resolve/src/types.ts +++ b/packages/jest-resolve/src/types.ts @@ -21,3 +21,11 @@ type ModuleNameMapperConfig = { regex: RegExp; moduleName: string | Array; }; + +// https://github.com/Microsoft/TypeScript/issues/3496#issuecomment-128553540 +type JSONValue = string | number | boolean | JSONObject | Array; +interface JSONObject { + [key: string]: JSONValue; +} + +export type PackageJSON = JSONObject; diff --git a/yarn.lock b/yarn.lock index 7871974f8337..fd4bcf67edee 100644 --- a/yarn.lock +++ b/yarn.lock @@ -5373,10 +5373,10 @@ __metadata: languageName: node linkType: hard -"@types/resolve@npm:^1.20.0": - version: 1.20.1 - resolution: "@types/resolve@npm:1.20.1" - checksum: d035d5aaadbd455027fa9457a4a263563d49647f088876aebd2b0388d4c35400b85c0382fdc2ec5253c35442abfc2d25431c989345b97fefe26a367811214343 +"@types/resolve@npm:^1.20.2": + version: 1.20.2 + resolution: "@types/resolve@npm:1.20.2" + checksum: 61c2cad2499ffc8eab36e3b773945d337d848d3ac6b7b0a87c805ba814bc838ef2f262fc0f109bfd8d2e0898ff8bd80ad1025f9ff64f1f71d3d4294c9f14e5f6 languageName: node linkType: hard @@ -13446,7 +13446,7 @@ __metadata: dependencies: "@tsd/typescript": ~4.6.2 "@types/graceful-fs": ^4.1.3 - "@types/resolve": ^1.20.0 + "@types/resolve": ^1.20.2 chalk: ^4.0.0 graceful-fs: ^4.2.9 jest-haste-map: ^28.0.0-alpha.11 From e72c52f2498e89f4ca60d045e5c2c0675cd02e9b Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Sat, 23 Apr 2022 11:19:23 +0300 Subject: [PATCH 093/128] feat(jest-runner): export `TestRunner` interface types and reexport types from other packages (#12715) --- CHANGELOG.md | 2 +- .../__typetests__/jest-runner.test.ts | 66 ++++++++++++++++++- packages/jest-runner/src/index.ts | 5 ++ packages/jest-runner/src/types.ts | 40 ++++++++++- 4 files changed, 107 insertions(+), 6 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 913b7572a4d3..d5b4d2c280c8 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -49,7 +49,7 @@ - `[jest-resolve]` Expose `JestResolver`, `AsyncResolver`, `SyncResolver`, `PackageFilter`, `PathFilter` and `PackageJSON` types ([#12707](https://github.com/facebook/jest/pull/12707), ([#12712](https://github.com/facebook/jest/pull/12712)) - `[jest-runner]` Allow `setupFiles` module to export an async function ([#12042](https://github.com/facebook/jest/pull/12042)) - `[jest-runner]` Allow passing `testEnvironmentOptions` via docblocks ([#12470](https://github.com/facebook/jest/pull/12470)) -- `[jest-runner]` Exposing `CallbackTestRunner`, `EmittingTestRunner` abstract classes to help typing third party runners ([#12646](https://github.com/facebook/jest/pull/12646)) +- `[jest-runner]` Expose `CallbackTestRunner`, `EmittingTestRunner` abstract classes and `CallbackTestRunnerInterface`, `EmittingTestRunnerInterface` to help typing third party runners ([#12646](https://github.com/facebook/jest/pull/12646), [#12715](https://github.com/facebook/jest/pull/12715)) - `[jest-runtime]` [**BREAKING**] `Runtime.createHasteMap` now returns a promise ([#12008](https://github.com/facebook/jest/pull/12008)) - `[jest-runtime]` Calling `jest.resetModules` function will clear FS and transform cache ([#12531](https://github.com/facebook/jest/pull/12531)) - `[jest-runtime]` [**BREAKING**] Remove `Context` type export, it must be imported from `@jest/test-result` ([#12685](https://github.com/facebook/jest/pull/12685)) diff --git a/packages/jest-runner/__typetests__/jest-runner.test.ts b/packages/jest-runner/__typetests__/jest-runner.test.ts index 04c00ab32d06..97ad722655ab 100644 --- a/packages/jest-runner/__typetests__/jest-runner.test.ts +++ b/packages/jest-runner/__typetests__/jest-runner.test.ts @@ -6,18 +6,21 @@ */ import {expectType} from 'tsd-lite'; -import type {Test, TestEvents} from '@jest/test-result'; -import type {Config} from '@jest/types'; import {CallbackTestRunner, EmittingTestRunner} from 'jest-runner'; import type { + CallbackTestRunnerInterface, + Config, + EmittingTestRunnerInterface, OnTestFailure, OnTestStart, OnTestSuccess, + Test, + TestEvents, TestRunnerContext, TestRunnerOptions, + TestWatcher, UnsubscribeFn, } from 'jest-runner'; -import type {TestWatcher} from 'jest-watcher'; const globalConfig = {} as Config.GlobalConfig; const runnerContext = {} as TestRunnerContext; @@ -45,6 +48,32 @@ const callbackRunner = new CallbackRunner(globalConfig, runnerContext); expectType(callbackRunner.isSerial); expectType(callbackRunner.supportsEventEmitters); +// CallbackTestRunnerInterface + +class CustomCallbackRunner implements CallbackTestRunnerInterface { + readonly #maxConcurrency: number; + readonly #globalConfig: Config.GlobalConfig; + + constructor(globalConfig: Config.GlobalConfig) { + this.#globalConfig = globalConfig; + this.#maxConcurrency = globalConfig.maxWorkers; + } + + async runTests( + tests: Array, + watcher: TestWatcher, + onStart: OnTestStart, + onResult: OnTestSuccess, + onFailure: OnTestFailure, + options: TestRunnerOptions, + ): Promise { + expectType(this.#globalConfig); + expectType(this.#maxConcurrency); + + return; + } +} + // EmittingRunner class EmittingRunner extends EmittingTestRunner { @@ -71,3 +100,34 @@ const emittingRunner = new EmittingRunner(globalConfig, runnerContext); expectType(emittingRunner.isSerial); expectType(emittingRunner.supportsEventEmitters); + +// EmittingTestRunnerInterface + +class CustomEmittingRunner implements EmittingTestRunnerInterface { + readonly #maxConcurrency: number; + readonly #globalConfig: Config.GlobalConfig; + readonly supportsEventEmitters = true; + + constructor(globalConfig: Config.GlobalConfig) { + this.#globalConfig = globalConfig; + this.#maxConcurrency = globalConfig.maxWorkers; + } + + async runTests( + tests: Array, + watcher: TestWatcher, + options: TestRunnerOptions, + ): Promise { + expectType(this.#globalConfig); + expectType(this.#maxConcurrency); + + return; + } + + on( + eventName: string, + listener: (eventData: TestEvents[Name]) => void | Promise, + ): UnsubscribeFn { + return () => {}; + } +} diff --git a/packages/jest-runner/src/index.ts b/packages/jest-runner/src/index.ts index 627b446798f2..4f1bb6bf074e 100644 --- a/packages/jest-runner/src/index.ts +++ b/packages/jest-runner/src/index.ts @@ -27,8 +27,13 @@ interface WorkerInterface extends Worker { worker: typeof worker; } +export type {Test, TestEvents} from '@jest/test-result'; +export type {Config} from '@jest/types'; +export type {TestWatcher} from 'jest-watcher'; export {CallbackTestRunner, EmittingTestRunner} from './types'; export type { + CallbackTestRunnerInterface, + EmittingTestRunnerInterface, OnTestFailure, OnTestStart, OnTestSuccess, diff --git a/packages/jest-runner/src/types.ts b/packages/jest-runner/src/types.ts index 4a80e06e8a1b..18a0ffe4e139 100644 --- a/packages/jest-runner/src/types.ts +++ b/packages/jest-runner/src/types.ts @@ -57,6 +57,36 @@ export type TestRunnerSerializedContext = { export type UnsubscribeFn = () => void; +export interface CallbackTestRunnerInterface { + readonly isSerial?: boolean; + readonly supportsEventEmitters?: boolean; + + runTests( + tests: Array, + watcher: TestWatcher, + onStart: OnTestStart, + onResult: OnTestSuccess, + onFailure: OnTestFailure, + options: TestRunnerOptions, + ): Promise; +} + +export interface EmittingTestRunnerInterface { + readonly isSerial?: boolean; + readonly supportsEventEmitters: true; + + runTests( + tests: Array, + watcher: TestWatcher, + options: TestRunnerOptions, + ): Promise; + + on( + eventName: Name, + listener: (eventData: TestEvents[Name]) => void | Promise, + ): UnsubscribeFn; +} + abstract class BaseTestRunner { readonly isSerial?: boolean; abstract readonly supportsEventEmitters: boolean; @@ -67,7 +97,10 @@ abstract class BaseTestRunner { ) {} } -export abstract class CallbackTestRunner extends BaseTestRunner { +export abstract class CallbackTestRunner + extends BaseTestRunner + implements CallbackTestRunnerInterface +{ readonly supportsEventEmitters = false; abstract runTests( @@ -80,7 +113,10 @@ export abstract class CallbackTestRunner extends BaseTestRunner { ): Promise; } -export abstract class EmittingTestRunner extends BaseTestRunner { +export abstract class EmittingTestRunner + extends BaseTestRunner + implements EmittingTestRunnerInterface +{ readonly supportsEventEmitters = true; abstract runTests( From 49ee1587faa43d6e5348cd90c80240a09c05db08 Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Sat, 23 Apr 2022 16:21:26 +0800 Subject: [PATCH 094/128] update dependency @microsoft/api-extractor to 7.23.0 (#12716) --- package.json | 2 +- yarn.lock | 104 +++++++++++++++++++++------------------------------ 2 files changed, 43 insertions(+), 63 deletions(-) diff --git a/package.json b/package.json index ff0747191f4b..af4d8269e3d9 100644 --- a/package.json +++ b/package.json @@ -12,7 +12,7 @@ "@crowdin/cli": "^3.5.2", "@jest/globals": "workspace:*", "@jest/test-utils": "workspace:*", - "@microsoft/api-extractor": "^7.19.4", + "@microsoft/api-extractor": "^7.23.0", "@tsconfig/node12": "^1.0.9", "@tsd/typescript": "~4.6.2", "@types/babel__core": "^7.1.14", diff --git a/yarn.lock b/yarn.lock index fd4bcf67edee..9dcb5bc0a72d 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2674,7 +2674,7 @@ __metadata: "@crowdin/cli": ^3.5.2 "@jest/globals": "workspace:*" "@jest/test-utils": "workspace:*" - "@microsoft/api-extractor": ^7.19.4 + "@microsoft/api-extractor": ^7.23.0 "@tsconfig/node12": ^1.0.9 "@tsd/typescript": ~4.6.2 "@types/babel__core": ^7.1.14 @@ -3799,55 +3799,55 @@ __metadata: languageName: node linkType: hard -"@microsoft/api-extractor-model@npm:7.16.0": - version: 7.16.0 - resolution: "@microsoft/api-extractor-model@npm:7.16.0" +"@microsoft/api-extractor-model@npm:7.17.2": + version: 7.17.2 + resolution: "@microsoft/api-extractor-model@npm:7.17.2" dependencies: - "@microsoft/tsdoc": 0.13.2 - "@microsoft/tsdoc-config": ~0.15.2 - "@rushstack/node-core-library": 3.45.1 - checksum: ba1bf057f5eed213aea45887a93c0cdabd0d7c9da2644aeb7460748fa33a01f04b91507923e7ea511452a7dfb849498089a2c3a844986ffc4c2abf8ab6d831a6 + "@microsoft/tsdoc": 0.14.1 + "@microsoft/tsdoc-config": ~0.16.1 + "@rushstack/node-core-library": 3.45.4 + checksum: 94c1c63674d85bf69cff9abbf94a1b2d2f5b6e3b651b8483d8949e39424cb29df156b589a297ca19f85ad1ff6380389e58a03198e7fe1ec34b59d5cae2166de7 languageName: node linkType: hard -"@microsoft/api-extractor@npm:^7.19.4": - version: 7.20.1 - resolution: "@microsoft/api-extractor@npm:7.20.1" +"@microsoft/api-extractor@npm:^7.23.0": + version: 7.23.0 + resolution: "@microsoft/api-extractor@npm:7.23.0" dependencies: - "@microsoft/api-extractor-model": 7.16.0 - "@microsoft/tsdoc": 0.13.2 - "@microsoft/tsdoc-config": ~0.15.2 - "@rushstack/node-core-library": 3.45.1 - "@rushstack/rig-package": 0.3.8 - "@rushstack/ts-command-line": 4.10.7 + "@microsoft/api-extractor-model": 7.17.2 + "@microsoft/tsdoc": 0.14.1 + "@microsoft/tsdoc-config": ~0.16.1 + "@rushstack/node-core-library": 3.45.4 + "@rushstack/rig-package": 0.3.11 + "@rushstack/ts-command-line": 4.10.10 colors: ~1.2.1 lodash: ~4.17.15 resolve: ~1.17.0 semver: ~7.3.0 source-map: ~0.6.1 - typescript: ~4.5.2 + typescript: ~4.6.3 bin: api-extractor: bin/api-extractor - checksum: c9fb01e3803b35f8ca2471fe67015bb74d4a997f4409737f5b3fc52ea633d8379689e4685f6502d81245649e5531cadd9bb37c50cc71068488ff0e67dea4af67 + checksum: 61d3609d7aa76bece292551eb9c7a1c04c2fa304962c8b7e97aa3b3add0431a225c022e32993e384a51290e121542c6a6b3ad4be24f5315a4c1501cf821018a2 languageName: node linkType: hard -"@microsoft/tsdoc-config@npm:~0.15.2": - version: 0.15.2 - resolution: "@microsoft/tsdoc-config@npm:0.15.2" +"@microsoft/tsdoc-config@npm:~0.16.1": + version: 0.16.1 + resolution: "@microsoft/tsdoc-config@npm:0.16.1" dependencies: - "@microsoft/tsdoc": 0.13.2 + "@microsoft/tsdoc": 0.14.1 ajv: ~6.12.6 jju: ~1.4.0 resolve: ~1.19.0 - checksum: 85eb7808d4e4541199437f39e6aed235aaece0a6d0fd05c0b923067d494d20baca483fc6871880d09630f6d4e62b8bb99af0fde503eb2b2ded1b7ae5f74dfaf3 + checksum: 2b2121803caf6584fe0264ad16f8fa10de68438c0b82bd25f918606052af5312050f38b6abd4bcf3d40f120713aab144762a7a280fa22dd12e5571cd08e348e1 languageName: node linkType: hard -"@microsoft/tsdoc@npm:0.13.2": - version: 0.13.2 - resolution: "@microsoft/tsdoc@npm:0.13.2" - checksum: 70948c5647495ef99752ff500e0f612c1fcf3476ea663ace19937e4d2f86fd78f0ad92ea5876d67e06b421f347d571b3d9e49c444935dc267768d5afd15581f8 +"@microsoft/tsdoc@npm:0.14.1": + version: 0.14.1 + resolution: "@microsoft/tsdoc@npm:0.14.1" + checksum: e4ad038ccff2cd96e0d53ee42e2136f0f5a925b16cfda14261f1c2eb55ba0088a0e3b08ff819b476ddc69b2242a391925fab7f6ae2afabb19b96f87e19c114fc languageName: node linkType: hard @@ -4380,9 +4380,9 @@ __metadata: languageName: node linkType: hard -"@rushstack/node-core-library@npm:3.45.1": - version: 3.45.1 - resolution: "@rushstack/node-core-library@npm:3.45.1" +"@rushstack/node-core-library@npm:3.45.4": + version: 3.45.4 + resolution: "@rushstack/node-core-library@npm:3.45.4" dependencies: "@types/node": 12.20.24 colors: ~1.2.1 @@ -4393,29 +4393,29 @@ __metadata: semver: ~7.3.0 timsort: ~0.3.0 z-schema: ~5.0.2 - checksum: 2001e1acda14e75dc3cc4aa988c2ec9609c2ed7a59ef27a5b97ce9a0380c534ad9eb96074821a52e52e34c06cc1f4a011c15f6e5d17bbf830430e739c6d185ce + checksum: f7049be8c145ef1d1ee2ee29b917440a3c88a5e4906c5b6bebe0d4c7854c93b759b7563475be383a4cedf8afd3914b34a6b988fe67b8dfce33545223b2a46cca languageName: node linkType: hard -"@rushstack/rig-package@npm:0.3.8": - version: 0.3.8 - resolution: "@rushstack/rig-package@npm:0.3.8" +"@rushstack/rig-package@npm:0.3.11": + version: 0.3.11 + resolution: "@rushstack/rig-package@npm:0.3.11" dependencies: resolve: ~1.17.0 strip-json-comments: ~3.1.1 - checksum: 375788eae1c18fa4807bbe96541ebddc65bcc44113f186fae2cfbf0b355deb376e20fa8a014f40a6babdcde86d446234dcbaf5d3df4fdca5bf196ec5d4c41f0b + checksum: a6354152a9ac7503a217e7903d2739d35f305b2331f880fca94e6f309ba78e86b58fa8eda888238429bc4203a5cef4df4218f80e636fa75290e68875b971697a languageName: node linkType: hard -"@rushstack/ts-command-line@npm:4.10.7": - version: 4.10.7 - resolution: "@rushstack/ts-command-line@npm:4.10.7" +"@rushstack/ts-command-line@npm:4.10.10": + version: 4.10.10 + resolution: "@rushstack/ts-command-line@npm:4.10.10" dependencies: "@types/argparse": 1.0.38 argparse: ~1.0.9 colors: ~1.2.1 string-argv: ~0.3.1 - checksum: 0c57867e5ea14b9296db403c2979995fe4bdeae3787331fc2d8faa18ee612b5fbcf989afcf5e30bc7f01cfe62003d451b29fc65fdda0790b95f3aacd72d41918 + checksum: e2d47cbe6df4c47e297ef84b83f1f6f2306ae14cd765066ea966f3e6ed48e1382d20c942a324ff9e389f5e673a9e1ba477f5b9514303709fcf85f28e14cdd26c languageName: node linkType: hard @@ -21606,7 +21606,7 @@ __metadata: languageName: node linkType: hard -"typescript@npm:^4.6.2": +"typescript@npm:^4.6.2, typescript@npm:~4.6.3": version: 4.6.3 resolution: "typescript@npm:4.6.3" bin: @@ -21616,17 +21616,7 @@ __metadata: languageName: node linkType: hard -"typescript@npm:~4.5.2": - version: 4.5.5 - resolution: "typescript@npm:4.5.5" - bin: - tsc: bin/tsc - tsserver: bin/tsserver - checksum: 506f4c919dc8aeaafa92068c997f1d213b9df4d9756d0fae1a1e7ab66b585ab3498050e236113a1c9e57ee08c21ec6814ca7a7f61378c058d79af50a4b1f5a5e - languageName: node - linkType: hard - -"typescript@patch:typescript@^4.6.2#~builtin": +"typescript@patch:typescript@^4.6.2#~builtin, typescript@patch:typescript@~4.6.3#~builtin": version: 4.6.3 resolution: "typescript@patch:typescript@npm%3A4.6.3#~builtin::version=4.6.3&hash=bda367" bin: @@ -21636,16 +21626,6 @@ __metadata: languageName: node linkType: hard -"typescript@patch:typescript@~4.5.2#~builtin": - version: 4.5.5 - resolution: "typescript@patch:typescript@npm%3A4.5.5#~builtin::version=4.5.5&hash=bda367" - bin: - tsc: bin/tsc - tsserver: bin/tsserver - checksum: 858c61fa63f7274ca4aaaffeced854d550bf416cff6e558c4884041b3311fb662f476f167cf5c9f8680c607239797e26a2ee0bcc6467fbc05bfcb218e1c6c671 - languageName: node - linkType: hard - "ua-parser-js@npm:^0.7.30": version: 0.7.31 resolution: "ua-parser-js@npm:0.7.31" From a28db24a27bc7276313ab0777c2baf3f65998c02 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Sat, 23 Apr 2022 12:37:56 +0300 Subject: [PATCH 095/128] chore: do not bundle type definitions for packages which have only one `.d.ts` file (#12718) --- scripts/bundleTs.mjs | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/scripts/bundleTs.mjs b/scripts/bundleTs.mjs index 4cac2d4a4b08..7d87a062e8cd 100644 --- a/scripts/bundleTs.mjs +++ b/scripts/bundleTs.mjs @@ -39,8 +39,16 @@ const copyrightSnippet = ` (async () => { const packages = getPackages(); - const packagesWithTs = packages.filter(p => - fs.existsSync(path.resolve(p.packageDir, 'tsconfig.json')), + const isTsPackage = p => + fs.existsSync(path.resolve(p.packageDir, 'tsconfig.json')); + + const hasMoreThanOneDefinitionFile = p => + fs + .readdirSync(path.resolve(p.packageDir, 'build')) + .filter(f => f.endsWith('.d.ts')).length > 1; + + const packagesToBundle = packages.filter( + p => isTsPackage(p) && hasMoreThanOneDefinitionFile(p), ); const typesNodeReferenceDirective = '/// '; @@ -115,7 +123,7 @@ const copyrightSnippet = ` let compilerState; await Promise.all( - packagesWithTs.map(async ({packageDir, pkg}) => { + packagesToBundle.map(async ({packageDir, pkg}) => { const configFile = path.resolve(packageDir, 'api-extractor.json'); await fs.promises.writeFile( @@ -134,7 +142,7 @@ const copyrightSnippet = ` if (!compilerState) { compilerState = CompilerState.create(extractorConfig, { - additionalEntryPoints: packagesWithTs.map(({pkg, packageDir}) => + additionalEntryPoints: packagesToBundle.map(({pkg, packageDir}) => path.resolve(packageDir, pkg.types), ), typescriptCompilerFolder, From 811228d6ae73a6563a98b0ee36b73f453e644f2f Mon Sep 17 00:00:00 2001 From: Zach Date: Sat, 23 Apr 2022 05:38:48 -0400 Subject: [PATCH 096/128] Support error logging before jest retry (#12201) Co-authored-by: Zachary Bogard --- CHANGELOG.md | 1 + docs/JestObjectAPI.md | 13 ++++++- .../__snapshots__/testRetries.test.ts.snap | 39 +++++++++++++++++++ e2e/__tests__/testRetries.test.ts | 11 ++++++ .../__tests__/logErrorsBeforeRetries.test.js | 18 +++++++++ packages/jest-circus/src/eventHandler.ts | 8 +++- .../jestAdapterInit.ts | 1 + packages/jest-circus/src/types.ts | 2 + packages/jest-circus/src/utils.ts | 3 ++ packages/jest-environment/src/index.ts | 10 ++++- packages/jest-message-util/src/index.ts | 10 ++--- .../jest-reporters/src/DefaultReporter.ts | 34 +++++++++++++++- .../src/__tests__/DefaultReporter.test.js | 1 + packages/jest-runtime/src/index.ts | 6 ++- .../jest-types/__typetests__/jest.test.ts | 1 + packages/jest-types/src/Circus.ts | 2 + packages/jest-types/src/TestResult.ts | 1 + packages/jest-util/src/deepCyclicCopy.ts | 2 +- 18 files changed, 151 insertions(+), 12 deletions(-) create mode 100644 e2e/__tests__/__snapshots__/testRetries.test.ts.snap create mode 100644 e2e/test-retries/__tests__/logErrorsBeforeRetries.test.js diff --git a/CHANGELOG.md b/CHANGELOG.md index d5b4d2c280c8..7c6c93cde7a5 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,7 @@ - `[babel-jest]` Export `createTransformer` function ([#12399](https://github.com/facebook/jest/pull/12399)) - `[expect]` Expose `AsymmetricMatchers`, `MatcherFunction` and `MatcherFunctionWithState` interfaces ([#12363](https://github.com/facebook/jest/pull/12363), [#12376](https://github.com/facebook/jest/pull/12376)) +- `[jest-circus]` Support error logging before retry ([#12201](https://github.com/facebook/jest/pull/12201)) - `[jest-circus, jest-jasmine2]` Allowed classes and functions as `describe` and `it`/`test` names ([#12484](https://github.com/facebook/jest/pull/12484)) - `[jest-cli, jest-config]` [**BREAKING**] Remove `testURL` config, use `testEnvironmentOptions.url` instead ([#10797](https://github.com/facebook/jest/pull/10797)) - `[jest-cli, jest-core]` Add `--shard` parameter for distributed parallel test execution ([#12546](https://github.com/facebook/jest/pull/12546)) diff --git a/docs/JestObjectAPI.md b/docs/JestObjectAPI.md index 23df34442ba0..3b77e532ab35 100644 --- a/docs/JestObjectAPI.md +++ b/docs/JestObjectAPI.md @@ -831,9 +831,9 @@ Example: jest.setTimeout(1000); // 1 second ``` -### `jest.retryTimes()` +### `jest.retryTimes(numRetries, options)` -Runs failed tests n-times until they pass or until the max number of retries is exhausted. This only works with the default [jest-circus](https://github.com/facebook/jest/tree/main/packages/jest-circus) runner! This must live at the top-level of a test file or in a describe block. Retries _will not_ work if `jest.retryTimes()` is called in a `beforeEach` or a `test` block. +Runs failed tests n-times until they pass or until the max number of retries is exhausted. `options` are optional. This only works with the default [jest-circus](https://github.com/facebook/jest/tree/main/packages/jest-circus) runner! This must live at the top-level of a test file or in a describe block. Retries _will not_ work if `jest.retryTimes()` is called in a `beforeEach` or a `test` block. Example in a test: @@ -844,4 +844,13 @@ test('will fail', () => { }); ``` +If `logErrorsBeforeRetry` is enabled, Jest will log the error(s) that caused the test to fail to the console, providing visibility on why a retry occurred. + +```js +jest.retryTimes(3, {logErrorsBeforeRetry: true}); +test('will fail', () => { + expect(true).toBe(false); +}); +``` + Returns the `jest` object for chaining. diff --git a/e2e/__tests__/__snapshots__/testRetries.test.ts.snap b/e2e/__tests__/__snapshots__/testRetries.test.ts.snap new file mode 100644 index 000000000000..09c1f807a028 --- /dev/null +++ b/e2e/__tests__/__snapshots__/testRetries.test.ts.snap @@ -0,0 +1,39 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`Test Retries logs error(s) before retry 1`] = ` +"LOGGING RETRY ERRORS retryTimes set + RETRY 1 + + expect(received).toBeFalsy() + + Received: true + + 14 | expect(true).toBeTruthy(); + 15 | } else { + > 16 | expect(true).toBeFalsy(); + | ^ + 17 | } + 18 | }); + 19 | + + at Object.toBeFalsy (__tests__/logErrorsBeforeRetries.test.js:16:18) + + RETRY 2 + + expect(received).toBeFalsy() + + Received: true + + 14 | expect(true).toBeTruthy(); + 15 | } else { + > 16 | expect(true).toBeFalsy(); + | ^ + 17 | } + 18 | }); + 19 | + + at Object.toBeFalsy (__tests__/logErrorsBeforeRetries.test.js:16:18) + +PASS __tests__/logErrorsBeforeRetries.test.js + ✓ retryTimes set" +`; diff --git a/e2e/__tests__/testRetries.test.ts b/e2e/__tests__/testRetries.test.ts index d29faeee59fb..ec938b9231e2 100644 --- a/e2e/__tests__/testRetries.test.ts +++ b/e2e/__tests__/testRetries.test.ts @@ -8,6 +8,7 @@ import * as path from 'path'; import * as fs from 'graceful-fs'; import {skipSuiteOnJasmine} from '@jest/test-utils'; +import {extractSummary} from '../Utils'; import runJest from '../runJest'; skipSuiteOnJasmine(); @@ -19,6 +20,7 @@ describe('Test Retries', () => { 'e2e/test-retries/', outputFileName, ); + const logErrorsBeforeRetryErrorMessage = 'LOGGING RETRY ERRORS'; afterAll(() => { fs.unlinkSync(outputFilePath); @@ -29,6 +31,15 @@ describe('Test Retries', () => { expect(result.exitCode).toEqual(0); expect(result.failed).toBe(false); + expect(result.stderr).not.toContain(logErrorsBeforeRetryErrorMessage); + }); + + it('logs error(s) before retry', () => { + const result = runJest('test-retries', ['logErrorsBeforeRetries.test.js']); + expect(result.exitCode).toEqual(0); + expect(result.failed).toBe(false); + expect(result.stderr).toContain(logErrorsBeforeRetryErrorMessage); + expect(extractSummary(result.stderr).rest).toMatchSnapshot(); }); it('reporter shows more than 1 invocation if test is retried', () => { diff --git a/e2e/test-retries/__tests__/logErrorsBeforeRetries.test.js b/e2e/test-retries/__tests__/logErrorsBeforeRetries.test.js new file mode 100644 index 000000000000..46d53526ba6e --- /dev/null +++ b/e2e/test-retries/__tests__/logErrorsBeforeRetries.test.js @@ -0,0 +1,18 @@ +/** + * Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ +'use strict'; + +let i = 0; +jest.retryTimes(3, {logErrorsBeforeRetry: true}); +it('retryTimes set', () => { + i++; + if (i === 3) { + expect(true).toBeTruthy(); + } else { + expect(true).toBeFalsy(); + } +}); diff --git a/packages/jest-circus/src/eventHandler.ts b/packages/jest-circus/src/eventHandler.ts index 891399ac9ab1..19febb73055e 100644 --- a/packages/jest-circus/src/eventHandler.ts +++ b/packages/jest-circus/src/eventHandler.ts @@ -10,7 +10,7 @@ import { injectGlobalErrorHandlers, restoreGlobalErrorHandlers, } from './globalErrorHandlers'; -import {TEST_TIMEOUT_SYMBOL} from './types'; +import {LOG_ERRORS_BEFORE_RETRY, TEST_TIMEOUT_SYMBOL} from './types'; import { addErrorToEachTestUnderDescribe, describeBlockHasTests, @@ -205,6 +205,12 @@ const eventHandler: Circus.EventHandler = (event, state) => { break; } case 'test_retry': { + const logErrorsBeforeRetry: boolean = + // eslint-disable-next-line no-restricted-globals + global[LOG_ERRORS_BEFORE_RETRY] || false; + if (logErrorsBeforeRetry) { + event.test.retryReasons.push(...event.test.errors); + } event.test.errors = []; break; } diff --git a/packages/jest-circus/src/legacy-code-todo-rewrite/jestAdapterInit.ts b/packages/jest-circus/src/legacy-code-todo-rewrite/jestAdapterInit.ts index cd2781a1af1f..8a81880c748e 100644 --- a/packages/jest-circus/src/legacy-code-todo-rewrite/jestAdapterInit.ts +++ b/packages/jest-circus/src/legacy-code-todo-rewrite/jestAdapterInit.ts @@ -220,6 +220,7 @@ export const runAndTransformResultsToJestFormat = async ({ invocations: testResult.invocations, location: testResult.location, numPassingAsserts: 0, + retryReasons: testResult.retryReasons, status, title: testResult.testPath[testResult.testPath.length - 1], }; diff --git a/packages/jest-circus/src/types.ts b/packages/jest-circus/src/types.ts index ff81f685234e..9192e2412b2d 100644 --- a/packages/jest-circus/src/types.ts +++ b/packages/jest-circus/src/types.ts @@ -11,6 +11,7 @@ export const STATE_SYM = Symbol('JEST_STATE_SYMBOL'); export const RETRY_TIMES = Symbol.for('RETRY_TIMES'); // To pass this value from Runtime object to state we need to use global[sym] export const TEST_TIMEOUT_SYMBOL = Symbol.for('TEST_TIMEOUT_SYMBOL'); +export const LOG_ERRORS_BEFORE_RETRY = Symbol.for('LOG_ERRORS_BEFORE_RETRY'); declare global { namespace NodeJS { @@ -18,6 +19,7 @@ declare global { [STATE_SYM]: Circus.State; [RETRY_TIMES]: string; [TEST_TIMEOUT_SYMBOL]: number; + [LOG_ERRORS_BEFORE_RETRY]: boolean; } } } diff --git a/packages/jest-circus/src/utils.ts b/packages/jest-circus/src/utils.ts index 8dc4ffbea57d..98f08a06c9ec 100644 --- a/packages/jest-circus/src/utils.ts +++ b/packages/jest-circus/src/utils.ts @@ -70,6 +70,7 @@ export const makeTest = ( mode, name: convertDescriptorToString(name), parent, + retryReasons: [], seenDone: false, startedAt: null, status: null, @@ -354,6 +355,7 @@ export const makeSingleTestResult = ( errorsDetailed, invocations: test.invocations, location, + retryReasons: test.retryReasons.map(_getError).map(getErrorStack), status, testPath: Array.from(testPath), }; @@ -475,6 +477,7 @@ export const parseSingleTestResult = ( invocations: testResult.invocations, location: testResult.location, numPassingAsserts: 0, + retryReasons: Array.from(testResult.retryReasons), status, title: testResult.testPath[testResult.testPath.length - 1], }; diff --git a/packages/jest-environment/src/index.ts b/packages/jest-environment/src/index.ts index 3005b3ef9a59..7a6e1cc8f7ef 100644 --- a/packages/jest-environment/src/index.ts +++ b/packages/jest-environment/src/index.ts @@ -232,10 +232,18 @@ export interface Jest { * Runs failed tests n-times until they pass or until the max number of * retries is exhausted. * + * If `logErrorsBeforeRetry` is enabled, Jest will log the error(s) that caused + * the test to fail to the console, providing visibility on why a retry occurred. + * retries is exhausted. + * * @remarks * Only available with `jest-circus` runner. */ - retryTimes(numRetries: number): Jest; + retryTimes( + numRetries: number, + options?: {logErrorsBeforeRetry?: boolean}, + ): Jest; + /** * Exhausts tasks queued by `setImmediate()`. * diff --git a/packages/jest-message-util/src/index.ts b/packages/jest-message-util/src/index.ts index 51f9f2da7bc7..0f6f38c58c47 100644 --- a/packages/jest-message-util/src/index.ts +++ b/packages/jest-message-util/src/index.ts @@ -63,8 +63,8 @@ const STACK_PATH_REGEXP = /\s*at.*\(?(\:\d*\:\d*|native)\)?/; const EXEC_ERROR_MESSAGE = 'Test suite failed to run'; const NOT_EMPTY_LINE_REGEXP = /^(?!$)/gm; -const indentAllLines = (lines: string, indent: string) => - lines.replace(NOT_EMPTY_LINE_REGEXP, indent); +export const indentAllLines = (lines: string): string => + lines.replace(NOT_EMPTY_LINE_REGEXP, MESSAGE_INDENT); const trim = (string: string) => (string || '').trim(); @@ -86,7 +86,7 @@ const getRenderedCallsite = ( {highlightCode: true}, ); - renderedCallsite = indentAllLines(renderedCallsite, MESSAGE_INDENT); + renderedCallsite = indentAllLines(renderedCallsite); renderedCallsite = `\n${renderedCallsite}\n`; return renderedCallsite; @@ -157,7 +157,7 @@ export const formatExecError = ( message = checkForCommonEnvironmentErrors(message); - message = indentAllLines(message, MESSAGE_INDENT); + message = indentAllLines(message); stack = stack && !options.noStackTrace @@ -360,7 +360,7 @@ export const formatResultsErrors = ( formatStackTrace(stack, config, options, testPath), )}\n`; - message = indentAllLines(message, MESSAGE_INDENT); + message = indentAllLines(message); const title = `${chalk.bold.red( TITLE_INDENT + diff --git a/packages/jest-reporters/src/DefaultReporter.ts b/packages/jest-reporters/src/DefaultReporter.ts index 69d8c867e0ce..432073401f3d 100644 --- a/packages/jest-reporters/src/DefaultReporter.ts +++ b/packages/jest-reporters/src/DefaultReporter.ts @@ -14,6 +14,11 @@ import type { TestResult, } from '@jest/test-result'; import type {Config} from '@jest/types'; +import { + formatStackTrace, + indentAllLines, + separateMessageFromStack, +} from 'jest-message-util'; import {clearLine, isInteractive} from 'jest-util'; import BaseReporter from './BaseReporter'; import Status from './Status'; @@ -181,10 +186,37 @@ export default class DefaultReporter extends BaseReporter { } printTestFileHeader( - _testPath: string, + testPath: string, config: Config.ProjectConfig, result: TestResult, ): void { + // log retry errors if any exist + result.testResults.forEach(testResult => { + const testRetryReasons = testResult.retryReasons; + if (testRetryReasons && testRetryReasons.length > 0) { + this.log( + `${chalk.reset.inverse.bold.yellow( + ' LOGGING RETRY ERRORS ', + )} ${chalk.bold(testResult.fullName)}`, + ); + testRetryReasons.forEach((retryReasons, index) => { + let {message, stack} = separateMessageFromStack(retryReasons); + stack = this._globalConfig.noStackTrace + ? '' + : chalk.dim( + formatStackTrace(stack, config, this._globalConfig, testPath), + ); + + message = indentAllLines(message); + + this.log( + `${chalk.reset.inverse.bold.blueBright(` RETRY ${index + 1} `)}\n`, + ); + this.log(`${message}\n${stack}\n`); + }); + } + }); + this.log(getResultHeader(result, this._globalConfig, config)); if (result.console) { this.log( diff --git a/packages/jest-reporters/src/__tests__/DefaultReporter.test.js b/packages/jest-reporters/src/__tests__/DefaultReporter.test.js index 8bf82aacb72f..addcfa415948 100644 --- a/packages/jest-reporters/src/__tests__/DefaultReporter.test.js +++ b/packages/jest-reporters/src/__tests__/DefaultReporter.test.js @@ -30,6 +30,7 @@ const testResult = { updated: 0, }, testFilePath: '/foo', + testResults: [], }; let stdout; diff --git a/packages/jest-runtime/src/index.ts b/packages/jest-runtime/src/index.ts index c98f97f0c3a7..1dc2c9a56322 100644 --- a/packages/jest-runtime/src/index.ts +++ b/packages/jest-runtime/src/index.ts @@ -119,6 +119,7 @@ type ResolveOptions = Parameters[1] & { const testTimeoutSymbol = Symbol.for('TEST_TIMEOUT_SYMBOL'); const retryTimesSymbol = Symbol.for('RETRY_TIMES'); +const logErrorsBeforeRetrySymbol = Symbol.for('LOG_ERRORS_BEFORE_RETRY'); const NODE_MODULES = `${path.sep}node_modules${path.sep}`; @@ -2117,8 +2118,11 @@ export default class Runtime { return jestObject; }; - const retryTimes = (numTestRetries: number) => { + const retryTimes: Jest['retryTimes'] = (numTestRetries, options) => { this._environment.global[retryTimesSymbol] = numTestRetries; + this._environment.global[logErrorsBeforeRetrySymbol] = + options?.logErrorsBeforeRetry; + return jestObject; }; diff --git a/packages/jest-types/__typetests__/jest.test.ts b/packages/jest-types/__typetests__/jest.test.ts index cb32315548f9..ce95ca1a828a 100644 --- a/packages/jest-types/__typetests__/jest.test.ts +++ b/packages/jest-types/__typetests__/jest.test.ts @@ -117,6 +117,7 @@ expectError(jest.unmock()); // Mock Functions +expectType(jest.retryTimes(3, {logErrorsBeforeRetry: true})); expectType(jest.clearAllMocks()); expectError(jest.clearAllMocks('moduleName')); diff --git a/packages/jest-types/src/Circus.ts b/packages/jest-types/src/Circus.ts index 47d9d61a7623..4318d4f7cf2a 100644 --- a/packages/jest-types/src/Circus.ts +++ b/packages/jest-types/src/Circus.ts @@ -182,6 +182,7 @@ export type TestResult = { invocations: number; status: TestStatus; location?: {column: number; line: number} | null; + retryReasons: Array; testPath: Array; }; @@ -234,6 +235,7 @@ export type TestEntry = { type: 'test'; asyncError: Exception; // Used if the test failure contains no usable stack trace errors: Array; + retryReasons: Array; fn: TestFn; invocations: number; mode: TestMode; diff --git a/packages/jest-types/src/TestResult.ts b/packages/jest-types/src/TestResult.ts index c8b5f123a1c9..ab8135420bcb 100644 --- a/packages/jest-types/src/TestResult.ts +++ b/packages/jest-types/src/TestResult.ts @@ -24,6 +24,7 @@ export type AssertionResult = { invocations?: number; location?: Callsite | null; numPassingAsserts: number; + retryReasons?: Array; status: Status; title: string; }; diff --git a/packages/jest-util/src/deepCyclicCopy.ts b/packages/jest-util/src/deepCyclicCopy.ts index d9f59bc409bb..53077c33c255 100644 --- a/packages/jest-util/src/deepCyclicCopy.ts +++ b/packages/jest-util/src/deepCyclicCopy.ts @@ -17,7 +17,7 @@ export default function deepCyclicCopy( options: DeepCyclicCopyOptions = {blacklist: EMPTY, keepPrototype: false}, cycles: WeakMap = new WeakMap(), ): T { - if (typeof value !== 'object' || value === null) { + if (typeof value !== 'object' || value === null || Buffer.isBuffer(value)) { return value; } else if (cycles.has(value)) { return cycles.get(value); From 7a8c9cf837edc6b9bbf9b3547f4ba49f2d448d6e Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Sat, 23 Apr 2022 19:55:39 +0800 Subject: [PATCH 097/128] Lock source-map-support verion to 0.5.13 (#12720) --- CHANGELOG.md | 1 + packages/jest-runner/package.json | 2 +- yarn.lock | 18 +++++++++--------- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7c6c93cde7a5..47271a331637 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -51,6 +51,7 @@ - `[jest-runner]` Allow `setupFiles` module to export an async function ([#12042](https://github.com/facebook/jest/pull/12042)) - `[jest-runner]` Allow passing `testEnvironmentOptions` via docblocks ([#12470](https://github.com/facebook/jest/pull/12470)) - `[jest-runner]` Expose `CallbackTestRunner`, `EmittingTestRunner` abstract classes and `CallbackTestRunnerInterface`, `EmittingTestRunnerInterface` to help typing third party runners ([#12646](https://github.com/facebook/jest/pull/12646), [#12715](https://github.com/facebook/jest/pull/12715)) +- `[jest-runner]` Lock version of `source-map-support` to 0.5.13 ([#12720](https://github.com/facebook/jest/pull/12720)) - `[jest-runtime]` [**BREAKING**] `Runtime.createHasteMap` now returns a promise ([#12008](https://github.com/facebook/jest/pull/12008)) - `[jest-runtime]` Calling `jest.resetModules` function will clear FS and transform cache ([#12531](https://github.com/facebook/jest/pull/12531)) - `[jest-runtime]` [**BREAKING**] Remove `Context` type export, it must be imported from `@jest/test-result` ([#12685](https://github.com/facebook/jest/pull/12685)) diff --git a/packages/jest-runner/package.json b/packages/jest-runner/package.json index 89207a4651f4..2438b4013536 100644 --- a/packages/jest-runner/package.json +++ b/packages/jest-runner/package.json @@ -36,7 +36,7 @@ "jest-util": "^28.0.0-alpha.9", "jest-watcher": "^28.0.0-alpha.9", "jest-worker": "^28.0.0-alpha.11", - "source-map-support": "^0.5.6", + "source-map-support": "0.5.13", "throat": "^6.0.1" }, "devDependencies": { diff --git a/yarn.lock b/yarn.lock index 9dcb5bc0a72d..b8e834791f83 100644 --- a/yarn.lock +++ b/yarn.lock @@ -13502,7 +13502,7 @@ __metadata: jest-util: ^28.0.0-alpha.9 jest-watcher: ^28.0.0-alpha.9 jest-worker: ^28.0.0-alpha.11 - source-map-support: ^0.5.6 + source-map-support: 0.5.13 throat: ^6.0.1 tsd-lite: ^0.5.1 languageName: unknown @@ -20294,23 +20294,23 @@ __metadata: languageName: node linkType: hard -"source-map-support@npm:^0.5.16, source-map-support@npm:~0.5.20": - version: 0.5.21 - resolution: "source-map-support@npm:0.5.21" +"source-map-support@npm:0.5.13": + version: 0.5.13 + resolution: "source-map-support@npm:0.5.13" dependencies: buffer-from: ^1.0.0 source-map: ^0.6.0 - checksum: 43e98d700d79af1d36f859bdb7318e601dfc918c7ba2e98456118ebc4c4872b327773e5a1df09b0524e9e5063bb18f0934538eace60cca2710d1fa687645d137 + checksum: 933550047b6c1a2328599a21d8b7666507427c0f5ef5eaadd56b5da0fd9505e239053c66fe181bf1df469a3b7af9d775778eee283cbb7ae16b902ddc09e93a97 languageName: node linkType: hard -"source-map-support@npm:^0.5.6": - version: 0.5.13 - resolution: "source-map-support@npm:0.5.13" +"source-map-support@npm:^0.5.16, source-map-support@npm:~0.5.20": + version: 0.5.21 + resolution: "source-map-support@npm:0.5.21" dependencies: buffer-from: ^1.0.0 source-map: ^0.6.0 - checksum: 933550047b6c1a2328599a21d8b7666507427c0f5ef5eaadd56b5da0fd9505e239053c66fe181bf1df469a3b7af9d775778eee283cbb7ae16b902ddc09e93a97 + checksum: 43e98d700d79af1d36f859bdb7318e601dfc918c7ba2e98456118ebc4c4872b327773e5a1df09b0524e9e5063bb18f0934538eace60cca2710d1fa687645d137 languageName: node linkType: hard From 4f1d199ae663a67976e6685f94b220169f1262b9 Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Sun, 24 Apr 2022 03:23:22 +0800 Subject: [PATCH 098/128] Add Yarn dedupe CI check (#12717) --- .github/workflows/nodejs.yml | 7 ++++--- package.json | 1 + yarn.lock | 16 +--------------- 3 files changed, 6 insertions(+), 18 deletions(-) diff --git a/.github/workflows/nodejs.yml b/.github/workflows/nodejs.yml index ec67774a5153..6fab04689f0c 100644 --- a/.github/workflows/nodejs.yml +++ b/.github/workflows/nodejs.yml @@ -83,7 +83,7 @@ jobs: run: yarn check-copyright-headers yarn-validate: - name: Validate Yarn constraints + name: Validate Yarn dependencies and constraints runs-on: ubuntu-latest needs: prepare-yarn-cache steps: @@ -93,8 +93,9 @@ jobs: node-version: lts/* cache: yarn - name: 'Check for unmet constraints (fix w/ "yarn constraints --fix")' - run: | - yarn constraints + run: yarn constraints + - name: 'Check for duplicate dependencies (fix w/ "yarn dedupe")' + run: yarn dedupe --check test: name: Node v${{ matrix.node-version }} on ${{ matrix.os }} (${{ matrix.shard }}) diff --git a/package.json b/package.json index af4d8269e3d9..83c5cebf727c 100644 --- a/package.json +++ b/package.json @@ -163,6 +163,7 @@ "node": "^12.13.0 || ^14.15.0 || ^16.13.0 || >=17.0.0" }, "resolutions": { + "@types/node": "~12.12.0", "babel-jest": "workspace:*", "jest": "workspace:*", "jest-environment-node": "workspace:*", diff --git a/yarn.lock b/yarn.lock index b8e834791f83..f6617c129033 100644 --- a/yarn.lock +++ b/yarn.lock @@ -5203,27 +5203,13 @@ __metadata: languageName: node linkType: hard -"@types/node@npm:*, @types/node@npm:~12.12.0": +"@types/node@npm:~12.12.0": version: 12.12.70 resolution: "@types/node@npm:12.12.70" checksum: 69c193e0bce8fa914d478f829bd923ee662b220e069a2e00ffbe109f27d0b38fbf2a9fe78c99eb4d4ccb294248ff8de68019a2c7fadb032d301c6feca25f3d22 languageName: node linkType: hard -"@types/node@npm:12.20.24": - version: 12.20.24 - resolution: "@types/node@npm:12.20.24" - checksum: e7a13460e2f5b0b5a32c0f3af7daf1a05201552a66d542d3cc3b1ea8b52d4730250f9eb1961d755e31cfe5d03c78340911a6242657a0a9a17d6f7e341fc9f366 - languageName: node - linkType: hard - -"@types/node@npm:^17.0.5": - version: 17.0.23 - resolution: "@types/node@npm:17.0.23" - checksum: a3517554737cbb042e76c30d0e5482192ac4d9bea0eeb086e2622d9cabf460a0eb52a696b99fcd18e7fcc93c96db6cc7ae507f6608f256ef0b5c1d8c87a5a470 - languageName: node - linkType: hard - "@types/normalize-package-data@npm:^2.4.0": version: 2.4.1 resolution: "@types/normalize-package-data@npm:2.4.1" From 62afb830bf68031c6846792470a0174055871bc5 Mon Sep 17 00:00:00 2001 From: Tom Mrazauskas Date: Sun, 24 Apr 2022 10:13:15 +0300 Subject: [PATCH 099/128] chore: revert #12718 and simply do not bundle type declarations of `@jest/globals` (#12721) --- scripts/bundleTs.mjs | 13 +++++-------- 1 file changed, 5 insertions(+), 8 deletions(-) diff --git a/scripts/bundleTs.mjs b/scripts/bundleTs.mjs index 7d87a062e8cd..4961d41ad2c6 100644 --- a/scripts/bundleTs.mjs +++ b/scripts/bundleTs.mjs @@ -36,23 +36,20 @@ const copyrightSnippet = ` */ `.trim(); +const typesNodeReferenceDirective = '/// '; + +const excludedPackages = new Set(['@jest/globals']); + (async () => { const packages = getPackages(); const isTsPackage = p => fs.existsSync(path.resolve(p.packageDir, 'tsconfig.json')); - const hasMoreThanOneDefinitionFile = p => - fs - .readdirSync(path.resolve(p.packageDir, 'build')) - .filter(f => f.endsWith('.d.ts')).length > 1; - const packagesToBundle = packages.filter( - p => isTsPackage(p) && hasMoreThanOneDefinitionFile(p), + p => isTsPackage(p) && !excludedPackages.has(p.pkg.name), ); - const typesNodeReferenceDirective = '/// '; - console.log(chalk.inverse(' Extracting TypeScript definition files ')); const sharedExtractorConfig = { From 4ec4b989c1b0aacea3f77edf93c7deb92f37fe22 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Sun, 24 Apr 2022 14:41:45 +0200 Subject: [PATCH 100/128] chore: cache yarn deps on netlify (#12725) --- netlify.toml | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/netlify.toml b/netlify.toml index 993bd38b2657..ddb2c3fdd54e 100644 --- a/netlify.toml +++ b/netlify.toml @@ -1,4 +1,3 @@ - # Note: this file's config override the Netlify UI admin config # production build @@ -10,6 +9,9 @@ [build.environment] NODE_VERSION = "lts/*" NODE_OPTIONS = "--max_old_space_size=4096" + # default cache + YARN_ENABLE_GLOBAL_CACHE = "true" + YARN_GLOBAL_FOLDER = "/opt/buildhome/.yarn_cache" [context.production] # Do not build the site if there's no site-related changes @@ -19,7 +21,6 @@ [context.deploy-preview] command = "yarn workspace jest-website netlify:ci:deployPreview" - [[plugins]] package = "netlify-plugin-cache" [plugins.inputs] From 9ebfe0ae4637175cc9608e5153311a512f6a15d0 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Sun, 24 Apr 2022 14:50:47 +0200 Subject: [PATCH 101/128] chorer: add note about babel config to upgrade guide (#12724) --- docs/UpgradingToJest28.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/docs/UpgradingToJest28.md b/docs/UpgradingToJest28.md index f329c731343f..9c507970ad99 100644 --- a/docs/UpgradingToJest28.md +++ b/docs/UpgradingToJest28.md @@ -7,7 +7,7 @@ Upgrading Jest from v27 to v28? This guide aims to help refactoring your configu :::info -See [changelog](https://github.com/facebook/jest/blob/main/CHANGELOG.md) for the full list of changes. +See [changelog](https://github.com/facebook/jest/blob/main/CHANGELOG.md#2800) for the full list of changes. ::: @@ -43,6 +43,10 @@ The `testURL` option is removed. Now you should use [`testEnvironmentOptions`](C + } ``` +### Babel config + +`babel-jest` now passes `root: config.rootDir` to Babel when resolving configuration. This improves compatibility when using `projects` with differing configuration, but it might mean your babel config isn't picked up in the same way anymore. You can override this option by passing options to `babel-jest` in your [configuration](Configuration.md#transform-objectstring-pathtotransformer--pathtotransformer-object). + ## Fake Timers Fake timers were refactored to allow passing options to the underlying [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). From c1a57cb2aef8afaf7ecd3f3399891885e1afde9e Mon Sep 17 00:00:00 2001 From: Feng Yu Date: Sun, 24 Apr 2022 22:43:46 +0800 Subject: [PATCH 102/128] chore(deps): bump isbinaryfile dependency to ^5.0.0 (#12726) --- package.json | 2 +- yarn.lock | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/package.json b/package.json index 83c5cebf727c..3671f6525764 100644 --- a/package.json +++ b/package.json @@ -46,7 +46,7 @@ "glob": "^7.1.3", "globby": "^11.0.1", "graceful-fs": "^4.2.9", - "isbinaryfile": "^4.0.0", + "isbinaryfile": "^5.0.0", "istanbul-lib-coverage": "^3.0.0", "istanbul-lib-report": "^3.0.0", "istanbul-reports": "^3.1.3", diff --git a/yarn.lock b/yarn.lock index f6617c129033..c5ebcb1f3630 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2708,7 +2708,7 @@ __metadata: glob: ^7.1.3 globby: ^11.0.1 graceful-fs: ^4.2.9 - isbinaryfile: ^4.0.0 + isbinaryfile: ^5.0.0 istanbul-lib-coverage: ^3.0.0 istanbul-lib-report: ^3.0.0 istanbul-reports: ^3.1.3 @@ -12869,10 +12869,10 @@ __metadata: languageName: node linkType: hard -"isbinaryfile@npm:^4.0.0": - version: 4.0.10 - resolution: "isbinaryfile@npm:4.0.10" - checksum: a6b28db7e23ac7a77d3707567cac81356ea18bd602a4f21f424f862a31d0e7ab4f250759c98a559ece35ffe4d99f0d339f1ab884ffa9795172f632ab8f88e686 +"isbinaryfile@npm:^5.0.0": + version: 5.0.0 + resolution: "isbinaryfile@npm:5.0.0" + checksum: 25cc27388d51b8322c103f5894f9e72ec04e017734e57c4b70be2666501ec7e7f6cbb4a5fcfd15260a7cac979bd1ddb7f5231f5a3098c0695c4e7c049513dfaf languageName: node linkType: hard From fc85b8f2bc20a4f1042a06127ec9632de860a39d Mon Sep 17 00:00:00 2001 From: Dan Armbrust Date: Mon, 25 Apr 2022 01:43:10 -0500 Subject: [PATCH 103/128] fix: replace hash routine md5 with sha256 (#12722) Co-authored-by: Dan Armbrust --- CHANGELOG.md | 1 + packages/babel-jest/src/index.ts | 5 +++-- .../jest-circus/src/__mocks__/testUtils.ts | 5 ++++- .../src/__tests__/normalize.test.ts | 5 +++-- packages/jest-config/src/normalize.ts | 5 +++-- .../src/index.ts | 10 ++++++---- packages/jest-haste-map/src/index.ts | 12 ++++++++--- .../jest-transform/src/ScriptTransformer.ts | 20 +++++++++++++------ 8 files changed, 43 insertions(+), 20 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 47271a331637..02523d11afd0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -67,6 +67,7 @@ ### Fixes +- `[*]` Use `sha256` instead of `md5` as hashing algortihm for compatibility with FIPS systems ([#12722](https://github.com/facebook/jest/pull/12722)) - `[babel-jest]` [**BREAKING**] Pass `rootDir` as `root` in Babel's options ([#12689](https://github.com/facebook/jest/pull/12689)) - `[expect]` Move typings of `.not`, `.rejects` and `.resolves` modifiers outside of `Matchers` interface ([#12346](https://github.com/facebook/jest/pull/12346)) - `[expect]` Throw useful error if `expect.extend` is called with invalid matchers ([#12488](https://github.com/facebook/jest/pull/12488)) diff --git a/packages/babel-jest/src/index.ts b/packages/babel-jest/src/index.ts index e4ac550eaf14..da93a3c4cecf 100644 --- a/packages/babel-jest/src/index.ts +++ b/packages/babel-jest/src/index.ts @@ -78,7 +78,7 @@ function getCacheKeyFromConfig( const configPath = [babelOptions.config || '', babelOptions.babelrc || '']; - return createHash('md5') + return createHash('sha256') .update(THIS_FILE) .update('\0', 'utf8') .update(JSON.stringify(babelOptions.options)) @@ -98,7 +98,8 @@ function getCacheKeyFromConfig( .update(process.env.BABEL_ENV || '') .update('\0', 'utf8') .update(process.version) - .digest('hex'); + .digest('hex') + .substring(0, 32); } function loadBabelConfig( diff --git a/packages/jest-circus/src/__mocks__/testUtils.ts b/packages/jest-circus/src/__mocks__/testUtils.ts index 52557f72fcb8..300159fd3e71 100644 --- a/packages/jest-circus/src/__mocks__/testUtils.ts +++ b/packages/jest-circus/src/__mocks__/testUtils.ts @@ -31,7 +31,10 @@ interface Result extends ExecaSyncReturnValue { } export const runTest = (source: string) => { - const filename = createHash('md5').update(source).digest('hex'); + const filename = createHash('sha256') + .update(source) + .digest('hex') + .substring(0, 32); const tmpFilename = path.join(tmpdir(), filename); const content = ` diff --git a/packages/jest-config/src/__tests__/normalize.test.ts b/packages/jest-config/src/__tests__/normalize.test.ts index 1fc435b0ecfb..a480b4b4229e 100644 --- a/packages/jest-config/src/__tests__/normalize.test.ts +++ b/packages/jest-config/src/__tests__/normalize.test.ts @@ -68,10 +68,11 @@ afterEach(() => { it('picks an id based on the rootDir', async () => { const rootDir = '/root/path/foo'; - const expected = createHash('md5') + const expected = createHash('sha256') .update('/root/path/foo') .update(String(Infinity)) - .digest('hex'); + .digest('hex') + .substring(0, 32); const {options} = await normalize( { rootDir, diff --git a/packages/jest-config/src/normalize.ts b/packages/jest-config/src/normalize.ts index d2fc5ade328e..0086b64ec97f 100644 --- a/packages/jest-config/src/normalize.ts +++ b/packages/jest-config/src/normalize.ts @@ -333,12 +333,13 @@ const normalizeMissingOptions = ( projectIndex: number, ): Config.InitialOptionsWithRootDir => { if (!options.id) { - options.id = createHash('md5') + options.id = createHash('sha256') .update(options.rootDir) // In case we load config from some path that has the same root dir .update(configPath || '') .update(String(projectIndex)) - .digest('hex'); + .digest('hex') + .substring(0, 32); } if (!options.setupFiles) { diff --git a/packages/jest-create-cache-key-function/src/index.ts b/packages/jest-create-cache-key-function/src/index.ts index 8f1a6f1eed80..835edc088885 100644 --- a/packages/jest-create-cache-key-function/src/index.ts +++ b/packages/jest-create-cache-key-function/src/index.ts @@ -49,9 +49,10 @@ function getGlobalCacheKey(files: Array, values: Array) { ] .reduce( (hash, chunk) => hash.update('\0', 'utf8').update(chunk || ''), - createHash('md5'), + createHash('sha256'), ) - .digest('hex'); + .digest('hex') + .substring(0, 32); } function getCacheKeyFunction(globalCacheKey: string): GetCacheKeyFunction { @@ -61,7 +62,7 @@ function getCacheKeyFunction(globalCacheKey: string): GetCacheKeyFunction { const inferredOptions = options || configString; const {config, instrument} = inferredOptions; - return createHash('md5') + return createHash('sha256') .update(globalCacheKey) .update('\0', 'utf8') .update(sourceText) @@ -69,7 +70,8 @@ function getCacheKeyFunction(globalCacheKey: string): GetCacheKeyFunction { .update(config.rootDir ? relative(config.rootDir, sourcePath) : '') .update('\0', 'utf8') .update(instrument ? 'instrument' : '') - .digest('hex'); + .digest('hex') + .substring(0, 32); }; } diff --git a/packages/jest-haste-map/src/index.ts b/packages/jest-haste-map/src/index.ts index a203bea0a845..f3762703050c 100644 --- a/packages/jest-haste-map/src/index.ts +++ b/packages/jest-haste-map/src/index.ts @@ -298,7 +298,10 @@ export default class HasteMap extends EventEmitter { } private async setupCachePath(options: Options): Promise { - const rootDirHash = createHash('md5').update(options.rootDir).digest('hex'); + const rootDirHash = createHash('sha256') + .update(options.rootDir) + .digest('hex') + .substring(0, 32); let hasteImplHash = ''; let dependencyExtractorHash = ''; @@ -344,8 +347,11 @@ export default class HasteMap extends EventEmitter { id: string, ...extra: Array ): string { - const hash = createHash('md5').update(extra.join('')); - return path.join(tmpdir, `${id.replace(/\W/g, '-')}-${hash.digest('hex')}`); + const hash = createHash('sha256').update(extra.join('')); + return path.join( + tmpdir, + `${id.replace(/\W/g, '-')}-${hash.digest('hex').substring(0, 32)}`, + ); } static getModuleMapFromJSON(json: SerializableModuleMap): HasteModuleMap { diff --git a/packages/jest-transform/src/ScriptTransformer.ts b/packages/jest-transform/src/ScriptTransformer.ts index 1c78f616f4bc..fc674e22ebac 100644 --- a/packages/jest-transform/src/ScriptTransformer.ts +++ b/packages/jest-transform/src/ScriptTransformer.ts @@ -116,19 +116,21 @@ class ScriptTransformer { transformerCacheKey: string | undefined, ): string { if (transformerCacheKey) { - return createHash('md5') + return createHash('sha256') .update(transformerCacheKey) .update(CACHE_VERSION) - .digest('hex'); + .digest('hex') + .substring(0, 32); } - return createHash('md5') + return createHash('sha256') .update(fileData) .update(transformOptions.configString) .update(transformOptions.instrument ? 'instrument' : '') .update(filename) .update(CACHE_VERSION) - .digest('hex'); + .digest('hex') + .substring(0, 32); } private _getCacheKey( @@ -869,7 +871,10 @@ const stripShebang = (content: string) => { * could get corrupted, out-of-sync, etc. */ function writeCodeCacheFile(cachePath: string, code: string) { - const checksum = createHash('md5').update(code).digest('hex'); + const checksum = createHash('sha256') + .update(code) + .digest('hex') + .substring(0, 32); writeCacheFile(cachePath, `${checksum}\n${code}`); } @@ -885,7 +890,10 @@ function readCodeCacheFile(cachePath: string): string | null { return null; } const code = content.substring(33); - const checksum = createHash('md5').update(code).digest('hex'); + const checksum = createHash('sha256') + .update(code) + .digest('hex') + .substring(0, 32); if (checksum === content.substring(0, 32)) { return code; } From 256c1afa9311c6c8f037f287d4a7f880a424a4cd Mon Sep 17 00:00:00 2001 From: ASHUTOSH KUMAR CHOUDHARY Date: Mon, 25 Apr 2022 12:22:40 +0530 Subject: [PATCH 104/128] chore(website): add some admonitions to 25.x (#12565) --- website/versioned_docs/version-25.x/CLI.md | 42 ++++- .../version-25.x/Configuration.md | 144 +++++++++++++++--- 2 files changed, 156 insertions(+), 30 deletions(-) diff --git a/website/versioned_docs/version-25.x/CLI.md b/website/versioned_docs/version-25.x/CLI.md index 458c41a5a502..5fbd6b2f4efe 100644 --- a/website/versioned_docs/version-25.x/CLI.md +++ b/website/versioned_docs/version-25.x/CLI.md @@ -98,7 +98,11 @@ jest --update-snapshot --detectOpenHandles ## Options -_Note: CLI options take precedence over values from the [Configuration](Configuration.md)._ +:::note + +CLI options take precedence over values from the [Configuration](Configuration.md). + +::: import TOCInline from '@theme/TOCInline'; @@ -118,7 +122,13 @@ Alias: `-b`. Exit the test suite immediately upon `n` number of failing test sui ### `--cache` -Whether to use the cache. Defaults to true. Disable the cache using `--no-cache`. _Note: the cache should only be disabled if you are experiencing caching related problems. On average, disabling the cache makes Jest at least two times slower._ +Whether to use the cache. Defaults to true. Disable the cache using `--no-cache`. + +:::note + +The cache should only be disabled if you are experiencing caching related problems. On average, disabling the cache makes Jest at least two times slower. + +::: If you want to inspect the cache, use `--showConfig` and look at the `cacheDirectory` value. If you need to clear the cache, use `--clearCache`. @@ -136,7 +146,13 @@ When this option is provided, Jest will assume it is running in a CI environment ### `--clearCache` -Deletes the Jest cache directory and then exits without running tests. Will delete `cacheDirectory` if the option is passed, or Jest's default cache directory. The default cache directory can be found by calling `jest --showConfig`. _Note: clearing the cache will reduce performance._ +Deletes the Jest cache directory and then exits without running tests. Will delete `cacheDirectory` if the option is passed, or Jest's default cache directory. The default cache directory can be found by calling `jest --showConfig`. + +:::caution + +Clearing the cache will reduce performance. + +::: ### `--clearMocks` @@ -198,7 +214,13 @@ Find and run the tests that cover a space separated list of source files that we ### `--forceExit` -Force Jest to exit after all tests have completed running. This is useful when resources set up by test code cannot be adequately cleaned up. _Note: This feature is an escape-hatch. If Jest doesn't exit at the end of a test run, it means external resources are still being held on to or timers are still pending in your code. It is advised to tear down external resources after each test to make sure Jest can shut down cleanly. You can use `--detectOpenHandles` to help track it down._ +Force Jest to exit after all tests have completed running. This is useful when resources set up by test code cannot be adequately cleaned up. + +:::note + +This feature is an escape-hatch. If Jest doesn't exit at the end of a test run, it means external resources are still being held on to or timers are still pending in your code. It is advised to tear down external resources after each test to make sure Jest can shut down cleanly. You can use `--detectOpenHandles` to help track it down. + +::: ### `--help` @@ -284,7 +306,11 @@ Alias: `-i`. Run all tests serially in the current process, rather than creating Run only the tests that were specified with their exact paths. -_Note: The default regex matching works fine on small runs, but becomes slow if provided with multiple patterns and/or against a lot of tests. This option replaces the regex matching logic and by that optimizes the time it takes Jest to filter specific test files_ +:::tip + +The default regex matching works fine on small runs, but becomes slow if provided with multiple patterns and/or against a lot of tests. This option replaces the regex matching logic and by that optimizes the time it takes Jest to filter specific test files. + +::: ### `--setupFilesAfterEnv ... ` @@ -319,7 +345,11 @@ The glob patterns Jest uses to detect test files. Please refer to the [`testMatc Alias: `-t`. Run only tests with a name that matches the regex. For example, suppose you want to run only tests related to authorization which will have names like `"GET /api/posts with auth"`, then you can use `jest -t=auth`. -_Note: The regex is matched against the full name, which is a combination of the test name and all its surrounding describe blocks._ +:::note + +The regex is matched against the full name, which is a combination of the test name and all its surrounding describe blocks. + +::: ### `--testPathIgnorePatterns=|[array]` diff --git a/website/versioned_docs/version-25.x/Configuration.md b/website/versioned_docs/version-25.x/Configuration.md index 6f9a9c607b1f..546b74d6ebac 100644 --- a/website/versioned_docs/version-25.x/Configuration.md +++ b/website/versioned_docs/version-25.x/Configuration.md @@ -97,9 +97,17 @@ test('if utils mocked automatically', () => { }); ``` -_Note: Node modules are automatically mocked when you have a manual mock in place (e.g.: `__mocks__/lodash.js`). More info [here](manual-mocks#mocking-node-modules)._ +:::note -_Note: Core modules, like `fs`, are not mocked by default. They can be mocked explicitly, like `jest.mock('fs')`._ +Node modules are automatically mocked when you have a manual mock in place (e.g.: `__mocks__/lodash.js`). More info [here](manual-mocks#mocking-node-modules). + +::: + +:::note + +Core modules, like `fs`, are not mocked by default. They can be mocked explicitly, like `jest.mock('fs')`. + +::: ### `bail` \[number | boolean] @@ -153,9 +161,17 @@ Example: This will collect coverage information for all the files inside the project's `rootDir`, except the ones that match `**/node_modules/**` or `**/vendor/**`. -_Note: Each glob pattern is applied in the order they are specified in the config. (For example `["!**/__tests__/**", "**/*.js"]` will not exclude `__tests__` because the negation is overwritten with the second pattern. In order to make the negated glob work in this example it has to come after `**/*.js`.)_ +:::note + +Each glob pattern is applied in the order they are specified in the config. (For example `["!**/__tests__/**", "**/*.js"]` will not exclude `__tests__` because the negation is overwritten with the second pattern. In order to make the negated glob work in this example it has to come after `**/*.js`.) + +::: -_Note: This option requires `collectCoverage` to be set to true or Jest to be invoked with `--coverage`._ +:::note + +This option requires `collectCoverage` to be set to true or Jest to be invoked with `--coverage`. + +:::
Help: @@ -205,7 +221,11 @@ Default: `["clover", "json", "lcov", "text"]` A list of reporter names that Jest uses when writing coverage reports. Any [istanbul reporter](https://github.com/istanbuljs/istanbuljs/tree/master/packages/istanbul-reports/lib) can be used. -_Note: Setting this option overwrites the default values. Add `"text"` or `"text-summary"` to see a coverage summary in the console output._ +:::note + +Setting this option overwrites the default values. Add `"text"` or `"text-summary"` to see a coverage summary in the console output. + +::: Additional options can be passed using the tuple form. For example, you may hide coverage report lines for all fully-covered files: @@ -416,11 +436,23 @@ Default: `undefined` This option allows the use of a custom global setup module which exports an async function that is triggered once before all test suites. This function gets Jest's `globalConfig` object as a parameter. -_Note: A global setup module configured in a project (using multi-project runner) will be triggered only when you run at least one test from this project._ +:::note + +A global setup module configured in a project (using multi-project runner) will be triggered only when you run at least one test from this project. + +::: -_Note: Any global variables that are defined through `globalSetup` can only be read in `globalTeardown`. You cannot retrieve globals defined here in your test suites._ +:::note -_Note: While code transformation is applied to the linked setup-file, Jest will **not** transform any code in `node_modules`. This is due to the need to load the actual transformers (e.g. `babel` or `typescript`) to perform transformation._ +Any global variables that are defined through `globalSetup` can only be read in `globalTeardown`. You cannot retrieve globals defined here in your test suites. + +::: + +:::note + +While code transformation is applied to the linked setup-file, Jest will **not** transform any code in `node_modules`. This is due to the need to load the actual transformers (e.g. `babel` or `typescript`) to perform transformation. + +::: Example: @@ -445,9 +477,17 @@ Default: `undefined` This option allows the use of a custom global teardown module which exports an async function that is triggered once after all test suites. This function gets Jest's `globalConfig` object as a parameter. -_Note: A global teardown module configured in a project (using multi-project runner) will be triggered only when you run at least one test from this project._ +:::tip + +A global teardown module configured in a project (using multi-project runner) will be triggered only when you run at least one test from this project. + +::: -_Note: The same caveat concerning transformation of `node_modules` as for `globalSetup` applies to `globalTeardown`._ +:::note + +The same caveat concerning transformation of `node_modules` as for `globalSetup` applies to `globalTeardown`. + +::: ### `haste` \[object] @@ -527,7 +567,11 @@ Example: The order in which the mappings are defined matters. Patterns are checked one by one until one fits. The most specific rule should be listed first. This is true for arrays of module names as well. -_Note: If you provide module name without boundaries `^$` it may cause hard to spot errors. E.g. `relay` will replace all modules which contain `relay` as a substring in its name: `relay`, `react-relay` and `graphql-relay` will all be pointed to your stub._ +:::caution + +If you provide module name without boundaries `^$` it may cause hard to spot errors. E.g. `relay` will replace all modules which contain `relay` as a substring in its name: `relay`, `react-relay` and `graphql-relay` will all be pointed to your stub. + +::: ### `modulePathIgnorePatterns` \[array<string>] @@ -625,7 +669,11 @@ The projects feature can also be used to run multiple configurations or multiple } ``` -_Note: When using multi-project runner, it's recommended to add a `displayName` for each project. This will show the `displayName` of a project next to its tests._ +:::note + +When using multi-project runner, it's recommended to add a `displayName` for each project. This will show the `displayName` of a project next to its tests. + +::: ### `reporters` \[array<moduleName | \[moduleName, options]>] @@ -747,7 +795,11 @@ The root directory that Jest should scan for tests and modules within. If you pu Oftentimes, you'll want to set this to `'src'` or `'lib'`, corresponding to where in your repository the code is stored. -_Note that using `''` as a string token in any other path-based config settings will refer back to this value. So, for example, if you want your [`setupFiles`](#setupfiles-array) config entry to point at the `env-setup.js` file at the root of your project, you could set its value to `["/env-setup.js"]`._ +:::note + +Using `''` as a string token in any other path-based config settings will refer back to this value. So, for example, if you want your [`setupFiles`](#setupfiles-array) config entry to point at the `env-setup.js` file at the root of your project, you could set its value to `["/env-setup.js"]`. + +::: ### `roots` \[array<string>] @@ -757,9 +809,17 @@ A list of paths to directories that Jest should use to search for files in. There are times where you only want Jest to search in a single sub-directory (such as cases where you have a `src/` directory in your repo), but prevent it from accessing the rest of the repo. -_Note: While `rootDir` is mostly used as a token to be re-used in other configuration options, `roots` is used by the internals of Jest to locate **test files and source files**. This applies also when searching for manual mocks for modules from `node_modules` (`__mocks__` will need to live in one of the `roots`)._ +:::note + +While `rootDir` is mostly used as a token to be re-used in other configuration options, `roots` is used by the internals of Jest to locate **test files and source files**. This applies also when searching for manual mocks for modules from `node_modules` (`__mocks__` will need to live in one of the `roots`). + +::: + +:::note + +By default, `roots` has a single entry `` but there are cases where you may want to have multiple roots within one project, for example `roots: ["/src/", "/tests/"]`. -_Note: By default, `roots` has a single entry `` but there are cases where you may want to have multiple roots within one project, for example `roots: ["/src/", "/tests/"]`._ +::: ### `runner` \[string] @@ -772,7 +832,11 @@ This option allows you to use a custom runner instead of Jest's default test run - [`jest-runner-tsc`](https://github.com/azz/jest-runner-tsc) - [`jest-runner-prettier`](https://github.com/keplersj/jest-runner-prettier) -_Note: The `runner` property value can omit the `jest-runner-` prefix of the package name._ +:::note + +The `runner` property value can omit the `jest-runner-` prefix of the package name. + +::: To write a test-runner, export a class with which accepts `globalConfig` in the constructor, and has a `runTests` method with the signature: @@ -805,7 +869,11 @@ If you want a path to be [relative to the root directory of your project](#rootd For example, Jest ships with several plug-ins to `jasmine` that work by monkey-patching the jasmine API. If you wanted to add even more jasmine plugins to the mix (or if you wanted some custom, project-wide matchers for example), you could do so in these modules. -_Note: `setupTestFrameworkScriptFile` is deprecated in favor of `setupFilesAfterEnv`._ +:::note + +`setupTestFrameworkScriptFile` is deprecated in favor of `setupFilesAfterEnv`. + +::: Example `setupFilesAfterEnv` array in a jest.config.js: @@ -943,7 +1011,11 @@ To use this class as your custom environment, refer to it by its full path withi */ ``` -_Note: TestEnvironment is sandboxed. Each test suite will trigger setup/teardown in their own TestEnvironment._ +:::note + +TestEnvironment is sandboxed. Each test suite will trigger setup/teardown in their own TestEnvironment. + +::: Example: @@ -1013,7 +1085,11 @@ Default: `1` The exit code Jest returns on test failure. -_Note: This does not change the exit code in the case of Jest errors (e.g. invalid configuration)._ +:::note + +This does not change the exit code in the case of Jest errors (e.g. invalid configuration). + +::: ### `testMatch` [array<string>] @@ -1025,7 +1101,11 @@ See the [micromatch](https://github.com/micromatch/micromatch) package for detai See also [`testRegex` [string | array<string>]](#testregex-string--arraystring), but note that you cannot specify both options. -_Note: Each glob pattern is applied in the order they are specified in the config. (For example `["!**/__fixtures__/**", "**/__tests__/**/*.js"]` will not exclude `__fixtures__` because the negation is overwritten with the second pattern. In order to make the negated glob work in this example it has to come after `**/__tests__/**/*.js`.)_ +:::note + +Each glob pattern is applied in the order they are specified in the config. (For example `["!**/__fixtures__/**", "**/__tests__/**/*.js"]` will not exclude `__fixtures__` because the negation is overwritten with the second pattern. In order to make the negated glob work in this example it has to come after `**/__tests__/**/*.js`.) + +::: ### `testPathIgnorePatterns` \[array<string>] @@ -1053,7 +1133,11 @@ The following is a visualization of the default regex: └── component.js # not test ``` -_Note: `testRegex` will try to detect test files using the **absolute file path**, therefore, having a folder with a name that matches it will run all the files as tests_ +:::note + +`testRegex` will try to detect test files using the **absolute file path**, therefore, having a folder with a name that matches it will run all the files as tests + +::: ### `testResultsProcessor` \[string] @@ -1196,9 +1280,17 @@ Examples of such compilers include: You can pass configuration to a transformer like `{filePattern: ['path-to-transformer', {options}]}` For example, to configure babel-jest for non-default behavior, `{"\\.js$": ['babel-jest', {rootMode: "upward"}]}` -_Note: a transformer is only run once per file unless the file has changed. During the development of a transformer it can be useful to run Jest with `--no-cache` to frequently [delete Jest's cache](Troubleshooting.md#caching-issues)._ +:::tip -_Note: when adding additional code transformers, this will overwrite the default config and `babel-jest` is no longer automatically loaded. If you want to use it to compile JavaScript or Typescript, it has to be explicitly defined by adding `{"\\.[jt]sx?$": "babel-jest"}` to the transform property. See [babel-jest plugin](https://github.com/facebook/jest/tree/main/packages/babel-jest#setup)_ +A transformer is only run once per file unless the file has changed. During the development of a transformer it can be useful to run Jest with `--no-cache` to frequently [delete Jest's cache](Troubleshooting.md#caching-issues). + +::: + +:::note + +When adding additional code transformers, this will overwrite the default config and `babel-jest` is no longer automatically loaded. If you want to use it to compile JavaScript or Typescript, it has to be explicitly defined by adding `{"\\.[jt]sx?$": "babel-jest"}` to the transform property. See [babel-jest plugin](https://github.com/facebook/jest/tree/main/packages/babel-jest#setup). + +::: ### `transformIgnorePatterns` \[array<string>] @@ -1271,7 +1363,11 @@ Examples of watch plugins include: - [`jest-watch-typeahead`](https://github.com/jest-community/jest-watch-typeahead) - [`jest-watch-yarn-workspaces`](https://github.com/cameronhunter/jest-watch-directories/tree/master/packages/jest-watch-yarn-workspaces) -_Note: The values in the `watchPlugins` property value can omit the `jest-watch-` prefix of the package name._ +:::note + +The values in the `watchPlugins` property value can omit the `jest-watch-` prefix of the package name. + +::: ### `watchman` \[boolean] From 039f43e95aa243ca3fce3293ff8efa0443956e20 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Mon, 25 Apr 2022 08:57:17 +0200 Subject: [PATCH 105/128] chore: combine all v27 docs into a single one (#12729) --- website/versioned_docs/version-27.0/CLI.md | 390 ----- .../version-27.0/Configuration.md | 1438 ---------------- .../version-27.0/ECMAScriptModules.md | 36 - .../versioned_docs/version-27.0/ExpectAPI.md | 1393 ---------------- .../version-27.0/GettingStarted.md | 173 -- .../version-27.0/JestObjectAPI.md | 686 -------- .../version-27.0/MockFunctionAPI.md | 448 ----- .../version-27.0/MockFunctions.md | 315 ---- .../versioned_docs/version-27.0/TimerMocks.md | 187 --- .../version-27.1/Architecture.md | 16 - .../version-27.1/BypassingModuleMocks.md | 58 - website/versioned_docs/version-27.1/CLI.md | 390 ----- .../version-27.1/CodeTransformation.md | 164 -- .../version-27.1/Configuration.md | 1473 ---------------- .../versioned_docs/version-27.1/DynamoDB.md | 81 - .../version-27.1/EnvironmentVariables.md | 14 - .../version-27.1/Es6ClassMocks.md | 443 ----- .../versioned_docs/version-27.1/ExpectAPI.md | 1393 ---------------- .../version-27.1/GettingStarted.md | 173 -- .../versioned_docs/version-27.1/GlobalAPI.md | 880 ---------- .../version-27.1/JestCommunity.md | 21 - .../version-27.1/JestObjectAPI.md | 686 -------- .../version-27.1/JestPlatform.md | 170 -- .../version-27.1/ManualMocks.md | 164 -- .../version-27.1/MigrationGuide.md | 22 - .../version-27.1/MockFunctionAPI.md | 448 ----- .../version-27.1/MockFunctions.md | 315 ---- .../versioned_docs/version-27.1/MongoDB.md | 61 - .../version-27.1/MoreResources.md | 24 - .../versioned_docs/version-27.1/Puppeteer.md | 168 -- .../version-27.1/SetupAndTeardown.md | 190 --- .../version-27.1/SnapshotTesting.md | 316 ---- .../version-27.1/TestingAsyncCode.md | 140 -- .../version-27.1/TestingFrameworks.md | 49 - .../versioned_docs/version-27.1/TimerMocks.md | 187 --- .../version-27.1/Troubleshooting.md | 206 --- .../version-27.1/TutorialAsync.md | 161 -- .../version-27.1/TutorialReact.md | 313 ---- .../version-27.1/TutorialReactNative.md | 215 --- .../version-27.1/TutorialjQuery.md | 66 - .../version-27.1/UsingMatchers.md | 164 -- .../version-27.1/WatchPlugins.md | 229 --- .../versioned_docs/version-27.1/Webpack.md | 221 --- .../version-27.2/Architecture.md | 16 - .../version-27.2/BypassingModuleMocks.md | 58 - website/versioned_docs/version-27.2/CLI.md | 394 ----- .../version-27.2/CodeTransformation.md | 164 -- .../version-27.2/Configuration.md | 1477 ----------------- .../versioned_docs/version-27.2/DynamoDB.md | 81 - .../version-27.2/ECMAScriptModules.md | 36 - .../version-27.2/EnvironmentVariables.md | 14 - .../version-27.2/Es6ClassMocks.md | 443 ----- .../versioned_docs/version-27.2/ExpectAPI.md | 1393 ---------------- .../version-27.2/GettingStarted.md | 173 -- .../versioned_docs/version-27.2/GlobalAPI.md | 880 ---------- .../version-27.2/JestCommunity.md | 21 - .../version-27.2/JestObjectAPI.md | 686 -------- .../version-27.2/JestPlatform.md | 170 -- .../version-27.2/ManualMocks.md | 164 -- .../version-27.2/MigrationGuide.md | 22 - .../version-27.2/MockFunctionAPI.md | 448 ----- .../version-27.2/MockFunctions.md | 315 ---- .../versioned_docs/version-27.2/MongoDB.md | 61 - .../version-27.2/MoreResources.md | 24 - .../versioned_docs/version-27.2/Puppeteer.md | 168 -- .../version-27.2/SetupAndTeardown.md | 190 --- .../version-27.2/SnapshotTesting.md | 316 ---- .../version-27.2/TestingAsyncCode.md | 140 -- .../version-27.2/TestingFrameworks.md | 49 - .../versioned_docs/version-27.2/TimerMocks.md | 187 --- .../version-27.2/Troubleshooting.md | 206 --- .../version-27.2/TutorialAsync.md | 161 -- .../version-27.2/TutorialReact.md | 313 ---- .../version-27.2/TutorialReactNative.md | 215 --- .../version-27.2/TutorialjQuery.md | 66 - .../version-27.2/UsingMatchers.md | 164 -- .../version-27.2/WatchPlugins.md | 229 --- .../versioned_docs/version-27.2/Webpack.md | 221 --- .../version-27.4/Architecture.md | 16 - .../version-27.4/BypassingModuleMocks.md | 58 - .../version-27.4/CodeTransformation.md | 164 -- .../version-27.4/Configuration.md | 1477 ----------------- .../versioned_docs/version-27.4/DynamoDB.md | 81 - .../version-27.4/ECMAScriptModules.md | 36 - .../version-27.4/EnvironmentVariables.md | 14 - .../version-27.4/Es6ClassMocks.md | 443 ----- .../versioned_docs/version-27.4/ExpectAPI.md | 1407 ---------------- .../version-27.4/GettingStarted.md | 173 -- .../versioned_docs/version-27.4/GlobalAPI.md | 880 ---------- .../version-27.4/JestCommunity.md | 21 - .../version-27.4/JestPlatform.md | 170 -- .../version-27.4/ManualMocks.md | 164 -- .../version-27.4/MigrationGuide.md | 22 - .../version-27.4/MockFunctionAPI.md | 448 ----- .../version-27.4/MockFunctions.md | 315 ---- .../versioned_docs/version-27.4/MongoDB.md | 61 - .../version-27.4/MoreResources.md | 24 - .../versioned_docs/version-27.4/Puppeteer.md | 168 -- .../version-27.4/SetupAndTeardown.md | 190 --- .../version-27.4/SnapshotTesting.md | 316 ---- .../version-27.4/TestingAsyncCode.md | 140 -- .../version-27.4/TestingFrameworks.md | 49 - .../versioned_docs/version-27.4/TimerMocks.md | 187 --- .../version-27.4/Troubleshooting.md | 206 --- .../version-27.4/TutorialAsync.md | 161 -- .../version-27.4/TutorialReact.md | 313 ---- .../version-27.4/TutorialReactNative.md | 215 --- .../version-27.4/TutorialjQuery.md | 66 - .../version-27.4/UsingMatchers.md | 164 -- .../version-27.4/WatchPlugins.md | 229 --- .../versioned_docs/version-27.4/Webpack.md | 221 --- .../version-27.5/Architecture.md | 16 - .../version-27.5/BypassingModuleMocks.md | 58 - website/versioned_docs/version-27.5/CLI.md | 394 ----- .../version-27.5/CodeTransformation.md | 164 -- .../versioned_docs/version-27.5/DynamoDB.md | 81 - .../version-27.5/ECMAScriptModules.md | 36 - .../version-27.5/EnvironmentVariables.md | 14 - .../version-27.5/Es6ClassMocks.md | 443 ----- .../versioned_docs/version-27.5/GlobalAPI.md | 880 ---------- .../version-27.5/JestCommunity.md | 21 - .../version-27.5/JestObjectAPI.md | 730 -------- .../version-27.5/JestPlatform.md | 170 -- .../version-27.5/ManualMocks.md | 164 -- .../version-27.5/MigrationGuide.md | 22 - .../versioned_docs/version-27.5/MongoDB.md | 61 - .../version-27.5/MoreResources.md | 24 - .../versioned_docs/version-27.5/Puppeteer.md | 168 -- .../version-27.5/SetupAndTeardown.md | 190 --- .../version-27.5/SnapshotTesting.md | 316 ---- .../version-27.5/TestingAsyncCode.md | 140 -- .../version-27.5/TestingFrameworks.md | 49 - .../version-27.5/Troubleshooting.md | 206 --- .../version-27.5/TutorialAsync.md | 161 -- .../version-27.5/TutorialReact.md | 313 ---- .../version-27.5/TutorialReactNative.md | 215 --- .../version-27.5/TutorialjQuery.md | 66 - .../version-27.5/UsingMatchers.md | 164 -- .../version-27.5/WatchPlugins.md | 229 --- .../versioned_docs/version-27.5/Webpack.md | 221 --- .../Architecture.md | 0 .../BypassingModuleMocks.md | 0 .../{version-27.4 => version-27.x}/CLI.md | 0 .../CodeTransformation.md | 0 .../Configuration.md | 0 .../DynamoDB.md | 0 .../ECMAScriptModules.md | 0 .../EnvironmentVariables.md | 0 .../Es6ClassMocks.md | 0 .../ExpectAPI.md | 0 .../GettingStarted.md | 0 .../GlobalAPI.md | 0 .../JestCommunity.md | 0 .../JestObjectAPI.md | 0 .../JestPlatform.md | 0 .../ManualMocks.md | 0 .../MigrationGuide.md | 0 .../MockFunctionAPI.md | 0 .../MockFunctions.md | 0 .../{version-27.0 => version-27.x}/MongoDB.md | 0 .../MoreResources.md | 0 .../Puppeteer.md | 0 .../SetupAndTeardown.md | 0 .../SnapshotTesting.md | 0 .../TestingAsyncCode.md | 0 .../TestingFrameworks.md | 0 .../TimerMocks.md | 0 .../Troubleshooting.md | 0 .../TutorialAsync.md | 0 .../TutorialReact.md | 0 .../TutorialReactNative.md | 0 .../TutorialjQuery.md | 0 .../UsingMatchers.md | 0 .../WatchPlugins.md | 0 .../{version-27.0 => version-27.x}/Webpack.md | 0 .../version-27.0-sidebars.json | 167 -- .../version-27.1-sidebars.json | 167 -- .../version-27.2-sidebars.json | 167 -- .../version-27.4-sidebars.json | 170 -- ...debars.json => version-27.x-sidebars.json} | 0 website/versions.json | 6 +- 181 files changed, 1 insertion(+), 39343 deletions(-) delete mode 100644 website/versioned_docs/version-27.0/CLI.md delete mode 100644 website/versioned_docs/version-27.0/Configuration.md delete mode 100644 website/versioned_docs/version-27.0/ECMAScriptModules.md delete mode 100644 website/versioned_docs/version-27.0/ExpectAPI.md delete mode 100644 website/versioned_docs/version-27.0/GettingStarted.md delete mode 100644 website/versioned_docs/version-27.0/JestObjectAPI.md delete mode 100644 website/versioned_docs/version-27.0/MockFunctionAPI.md delete mode 100644 website/versioned_docs/version-27.0/MockFunctions.md delete mode 100644 website/versioned_docs/version-27.0/TimerMocks.md delete mode 100644 website/versioned_docs/version-27.1/Architecture.md delete mode 100644 website/versioned_docs/version-27.1/BypassingModuleMocks.md delete mode 100644 website/versioned_docs/version-27.1/CLI.md delete mode 100644 website/versioned_docs/version-27.1/CodeTransformation.md delete mode 100644 website/versioned_docs/version-27.1/Configuration.md delete mode 100644 website/versioned_docs/version-27.1/DynamoDB.md delete mode 100644 website/versioned_docs/version-27.1/EnvironmentVariables.md delete mode 100644 website/versioned_docs/version-27.1/Es6ClassMocks.md delete mode 100644 website/versioned_docs/version-27.1/ExpectAPI.md delete mode 100644 website/versioned_docs/version-27.1/GettingStarted.md delete mode 100644 website/versioned_docs/version-27.1/GlobalAPI.md delete mode 100644 website/versioned_docs/version-27.1/JestCommunity.md delete mode 100644 website/versioned_docs/version-27.1/JestObjectAPI.md delete mode 100644 website/versioned_docs/version-27.1/JestPlatform.md delete mode 100644 website/versioned_docs/version-27.1/ManualMocks.md delete mode 100644 website/versioned_docs/version-27.1/MigrationGuide.md delete mode 100644 website/versioned_docs/version-27.1/MockFunctionAPI.md delete mode 100644 website/versioned_docs/version-27.1/MockFunctions.md delete mode 100644 website/versioned_docs/version-27.1/MongoDB.md delete mode 100644 website/versioned_docs/version-27.1/MoreResources.md delete mode 100644 website/versioned_docs/version-27.1/Puppeteer.md delete mode 100644 website/versioned_docs/version-27.1/SetupAndTeardown.md delete mode 100644 website/versioned_docs/version-27.1/SnapshotTesting.md delete mode 100644 website/versioned_docs/version-27.1/TestingAsyncCode.md delete mode 100644 website/versioned_docs/version-27.1/TestingFrameworks.md delete mode 100644 website/versioned_docs/version-27.1/TimerMocks.md delete mode 100644 website/versioned_docs/version-27.1/Troubleshooting.md delete mode 100644 website/versioned_docs/version-27.1/TutorialAsync.md delete mode 100644 website/versioned_docs/version-27.1/TutorialReact.md delete mode 100644 website/versioned_docs/version-27.1/TutorialReactNative.md delete mode 100644 website/versioned_docs/version-27.1/TutorialjQuery.md delete mode 100644 website/versioned_docs/version-27.1/UsingMatchers.md delete mode 100644 website/versioned_docs/version-27.1/WatchPlugins.md delete mode 100644 website/versioned_docs/version-27.1/Webpack.md delete mode 100644 website/versioned_docs/version-27.2/Architecture.md delete mode 100644 website/versioned_docs/version-27.2/BypassingModuleMocks.md delete mode 100644 website/versioned_docs/version-27.2/CLI.md delete mode 100644 website/versioned_docs/version-27.2/CodeTransformation.md delete mode 100644 website/versioned_docs/version-27.2/Configuration.md delete mode 100644 website/versioned_docs/version-27.2/DynamoDB.md delete mode 100644 website/versioned_docs/version-27.2/ECMAScriptModules.md delete mode 100644 website/versioned_docs/version-27.2/EnvironmentVariables.md delete mode 100644 website/versioned_docs/version-27.2/Es6ClassMocks.md delete mode 100644 website/versioned_docs/version-27.2/ExpectAPI.md delete mode 100644 website/versioned_docs/version-27.2/GettingStarted.md delete mode 100644 website/versioned_docs/version-27.2/GlobalAPI.md delete mode 100644 website/versioned_docs/version-27.2/JestCommunity.md delete mode 100644 website/versioned_docs/version-27.2/JestObjectAPI.md delete mode 100644 website/versioned_docs/version-27.2/JestPlatform.md delete mode 100644 website/versioned_docs/version-27.2/ManualMocks.md delete mode 100644 website/versioned_docs/version-27.2/MigrationGuide.md delete mode 100644 website/versioned_docs/version-27.2/MockFunctionAPI.md delete mode 100644 website/versioned_docs/version-27.2/MockFunctions.md delete mode 100644 website/versioned_docs/version-27.2/MongoDB.md delete mode 100644 website/versioned_docs/version-27.2/MoreResources.md delete mode 100644 website/versioned_docs/version-27.2/Puppeteer.md delete mode 100644 website/versioned_docs/version-27.2/SetupAndTeardown.md delete mode 100644 website/versioned_docs/version-27.2/SnapshotTesting.md delete mode 100644 website/versioned_docs/version-27.2/TestingAsyncCode.md delete mode 100644 website/versioned_docs/version-27.2/TestingFrameworks.md delete mode 100644 website/versioned_docs/version-27.2/TimerMocks.md delete mode 100644 website/versioned_docs/version-27.2/Troubleshooting.md delete mode 100644 website/versioned_docs/version-27.2/TutorialAsync.md delete mode 100644 website/versioned_docs/version-27.2/TutorialReact.md delete mode 100644 website/versioned_docs/version-27.2/TutorialReactNative.md delete mode 100644 website/versioned_docs/version-27.2/TutorialjQuery.md delete mode 100644 website/versioned_docs/version-27.2/UsingMatchers.md delete mode 100644 website/versioned_docs/version-27.2/WatchPlugins.md delete mode 100644 website/versioned_docs/version-27.2/Webpack.md delete mode 100644 website/versioned_docs/version-27.4/Architecture.md delete mode 100644 website/versioned_docs/version-27.4/BypassingModuleMocks.md delete mode 100644 website/versioned_docs/version-27.4/CodeTransformation.md delete mode 100644 website/versioned_docs/version-27.4/Configuration.md delete mode 100644 website/versioned_docs/version-27.4/DynamoDB.md delete mode 100644 website/versioned_docs/version-27.4/ECMAScriptModules.md delete mode 100644 website/versioned_docs/version-27.4/EnvironmentVariables.md delete mode 100644 website/versioned_docs/version-27.4/Es6ClassMocks.md delete mode 100644 website/versioned_docs/version-27.4/ExpectAPI.md delete mode 100644 website/versioned_docs/version-27.4/GettingStarted.md delete mode 100644 website/versioned_docs/version-27.4/GlobalAPI.md delete mode 100644 website/versioned_docs/version-27.4/JestCommunity.md delete mode 100644 website/versioned_docs/version-27.4/JestPlatform.md delete mode 100644 website/versioned_docs/version-27.4/ManualMocks.md delete mode 100644 website/versioned_docs/version-27.4/MigrationGuide.md delete mode 100644 website/versioned_docs/version-27.4/MockFunctionAPI.md delete mode 100644 website/versioned_docs/version-27.4/MockFunctions.md delete mode 100644 website/versioned_docs/version-27.4/MongoDB.md delete mode 100644 website/versioned_docs/version-27.4/MoreResources.md delete mode 100644 website/versioned_docs/version-27.4/Puppeteer.md delete mode 100644 website/versioned_docs/version-27.4/SetupAndTeardown.md delete mode 100644 website/versioned_docs/version-27.4/SnapshotTesting.md delete mode 100644 website/versioned_docs/version-27.4/TestingAsyncCode.md delete mode 100644 website/versioned_docs/version-27.4/TestingFrameworks.md delete mode 100644 website/versioned_docs/version-27.4/TimerMocks.md delete mode 100644 website/versioned_docs/version-27.4/Troubleshooting.md delete mode 100644 website/versioned_docs/version-27.4/TutorialAsync.md delete mode 100644 website/versioned_docs/version-27.4/TutorialReact.md delete mode 100644 website/versioned_docs/version-27.4/TutorialReactNative.md delete mode 100644 website/versioned_docs/version-27.4/TutorialjQuery.md delete mode 100644 website/versioned_docs/version-27.4/UsingMatchers.md delete mode 100644 website/versioned_docs/version-27.4/WatchPlugins.md delete mode 100644 website/versioned_docs/version-27.4/Webpack.md delete mode 100644 website/versioned_docs/version-27.5/Architecture.md delete mode 100644 website/versioned_docs/version-27.5/BypassingModuleMocks.md delete mode 100644 website/versioned_docs/version-27.5/CLI.md delete mode 100644 website/versioned_docs/version-27.5/CodeTransformation.md delete mode 100644 website/versioned_docs/version-27.5/DynamoDB.md delete mode 100644 website/versioned_docs/version-27.5/ECMAScriptModules.md delete mode 100644 website/versioned_docs/version-27.5/EnvironmentVariables.md delete mode 100644 website/versioned_docs/version-27.5/Es6ClassMocks.md delete mode 100644 website/versioned_docs/version-27.5/GlobalAPI.md delete mode 100644 website/versioned_docs/version-27.5/JestCommunity.md delete mode 100644 website/versioned_docs/version-27.5/JestObjectAPI.md delete mode 100644 website/versioned_docs/version-27.5/JestPlatform.md delete mode 100644 website/versioned_docs/version-27.5/ManualMocks.md delete mode 100644 website/versioned_docs/version-27.5/MigrationGuide.md delete mode 100644 website/versioned_docs/version-27.5/MongoDB.md delete mode 100644 website/versioned_docs/version-27.5/MoreResources.md delete mode 100644 website/versioned_docs/version-27.5/Puppeteer.md delete mode 100644 website/versioned_docs/version-27.5/SetupAndTeardown.md delete mode 100644 website/versioned_docs/version-27.5/SnapshotTesting.md delete mode 100644 website/versioned_docs/version-27.5/TestingAsyncCode.md delete mode 100644 website/versioned_docs/version-27.5/TestingFrameworks.md delete mode 100644 website/versioned_docs/version-27.5/Troubleshooting.md delete mode 100644 website/versioned_docs/version-27.5/TutorialAsync.md delete mode 100644 website/versioned_docs/version-27.5/TutorialReact.md delete mode 100644 website/versioned_docs/version-27.5/TutorialReactNative.md delete mode 100644 website/versioned_docs/version-27.5/TutorialjQuery.md delete mode 100644 website/versioned_docs/version-27.5/UsingMatchers.md delete mode 100644 website/versioned_docs/version-27.5/WatchPlugins.md delete mode 100644 website/versioned_docs/version-27.5/Webpack.md rename website/versioned_docs/{version-27.0 => version-27.x}/Architecture.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/BypassingModuleMocks.md (100%) rename website/versioned_docs/{version-27.4 => version-27.x}/CLI.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/CodeTransformation.md (100%) rename website/versioned_docs/{version-27.5 => version-27.x}/Configuration.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/DynamoDB.md (100%) rename website/versioned_docs/{version-27.1 => version-27.x}/ECMAScriptModules.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/EnvironmentVariables.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/Es6ClassMocks.md (100%) rename website/versioned_docs/{version-27.5 => version-27.x}/ExpectAPI.md (100%) rename website/versioned_docs/{version-27.5 => version-27.x}/GettingStarted.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/GlobalAPI.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/JestCommunity.md (100%) rename website/versioned_docs/{version-27.4 => version-27.x}/JestObjectAPI.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/JestPlatform.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/ManualMocks.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/MigrationGuide.md (100%) rename website/versioned_docs/{version-27.5 => version-27.x}/MockFunctionAPI.md (100%) rename website/versioned_docs/{version-27.5 => version-27.x}/MockFunctions.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/MongoDB.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/MoreResources.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/Puppeteer.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/SetupAndTeardown.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/SnapshotTesting.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/TestingAsyncCode.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/TestingFrameworks.md (100%) rename website/versioned_docs/{version-27.5 => version-27.x}/TimerMocks.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/Troubleshooting.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/TutorialAsync.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/TutorialReact.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/TutorialReactNative.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/TutorialjQuery.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/UsingMatchers.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/WatchPlugins.md (100%) rename website/versioned_docs/{version-27.0 => version-27.x}/Webpack.md (100%) delete mode 100644 website/versioned_sidebars/version-27.0-sidebars.json delete mode 100644 website/versioned_sidebars/version-27.1-sidebars.json delete mode 100644 website/versioned_sidebars/version-27.2-sidebars.json delete mode 100644 website/versioned_sidebars/version-27.4-sidebars.json rename website/versioned_sidebars/{version-27.5-sidebars.json => version-27.x-sidebars.json} (100%) diff --git a/website/versioned_docs/version-27.0/CLI.md b/website/versioned_docs/version-27.0/CLI.md deleted file mode 100644 index 74e9d12c8d15..000000000000 --- a/website/versioned_docs/version-27.0/CLI.md +++ /dev/null @@ -1,390 +0,0 @@ ---- -id: cli -title: Jest CLI Options ---- - -The `jest` command line runner has a number of useful options. You can run `jest --help` to view all available options. Many of the options shown below can also be used together to run tests exactly the way you want. Every one of Jest's [Configuration](Configuration.md) options can also be specified through the CLI. - -Here is a brief overview: - -## Running from the command line - -Run all tests (default): - -```bash -jest -``` - -Run only the tests that were specified with a pattern or filename: - -```bash -jest my-test #or -jest path/to/my-test.js -``` - -Run tests related to changed files based on hg/git (uncommitted files): - -```bash -jest -o -``` - -Run tests related to `path/to/fileA.js` and `path/to/fileB.js`: - -```bash -jest --findRelatedTests path/to/fileA.js path/to/fileB.js -``` - -Run tests that match this spec name (match against the name in `describe` or `test`, basically). - -```bash -jest -t name-of-spec -``` - -Run watch mode: - -```bash -jest --watch #runs jest -o by default -jest --watchAll #runs all tests -``` - -Watch mode also enables to specify the name or path to a file to focus on a specific set of tests. - -## Using with yarn - -If you run Jest via `yarn test`, you can pass the command line arguments directly as Jest arguments. - -Instead of: - -```bash -jest -u -t="ColorPicker" -``` - -you can use: - -```bash -yarn test -u -t="ColorPicker" -``` - -## Using with npm scripts - -If you run Jest via `npm test`, you can still use the command line arguments by inserting a `--` between `npm test` and the Jest arguments. - -Instead of: - -```bash -jest -u -t="ColorPicker" -``` - -you can use: - -```bash -npm test -- -u -t="ColorPicker" -``` - -## Camelcase & dashed args support - -Jest supports both camelcase and dashed arg formats. The following examples will have an equal result: - -```bash -jest --collect-coverage -jest --collectCoverage -``` - -Arguments can also be mixed: - -```bash -jest --update-snapshot --detectOpenHandles -``` - -## Options - -_Note: CLI options take precedence over values from the [Configuration](Configuration.md)._ - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Reference - -### `jest ` - -When you run `jest` with an argument, that argument is treated as a regular expression to match against files in your project. It is possible to run test suites by providing a pattern. Only the files that the pattern matches will be picked up and executed. Depending on your terminal, you may need to quote this argument: `jest "my.*(complex)?pattern"`. On Windows, you will need to use `/` as a path separator or escape `\` as `\\`. - -### `--bail` - -Alias: `-b`. Exit the test suite immediately upon `n` number of failing test suite. Defaults to `1`. - -### `--cache` - -Whether to use the cache. Defaults to true. Disable the cache using `--no-cache`. _Note: the cache should only be disabled if you are experiencing caching related problems. On average, disabling the cache makes Jest at least two times slower._ - -If you want to inspect the cache, use `--showConfig` and look at the `cacheDirectory` value. If you need to clear the cache, use `--clearCache`. - -### `--changedFilesWithAncestor` - -Runs tests related to the current changes and the changes made in the last commit. Behaves similarly to `--onlyChanged`. - -### `--changedSince` - -Runs tests related to the changes since the provided branch or commit hash. If the current branch has diverged from the given branch, then only changes made locally will be tested. Behaves similarly to `--onlyChanged`. - -### `--ci` - -When this option is provided, Jest will assume it is running in a CI environment. This changes the behavior when a new snapshot is encountered. Instead of the regular behavior of storing a new snapshot automatically, it will fail the test and require Jest to be run with `--updateSnapshot`. - -### `--clearCache` - -Deletes the Jest cache directory and then exits without running tests. Will delete `cacheDirectory` if the option is passed, or Jest's default cache directory. The default cache directory can be found by calling `jest --showConfig`. _Note: clearing the cache will reduce performance._ - -### `--clearMocks` - -Automatically clear mock calls, instances and results before every test. Equivalent to calling [`jest.clearAllMocks()`](JestObjectAPI.md#jestclearallmocks) before each test. This does not remove any mock implementation that may have been provided. - -### `--collectCoverageFrom=` - -A glob pattern relative to `rootDir` matching the files that coverage info needs to be collected from. - -### `--colors` - -Forces test results output highlighting even if stdout is not a TTY. - -### `--config=` - -Alias: `-c`. The path to a Jest config file specifying how to find and execute tests. If no `rootDir` is set in the config, the directory containing the config file is assumed to be the `rootDir` for the project. This can also be a JSON-encoded value which Jest will use as configuration. - -### `--coverage[=]` - -Alias: `--collectCoverage`. Indicates that test coverage information should be collected and reported in the output. Optionally pass `` to override option set in configuration. - -### `--coverageProvider=` - -Indicates which provider should be used to instrument code for coverage. Allowed values are `babel` (default) or `v8`. - -Note that using `v8` is considered experimental. This uses V8's builtin code coverage rather than one based on Babel. It is not as well tested, and it has also improved in the last few releases of Node. Using the latest versions of node (v14 at the time of this writing) will yield better results. - -### `--debug` - -Print debugging info about your Jest config. - -### `--detectOpenHandles` - -Attempt to collect and print open handles preventing Jest from exiting cleanly. Use this in cases where you need to use `--forceExit` in order for Jest to exit to potentially track down the reason. This implies `--runInBand`, making tests run serially. Implemented using [`async_hooks`](https://nodejs.org/api/async_hooks.html). This option has a significant performance penalty and should only be used for debugging. - -### `--env=` - -The test environment used for all tests. This can point to any file or node module. Examples: `jsdom`, `node` or `path/to/my-environment.js`. - -### `--errorOnDeprecated` - -Make calling deprecated APIs throw helpful error messages. Useful for easing the upgrade process. - -### `--expand` - -Alias: `-e`. Use this flag to show full diffs and errors instead of a patch. - -### `--filter=` - -Path to a module exporting a filtering function. This method receives a list of tests which can be manipulated to exclude tests from running. Especially useful when used in conjunction with a testing infrastructure to filter known broken. - -### `--findRelatedTests ` - -Find and run the tests that cover a space separated list of source files that were passed in as arguments. Useful for pre-commit hook integration to run the minimal amount of tests necessary. Can be used together with `--coverage` to include a test coverage for the source files, no duplicate `--collectCoverageFrom` arguments needed. - -### `--forceExit` - -Force Jest to exit after all tests have completed running. This is useful when resources set up by test code cannot be adequately cleaned up. _Note: This feature is an escape-hatch. If Jest doesn't exit at the end of a test run, it means external resources are still being held on to or timers are still pending in your code. It is advised to tear down external resources after each test to make sure Jest can shut down cleanly. You can use `--detectOpenHandles` to help track it down._ - -### `--help` - -Show the help information, similar to this page. - -### `--init` - -Generate a basic configuration file. Based on your project, Jest will ask you a few questions that will help to generate a `jest.config.js` file with a short description for each option. - -### `--injectGlobals` - -Insert Jest's globals (`expect`, `test`, `describe`, `beforeEach` etc.) into the global environment. If you set this to `false`, you should import from `@jest/globals`, e.g. - -```ts -import {expect, jest, test} from '@jest/globals'; - -jest.useFakeTimers(); - -test('some test', () => { - expect(Date.now()).toBe(0); -}); -``` - -_Note: This option is only supported using the default `jest-circus` test runner._ - -### `--json` - -Prints the test results in JSON. This mode will send all other test output and user messages to stderr. - -### `--outputFile=` - -Write test results to a file when the `--json` option is also specified. The returned JSON structure is documented in [testResultsProcessor](Configuration.md#testresultsprocessor-string). - -### `--lastCommit` - -Run all tests affected by file changes in the last commit made. Behaves similarly to `--onlyChanged`. - -### `--listTests` - -Lists all test files that Jest will run given the arguments, and exits. - -### `--logHeapUsage` - -Logs the heap usage after every test. Useful to debug memory leaks. Use together with `--runInBand` and `--expose-gc` in node. - -### `--maxConcurrency=` - -Prevents Jest from executing more than the specified amount of tests at the same time. Only affects tests that use `test.concurrent`. - -### `--maxWorkers=|` - -Alias: `-w`. Specifies the maximum number of workers the worker-pool will spawn for running tests. In single run mode, this defaults to the number of the cores available on your machine minus one for the main thread. In watch mode, this defaults to half of the available cores on your machine to ensure Jest is unobtrusive and does not grind your machine to a halt. It may be useful to adjust this in resource limited environments like CIs but the defaults should be adequate for most use-cases. - -For environments with variable CPUs available, you can use percentage based configuration: `--maxWorkers=50%` - -### `--noStackTrace` - -Disables stack trace in test results output. - -### `--notify` - -Activates notifications for test results. Good for when you don't want your consciousness to be able to focus on anything except JavaScript testing. - -### `--onlyChanged` - -Alias: `-o`. Attempts to identify which tests to run based on which files have changed in the current repository. Only works if you're running tests in a git/hg repository at the moment and requires a static dependency graph (ie. no dynamic requires). - -### `--passWithNoTests` - -Allows the test suite to pass when no files are found. - -### `--projects ... ` - -Run tests from one or more projects, found in the specified paths; also takes path globs. This option is the CLI equivalent of the [`projects`](configuration#projects-arraystring--projectconfig) configuration option. Note that if configuration files are found in the specified paths, _all_ projects specified within those configuration files will be run. - -### `--reporters` - -Run tests with specified reporters. [Reporter options](configuration#reporters-arraymodulename--modulename-options) are not available via CLI. Example with multiple reporters: - -`jest --reporters="default" --reporters="jest-junit"` - -### `--resetMocks` - -Automatically reset mock state before every test. Equivalent to calling [`jest.resetAllMocks()`](JestObjectAPI.md#jestresetallmocks) before each test. This will lead to any mocks having their fake implementations removed but does not restore their initial implementation. - -### `--restoreMocks` - -Automatically restore mock state and implementation before every test. Equivalent to calling [`jest.restoreAllMocks()`](JestObjectAPI.md#jestrestoreallmocks) before each test. This will lead to any mocks having their fake implementations removed and restores their initial implementation. - -### `--roots` - -A list of paths to directories that Jest should use to search for files in. - -### `--runInBand` - -Alias: `-i`. Run all tests serially in the current process, rather than creating a worker pool of child processes that run tests. This can be useful for debugging. - -### `--runTestsByPath` - -Run only the tests that were specified with their exact paths. - -_Note: The default regex matching works fine on small runs, but becomes slow if provided with multiple patterns and/or against a lot of tests. This option replaces the regex matching logic and by that optimizes the time it takes Jest to filter specific test files_ - -### `--selectProjects ... ` - -Run only the tests of the specified projects. Jest uses the attribute `displayName` in the configuration to identify each project. If you use this option, you should provide a `displayName` to all your projects. - -### `--setupFilesAfterEnv ... ` - -A list of paths to modules that run some code to configure or to set up the testing framework before each test. Beware that files imported by the setup scripts will not be mocked during testing. - -### `--showConfig` - -Print your Jest config and then exits. - -### `--silent` - -Prevent tests from printing messages through the console. - -### `--testLocationInResults` - -Adds a `location` field to test results. Useful if you want to report the location of a test in a reporter. - -Note that `column` is 0-indexed while `line` is not. - -```json -{ - "column": 4, - "line": 5 -} -``` - -### `--testMatch glob1 ... globN` - -The glob patterns Jest uses to detect test files. Please refer to the [`testMatch` configuration](Configuration.md#testmatch-arraystring) for details. - -### `--testNamePattern=` - -Alias: `-t`. Run only tests with a name that matches the regex. For example, suppose you want to run only tests related to authorization which will have names like `"GET /api/posts with auth"`, then you can use `jest -t=auth`. - -_Note: The regex is matched against the full name, which is a combination of the test name and all its surrounding describe blocks._ - -### `--testPathIgnorePatterns=|[array]` - -A single or array of regexp pattern strings that are tested against all tests paths before executing the test. Contrary to `--testPathPattern`, it will only run those tests with a path that does not match with the provided regexp expressions. - -To pass as an array use escaped parentheses and space delimited regexps such as `\(/node_modules/ /tests/e2e/\)`. Alternatively, you can omit parentheses by combining regexps into a single regexp like `/node_modules/|/tests/e2e/`. These two examples are equivalent. - -### `--testPathPattern=` - -A regexp pattern string that is matched against all tests paths before executing the test. On Windows, you will need to use `/` as a path separator or escape `\` as `\\`. - -### `--testRunner=` - -Lets you specify a custom test runner. - -### `--testSequencer=` - -Lets you specify a custom test sequencer. Please refer to the documentation of the corresponding configuration property for details. - -### `--testTimeout=` - -Default timeout of a test in milliseconds. Default value: 5000. - -### `--updateSnapshot` - -Alias: `-u`. Use this flag to re-record every snapshot that fails during this test run. Can be used together with a test suite pattern or with `--testNamePattern` to re-record snapshots. - -### `--useStderr` - -Divert all output to stderr. - -### `--verbose` - -Display individual test results with the test suite hierarchy. - -### `--version` - -Alias: `-v`. Print the version and exit. - -### `--watch` - -Watch files for changes and rerun tests related to changed files. If you want to re-run all tests when a file has changed, use the `--watchAll` option instead. - -### `--watchAll` - -Watch files for changes and rerun all tests when something changes. If you want to re-run only the tests that depend on the changed files, use the `--watch` option. - -Use `--watchAll=false` to explicitly disable the watch mode. Note that in most CI environments, this is automatically handled for you. - -### `--watchman` - -Whether to use [`watchman`](https://facebook.github.io/watchman/) for file crawling. Defaults to `true`. Disable using `--no-watchman`. diff --git a/website/versioned_docs/version-27.0/Configuration.md b/website/versioned_docs/version-27.0/Configuration.md deleted file mode 100644 index 3e3c5128dcda..000000000000 --- a/website/versioned_docs/version-27.0/Configuration.md +++ /dev/null @@ -1,1438 +0,0 @@ ---- -id: configuration -title: Configuring Jest ---- - -Jest's configuration can be defined in the `package.json` file of your project, or through a `jest.config.js`, or `jest.config.ts` file or through the `--config ` option. If you'd like to use your `package.json` to store Jest's config, the `"jest"` key should be used on the top level so Jest will know how to find your settings: - -```json -{ - "name": "my-project", - "jest": { - "verbose": true - } -} -``` - -Or through JavaScript: - -```js title="jest.config.js" -// Sync object -/** @type {import('@jest/types').Config.InitialOptions} */ -const config = { - verbose: true, -}; - -module.exports = config; - -// Or async function -module.exports = async () => { - return { - verbose: true, - }; -}; -``` - -Or through TypeScript (if `ts-node` is installed): - -```ts title="jest.config.ts" -import type {Config} from '@jest/types'; - -// Sync object -const config: Config.InitialOptions = { - verbose: true, -}; -export default config; - -// Or async function -export default async (): Promise => { - return { - verbose: true, - }; -}; -``` - -Please keep in mind that the resulting configuration must be JSON-serializable. - -When using the `--config` option, the JSON file must not contain a "jest" key: - -```json -{ - "bail": 1, - "verbose": true -} -``` - -## Options - -These options let you control Jest's behavior in your `package.json` file. The Jest philosophy is to work great by default, but sometimes you just need more configuration power. - -### Defaults - -You can retrieve Jest's default options to expand them if needed: - -```js title="jest.config.js" -const {defaults} = require('jest-config'); -module.exports = { - // ... - moduleFileExtensions: [...defaults.moduleFileExtensions, 'ts', 'tsx'], - // ... -}; -``` - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Reference - -### `automock` \[boolean] - -Default: `false` - -This option tells Jest that all imported modules in your tests should be mocked automatically. All modules used in your tests will have a replacement implementation, keeping the API surface. - -Example: - -```js title="utils.js" -export default { - authorize: () => { - return 'token'; - }, - isAuthorized: secret => secret === 'wizard', -}; -``` - -```js -//__tests__/automocking.test.js -import utils from '../utils'; - -test('if utils mocked automatically', () => { - // Public methods of `utils` are now mock functions - expect(utils.authorize.mock).toBeTruthy(); - expect(utils.isAuthorized.mock).toBeTruthy(); - - // You can provide them with your own implementation - // or pass the expected return value - utils.authorize.mockReturnValue('mocked_token'); - utils.isAuthorized.mockReturnValue(true); - - expect(utils.authorize()).toBe('mocked_token'); - expect(utils.isAuthorized('not_wizard')).toBeTruthy(); -}); -``` - -_Note: Node modules are automatically mocked when you have a manual mock in place (e.g.: `__mocks__/lodash.js`). More info [here](manual-mocks#mocking-node-modules)._ - -_Note: Core modules, like `fs`, are not mocked by default. They can be mocked explicitly, like `jest.mock('fs')`._ - -### `bail` \[number | boolean] - -Default: `0` - -By default, Jest runs all tests and produces all errors into the console upon completion. The bail config option can be used here to have Jest stop running tests after `n` failures. Setting bail to `true` is the same as setting bail to `1`. - -### `cacheDirectory` \[string] - -Default: `"/tmp/"` - -The directory where Jest should store its cached dependency information. - -Jest attempts to scan your dependency tree once (up-front) and cache it in order to ease some of the filesystem churn that needs to happen while running tests. This config option lets you customize where Jest stores that cache data on disk. - -### `clearMocks` \[boolean] - -Default: `false` - -Automatically clear mock calls, instances and results before every test. Equivalent to calling [`jest.clearAllMocks()`](JestObjectAPI.md#jestclearallmocks) before each test. This does not remove any mock implementation that may have been provided. - -### `collectCoverage` \[boolean] - -Default: `false` - -Indicates whether the coverage information should be collected while executing the test. Because this retrofits all executed files with coverage collection statements, it may significantly slow down your tests. - -### `collectCoverageFrom` \[array] - -Default: `undefined` - -An array of [glob patterns](https://github.com/micromatch/micromatch) indicating a set of files for which coverage information should be collected. If a file matches the specified glob pattern, coverage information will be collected for it even if no tests exist for this file and it's never required in the test suite. - -Example: - -```json -{ - "collectCoverageFrom": [ - "**/*.{js,jsx}", - "!**/node_modules/**", - "!**/vendor/**" - ] -} -``` - -This will collect coverage information for all the files inside the project's `rootDir`, except the ones that match `**/node_modules/**` or `**/vendor/**`. - -_Note: Each glob pattern is applied in the order they are specified in the config. (For example `["!**/__tests__/**", "**/*.js"]` will not exclude `__tests__` because the negation is overwritten with the second pattern. In order to make the negated glob work in this example it has to come after `**/*.js`.)_ - -_Note: This option requires `collectCoverage` to be set to true or Jest to be invoked with `--coverage`._ - -
- Help: - If you are seeing coverage output such as... - -``` -=============================== Coverage summary =============================== -Statements : Unknown% ( 0/0 ) -Branches : Unknown% ( 0/0 ) -Functions : Unknown% ( 0/0 ) -Lines : Unknown% ( 0/0 ) -================================================================================ -Jest: Coverage data for global was not found. -``` - -Most likely your glob patterns are not matching any files. Refer to the [micromatch](https://github.com/micromatch/micromatch) documentation to ensure your globs are compatible. - -
- -### `coverageDirectory` \[string] - -Default: `undefined` - -The directory where Jest should output its coverage files. - -### `coveragePathIgnorePatterns` \[array<string>] - -Default: `["/node_modules/"]` - -An array of regexp pattern strings that are matched against all file paths before executing the test. If the file path matches any of the patterns, coverage information will be skipped. - -These pattern strings match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. Example: `["/build/", "/node_modules/"]`. - -### `coverageProvider` \[string] - -Indicates which provider should be used to instrument code for coverage. Allowed values are `babel` (default) or `v8`. - -Note that using `v8` is considered experimental. This uses V8's builtin code coverage rather than one based on Babel. It is not as well tested, and it has also improved in the last few releases of Node. Using the latest versions of node (v14 at the time of this writing) will yield better results. - -### `coverageReporters` \[array<string | \[string, options]>] - -Default: `["clover", "json", "lcov", "text"]` - -A list of reporter names that Jest uses when writing coverage reports. Any [istanbul reporter](https://github.com/istanbuljs/istanbuljs/tree/master/packages/istanbul-reports/lib) can be used. - -_Note: Setting this option overwrites the default values. Add `"text"` or `"text-summary"` to see a coverage summary in the console output._ - -Additional options can be passed using the tuple form. For example, you may hide coverage report lines for all fully-covered files: - -```json -{ - "coverageReporters": ["clover", "json", "lcov", ["text", {"skipFull": true}]] -} -``` - -For more information about the options object shape refer to `CoverageReporterWithOptions` type in the [type definitions](https://github.com/facebook/jest/tree/main/packages/jest-types/src/Config.ts). - -### `coverageThreshold` \[object] - -Default: `undefined` - -This will be used to configure minimum threshold enforcement for coverage results. Thresholds can be specified as `global`, as a [glob](https://github.com/isaacs/node-glob#glob-primer), and as a directory or file path. If thresholds aren't met, jest will fail. Thresholds specified as a positive number are taken to be the minimum percentage required. Thresholds specified as a negative number represent the maximum number of uncovered entities allowed. - -For example, with the following configuration jest will fail if there is less than 80% branch, line, and function coverage, or if there are more than 10 uncovered statements: - -```json -{ - ... - "jest": { - "coverageThreshold": { - "global": { - "branches": 80, - "functions": 80, - "lines": 80, - "statements": -10 - } - } - } -} -``` - -If globs or paths are specified alongside `global`, coverage data for matching paths will be subtracted from overall coverage and thresholds will be applied independently. Thresholds for globs are applied to all files matching the glob. If the file specified by path is not found, an error is returned. - -For example, with the following configuration: - -```json -{ - ... - "jest": { - "coverageThreshold": { - "global": { - "branches": 50, - "functions": 50, - "lines": 50, - "statements": 50 - }, - "./src/components/": { - "branches": 40, - "statements": 40 - }, - "./src/reducers/**/*.js": { - "statements": 90 - }, - "./src/api/very-important-module.js": { - "branches": 100, - "functions": 100, - "lines": 100, - "statements": 100 - } - } - } -} -``` - -Jest will fail if: - -- The `./src/components` directory has less than 40% branch or statement coverage. -- One of the files matching the `./src/reducers/**/*.js` glob has less than 90% statement coverage. -- The `./src/api/very-important-module.js` file has less than 100% coverage. -- Every remaining file combined has less than 50% coverage (`global`). - -### `dependencyExtractor` \[string] - -Default: `undefined` - -This option allows the use of a custom dependency extractor. It must be a node module that exports an object with an `extract` function. E.g.: - -```javascript -const crypto = require('crypto'); -const fs = require('fs'); - -module.exports = { - extract(code, filePath, defaultExtract) { - const deps = defaultExtract(code, filePath); - // Scan the file and add dependencies in `deps` (which is a `Set`) - return deps; - }, - getCacheKey() { - return crypto - .createHash('md5') - .update(fs.readFileSync(__filename)) - .digest('hex'); - }, -}; -``` - -The `extract` function should return an iterable (`Array`, `Set`, etc.) with the dependencies found in the code. - -That module can also contain a `getCacheKey` function to generate a cache key to determine if the logic has changed and any cached artifacts relying on it should be discarded. - -### `displayName` \[string, object] - -default: `undefined` - -Allows for a label to be printed alongside a test while it is running. This becomes more useful in multi-project repositories where there can be many jest configuration files. This visually tells which project a test belongs to. Here are sample valid values. - -```js -module.exports = { - displayName: 'CLIENT', -}; -``` - -or - -```js -module.exports = { - displayName: { - name: 'CLIENT', - color: 'blue', - }, -}; -``` - -As a secondary option, an object with the properties `name` and `color` can be passed. This allows for a custom configuration of the background color of the displayName. `displayName` defaults to white when its value is a string. Jest uses [chalk](https://github.com/chalk/chalk) to provide the color. As such, all of the valid options for colors supported by chalk are also supported by jest. - -### `errorOnDeprecated` \[boolean] - -Default: `false` - -Make calling deprecated APIs throw helpful error messages. Useful for easing the upgrade process. - -### `extensionsToTreatAsEsm` \[array<string>] - -Default: `[]` - -Jest will run `.mjs` and `.js` files with nearest `package.json`'s `type` field set to `module` as ECMAScript Modules. If you have any other files that should run with native ESM, you need to specify their file extension here. - -> Note: Jest's ESM support is still experimental, see [its docs for more details](ECMAScriptModules.md). - -```json -{ - ... - "jest": { - "extensionsToTreatAsEsm": [".ts"] - } -} -``` - -### `extraGlobals` \[array<string>] - -Default: `undefined` - -Test files run inside a [vm](https://nodejs.org/api/vm.html), which slows calls to global context properties (e.g. `Math`). With this option you can specify extra properties to be defined inside the vm for faster lookups. - -For example, if your tests call `Math` often, you can pass it by setting `extraGlobals`. - -```json -{ - ... - "jest": { - "extraGlobals": ["Math"] - } -} -``` - -### `forceCoverageMatch` \[array<string>] - -Default: `['']` - -Test files are normally ignored from collecting code coverage. With this option, you can overwrite this behavior and include otherwise ignored files in code coverage. - -For example, if you have tests in source files named with `.t.js` extension as following: - -```javascript title="sum.t.js" -export function sum(a, b) { - return a + b; -} - -if (process.env.NODE_ENV === 'test') { - test('sum', () => { - expect(sum(1, 2)).toBe(3); - }); -} -``` - -You can collect coverage from those files with setting `forceCoverageMatch`. - -```json -{ - ... - "jest": { - "forceCoverageMatch": ["**/*.t.js"] - } -} -``` - -### `globals` \[object] - -Default: `{}` - -A set of global variables that need to be available in all test environments. - -For example, the following would create a global `__DEV__` variable set to `true` in all test environments: - -```json -{ - ... - "jest": { - "globals": { - "__DEV__": true - } - } -} -``` - -Note that, if you specify a global reference value (like an object or array) here, and some code mutates that value in the midst of running a test, that mutation will _not_ be persisted across test runs for other test files. In addition, the `globals` object must be json-serializable, so it can't be used to specify global functions. For that, you should use `setupFiles`. - -### `globalSetup` \[string] - -Default: `undefined` - -This option allows the use of a custom global setup module which exports an async function that is triggered once before all test suites. This function gets Jest's `globalConfig` object as a parameter. - -_Note: A global setup module configured in a project (using multi-project runner) will be triggered only when you run at least one test from this project._ - -_Note: Any global variables that are defined through `globalSetup` can only be read in `globalTeardown`. You cannot retrieve globals defined here in your test suites._ - -_Note: While code transformation is applied to the linked setup-file, Jest will **not** transform any code in `node_modules`. This is due to the need to load the actual transformers (e.g. `babel` or `typescript`) to perform transformation._ - -Example: - -```js title="setup.js" -// can be synchronous -module.exports = async () => { - // ... - // Set reference to mongod in order to close the server during teardown. - global.__MONGOD__ = mongod; -}; -``` - -```js title="teardown.js" -module.exports = async function () { - await global.__MONGOD__.stop(); -}; -``` - -### `globalTeardown` \[string] - -Default: `undefined` - -This option allows the use of a custom global teardown module which exports an async function that is triggered once after all test suites. This function gets Jest's `globalConfig` object as a parameter. - -_Note: A global teardown module configured in a project (using multi-project runner) will be triggered only when you run at least one test from this project._ - -_Note: The same caveat concerning transformation of `node_modules` as for `globalSetup` applies to `globalTeardown`._ - -### `haste` \[object] - -Default: `undefined` - -This will be used to configure the behavior of `jest-haste-map`, Jest's internal file crawler/cache system. The following options are supported: - -```ts -type HasteConfig = { - /** Whether to hash files using SHA-1. */ - computeSha1?: boolean; - /** The platform to use as the default, e.g. 'ios'. */ - defaultPlatform?: string | null; - /** Force use of Node's `fs` APIs rather than shelling out to `find` */ - forceNodeFilesystemAPI?: boolean; - /** - * Whether to follow symlinks when crawling for files. - * This options cannot be used in projects which use watchman. - * Projects with `watchman` set to true will error if this option is set to true. - */ - enableSymlinks?: boolean; - /** Path to a custom implementation of Haste. */ - hasteImplModulePath?: string; - /** All platforms to target, e.g ['ios', 'android']. */ - platforms?: Array; - /** Whether to throw on error on module collision. */ - throwOnModuleCollision?: boolean; - /** Custom HasteMap module */ - hasteMapModulePath?: string; -}; -``` - -### `injectGlobals` \[boolean] - -Default: `true` - -Insert Jest's globals (`expect`, `test`, `describe`, `beforeEach` etc.) into the global environment. If you set this to `false`, you should import from `@jest/globals`, e.g. - -```ts -import {expect, jest, test} from '@jest/globals'; - -jest.useFakeTimers(); - -test('some test', () => { - expect(Date.now()).toBe(0); -}); -``` - -_Note: This option is only supported using the default `jest-circus`. test runner_ - -### `maxConcurrency` \[number] - -Default: `5` - -A number limiting the number of tests that are allowed to run at the same time when using `test.concurrent`. Any test above this limit will be queued and executed once a slot is released. - -### `maxWorkers` \[number | string] - -Specifies the maximum number of workers the worker-pool will spawn for running tests. In single run mode, this defaults to the number of the cores available on your machine minus one for the main thread. In watch mode, this defaults to half of the available cores on your machine to ensure Jest is unobtrusive and does not grind your machine to a halt. It may be useful to adjust this in resource limited environments like CIs but the defaults should be adequate for most use-cases. - -For environments with variable CPUs available, you can use percentage based configuration: `"maxWorkers": "50%"` - -### `moduleDirectories` \[array<string>] - -Default: `["node_modules"]` - -An array of directory names to be searched recursively up from the requiring module's location. Setting this option will _override_ the default, if you wish to still search `node_modules` for packages include it along with any other options: `["node_modules", "bower_components"]` - -### `moduleFileExtensions` \[array<string>] - -Default: `["js", "jsx", "ts", "tsx", "json", "node"]` - -An array of file extensions your modules use. If you require modules without specifying a file extension, these are the extensions Jest will look for, in left-to-right order. - -We recommend placing the extensions most commonly used in your project on the left, so if you are using TypeScript, you may want to consider moving "ts" and/or "tsx" to the beginning of the array. - -### `moduleNameMapper` \[object<string, string | array<string>>] - -Default: `null` - -A map from regular expressions to module names or to arrays of module names that allow to stub out resources, like images or styles with a single module. - -Modules that are mapped to an alias are unmocked by default, regardless of whether automocking is enabled or not. - -Use `` string token to refer to [`rootDir`](#rootdir-string) value if you want to use file paths. - -Additionally, you can substitute captured regex groups using numbered backreferences. - -Example: - -```json -{ - "moduleNameMapper": { - "^image![a-zA-Z0-9$_-]+$": "GlobalImageStub", - "^[./a-zA-Z0-9$_-]+\\.png$": "/RelativeImageStub.js", - "module_name_(.*)": "/substituted_module_$1.js", - "assets/(.*)": [ - "/images/$1", - "/photos/$1", - "/recipes/$1" - ] - } -} -``` - -The order in which the mappings are defined matters. Patterns are checked one by one until one fits. The most specific rule should be listed first. This is true for arrays of module names as well. - -_Note: If you provide module name without boundaries `^$` it may cause hard to spot errors. E.g. `relay` will replace all modules which contain `relay` as a substring in its name: `relay`, `react-relay` and `graphql-relay` will all be pointed to your stub._ - -### `modulePathIgnorePatterns` \[array<string>] - -Default: `[]` - -An array of regexp pattern strings that are matched against all module paths before those paths are to be considered 'visible' to the module loader. If a given module's path matches any of the patterns, it will not be `require()`-able in the test environment. - -These pattern strings match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. Example: `["/build/"]`. - -### `modulePaths` \[array<string>] - -Default: `[]` - -An alternative API to setting the `NODE_PATH` env variable, `modulePaths` is an array of absolute paths to additional locations to search when resolving modules. Use the `` string token to include the path to your project's root directory. Example: `["/app/"]`. - -### `notify` \[boolean] - -Default: `false` - -Activates notifications for test results. - -**Beware:** Jest uses [node-notifier](https://github.com/mikaelbr/node-notifier) to display desktop notifications. On Windows, it creates a new start menu entry on the first use and not display the notification. Notifications will be properly displayed on subsequent runs - -### `notifyMode` \[string] - -Default: `failure-change` - -Specifies notification mode. Requires `notify: true`. - -#### Modes - -- `always`: always send a notification. -- `failure`: send a notification when tests fail. -- `success`: send a notification when tests pass. -- `change`: send a notification when the status changed. -- `success-change`: send a notification when tests pass or once when it fails. -- `failure-change`: send a notification when tests fail or once when it passes. - -### `preset` \[string] - -Default: `undefined` - -A preset that is used as a base for Jest's configuration. A preset should point to an npm module that has a `jest-preset.json`, `jest-preset.js`, `jest-preset.cjs` or `jest-preset.mjs` file at the root. - -For example, this preset `foo-bar/jest-preset.js` will be configured as follows: - -```json -{ - "preset": "foo-bar" -} -``` - -Presets may also be relative to filesystem paths. - -```json -{ - "preset": "./node_modules/foo-bar/jest-preset.js" -} -``` - -### `prettierPath` \[string] - -Default: `'prettier'` - -Sets the path to the [`prettier`](https://prettier.io/) node module used to update inline snapshots. - -### `projects` \[array<string | ProjectConfig>] - -Default: `undefined` - -When the `projects` configuration is provided with an array of paths or glob patterns, Jest will run tests in all of the specified projects at the same time. This is great for monorepos or when working on multiple projects at the same time. - -```json -{ - "projects": ["", "/examples/*"] -} -``` - -This example configuration will run Jest in the root directory as well as in every folder in the examples directory. You can have an unlimited amount of projects running in the same Jest instance. - -The projects feature can also be used to run multiple configurations or multiple [runners](#runner-string). For this purpose, you can pass an array of configuration objects. For example, to run both tests and ESLint (via [jest-runner-eslint](https://github.com/jest-community/jest-runner-eslint)) in the same invocation of Jest: - -```json -{ - "projects": [ - { - "displayName": "test" - }, - { - "displayName": "lint", - "runner": "jest-runner-eslint", - "testMatch": ["/**/*.js"] - } - ] -} -``` - -_Note: When using multi-project runner, it's recommended to add a `displayName` for each project. This will show the `displayName` of a project next to its tests._ - -### `reporters` \[array<moduleName | \[moduleName, options]>] - -Default: `undefined` - -Use this configuration option to add custom reporters to Jest. A custom reporter is a class that implements `onRunStart`, `onTestStart`, `onTestResult`, `onRunComplete` methods that will be called when any of those events occurs. - -If custom reporters are specified, the default Jest reporters will be overridden. To keep default reporters, `default` can be passed as a module name. - -This will override default reporters: - -```json -{ - "reporters": ["/my-custom-reporter.js"] -} -``` - -This will use custom reporter in addition to default reporters that Jest provides: - -```json -{ - "reporters": ["default", "/my-custom-reporter.js"] -} -``` - -Additionally, custom reporters can be configured by passing an `options` object as a second argument: - -```json -{ - "reporters": [ - "default", - ["/my-custom-reporter.js", {"banana": "yes", "pineapple": "no"}] - ] -} -``` - -Custom reporter modules must define a class that takes a `GlobalConfig` and reporter options as constructor arguments: - -Example reporter: - -```js title="my-custom-reporter.js" -class MyCustomReporter { - constructor(globalConfig, options) { - this._globalConfig = globalConfig; - this._options = options; - } - - onRunComplete(contexts, results) { - console.log('Custom reporter output:'); - console.log('GlobalConfig: ', this._globalConfig); - console.log('Options: ', this._options); - } -} - -module.exports = MyCustomReporter; -// or export default MyCustomReporter; -``` - -Custom reporters can also force Jest to exit with non-0 code by returning an Error from `getLastError()` methods - -```js -class MyCustomReporter { - // ... - getLastError() { - if (this._shouldFail) { - return new Error('my-custom-reporter.js reported an error'); - } - } -} -``` - -For the full list of methods and argument types see `Reporter` interface in [packages/jest-reporters/src/types.ts](https://github.com/facebook/jest/blob/main/packages/jest-reporters/src/types.ts) - -### `resetMocks` \[boolean] - -Default: `false` - -Automatically reset mock state before every test. Equivalent to calling [`jest.resetAllMocks()`](JestObjectAPI.md#jestresetallmocks) before each test. This will lead to any mocks having their fake implementations removed but does not restore their initial implementation. - -### `resetModules` \[boolean] - -Default: `false` - -By default, each test file gets its own independent module registry. Enabling `resetModules` goes a step further and resets the module registry before running each individual test. This is useful to isolate modules for every test so that the local module state doesn't conflict between tests. This can be done programmatically using [`jest.resetModules()`](JestObjectAPI.md#jestresetmodules). - -### `resolver` \[string] - -Default: `undefined` - -This option allows the use of a custom resolver. This resolver must be a node module that exports a function expecting a string as the first argument for the path to resolve and an object with the following structure as the second argument: - -```json -{ - "basedir": string, - "defaultResolver": "function(request, options)", - "extensions": [string], - "moduleDirectory": [string], - "paths": [string], - "packageFilter": "function(pkg, pkgdir)", - "rootDir": [string] -} -``` - -The function should either return a path to the module that should be resolved or throw an error if the module can't be found. - -Note: the defaultResolver passed as an option is the Jest default resolver which might be useful when you write your custom one. It takes the same arguments as your custom one, e.g. `(request, options)`. - -For example, if you want to respect Browserify's [`"browser"` field](https://github.com/browserify/browserify-handbook/blob/master/readme.markdown#browser-field), you can use the following configuration: - -```json -{ - ... - "jest": { - "resolver": "/resolver.js" - } -} -``` - -```js title="resolver.js" -const browserResolve = require('browser-resolve'); - -module.exports = browserResolve.sync; -``` - -By combining `defaultResolver` and `packageFilter` we can implement a `package.json` "pre-processor" that allows us to change how the default resolver will resolve modules. For example, imagine we want to use the field `"module"` if it is present, otherwise fallback to `"main"`: - -```json -{ - ... - "jest": { - "resolver": "my-module-resolve" - } -} -``` - -```js -// my-module-resolve package - -module.exports = (request, options) => { - // Call the defaultResolver, so we leverage its cache, error handling, etc. - return options.defaultResolver(request, { - ...options, - // Use packageFilter to process parsed `package.json` before the resolution (see https://www.npmjs.com/package/resolve#resolveid-opts-cb) - packageFilter: pkg => { - return { - ...pkg, - // Alter the value of `main` before resolving the package - main: pkg.module || pkg.main, - }; - }, - }); -}; -``` - -### `restoreMocks` \[boolean] - -Default: `false` - -Automatically restore mock state and implementation before every test. Equivalent to calling [`jest.restoreAllMocks()`](JestObjectAPI.md#jestrestoreallmocks) before each test. This will lead to any mocks having their fake implementations removed and restores their initial implementation. - -### `rootDir` \[string] - -Default: The root of the directory containing your Jest [config file](#) _or_ the `package.json` _or_ the [`pwd`](http://en.wikipedia.org/wiki/Pwd) if no `package.json` is found - -The root directory that Jest should scan for tests and modules within. If you put your Jest config inside your `package.json` and want the root directory to be the root of your repo, the value for this config param will default to the directory of the `package.json`. - -Oftentimes, you'll want to set this to `'src'` or `'lib'`, corresponding to where in your repository the code is stored. - -_Note that using `''` as a string token in any other path-based config settings will refer back to this value. So, for example, if you want your [`setupFiles`](#setupfiles-array) config entry to point at the `env-setup.js` file at the root of your project, you could set its value to `["/env-setup.js"]`._ - -### `roots` \[array<string>] - -Default: `[""]` - -A list of paths to directories that Jest should use to search for files in. - -There are times where you only want Jest to search in a single sub-directory (such as cases where you have a `src/` directory in your repo), but prevent it from accessing the rest of the repo. - -_Note: While `rootDir` is mostly used as a token to be re-used in other configuration options, `roots` is used by the internals of Jest to locate **test files and source files**. This applies also when searching for manual mocks for modules from `node_modules` (`__mocks__` will need to live in one of the `roots`)._ - -_Note: By default, `roots` has a single entry `` but there are cases where you may want to have multiple roots within one project, for example `roots: ["/src/", "/tests/"]`._ - -### `runner` \[string] - -Default: `"jest-runner"` - -This option allows you to use a custom runner instead of Jest's default test runner. Examples of runners include: - -- [`jest-runner-eslint`](https://github.com/jest-community/jest-runner-eslint) -- [`jest-runner-mocha`](https://github.com/rogeliog/jest-runner-mocha) -- [`jest-runner-tsc`](https://github.com/azz/jest-runner-tsc) -- [`jest-runner-prettier`](https://github.com/keplersj/jest-runner-prettier) - -_Note: The `runner` property value can omit the `jest-runner-` prefix of the package name._ - -To write a test-runner, export a class with which accepts `globalConfig` in the constructor, and has a `runTests` method with the signature: - -```ts -async function runTests( - tests: Array, - watcher: TestWatcher, - onStart: OnTestStart, - onResult: OnTestSuccess, - onFailure: OnTestFailure, - options: TestRunnerOptions, -): Promise; -``` - -If you need to restrict your test-runner to only run in serial rather than being executed in parallel your class should have the property `isSerial` to be set as `true`. - -### `setupFiles` \[array] - -Default: `[]` - -A list of paths to modules that run some code to configure or set up the testing environment. Each setupFile will be run once per test file. Since every test runs in its own environment, these scripts will be executed in the testing environment before executing [`setupFilesAfterEnv`](#setupfilesafterenv-array) and before the test code itself. - -### `setupFilesAfterEnv` \[array] - -Default: `[]` - -A list of paths to modules that run some code to configure or set up the testing framework before each test file in the suite is executed. Since [`setupFiles`](#setupfiles-array) executes before the test framework is installed in the environment, this script file presents you the opportunity of running some code immediately after the test framework has been installed in the environment but before the test code itself. - -If you want a path to be [relative to the root directory of your project](#rootdir-string), please include `` inside a path's string, like `"/a-configs-folder"`. - -For example, Jest ships with several plug-ins to `jasmine` that work by monkey-patching the jasmine API. If you wanted to add even more jasmine plugins to the mix (or if you wanted some custom, project-wide matchers for example), you could do so in these modules. - -Example `setupFilesAfterEnv` array in a jest.config.js: - -```js -module.exports = { - setupFilesAfterEnv: ['./jest.setup.js'], -}; -``` - -Example `jest.setup.js` file - -```js -jest.setTimeout(10000); // in milliseconds - -// you can even use the setup/teardown methods -beforeAll(() => { - // your code -}); -beforeEach(() => { - // your code -}); -afterEach(() => { - // your code -}); -afterAll(() => { - // your code -}); -``` - -### `slowTestThreshold` \[number] - -Default: `5` - -The number of seconds after which a test is considered as slow and reported as such in the results. - -### `snapshotResolver` \[string] - -Default: `undefined` - -The path to a module that can resolve test<->snapshot path. This config option lets you customize where Jest stores snapshot files on disk. - -Example snapshot resolver module: - -```js -module.exports = { - // resolves from test to snapshot path - resolveSnapshotPath: (testPath, snapshotExtension) => - testPath.replace('__tests__', '__snapshots__') + snapshotExtension, - - // resolves from snapshot to test path - resolveTestPath: (snapshotFilePath, snapshotExtension) => - snapshotFilePath - .replace('__snapshots__', '__tests__') - .slice(0, -snapshotExtension.length), - - // Example test path, used for preflight consistency check of the implementation above - testPathForConsistencyCheck: 'some/__tests__/example.test.js', -}; -``` - -### `snapshotSerializers` \[array<string>] - -Default: `[]` - -A list of paths to snapshot serializer modules Jest should use for snapshot testing. - -Jest has default serializers for built-in JavaScript types, HTML elements (Jest 20.0.0+), ImmutableJS (Jest 20.0.0+) and for React elements. See [snapshot test tutorial](TutorialReactNative.md#snapshot-test) for more information. - -Example serializer module: - -```js -// my-serializer-module -module.exports = { - serialize(val, config, indentation, depth, refs, printer) { - return `Pretty foo: ${printer(val.foo)}`; - }, - - test(val) { - return val && Object.prototype.hasOwnProperty.call(val, 'foo'); - }, -}; -``` - -`printer` is a function that serializes a value using existing plugins. - -To use `my-serializer-module` as a serializer, configuration would be as follows: - -```json -{ - ... - "jest": { - "snapshotSerializers": ["my-serializer-module"] - } -} -``` - -Finally tests would look as follows: - -```js -test(() => { - const bar = { - foo: { - x: 1, - y: 2, - }, - }; - - expect(bar).toMatchSnapshot(); -}); -``` - -Rendered snapshot: - -```json -Pretty foo: Object { - "x": 1, - "y": 2, -} -``` - -To make a dependency explicit instead of implicit, you can call [`expect.addSnapshotSerializer`](ExpectAPI.md#expectaddsnapshotserializerserializer) to add a module for an individual test file instead of adding its path to `snapshotSerializers` in Jest configuration. - -More about serializers API can be found [here](https://github.com/facebook/jest/tree/main/packages/pretty-format/README.md#serialize). - -### `testEnvironment` \[string] - -Default: `"node"` - -The test environment that will be used for testing. The default environment in Jest is a Node.js environment. If you are building a web app, you can use a browser-like environment through [`jsdom`](https://github.com/jsdom/jsdom) instead. - -By adding a `@jest-environment` docblock at the top of the file, you can specify another environment to be used for all tests in that file: - -```js -/** - * @jest-environment jsdom - */ - -test('use jsdom in this test file', () => { - const element = document.createElement('div'); - expect(element).not.toBeNull(); -}); -``` - -You can create your own module that will be used for setting up the test environment. The module must export a class with `setup`, `teardown` and `getVmContext` methods. You can also pass variables from this module to your test suites by assigning them to `this.global` object – this will make them available in your test suites as global variables. - -The class may optionally expose an asynchronous `handleTestEvent` method to bind to events fired by [`jest-circus`](https://github.com/facebook/jest/tree/main/packages/jest-circus). Normally, `jest-circus` test runner would pause until a promise returned from `handleTestEvent` gets fulfilled, **except for the next events**: `start_describe_definition`, `finish_describe_definition`, `add_hook`, `add_test` or `error` (for the up-to-date list you can look at [SyncEvent type in the types definitions](https://github.com/facebook/jest/tree/main/packages/jest-types/src/Circus.ts)). That is caused by backward compatibility reasons and `process.on('unhandledRejection', callback)` signature, but that usually should not be a problem for most of the use cases. - -Any docblock pragmas in test files will be passed to the environment constructor and can be used for per-test configuration. If the pragma does not have a value, it will be present in the object with its value set to an empty string. If the pragma is not present, it will not be present in the object. - -To use this class as your custom environment, refer to it by its full path within the project. For example, if your class is stored in `my-custom-environment.js` in some subfolder of your project, then the annotation might look like this: - -```js -/** - * @jest-environment ./src/test/my-custom-environment - */ -``` - -_Note: TestEnvironment is sandboxed. Each test suite will trigger setup/teardown in their own TestEnvironment._ - -Example: - -```js -// my-custom-environment -const NodeEnvironment = require('jest-environment-node'); - -class CustomEnvironment extends NodeEnvironment { - constructor(config, context) { - super(config, context); - this.testPath = context.testPath; - this.docblockPragmas = context.docblockPragmas; - } - - async setup() { - await super.setup(); - await someSetupTasks(this.testPath); - this.global.someGlobalObject = createGlobalObject(); - - // Will trigger if docblock contains @my-custom-pragma my-pragma-value - if (this.docblockPragmas['my-custom-pragma'] === 'my-pragma-value') { - // ... - } - } - - async teardown() { - this.global.someGlobalObject = destroyGlobalObject(); - await someTeardownTasks(); - await super.teardown(); - } - - getVmContext() { - return super.getVmContext(); - } - - async handleTestEvent(event, state) { - if (event.name === 'test_start') { - // ... - } - } -} - -module.exports = CustomEnvironment; -``` - -```js -// my-test-suite -/** - * @jest-environment ./my-custom-environment - */ -let someGlobalObject; - -beforeAll(() => { - someGlobalObject = global.someGlobalObject; -}); -``` - -### `testEnvironmentOptions` \[Object] - -Default: `{}` - -Test environment options that will be passed to the `testEnvironment`. The relevant options depend on the environment. For example, you can override options given to [jsdom](https://github.com/jsdom/jsdom) such as `{userAgent: "Agent/007"}`. - -### `testFailureExitCode` \[number] - -Default: `1` - -The exit code Jest returns on test failure. - -_Note: This does not change the exit code in the case of Jest errors (e.g. invalid configuration)._ - -### `testMatch` \[array<string>] - -(default: `[ "**/__tests__/**/*.[jt]s?(x)", "**/?(*.)+(spec|test).[jt]s?(x)" ]`) - -The glob patterns Jest uses to detect test files. By default it looks for `.js`, `.jsx`, `.ts` and `.tsx` files inside of `__tests__` folders, as well as any files with a suffix of `.test` or `.spec` (e.g. `Component.test.js` or `Component.spec.js`). It will also find files called `test.js` or `spec.js`. - -See the [micromatch](https://github.com/micromatch/micromatch) package for details of the patterns you can specify. - -See also [`testRegex` [string | array<string>]](#testregex-string--arraystring), but note that you cannot specify both options. - -_Note: Each glob pattern is applied in the order they are specified in the config. (For example `["!**/__fixtures__/**", "**/__tests__/**/*.js"]` will not exclude `__fixtures__` because the negation is overwritten with the second pattern. In order to make the negated glob work in this example it has to come after `**/__tests__/**/*.js`.)_ - -### `testPathIgnorePatterns` \[array<string>] - -Default: `["/node_modules/"]` - -An array of regexp pattern strings that are matched against all test paths before executing the test. If the test path matches any of the patterns, it will be skipped. - -These pattern strings match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. Example: `["/build/", "/node_modules/"]`. - -### `testRegex` \[string | array<string>] - -Default: `(/__tests__/.*|(\\.|/)(test|spec))\\.[jt]sx?$` - -The pattern or patterns Jest uses to detect test files. By default it looks for `.js`, `.jsx`, `.ts` and `.tsx` files inside of `__tests__` folders, as well as any files with a suffix of `.test` or `.spec` (e.g. `Component.test.js` or `Component.spec.js`). It will also find files called `test.js` or `spec.js`. See also [`testMatch` [array<string>]](#testmatch-arraystring), but note that you cannot specify both options. - -The following is a visualization of the default regex: - -```bash -├── __tests__ -│ └── component.spec.js # test -│ └── anything # test -├── package.json # not test -├── foo.test.js # test -├── bar.spec.jsx # test -└── component.js # not test -``` - -_Note: `testRegex` will try to detect test files using the **absolute file path**, therefore, having a folder with a name that matches it will run all the files as tests_ - -### `testResultsProcessor` \[string] - -Default: `undefined` - -This option allows the use of a custom results processor. This processor must be a node module that exports a function expecting an object with the following structure as the first argument and return it: - -```json -{ - "success": boolean, - "startTime": epoch, - "numTotalTestSuites": number, - "numPassedTestSuites": number, - "numFailedTestSuites": number, - "numRuntimeErrorTestSuites": number, - "numTotalTests": number, - "numPassedTests": number, - "numFailedTests": number, - "numPendingTests": number, - "numTodoTests": number, - "openHandles": Array, - "testResults": [{ - "numFailingTests": number, - "numPassingTests": number, - "numPendingTests": number, - "testResults": [{ - "title": string (message in it block), - "status": "failed" | "pending" | "passed", - "ancestorTitles": [string (message in describe blocks)], - "failureMessages": [string], - "numPassingAsserts": number, - "location": { - "column": number, - "line": number - } - }, - ... - ], - "perfStats": { - "start": epoch, - "end": epoch - }, - "testFilePath": absolute path to test file, - "coverage": {} - }, - "testExecError:" (exists if there was a top-level failure) { - "message": string - "stack": string - } - ... - ] -} -``` - -`testResultsProcessor` and `reporters` are very similar to each other. One difference is that a test result processor only gets called after all tests finished. Whereas a reporter has the ability to receive test results after individual tests and/or test suites are finished. - -### `testRunner` \[string] - -Default: `jest-circus/runner` - -This option allows the use of a custom test runner. The default is `jest-circus`. A custom test runner can be provided by specifying a path to a test runner implementation. - -The test runner module must export a function with the following signature: - -```ts -function testRunner( - globalConfig: GlobalConfig, - config: ProjectConfig, - environment: Environment, - runtime: Runtime, - testPath: string, -): Promise; -``` - -An example of such function can be found in our default [jasmine2 test runner package](https://github.com/facebook/jest/blob/main/packages/jest-jasmine2/src/index.ts). - -### `testSequencer` \[string] - -Default: `@jest/test-sequencer` - -This option allows you to use a custom sequencer instead of Jest's default. `sort` may optionally return a Promise. - -Example: - -Sort test path alphabetically. - -```js title="testSequencer.js" -const Sequencer = require('@jest/test-sequencer').default; - -class CustomSequencer extends Sequencer { - sort(tests) { - // Test structure information - // https://github.com/facebook/jest/blob/6b8b1404a1d9254e7d5d90a8934087a9c9899dab/packages/jest-runner/src/types.ts#L17-L21 - const copyTests = Array.from(tests); - return copyTests.sort((testA, testB) => (testA.path > testB.path ? 1 : -1)); - } -} - -module.exports = CustomSequencer; -``` - -Use it in your Jest config file like this: - -```json -{ - "testSequencer": "path/to/testSequencer.js" -} -``` - -### `testTimeout` \[number] - -Default: `5000` - -Default timeout of a test in milliseconds. - -### `testURL` \[string] - -Default: `http://localhost` - -This option sets the URL for the jsdom environment. It is reflected in properties such as `location.href`. - -### `timers` \[string] - -Default: `real` - -Setting this value to `fake` or `modern` enables fake timers for all tests by default. Fake timers are useful when a piece of code sets a long timeout that we don't want to wait for in a test. You can learn more about fake timers [here](JestObjectAPI.md#jestusefaketimersimplementation-modern--legacy). - -If the value is `legacy`, the old implementation will be used as implementation instead of one backed by [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). - -### `transform` \[object<string, pathToTransformer | \[pathToTransformer, object]>] - -Default: `{"\\.[jt]sx?$": "babel-jest"}` - -A map from regular expressions to paths to transformers. A transformer is a module that provides a synchronous function for transforming source files. For example, if you wanted to be able to use a new language feature in your modules or tests that aren't yet supported by node, you might plug in one of many compilers that compile a future version of JavaScript to a current one. Example: see the [examples/typescript](https://github.com/facebook/jest/blob/main/examples/typescript/package.json#L16) example or the [webpack tutorial](Webpack.md). - -Examples of such compilers include: - -- [Babel](https://babeljs.io/) -- [TypeScript](http://www.typescriptlang.org/) -- To build your own please visit the [Custom Transformer](CodeTransformation.md#writing-custom-transformers) section - -You can pass configuration to a transformer like `{filePattern: ['path-to-transformer', {options}]}` For example, to configure babel-jest for non-default behavior, `{"\\.js$": ['babel-jest', {rootMode: "upward"}]}` - -_Note: a transformer is only run once per file unless the file has changed. During the development of a transformer it can be useful to run Jest with `--no-cache` to frequently [delete Jest's cache](Troubleshooting.md#caching-issues)._ - -_Note: when adding additional code transformers, this will overwrite the default config and `babel-jest` is no longer automatically loaded. If you want to use it to compile JavaScript or Typescript, it has to be explicitly defined by adding `{"\\.[jt]sx?$": "babel-jest"}` to the transform property. See [babel-jest plugin](https://github.com/facebook/jest/tree/main/packages/babel-jest#setup)_ - -A transformer must be an object with at least a `process` function, and it's also recommended to include a `getCacheKey` function. If your transformer is written in ESM you should have a default export with that object. - -If the tests are written using [native ESM](ECMAScriptModules.md) the transformer can export `processAsync` and `getCacheKeyAsync` instead or in addition to the synchronous variants. - -### `transformIgnorePatterns` \[array<string>] - -Default: `["/node_modules/", "\\.pnp\\.[^\\\/]+$"]` - -An array of regexp pattern strings that are matched against all source file paths before transformation. If the file path matches **any** of the patterns, it will not be transformed. - -Providing regexp patterns that overlap with each other may result in files not being transformed that you expected to be transformed. For example: - -```json -{ - "transformIgnorePatterns": ["/node_modules/(?!(foo|bar)/)", "/bar/"] -} -``` - -The first pattern will match (and therefore not transform) files inside `/node_modules` except for those in `/node_modules/foo/` and `/node_modules/bar/`. The second pattern will match (and therefore not transform) files inside any path with `/bar/` in it. With the two together, files in `/node_modules/bar/` will not be transformed because it does match the second pattern, even though it was excluded by the first. - -Sometimes it happens (especially in React Native or TypeScript projects) that 3rd party modules are published as untranspiled code. Since all files inside `node_modules` are not transformed by default, Jest will not understand the code in these modules, resulting in syntax errors. To overcome this, you may use `transformIgnorePatterns` to allow transpiling such modules. You'll find a good example of this use case in [React Native Guide](/docs/tutorial-react-native#transformignorepatterns-customization). - -These pattern strings match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. - -Example: - -```json -{ - "transformIgnorePatterns": [ - "/bower_components/", - "/node_modules/" - ] -} -``` - -### `unmockedModulePathPatterns` \[array<string>] - -Default: `[]` - -An array of regexp pattern strings that are matched against all modules before the module loader will automatically return a mock for them. If a module's path matches any of the patterns in this list, it will not be automatically mocked by the module loader. - -This is useful for some commonly used 'utility' modules that are almost always used as implementation details almost all the time (like underscore/lo-dash, etc). It's generally a best practice to keep this list as small as possible and always use explicit `jest.mock()`/`jest.unmock()` calls in individual tests. Explicit per-test setup is far easier for other readers of the test to reason about the environment the test will run in. - -It is possible to override this setting in individual tests by explicitly calling `jest.mock()` at the top of the test file. - -### `verbose` \[boolean] - -Default: `false` - -Indicates whether each individual test should be reported during the run. All errors will also still be shown on the bottom after execution. Note that if there is only one test file being run it will default to `true`. - -### `watchPathIgnorePatterns` \[array<string>] - -Default: `[]` - -An array of RegExp patterns that are matched against all source file paths before re-running tests in watch mode. If the file path matches any of the patterns, when it is updated, it will not trigger a re-run of tests. - -These patterns match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. Example: `["/node_modules/"]`. - -Even if nothing is specified here, the watcher will ignore changes to the version control folders (.git, .hg). Other hidden files and directories, i.e. those that begin with a dot (`.`), are watched by default. Remember to escape the dot when you add them to `watchPathIgnorePatterns` as it is a special RegExp character. - -Example: - -```json -{ - "watchPathIgnorePatterns": ["/\\.tmp/", "/bar/"] -} -``` - -### `watchPlugins` \[array<string | \[string, Object]>] - -Default: `[]` - -This option allows you to use custom watch plugins. Read more about watch plugins [here](watch-plugins). - -Examples of watch plugins include: - -- [`jest-watch-master`](https://github.com/rickhanlonii/jest-watch-master) -- [`jest-watch-select-projects`](https://github.com/rogeliog/jest-watch-select-projects) -- [`jest-watch-suspend`](https://github.com/unional/jest-watch-suspend) -- [`jest-watch-typeahead`](https://github.com/jest-community/jest-watch-typeahead) -- [`jest-watch-yarn-workspaces`](https://github.com/cameronhunter/jest-watch-directories/tree/master/packages/jest-watch-yarn-workspaces) - -_Note: The values in the `watchPlugins` property value can omit the `jest-watch-` prefix of the package name._ - -### `watchman` \[boolean] - -Default: `true` - -Whether to use [`watchman`](https://facebook.github.io/watchman/) for file crawling. - -### `//` \[string] - -No default - -This option allows comments in `package.json`. Include the comment text as the value of this key anywhere in `package.json`. - -Example: - -```json -{ - "name": "my-project", - "jest": { - "//": "Comment goes here", - "verbose": true - } -} -``` diff --git a/website/versioned_docs/version-27.0/ECMAScriptModules.md b/website/versioned_docs/version-27.0/ECMAScriptModules.md deleted file mode 100644 index a2f513282a09..000000000000 --- a/website/versioned_docs/version-27.0/ECMAScriptModules.md +++ /dev/null @@ -1,36 +0,0 @@ ---- -id: ecmascript-modules -title: ECMAScript Modules ---- - -Jest ships with _experimental_ support for ECMAScript Modules (ESM). - -> Note that due to its experimental nature there are many bugs and missing features in Jest's implementation, both known and unknown. You should check out the [tracking issue](https://github.com/facebook/jest/issues/9430) and the [label](https://github.com/facebook/jest/labels/ES%20Modules) on the issue tracker for the latest status. - -> Also note that the APIs Jest uses to implement ESM support is still [considered experimental by Node](https://nodejs.org/api/vm.html#vm_class_vm_module) (as of version `14.13.1`). - -With the warnings out of the way, this is how you activate ESM support in your tests. - -1. Ensure you either disable [code transforms](./configuration#transform-objectstring-pathtotransformer--pathtotransformer-object) by passing `transform: {}` or otherwise configure your transformer to emit ESM rather than the default CommonJS (CJS). -1. Execute `node` with `--experimental-vm-modules`, e.g. `node --experimental-vm-modules node_modules/jest/bin/jest.js` or `NODE_OPTIONS=--experimental-vm-modules npx jest` etc.. - - On Windows, you can use [`cross-env`](https://github.com/kentcdodds/cross-env) to be able to set environment variables. - - If you use Yarn, you can use `yarn node --experimental-vm-modules $(yarn bin jest)`. This command will also work if you use [Yarn Plug'n'Play](https://yarnpkg.com/features/pnp). - -1. Beyond that, we attempt to follow `node`'s logic for activating "ESM mode" (such as looking at `type` in `package.json` or `mjs` files), see [their docs](https://nodejs.org/api/esm.html#esm_enabling) for details. -1. If you want to treat other file extensions (such as `.jsx` or `.ts`) as ESM, please use the [`extensionsToTreatAsEsm` option](Configuration.md#extensionstotreatasesm-arraystring). - -## Differences between ESM and CommonJS - -Most of the differences are explained in [Node's documentation](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs), but in addition to the things mentioned there, Jest injects a special variable into all executed files - the [`jest` object](JestObjectAPI.md). To access this object in ESM, you need to import it from the `@jest/globals` module. - -```js -import {jest} from '@jest/globals'; - -jest.useFakeTimers(); - -// etc. -``` - -Please note that we currently don't support `jest.mock` in a clean way in ESM, but that is something we intend to add proper support for in the future. Follow [this issue](https://github.com/facebook/jest/issues/10025) for updates. diff --git a/website/versioned_docs/version-27.0/ExpectAPI.md b/website/versioned_docs/version-27.0/ExpectAPI.md deleted file mode 100644 index 0d1adaef5782..000000000000 --- a/website/versioned_docs/version-27.0/ExpectAPI.md +++ /dev/null @@ -1,1393 +0,0 @@ ---- -id: expect -title: Expect ---- - -When you're writing tests, you often need to check that values meet certain conditions. `expect` gives you access to a number of "matchers" that let you validate different things. - -For additional Jest matchers maintained by the Jest Community check out [`jest-extended`](https://github.com/jest-community/jest-extended). - -## Methods - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Reference - -### `expect(value)` - -The `expect` function is used every time you want to test a value. You will rarely call `expect` by itself. Instead, you will use `expect` along with a "matcher" function to assert something about a value. - -It's easier to understand this with an example. Let's say you have a method `bestLaCroixFlavor()` which is supposed to return the string `'grapefruit'`. Here's how you would test that: - -```js -test('the best flavor is grapefruit', () => { - expect(bestLaCroixFlavor()).toBe('grapefruit'); -}); -``` - -In this case, `toBe` is the matcher function. There are a lot of different matcher functions, documented below, to help you test different things. - -The argument to `expect` should be the value that your code produces, and any argument to the matcher should be the correct value. If you mix them up, your tests will still work, but the error messages on failing tests will look strange. - -### `expect.extend(matchers)` - -You can use `expect.extend` to add your own matchers to Jest. For example, let's say that you're testing a number utility library and you're frequently asserting that numbers appear within particular ranges of other numbers. You could abstract that into a `toBeWithinRange` matcher: - -```js -expect.extend({ - toBeWithinRange(received, floor, ceiling) { - const pass = received >= floor && received <= ceiling; - if (pass) { - return { - message: () => - `expected ${received} not to be within range ${floor} - ${ceiling}`, - pass: true, - }; - } else { - return { - message: () => - `expected ${received} to be within range ${floor} - ${ceiling}`, - pass: false, - }; - } - }, -}); - -test('numeric ranges', () => { - expect(100).toBeWithinRange(90, 110); - expect(101).not.toBeWithinRange(0, 100); - expect({apples: 6, bananas: 3}).toEqual({ - apples: expect.toBeWithinRange(1, 10), - bananas: expect.not.toBeWithinRange(11, 20), - }); -}); -``` - -_Note_: In TypeScript, when using `@types/jest` for example, you can declare the new `toBeWithinRange` matcher in the imported module like this: - -```ts -interface CustomMatchers { - toBeWithinRange(floor: number, ceiling: number): R; -} - -declare global { - namespace jest { - interface Expect extends CustomMatchers {} - interface Matchers extends CustomMatchers {} - interface InverseAsymmetricMatchers extends CustomMatchers {} - } -} -``` - -#### Async Matchers - -`expect.extend` also supports async matchers. Async matchers return a Promise so you will need to await the returned value. Let's use an example matcher to illustrate the usage of them. We are going to implement a matcher called `toBeDivisibleByExternalValue`, where the divisible number is going to be pulled from an external source. - -```js -expect.extend({ - async toBeDivisibleByExternalValue(received) { - const externalValue = await getExternalValueFromRemoteSource(); - const pass = received % externalValue == 0; - if (pass) { - return { - message: () => - `expected ${received} not to be divisible by ${externalValue}`, - pass: true, - }; - } else { - return { - message: () => - `expected ${received} to be divisible by ${externalValue}`, - pass: false, - }; - } - }, -}); - -test('is divisible by external value', async () => { - await expect(100).toBeDivisibleByExternalValue(); - await expect(101).not.toBeDivisibleByExternalValue(); -}); -``` - -#### Custom Matchers API - -Matchers should return an object (or a Promise of an object) with two keys. `pass` indicates whether there was a match or not, and `message` provides a function with no arguments that returns an error message in case of failure. Thus, when `pass` is false, `message` should return the error message for when `expect(x).yourMatcher()` fails. And when `pass` is true, `message` should return the error message for when `expect(x).not.yourMatcher()` fails. - -Matchers are called with the argument passed to `expect(x)` followed by the arguments passed to `.yourMatcher(y, z)`: - -```js -expect.extend({ - yourMatcher(x, y, z) { - return { - pass: true, - message: () => '', - }; - }, -}); -``` - -These helper functions and properties can be found on `this` inside a custom matcher: - -#### `this.isNot` - -A boolean to let you know this matcher was called with the negated `.not` modifier allowing you to display a clear and correct matcher hint (see example code). - -#### `this.promise` - -A string allowing you to display a clear and correct matcher hint: - -- `'rejects'` if matcher was called with the promise `.rejects` modifier -- `'resolves'` if matcher was called with the promise `.resolves` modifier -- `''` if matcher was not called with a promise modifier - -#### `this.equals(a, b)` - -This is a deep-equality function that will return `true` if two objects have the same values (recursively). - -#### `this.expand` - -A boolean to let you know this matcher was called with an `expand` option. When Jest is called with the `--expand` flag, `this.expand` can be used to determine if Jest is expected to show full diffs and errors. - -#### `this.utils` - -There are a number of helpful tools exposed on `this.utils` primarily consisting of the exports from [`jest-matcher-utils`](https://github.com/facebook/jest/tree/main/packages/jest-matcher-utils). - -The most useful ones are `matcherHint`, `printExpected` and `printReceived` to format the error messages nicely. For example, take a look at the implementation for the `toBe` matcher: - -```js -const {diff} = require('jest-diff'); -expect.extend({ - toBe(received, expected) { - const options = { - comment: 'Object.is equality', - isNot: this.isNot, - promise: this.promise, - }; - - const pass = Object.is(received, expected); - - const message = pass - ? () => - // eslint-disable-next-line prefer-template - this.utils.matcherHint('toBe', undefined, undefined, options) + - '\n\n' + - `Expected: not ${this.utils.printExpected(expected)}\n` + - `Received: ${this.utils.printReceived(received)}` - : () => { - const diffString = diff(expected, received, { - expand: this.expand, - }); - return ( - // eslint-disable-next-line prefer-template - this.utils.matcherHint('toBe', undefined, undefined, options) + - '\n\n' + - (diffString && diffString.includes('- Expect') - ? `Difference:\n\n${diffString}` - : `Expected: ${this.utils.printExpected(expected)}\n` + - `Received: ${this.utils.printReceived(received)}`) - ); - }; - - return {actual: received, message, pass}; - }, -}); -``` - -This will print something like this: - -```bash - expect(received).toBe(expected) - - Expected value to be (using Object.is): - "banana" - Received: - "apple" -``` - -When an assertion fails, the error message should give as much signal as necessary to the user so they can resolve their issue quickly. You should craft a precise failure message to make sure users of your custom assertions have a good developer experience. - -#### Custom snapshot matchers - -To use snapshot testing inside of your custom matcher you can import `jest-snapshot` and use it from within your matcher. - -Here's a snapshot matcher that trims a string to store for a given length, `.toMatchTrimmedSnapshot(length)`: - -```js -const {toMatchSnapshot} = require('jest-snapshot'); - -expect.extend({ - toMatchTrimmedSnapshot(received, length) { - return toMatchSnapshot.call( - this, - received.substring(0, length), - 'toMatchTrimmedSnapshot', - ); - }, -}); - -it('stores only 10 characters', () => { - expect('extra long string oh my gerd').toMatchTrimmedSnapshot(10); -}); - -/* -Stored snapshot will look like: - -exports[`stores only 10 characters: toMatchTrimmedSnapshot 1`] = `"extra long"`; -*/ -``` - -It's also possible to create custom matchers for inline snapshots, the snapshots will be correctly added to the custom matchers. However, inline snapshot will always try to append to the first argument or the second when the first argument is the property matcher, so it's not possible to accept custom arguments in the custom matchers. - -```js -const {toMatchInlineSnapshot} = require('jest-snapshot'); - -expect.extend({ - toMatchTrimmedInlineSnapshot(received, ...rest) { - return toMatchInlineSnapshot.call(this, received.substring(0, 10), ...rest); - }, -}); - -it('stores only 10 characters', () => { - expect('extra long string oh my gerd').toMatchTrimmedInlineSnapshot(); - /* - The snapshot will be added inline like - expect('extra long string oh my gerd').toMatchTrimmedInlineSnapshot( - `"extra long"` - ); - */ -}); -``` - -#### async - -If your custom inline snapshot matcher is async i.e. uses `async`-`await` you might encounter an error like "Multiple inline snapshots for the same call are not supported". Jest needs additional context information to find where the custom inline snapshot matcher was used to update the snapshots properly. - -```js -const {toMatchInlineSnapshot} = require('jest-snapshot'); - -expect.extend({ - async toMatchObservationInlineSnapshot(fn, ...rest) { - // The error (and its stacktrace) must be created before any `await` - this.error = new Error(); - - // The implementation of `observe` doesn't matter. - // It only matters that the custom snapshot matcher is async. - const observation = await observe(async () => { - await fn(); - }); - - return toMatchInlineSnapshot.call(this, recording, ...rest); - }, -}); - -it('observes something', async () => { - await expect(async () => { - return 'async action'; - }).toMatchTrimmedInlineSnapshot(); - /* - The snapshot will be added inline like - await expect(async () => { - return 'async action'; - }).toMatchTrimmedInlineSnapshot(`"async action"`); - */ -}); -``` - -#### Bail out - -Usually `jest` tries to match every snapshot that is expected in a test. - -Sometimes it might not make sense to continue the test if a prior snapshot failed. For example, when you make snapshots of a state-machine after various transitions you can abort the test once one transition produced the wrong state. - -In that case you can implement a custom snapshot matcher that throws on the first mismatch instead of collecting every mismatch. - -```js -const {toMatchInlineSnapshot} = require('jest-snapshot'); - -expect.extend({ - toMatchStateInlineSnapshot(...args) { - this.dontThrow = () => {}; - - return toMatchInlineSnapshot.call(this, ...args); - }, -}); - -let state = 'initial'; - -function transition() { - // Typo in the implementation should cause the test to fail - if (state === 'INITIAL') { - state = 'pending'; - } else if (state === 'pending') { - state = 'done'; - } -} - -it('transitions as expected', () => { - expect(state).toMatchStateInlineSnapshot(`"initial"`); - - transition(); - // Already produces a mismatch. No point in continuing the test. - expect(state).toMatchStateInlineSnapshot(`"loading"`); - - transition(); - expect(state).toMatchStateInlineSnapshot(`"done"`); -}); -``` - -### `expect.anything()` - -`expect.anything()` matches anything but `null` or `undefined`. You can use it inside `toEqual` or `toBeCalledWith` instead of a literal value. For example, if you want to check that a mock function is called with a non-null argument: - -```js -test('map calls its argument with a non-null argument', () => { - const mock = jest.fn(); - [1].map(x => mock(x)); - expect(mock).toBeCalledWith(expect.anything()); -}); -``` - -### `expect.any(constructor)` - -`expect.any(constructor)` matches anything that was created with the given constructor or if it's a primitive that is of the passed type. You can use it inside `toEqual` or `toBeCalledWith` instead of a literal value. For example, if you want to check that a mock function is called with a number: - -```js -class Cat {} -function getCat(fn) { - return fn(new Cat()); -} - -test('randocall calls its callback with a class instance', () => { - const mock = jest.fn(); - getCat(mock); - expect(mock).toBeCalledWith(expect.any(Cat)); -}); - -function randocall(fn) { - return fn(Math.floor(Math.random() * 6 + 1)); -} - -test('randocall calls its callback with a number', () => { - const mock = jest.fn(); - randocall(mock); - expect(mock).toBeCalledWith(expect.any(Number)); -}); -``` - -### `expect.arrayContaining(array)` - -`expect.arrayContaining(array)` matches a received array which contains all of the elements in the expected array. That is, the expected array is a **subset** of the received array. Therefore, it matches a received array which contains elements that are **not** in the expected array. - -You can use it instead of a literal value: - -- in `toEqual` or `toBeCalledWith` -- to match a property in `objectContaining` or `toMatchObject` - -```js -describe('arrayContaining', () => { - const expected = ['Alice', 'Bob']; - it('matches even if received contains additional elements', () => { - expect(['Alice', 'Bob', 'Eve']).toEqual(expect.arrayContaining(expected)); - }); - it('does not match if received does not contain expected elements', () => { - expect(['Bob', 'Eve']).not.toEqual(expect.arrayContaining(expected)); - }); -}); -``` - -```js -describe('Beware of a misunderstanding! A sequence of dice rolls', () => { - const expected = [1, 2, 3, 4, 5, 6]; - it('matches even with an unexpected number 7', () => { - expect([4, 1, 6, 7, 3, 5, 2, 5, 4, 6]).toEqual( - expect.arrayContaining(expected), - ); - }); - it('does not match without an expected number 2', () => { - expect([4, 1, 6, 7, 3, 5, 7, 5, 4, 6]).not.toEqual( - expect.arrayContaining(expected), - ); - }); -}); -``` - -### `expect.assertions(number)` - -`expect.assertions(number)` verifies that a certain number of assertions are called during a test. This is often useful when testing asynchronous code, in order to make sure that assertions in a callback actually got called. - -For example, let's say that we have a function `doAsync` that receives two callbacks `callback1` and `callback2`, it will asynchronously call both of them in an unknown order. We can test this with: - -```js -test('doAsync calls both callbacks', () => { - expect.assertions(2); - function callback1(data) { - expect(data).toBeTruthy(); - } - function callback2(data) { - expect(data).toBeTruthy(); - } - - await doAsync(callback1, callback2); -}); -``` - -The `expect.assertions(2)` call ensures that both callbacks actually get called. - -### `expect.hasAssertions()` - -`expect.hasAssertions()` verifies that at least one assertion is called during a test. This is often useful when testing asynchronous code, in order to make sure that assertions in a callback actually got called. - -For example, let's say that we have a few functions that all deal with state. `prepareState` calls a callback with a state object, `validateState` runs on that state object, and `waitOnState` returns a promise that waits until all `prepareState` callbacks complete. We can test this with: - -```js -test('prepareState prepares a valid state', () => { - expect.hasAssertions(); - prepareState(state => { - expect(validateState(state)).toBeTruthy(); - }); - return waitOnState(); -}); -``` - -The `expect.hasAssertions()` call ensures that the `prepareState` callback actually gets called. - -### `expect.not.arrayContaining(array)` - -`expect.not.arrayContaining(array)` matches a received array which does not contain all of the elements in the expected array. That is, the expected array **is not a subset** of the received array. - -It is the inverse of `expect.arrayContaining`. - -```js -describe('not.arrayContaining', () => { - const expected = ['Samantha']; - - it('matches if the actual array does not contain the expected elements', () => { - expect(['Alice', 'Bob', 'Eve']).toEqual( - expect.not.arrayContaining(expected), - ); - }); -}); -``` - -### `expect.not.objectContaining(object)` - -`expect.not.objectContaining(object)` matches any received object that does not recursively match the expected properties. That is, the expected object **is not a subset** of the received object. Therefore, it matches a received object which contains properties that are **not** in the expected object. - -It is the inverse of `expect.objectContaining`. - -```js -describe('not.objectContaining', () => { - const expected = {foo: 'bar'}; - - it('matches if the actual object does not contain expected key: value pairs', () => { - expect({bar: 'baz'}).toEqual(expect.not.objectContaining(expected)); - }); -}); -``` - -### `expect.not.stringContaining(string)` - -`expect.not.stringContaining(string)` matches the received value if it is not a string or if it is a string that does not contain the exact expected string. - -It is the inverse of `expect.stringContaining`. - -```js -describe('not.stringContaining', () => { - const expected = 'Hello world!'; - - it('matches if the received value does not contain the expected substring', () => { - expect('How are you?').toEqual(expect.not.stringContaining(expected)); - }); -}); -``` - -### `expect.not.stringMatching(string | regexp)` - -`expect.not.stringMatching(string | regexp)` matches the received value if it is not a string or if it is a string that does not match the expected string or regular expression. - -It is the inverse of `expect.stringMatching`. - -```js -describe('not.stringMatching', () => { - const expected = /Hello world!/; - - it('matches if the received value does not match the expected regex', () => { - expect('How are you?').toEqual(expect.not.stringMatching(expected)); - }); -}); -``` - -### `expect.objectContaining(object)` - -`expect.objectContaining(object)` matches any received object that recursively matches the expected properties. That is, the expected object is a **subset** of the received object. Therefore, it matches a received object which contains properties that **are present** in the expected object. - -Instead of literal property values in the expected object, you can use matchers, `expect.anything()`, and so on. - -For example, let's say that we expect an `onPress` function to be called with an `Event` object, and all we need to verify is that the event has `event.x` and `event.y` properties. We can do that with: - -```js -test('onPress gets called with the right thing', () => { - const onPress = jest.fn(); - simulatePresses(onPress); - expect(onPress).toBeCalledWith( - expect.objectContaining({ - x: expect.any(Number), - y: expect.any(Number), - }), - ); -}); -``` - -### `expect.stringContaining(string)` - -`expect.stringContaining(string)` matches the received value if it is a string that contains the exact expected string. - -### `expect.stringMatching(string | regexp)` - -`expect.stringMatching(string | regexp)` matches the received value if it is a string that matches the expected string or regular expression. - -You can use it instead of a literal value: - -- in `toEqual` or `toBeCalledWith` -- to match an element in `arrayContaining` -- to match a property in `objectContaining` or `toMatchObject` - -This example also shows how you can nest multiple asymmetric matchers, with `expect.stringMatching` inside the `expect.arrayContaining`. - -```js -describe('stringMatching in arrayContaining', () => { - const expected = [ - expect.stringMatching(/^Alic/), - expect.stringMatching(/^[BR]ob/), - ]; - it('matches even if received contains additional elements', () => { - expect(['Alicia', 'Roberto', 'Evelina']).toEqual( - expect.arrayContaining(expected), - ); - }); - it('does not match if received does not contain expected elements', () => { - expect(['Roberto', 'Evelina']).not.toEqual( - expect.arrayContaining(expected), - ); - }); -}); -``` - -### `expect.addSnapshotSerializer(serializer)` - -You can call `expect.addSnapshotSerializer` to add a module that formats application-specific data structures. - -For an individual test file, an added module precedes any modules from `snapshotSerializers` configuration, which precede the default snapshot serializers for built-in JavaScript types and for React elements. The last module added is the first module tested. - -```js -import serializer from 'my-serializer-module'; -expect.addSnapshotSerializer(serializer); - -// affects expect(value).toMatchSnapshot() assertions in the test file -``` - -If you add a snapshot serializer in individual test files instead of adding it to `snapshotSerializers` configuration: - -- You make the dependency explicit instead of implicit. -- You avoid limits to configuration that might cause you to eject from [create-react-app](https://github.com/facebookincubator/create-react-app). - -See [configuring Jest](Configuration.md#snapshotserializers-arraystring) for more information. - -### `.not` - -If you know how to test something, `.not` lets you test its opposite. For example, this code tests that the best La Croix flavor is not coconut: - -```js -test('the best flavor is not coconut', () => { - expect(bestLaCroixFlavor()).not.toBe('coconut'); -}); -``` - -### `.resolves` - -Use `resolves` to unwrap the value of a fulfilled promise so any other matcher can be chained. If the promise is rejected the assertion fails. - -For example, this code tests that the promise resolves and that the resulting value is `'lemon'`: - -```js -test('resolves to lemon', () => { - // make sure to add a return statement - return expect(Promise.resolve('lemon')).resolves.toBe('lemon'); -}); -``` - -Note that, since you are still testing promises, the test is still asynchronous. Hence, you will need to [tell Jest to wait](TestingAsyncCode.md#promises) by returning the unwrapped assertion. - -Alternatively, you can use `async/await` in combination with `.resolves`: - -```js -test('resolves to lemon', async () => { - await expect(Promise.resolve('lemon')).resolves.toBe('lemon'); - await expect(Promise.resolve('lemon')).resolves.not.toBe('octopus'); -}); -``` - -### `.rejects` - -Use `.rejects` to unwrap the reason of a rejected promise so any other matcher can be chained. If the promise is fulfilled the assertion fails. - -For example, this code tests that the promise rejects with reason `'octopus'`: - -```js -test('rejects to octopus', () => { - // make sure to add a return statement - return expect(Promise.reject(new Error('octopus'))).rejects.toThrow( - 'octopus', - ); -}); -``` - -Note that, since you are still testing promises, the test is still asynchronous. Hence, you will need to [tell Jest to wait](TestingAsyncCode.md#promises) by returning the unwrapped assertion. - -Alternatively, you can use `async/await` in combination with `.rejects`. - -```js -test('rejects to octopus', async () => { - await expect(Promise.reject(new Error('octopus'))).rejects.toThrow('octopus'); -}); -``` - -### `.toBe(value)` - -Use `.toBe` to compare primitive values or to check referential identity of object instances. It calls `Object.is` to compare values, which is even better for testing than `===` strict equality operator. - -For example, this code will validate some properties of the `can` object: - -```js -const can = { - name: 'pamplemousse', - ounces: 12, -}; - -describe('the can', () => { - test('has 12 ounces', () => { - expect(can.ounces).toBe(12); - }); - - test('has a sophisticated name', () => { - expect(can.name).toBe('pamplemousse'); - }); -}); -``` - -Don't use `.toBe` with floating-point numbers. For example, due to rounding, in JavaScript `0.2 + 0.1` is not strictly equal to `0.3`. If you have floating point numbers, try `.toBeCloseTo` instead. - -Although the `.toBe` matcher **checks** referential identity, it **reports** a deep comparison of values if the assertion fails. If differences between properties do not help you to understand why a test fails, especially if the report is large, then you might move the comparison into the `expect` function. For example, to assert whether or not elements are the same instance: - -- rewrite `expect(received).toBe(expected)` as `expect(Object.is(received, expected)).toBe(true)` -- rewrite `expect(received).not.toBe(expected)` as `expect(Object.is(received, expected)).toBe(false)` - -### `.toHaveBeenCalled()` - -Also under the alias: `.toBeCalled()` - -Use `.toHaveBeenCalledWith` to ensure that a mock function was called with specific arguments. The arguments are checked with the same algorithm that `.toEqual` uses. - -For example, let's say you have a `drinkAll(drink, flavour)` function that takes a `drink` function and applies it to all available beverages. You might want to check that `drink` gets called for `'lemon'`, but not for `'octopus'`, because `'octopus'` flavour is really weird and why would anything be octopus-flavoured? You can do that with this test suite: - -```js -function drinkAll(callback, flavour) { - if (flavour !== 'octopus') { - callback(flavour); - } -} - -describe('drinkAll', () => { - test('drinks something lemon-flavoured', () => { - const drink = jest.fn(); - drinkAll(drink, 'lemon'); - expect(drink).toHaveBeenCalled(); - }); - - test('does not drink something octopus-flavoured', () => { - const drink = jest.fn(); - drinkAll(drink, 'octopus'); - expect(drink).not.toHaveBeenCalled(); - }); -}); -``` - -### `.toHaveBeenCalledTimes(number)` - -Also under the alias: `.toBeCalledTimes(number)` - -Use `.toHaveBeenCalledTimes` to ensure that a mock function got called exact number of times. - -For example, let's say you have a `drinkEach(drink, Array)` function that takes a `drink` function and applies it to array of passed beverages. You might want to check that drink function was called exact number of times. You can do that with this test suite: - -```js -test('drinkEach drinks each drink', () => { - const drink = jest.fn(); - drinkEach(drink, ['lemon', 'octopus']); - expect(drink).toHaveBeenCalledTimes(2); -}); -``` - -### `.toHaveBeenCalledWith(arg1, arg2, ...)` - -Also under the alias: `.toBeCalledWith()` - -Use `.toHaveBeenCalledWith` to ensure that a mock function was called with specific arguments. The arguments are checked with the same algorithm that `.toEqual` uses. - -For example, let's say that you can register a beverage with a `register` function, and `applyToAll(f)` should apply the function `f` to all registered beverages. To make sure this works, you could write: - -```js -test('registration applies correctly to orange La Croix', () => { - const beverage = new LaCroix('orange'); - register(beverage); - const f = jest.fn(); - applyToAll(f); - expect(f).toHaveBeenCalledWith(beverage); -}); -``` - -### `.toHaveBeenLastCalledWith(arg1, arg2, ...)` - -Also under the alias: `.lastCalledWith(arg1, arg2, ...)` - -If you have a mock function, you can use `.toHaveBeenLastCalledWith` to test what arguments it was last called with. For example, let's say you have a `applyToAllFlavors(f)` function that applies `f` to a bunch of flavors, and you want to ensure that when you call it, the last flavor it operates on is `'mango'`. You can write: - -```js -test('applying to all flavors does mango last', () => { - const drink = jest.fn(); - applyToAllFlavors(drink); - expect(drink).toHaveBeenLastCalledWith('mango'); -}); -``` - -### `.toHaveBeenNthCalledWith(nthCall, arg1, arg2, ....)` - -Also under the alias: `.nthCalledWith(nthCall, arg1, arg2, ...)` - -If you have a mock function, you can use `.toHaveBeenNthCalledWith` to test what arguments it was nth called with. For example, let's say you have a `drinkEach(drink, Array)` function that applies `f` to a bunch of flavors, and you want to ensure that when you call it, the first flavor it operates on is `'lemon'` and the second one is `'octopus'`. You can write: - -```js -test('drinkEach drinks each drink', () => { - const drink = jest.fn(); - drinkEach(drink, ['lemon', 'octopus']); - expect(drink).toHaveBeenNthCalledWith(1, 'lemon'); - expect(drink).toHaveBeenNthCalledWith(2, 'octopus'); -}); -``` - -Note: the nth argument must be positive integer starting from 1. - -### `.toHaveReturned()` - -Also under the alias: `.toReturn()` - -If you have a mock function, you can use `.toHaveReturned` to test that the mock function successfully returned (i.e., did not throw an error) at least one time. For example, let's say you have a mock `drink` that returns `true`. You can write: - -```js -test('drinks returns', () => { - const drink = jest.fn(() => true); - - drink(); - - expect(drink).toHaveReturned(); -}); -``` - -### `.toHaveReturnedTimes(number)` - -Also under the alias: `.toReturnTimes(number)` - -Use `.toHaveReturnedTimes` to ensure that a mock function returned successfully (i.e., did not throw an error) an exact number of times. Any calls to the mock function that throw an error are not counted toward the number of times the function returned. - -For example, let's say you have a mock `drink` that returns `true`. You can write: - -```js -test('drink returns twice', () => { - const drink = jest.fn(() => true); - - drink(); - drink(); - - expect(drink).toHaveReturnedTimes(2); -}); -``` - -### `.toHaveReturnedWith(value)` - -Also under the alias: `.toReturnWith(value)` - -Use `.toHaveReturnedWith` to ensure that a mock function returned a specific value. - -For example, let's say you have a mock `drink` that returns the name of the beverage that was consumed. You can write: - -```js -test('drink returns La Croix', () => { - const beverage = {name: 'La Croix'}; - const drink = jest.fn(beverage => beverage.name); - - drink(beverage); - - expect(drink).toHaveReturnedWith('La Croix'); -}); -``` - -### `.toHaveLastReturnedWith(value)` - -Also under the alias: `.lastReturnedWith(value)` - -Use `.toHaveLastReturnedWith` to test the specific value that a mock function last returned. If the last call to the mock function threw an error, then this matcher will fail no matter what value you provided as the expected return value. - -For example, let's say you have a mock `drink` that returns the name of the beverage that was consumed. You can write: - -```js -test('drink returns La Croix (Orange) last', () => { - const beverage1 = {name: 'La Croix (Lemon)'}; - const beverage2 = {name: 'La Croix (Orange)'}; - const drink = jest.fn(beverage => beverage.name); - - drink(beverage1); - drink(beverage2); - - expect(drink).toHaveLastReturnedWith('La Croix (Orange)'); -}); -``` - -### `.toHaveNthReturnedWith(nthCall, value)` - -Also under the alias: `.nthReturnedWith(nthCall, value)` - -Use `.toHaveNthReturnedWith` to test the specific value that a mock function returned for the nth call. If the nth call to the mock function threw an error, then this matcher will fail no matter what value you provided as the expected return value. - -For example, let's say you have a mock `drink` that returns the name of the beverage that was consumed. You can write: - -```js -test('drink returns expected nth calls', () => { - const beverage1 = {name: 'La Croix (Lemon)'}; - const beverage2 = {name: 'La Croix (Orange)'}; - const drink = jest.fn(beverage => beverage.name); - - drink(beverage1); - drink(beverage2); - - expect(drink).toHaveNthReturnedWith(1, 'La Croix (Lemon)'); - expect(drink).toHaveNthReturnedWith(2, 'La Croix (Orange)'); -}); -``` - -Note: the nth argument must be positive integer starting from 1. - -### `.toHaveLength(number)` - -Use `.toHaveLength` to check that an object has a `.length` property and it is set to a certain numeric value. - -This is especially useful for checking arrays or strings size. - -```js -expect([1, 2, 3]).toHaveLength(3); -expect('abc').toHaveLength(3); -expect('').not.toHaveLength(5); -``` - -### `.toHaveProperty(keyPath, value?)` - -Use `.toHaveProperty` to check if property at provided reference `keyPath` exists for an object. For checking deeply nested properties in an object you may use [dot notation](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Operators/Property_accessors) or an array containing the keyPath for deep references. - -You can provide an optional `value` argument to compare the received property value (recursively for all properties of object instances, also known as deep equality, like the `toEqual` matcher). - -The following example contains a `houseForSale` object with nested properties. We are using `toHaveProperty` to check for the existence and values of various properties in the object. - -```js -// Object containing house features to be tested -const houseForSale = { - bath: true, - bedrooms: 4, - kitchen: { - amenities: ['oven', 'stove', 'washer'], - area: 20, - wallColor: 'white', - 'nice.oven': true, - }, - 'ceiling.height': 2, -}; - -test('this house has my desired features', () => { - // Example Referencing - expect(houseForSale).toHaveProperty('bath'); - expect(houseForSale).toHaveProperty('bedrooms', 4); - - expect(houseForSale).not.toHaveProperty('pool'); - - // Deep referencing using dot notation - expect(houseForSale).toHaveProperty('kitchen.area', 20); - expect(houseForSale).toHaveProperty('kitchen.amenities', [ - 'oven', - 'stove', - 'washer', - ]); - - expect(houseForSale).not.toHaveProperty('kitchen.open'); - - // Deep referencing using an array containing the keyPath - expect(houseForSale).toHaveProperty(['kitchen', 'area'], 20); - expect(houseForSale).toHaveProperty( - ['kitchen', 'amenities'], - ['oven', 'stove', 'washer'], - ); - expect(houseForSale).toHaveProperty(['kitchen', 'amenities', 0], 'oven'); - expect(houseForSale).toHaveProperty(['kitchen', 'nice.oven']); - expect(houseForSale).not.toHaveProperty(['kitchen', 'open']); - - // Referencing keys with dot in the key itself - expect(houseForSale).toHaveProperty(['ceiling.height'], 'tall'); -}); -``` - -### `.toBeCloseTo(number, numDigits?)` - -Use `toBeCloseTo` to compare floating point numbers for approximate equality. - -The optional `numDigits` argument limits the number of digits to check **after** the decimal point. For the default value `2`, the test criterion is `Math.abs(expected - received) < 0.005` (that is, `10 ** -2 / 2`). - -Intuitive equality comparisons often fail, because arithmetic on decimal (base 10) values often have rounding errors in limited precision binary (base 2) representation. For example, this test fails: - -```js -test('adding works sanely with decimals', () => { - expect(0.2 + 0.1).toBe(0.3); // Fails! -}); -``` - -It fails because in JavaScript, `0.2 + 0.1` is actually `0.30000000000000004`. - -For example, this test passes with a precision of 5 digits: - -```js -test('adding works sanely with decimals', () => { - expect(0.2 + 0.1).toBeCloseTo(0.3, 5); -}); -``` - -Because floating point errors are the problem that `toBeCloseTo` solves, it does not support big integer values. - -### `.toBeDefined()` - -Use `.toBeDefined` to check that a variable is not undefined. For example, if you want to check that a function `fetchNewFlavorIdea()` returns _something_, you can write: - -```js -test('there is a new flavor idea', () => { - expect(fetchNewFlavorIdea()).toBeDefined(); -}); -``` - -You could write `expect(fetchNewFlavorIdea()).not.toBe(undefined)`, but it's better practice to avoid referring to `undefined` directly in your code. - -### `.toBeFalsy()` - -Use `.toBeFalsy` when you don't care what a value is and you want to ensure a value is false in a boolean context. For example, let's say you have some application code that looks like: - -```js -drinkSomeLaCroix(); -if (!getErrors()) { - drinkMoreLaCroix(); -} -``` - -You may not care what `getErrors` returns, specifically - it might return `false`, `null`, or `0`, and your code would still work. So if you want to test there are no errors after drinking some La Croix, you could write: - -```js -test('drinking La Croix does not lead to errors', () => { - drinkSomeLaCroix(); - expect(getErrors()).toBeFalsy(); -}); -``` - -In JavaScript, there are six falsy values: `false`, `0`, `''`, `null`, `undefined`, and `NaN`. Everything else is truthy. - -### `.toBeGreaterThan(number | bigint)` - -Use `toBeGreaterThan` to compare `received > expected` for number or big integer values. For example, test that `ouncesPerCan()` returns a value of more than 10 ounces: - -```js -test('ounces per can is more than 10', () => { - expect(ouncesPerCan()).toBeGreaterThan(10); -}); -``` - -### `.toBeGreaterThanOrEqual(number | bigint)` - -Use `toBeGreaterThanOrEqual` to compare `received >= expected` for number or big integer values. For example, test that `ouncesPerCan()` returns a value of at least 12 ounces: - -```js -test('ounces per can is at least 12', () => { - expect(ouncesPerCan()).toBeGreaterThanOrEqual(12); -}); -``` - -### `.toBeLessThan(number | bigint)` - -Use `toBeLessThan` to compare `received < expected` for number or big integer values. For example, test that `ouncesPerCan()` returns a value of less than 20 ounces: - -```js -test('ounces per can is less than 20', () => { - expect(ouncesPerCan()).toBeLessThan(20); -}); -``` - -### `.toBeLessThanOrEqual(number | bigint)` - -Use `toBeLessThanOrEqual` to compare `received <= expected` for number or big integer values. For example, test that `ouncesPerCan()` returns a value of at most 12 ounces: - -```js -test('ounces per can is at most 12', () => { - expect(ouncesPerCan()).toBeLessThanOrEqual(12); -}); -``` - -### `.toBeInstanceOf(Class)` - -Use `.toBeInstanceOf(Class)` to check that an object is an instance of a class. This matcher uses `instanceof` underneath. - -```js -class A {} - -expect(new A()).toBeInstanceOf(A); -expect(() => {}).toBeInstanceOf(Function); -expect(new A()).toBeInstanceOf(Function); // throws -``` - -### `.toBeNull()` - -`.toBeNull()` is the same as `.toBe(null)` but the error messages are a bit nicer. So use `.toBeNull()` when you want to check that something is null. - -```js -function bloop() { - return null; -} - -test('bloop returns null', () => { - expect(bloop()).toBeNull(); -}); -``` - -### `.toBeTruthy()` - -Use `.toBeTruthy` when you don't care what a value is and you want to ensure a value is true in a boolean context. For example, let's say you have some application code that looks like: - -```js -drinkSomeLaCroix(); -if (thirstInfo()) { - drinkMoreLaCroix(); -} -``` - -You may not care what `thirstInfo` returns, specifically - it might return `true` or a complex object, and your code would still work. So if you want to test that `thirstInfo` will be truthy after drinking some La Croix, you could write: - -```js -test('drinking La Croix leads to having thirst info', () => { - drinkSomeLaCroix(); - expect(thirstInfo()).toBeTruthy(); -}); -``` - -In JavaScript, there are six falsy values: `false`, `0`, `''`, `null`, `undefined`, and `NaN`. Everything else is truthy. - -### `.toBeUndefined()` - -Use `.toBeUndefined` to check that a variable is undefined. For example, if you want to check that a function `bestDrinkForFlavor(flavor)` returns `undefined` for the `'octopus'` flavor, because there is no good octopus-flavored drink: - -```js -test('the best drink for octopus flavor is undefined', () => { - expect(bestDrinkForFlavor('octopus')).toBeUndefined(); -}); -``` - -You could write `expect(bestDrinkForFlavor('octopus')).toBe(undefined)`, but it's better practice to avoid referring to `undefined` directly in your code. - -### `.toBeNaN()` - -Use `.toBeNaN` when checking a value is `NaN`. - -```js -test('passes when value is NaN', () => { - expect(NaN).toBeNaN(); - expect(1).not.toBeNaN(); -}); -``` - -### `.toContain(item)` - -Use `.toContain` when you want to check that an item is in an array. For testing the items in the array, this uses `===`, a strict equality check. `.toContain` can also check whether a string is a substring of another string. - -For example, if `getAllFlavors()` returns an array of flavors and you want to be sure that `lime` is in there, you can write: - -```js -test('the flavor list contains lime', () => { - expect(getAllFlavors()).toContain('lime'); -}); -``` - -This matcher also accepts others iterables such as strings, sets, node lists and HTML collections. - -### `.toContainEqual(item)` - -Use `.toContainEqual` when you want to check that an item with a specific structure and values is contained in an array. For testing the items in the array, this matcher recursively checks the equality of all fields, rather than checking for object identity. - -```js -describe('my beverage', () => { - test('is delicious and not sour', () => { - const myBeverage = {delicious: true, sour: false}; - expect(myBeverages()).toContainEqual(myBeverage); - }); -}); -``` - -### `.toEqual(value)` - -Use `.toEqual` to compare recursively all properties of object instances (also known as "deep" equality). It calls `Object.is` to compare primitive values, which is even better for testing than `===` strict equality operator. - -For example, `.toEqual` and `.toBe` behave differently in this test suite, so all the tests pass: - -```js -const can1 = { - flavor: 'grapefruit', - ounces: 12, -}; -const can2 = { - flavor: 'grapefruit', - ounces: 12, -}; - -describe('the La Croix cans on my desk', () => { - test('have all the same properties', () => { - expect(can1).toEqual(can2); - }); - test('are not the exact same can', () => { - expect(can1).not.toBe(can2); - }); -}); -``` - -> Note: `.toEqual` won't perform a _deep equality_ check for two errors. Only the `message` property of an Error is considered for equality. It is recommended to use the `.toThrow` matcher for testing against errors. - -If differences between properties do not help you to understand why a test fails, especially if the report is large, then you might move the comparison into the `expect` function. For example, use `equals` method of `Buffer` class to assert whether or not buffers contain the same content: - -- rewrite `expect(received).toEqual(expected)` as `expect(received.equals(expected)).toBe(true)` -- rewrite `expect(received).not.toEqual(expected)` as `expect(received.equals(expected)).toBe(false)` - -### `.toMatch(regexp | string)` - -Use `.toMatch` to check that a string matches a regular expression. - -For example, you might not know what exactly `essayOnTheBestFlavor()` returns, but you know it's a really long string, and the substring `grapefruit` should be in there somewhere. You can test this with: - -```js -describe('an essay on the best flavor', () => { - test('mentions grapefruit', () => { - expect(essayOnTheBestFlavor()).toMatch(/grapefruit/); - expect(essayOnTheBestFlavor()).toMatch(new RegExp('grapefruit')); - }); -}); -``` - -This matcher also accepts a string, which it will try to match: - -```js -describe('grapefruits are healthy', () => { - test('grapefruits are a fruit', () => { - expect('grapefruits').toMatch('fruit'); - }); -}); -``` - -### `.toMatchObject(object)` - -Use `.toMatchObject` to check that a JavaScript object matches a subset of the properties of an object. It will match received objects with properties that are **not** in the expected object. - -You can also pass an array of objects, in which case the method will return true only if each object in the received array matches (in the `toMatchObject` sense described above) the corresponding object in the expected array. This is useful if you want to check that two arrays match in their number of elements, as opposed to `arrayContaining`, which allows for extra elements in the received array. - -You can match properties against values or against matchers. - -```js -const houseForSale = { - bath: true, - bedrooms: 4, - kitchen: { - amenities: ['oven', 'stove', 'washer'], - area: 20, - wallColor: 'white', - }, -}; -const desiredHouse = { - bath: true, - kitchen: { - amenities: ['oven', 'stove', 'washer'], - wallColor: expect.stringMatching(/white|yellow/), - }, -}; - -test('the house has my desired features', () => { - expect(houseForSale).toMatchObject(desiredHouse); -}); -``` - -```js -describe('toMatchObject applied to arrays', () => { - test('the number of elements must match exactly', () => { - expect([{foo: 'bar'}, {baz: 1}]).toMatchObject([{foo: 'bar'}, {baz: 1}]); - }); - - test('.toMatchObject is called for each elements, so extra object properties are okay', () => { - expect([{foo: 'bar'}, {baz: 1, extra: 'quux'}]).toMatchObject([ - {foo: 'bar'}, - {baz: 1}, - ]); - }); -}); -``` - -### `.toMatchSnapshot(propertyMatchers?, hint?)` - -This ensures that a value matches the most recent snapshot. Check out [the Snapshot Testing guide](SnapshotTesting.md) for more information. - -You can provide an optional `propertyMatchers` object argument, which has asymmetric matchers as values of a subset of expected properties, **if** the received value will be an **object** instance. It is like `toMatchObject` with flexible criteria for a subset of properties, followed by a snapshot test as exact criteria for the rest of the properties. - -You can provide an optional `hint` string argument that is appended to the test name. Although Jest always appends a number at the end of a snapshot name, short descriptive hints might be more useful than numbers to differentiate **multiple** snapshots in a **single** `it` or `test` block. Jest sorts snapshots by name in the corresponding `.snap` file. - -### `.toMatchInlineSnapshot(propertyMatchers?, inlineSnapshot)` - -Ensures that a value matches the most recent snapshot. - -You can provide an optional `propertyMatchers` object argument, which has asymmetric matchers as values of a subset of expected properties, **if** the received value will be an **object** instance. It is like `toMatchObject` with flexible criteria for a subset of properties, followed by a snapshot test as exact criteria for the rest of the properties. - -Jest adds the `inlineSnapshot` string argument to the matcher in the test file (instead of an external `.snap` file) the first time that the test runs. - -Check out the section on [Inline Snapshots](SnapshotTesting.md#inline-snapshots) for more info. - -### `.toStrictEqual(value)` - -Use `.toStrictEqual` to test that objects have the same types as well as structure. - -Differences from `.toEqual`: - -- Keys with `undefined` properties are checked. e.g. `{a: undefined, b: 2}` does not match `{b: 2}` when using `.toStrictEqual`. -- Array sparseness is checked. e.g. `[, 1]` does not match `[undefined, 1]` when using `.toStrictEqual`. -- Object types are checked to be equal. e.g. A class instance with fields `a` and `b` will not equal a literal object with fields `a` and `b`. - -```js -class LaCroix { - constructor(flavor) { - this.flavor = flavor; - } -} - -describe('the La Croix cans on my desk', () => { - test('are not semantically the same', () => { - expect(new LaCroix('lemon')).toEqual({flavor: 'lemon'}); - expect(new LaCroix('lemon')).not.toStrictEqual({flavor: 'lemon'}); - }); -}); -``` - -### `.toThrow(error?)` - -Also under the alias: `.toThrowError(error?)` - -Use `.toThrow` to test that a function throws when it is called. For example, if we want to test that `drinkFlavor('octopus')` throws, because octopus flavor is too disgusting to drink, we could write: - -```js -test('throws on octopus', () => { - expect(() => { - drinkFlavor('octopus'); - }).toThrow(); -}); -``` - -> Note: You must wrap the code in a function, otherwise the error will not be caught and the assertion will fail. - -You can provide an optional argument to test that a specific error is thrown: - -- regular expression: error message **matches** the pattern -- string: error message **includes** the substring -- error object: error message is **equal to** the message property of the object -- error class: error object is **instance of** class - -For example, let's say that `drinkFlavor` is coded like this: - -```js -function drinkFlavor(flavor) { - if (flavor == 'octopus') { - throw new DisgustingFlavorError('yuck, octopus flavor'); - } - // Do some other stuff -} -``` - -We could test this error gets thrown in several ways: - -```js -test('throws on octopus', () => { - function drinkOctopus() { - drinkFlavor('octopus'); - } - - // Test that the error message says "yuck" somewhere: these are equivalent - expect(drinkOctopus).toThrowError(/yuck/); - expect(drinkOctopus).toThrowError('yuck'); - - // Test the exact error message - expect(drinkOctopus).toThrowError(/^yuck, octopus flavor$/); - expect(drinkOctopus).toThrowError(new Error('yuck, octopus flavor')); - - // Test that we get a DisgustingFlavorError - expect(drinkOctopus).toThrowError(DisgustingFlavorError); -}); -``` - -### `.toThrowErrorMatchingSnapshot(hint?)` - -Use `.toThrowErrorMatchingSnapshot` to test that a function throws an error matching the most recent snapshot when it is called. - -You can provide an optional `hint` string argument that is appended to the test name. Although Jest always appends a number at the end of a snapshot name, short descriptive hints might be more useful than numbers to differentiate **multiple** snapshots in a **single** `it` or `test` block. Jest sorts snapshots by name in the corresponding `.snap` file. - -For example, let's say you have a `drinkFlavor` function that throws whenever the flavor is `'octopus'`, and is coded like this: - -```js -function drinkFlavor(flavor) { - if (flavor == 'octopus') { - throw new DisgustingFlavorError('yuck, octopus flavor'); - } - // Do some other stuff -} -``` - -The test for this function will look this way: - -```js -test('throws on octopus', () => { - function drinkOctopus() { - drinkFlavor('octopus'); - } - - expect(drinkOctopus).toThrowErrorMatchingSnapshot(); -}); -``` - -And it will generate the following snapshot: - -```js -exports[`drinking flavors throws on octopus 1`] = `"yuck, octopus flavor"`; -``` - -Check out [React Tree Snapshot Testing](/blog/2016/07/27/jest-14) for more information on snapshot testing. - -### `.toThrowErrorMatchingInlineSnapshot(inlineSnapshot)` - -Use `.toThrowErrorMatchingInlineSnapshot` to test that a function throws an error matching the most recent snapshot when it is called. - -Jest adds the `inlineSnapshot` string argument to the matcher in the test file (instead of an external `.snap` file) the first time that the test runs. - -Check out the section on [Inline Snapshots](SnapshotTesting.md#inline-snapshots) for more info. diff --git a/website/versioned_docs/version-27.0/GettingStarted.md b/website/versioned_docs/version-27.0/GettingStarted.md deleted file mode 100644 index db798b49b5c1..000000000000 --- a/website/versioned_docs/version-27.0/GettingStarted.md +++ /dev/null @@ -1,173 +0,0 @@ ---- -id: getting-started -title: Getting Started ---- - -Install Jest using [`yarn`](https://yarnpkg.com/en/package/jest): - -```bash -yarn add --dev jest -``` - -Or [`npm`](https://www.npmjs.com/package/jest): - -```bash -npm install --save-dev jest -``` - -Note: Jest documentation uses `yarn` commands, but `npm` will also work. You can compare `yarn` and `npm` commands in the [yarn docs, here](https://yarnpkg.com/en/docs/migrating-from-npm#toc-cli-commands-comparison). - -Let's get started by writing a test for a hypothetical function that adds two numbers. First, create a `sum.js` file: - -```javascript -function sum(a, b) { - return a + b; -} -module.exports = sum; -``` - -Then, create a file named `sum.test.js`. This will contain our actual test: - -```javascript -const sum = require('./sum'); - -test('adds 1 + 2 to equal 3', () => { - expect(sum(1, 2)).toBe(3); -}); -``` - -Add the following section to your `package.json`: - -```json -{ - "scripts": { - "test": "jest" - } -} -``` - -Finally, run `yarn test` or `npm run test` and Jest will print this message: - -```bash -PASS ./sum.test.js -✓ adds 1 + 2 to equal 3 (5ms) -``` - -**You just successfully wrote your first test using Jest!** - -This test used `expect` and `toBe` to test that two values were exactly identical. To learn about the other things that Jest can test, see [Using Matchers](UsingMatchers.md). - -## Running from command line - -You can run Jest directly from the CLI (if it's globally available in your `PATH`, e.g. by `yarn global add jest` or `npm install jest --global`) with a variety of useful options. - -Here's how to run Jest on files matching `my-test`, using `config.json` as a configuration file and display a native OS notification after the run: - -```bash -jest my-test --notify --config=config.json -``` - -If you'd like to learn more about running `jest` through the command line, take a look at the [Jest CLI Options](CLI.md) page. - -## Additional Configuration - -### Generate a basic configuration file - -Based on your project, Jest will ask you a few questions and will create a basic configuration file with a short description for each option: - -```bash -jest --init -``` - -### Using Babel - -To use [Babel](https://babeljs.io/), install required dependencies via `yarn`: - -```bash -yarn add --dev babel-jest @babel/core @babel/preset-env -``` - -Configure Babel to target your current version of Node by creating a `babel.config.js` file in the root of your project: - -```javascript title="babel.config.js" -module.exports = { - presets: [['@babel/preset-env', {targets: {node: 'current'}}]], -}; -``` - -_The ideal configuration for Babel will depend on your project._ See [Babel's docs](https://babeljs.io/docs/en/) for more details. - -
Making your Babel config jest-aware - -Jest will set `process.env.NODE_ENV` to `'test'` if it's not set to something else. You can use that in your configuration to conditionally setup only the compilation needed for Jest, e.g. - -```javascript title="babel.config.js" -module.exports = api => { - const isTest = api.env('test'); - // You can use isTest to determine what presets and plugins to use. - - return { - // ... - }; -}; -``` - -> Note: `babel-jest` is automatically installed when installing Jest and will automatically transform files if a babel configuration exists in your project. To avoid this behavior, you can explicitly reset the `transform` configuration option: - -```javascript title="jest.config.js" -module.exports = { - transform: {}, -}; -``` - -
- -### Using webpack - -Jest can be used in projects that use [webpack](https://webpack.js.org/) to manage assets, styles, and compilation. Webpack does offer some unique challenges over other tools. Refer to the [webpack guide](Webpack.md) to get started. - -### Using parcel - -Jest can be used in projects that use [parcel-bundler](https://parceljs.org/) to manage assets, styles, and compilation similar to webpack. Parcel requires zero configuration. Refer to the official [docs](https://parceljs.org/docs/) to get started. - -### Using TypeScript - -#### Via `babel` - -Jest supports TypeScript, via Babel. First, make sure you followed the instructions on [using Babel](#using-babel) above. Next, install the `@babel/preset-typescript` via `yarn`: - -```bash -yarn add --dev @babel/preset-typescript -``` - -Then add `@babel/preset-typescript` to the list of presets in your `babel.config.js`. - -```javascript title="babel.config.js" -module.exports = { - presets: [ - ['@babel/preset-env', {targets: {node: 'current'}}], - // highlight-next-line - '@babel/preset-typescript', - ], -}; -``` - -However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transform-typescript#caveats) to using TypeScript with Babel. Because TypeScript support in Babel is purely transpilation, Jest will not type-check your tests as they are run. If you want that, you can use [ts-jest](https://github.com/kulshekhar/ts-jest) instead, or just run the TypeScript compiler [tsc](https://www.typescriptlang.org/docs/handbook/compiler-options.html) separately (or as part of your build process). - -#### Via `ts-jest` - -[ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. - -```bash -yarn add --dev ts-jest -``` - -#### Type definitions - -You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. - -> For `@types/*` modules it's recommended to try to match the version of the associated module. For example, if you are using `26.4.0` of `jest` then using `26.4.x` of `@types/jest` is ideal. In general, try to match the major (`26`) and minor (`4`) version as closely as possible. - -```bash -yarn add --dev @types/jest -``` diff --git a/website/versioned_docs/version-27.0/JestObjectAPI.md b/website/versioned_docs/version-27.0/JestObjectAPI.md deleted file mode 100644 index de5d9a92a145..000000000000 --- a/website/versioned_docs/version-27.0/JestObjectAPI.md +++ /dev/null @@ -1,686 +0,0 @@ ---- -id: jest-object -title: The Jest Object ---- - -The `jest` object is automatically in scope within every test file. The methods in the `jest` object help create mocks and let you control Jest's overall behavior. It can also be imported explicitly by via `import {jest} from '@jest/globals'`. - -## Methods - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Mock Modules - -### `jest.disableAutomock()` - -Disables automatic mocking in the module loader. - -> See `automock` section of [configuration](Configuration.md#automock-boolean) for more information - -After this method is called, all `require()`s will return the real versions of each module (rather than a mocked version). - -Jest configuration: - -```json -{ - "automock": true -} -``` - -Example: - -```js title="utils.js" -export default { - authorize: () => { - return 'token'; - }, -}; -``` - -```js title="__tests__/disableAutomocking.js" -import utils from '../utils'; - -jest.disableAutomock(); - -test('original implementation', () => { - // now we have the original implementation, - // even if we set the automocking in a jest configuration - expect(utils.authorize()).toBe('token'); -}); -``` - -This is usually useful when you have a scenario where the number of dependencies you want to mock is far less than the number of dependencies that you don't. For example, if you're writing a test for a module that uses a large number of dependencies that can be reasonably classified as "implementation details" of the module, then you likely do not want to mock them. - -Examples of dependencies that might be considered "implementation details" are things ranging from language built-ins (e.g. Array.prototype methods) to highly common utility methods (e.g. underscore/lo-dash, array utilities, etc) and entire libraries like React.js. - -Returns the `jest` object for chaining. - -_Note: this method was previously called `autoMockOff`. When using `babel-jest`, calls to `disableAutomock` will automatically be hoisted to the top of the code block. Use `autoMockOff` if you want to explicitly avoid this behavior._ - -### `jest.enableAutomock()` - -Enables automatic mocking in the module loader. - -Returns the `jest` object for chaining. - -> See `automock` section of [configuration](Configuration.md#automock-boolean) for more information - -Example: - -```js title="utils.js" -export default { - authorize: () => { - return 'token'; - }, - isAuthorized: secret => secret === 'wizard', -}; -``` - -```js title="__tests__/enableAutomocking.js" -jest.enableAutomock(); - -import utils from '../utils'; - -test('original implementation', () => { - // now we have the mocked implementation, - expect(utils.authorize._isMockFunction).toBeTruthy(); - expect(utils.isAuthorized._isMockFunction).toBeTruthy(); -}); -``` - -_Note: this method was previously called `autoMockOn`. When using `babel-jest`, calls to `enableAutomock` will automatically be hoisted to the top of the code block. Use `autoMockOn` if you want to explicitly avoid this behavior._ - -### `jest.createMockFromModule(moduleName)` - -##### renamed in Jest **26.0.0+** - -Also under the alias: `.genMockFromModule(moduleName)` - -Given the name of a module, use the automatic mocking system to generate a mocked version of the module for you. - -This is useful when you want to create a [manual mock](ManualMocks.md) that extends the automatic mock's behavior. - -Example: - -```js title="utils.js" -export default { - authorize: () => { - return 'token'; - }, - isAuthorized: secret => secret === 'wizard', -}; -``` - -```js title="__tests__/createMockFromModule.test.js" -const utils = jest.createMockFromModule('../utils').default; -utils.isAuthorized = jest.fn(secret => secret === 'not wizard'); - -test('implementation created by jest.createMockFromModule', () => { - expect(utils.authorize.mock).toBeTruthy(); - expect(utils.isAuthorized('not wizard')).toEqual(true); -}); -``` - -This is how `createMockFromModule` will mock the following data types: - -#### `Function` - -Creates a new [mock function](mock-functions). The new function has no formal parameters and when called will return `undefined`. This functionality also applies to `async` functions. - -#### `Class` - -Creates a new class. The interface of the original class is maintained, all of the class member functions and properties will be mocked. - -#### `Object` - -Creates a new deeply cloned object. The object keys are maintained and their values are mocked. - -#### `Array` - -Creates a new empty array, ignoring the original. - -#### `Primitives` - -Creates a new property with the same primitive value as the original property. - -Example: - -```js title="example.js" -module.exports = { - function: function square(a, b) { - return a * b; - }, - asyncFunction: async function asyncSquare(a, b) { - const result = (await a) * b; - return result; - }, - class: new (class Bar { - constructor() { - this.array = [1, 2, 3]; - } - foo() {} - })(), - object: { - baz: 'foo', - bar: { - fiz: 1, - buzz: [1, 2, 3], - }, - }, - array: [1, 2, 3], - number: 123, - string: 'baz', - boolean: true, - symbol: Symbol.for('a.b.c'), -}; -``` - -```js title="__tests__/example.test.js" -const example = jest.createMockFromModule('./example'); - -test('should run example code', () => { - // creates a new mocked function with no formal arguments. - expect(example.function.name).toEqual('square'); - expect(example.function.length).toEqual(0); - - // async functions get the same treatment as standard synchronous functions. - expect(example.asyncFunction.name).toEqual('asyncSquare'); - expect(example.asyncFunction.length).toEqual(0); - - // creates a new class with the same interface, member functions and properties are mocked. - expect(example.class.constructor.name).toEqual('Bar'); - expect(example.class.foo.name).toEqual('foo'); - expect(example.class.array.length).toEqual(0); - - // creates a deeply cloned version of the original object. - expect(example.object).toEqual({ - baz: 'foo', - bar: { - fiz: 1, - buzz: [], - }, - }); - - // creates a new empty array, ignoring the original array. - expect(example.array.length).toEqual(0); - - // creates a new property with the same primitive value as the original property. - expect(example.number).toEqual(123); - expect(example.string).toEqual('baz'); - expect(example.boolean).toEqual(true); - expect(example.symbol).toEqual(Symbol.for('a.b.c')); -}); -``` - -### `jest.mock(moduleName, factory, options)` - -Mocks a module with an auto-mocked version when it is being required. `factory` and `options` are optional. For example: - -```js title="banana.js" -module.exports = () => 'banana'; -``` - -```js title="__tests__/test.js" -jest.mock('../banana'); - -const banana = require('../banana'); // banana will be explicitly mocked. - -banana(); // will return 'undefined' because the function is auto-mocked. -``` - -The second argument can be used to specify an explicit module factory that is being run instead of using Jest's automocking feature: - -```js -jest.mock('../moduleName', () => { - return jest.fn(() => 42); -}); - -// This runs the function specified as second argument to `jest.mock`. -const moduleName = require('../moduleName'); -moduleName(); // Will return '42'; -``` - -When using the `factory` parameter for an ES6 module with a default export, the `__esModule: true` property needs to be specified. This property is normally generated by Babel / TypeScript, but here it needs to be set manually. When importing a default export, it's an instruction to import the property named `default` from the export object: - -```js -import moduleName, {foo} from '../moduleName'; - -jest.mock('../moduleName', () => { - return { - __esModule: true, - default: jest.fn(() => 42), - foo: jest.fn(() => 43), - }; -}); - -moduleName(); // Will return 42 -foo(); // Will return 43 -``` - -The third argument can be used to create virtual mocks – mocks of modules that don't exist anywhere in the system: - -```js -jest.mock( - '../moduleName', - () => { - /* - * Custom implementation of a module that doesn't exist in JS, - * like a generated module or a native module in react-native. - */ - }, - {virtual: true}, -); -``` - -> **Warning:** Importing a module in a setup file (as specified by `setupFilesAfterEnv`) will prevent mocking for the module in question, as well as all the modules that it imports. - -Modules that are mocked with `jest.mock` are mocked only for the file that calls `jest.mock`. Another file that imports the module will get the original implementation even if it runs after the test file that mocks the module. - -Returns the `jest` object for chaining. - -### `jest.unmock(moduleName)` - -Indicates that the module system should never return a mocked version of the specified module from `require()` (e.g. that it should always return the real module). - -The most common use of this API is for specifying the module a given test intends to be testing (and thus doesn't want automatically mocked). - -Returns the `jest` object for chaining. - -### `jest.doMock(moduleName, factory, options)` - -When using `babel-jest`, calls to `mock` will automatically be hoisted to the top of the code block. Use this method if you want to explicitly avoid this behavior. - -One example when this is useful is when you want to mock a module differently within the same file: - -```js -beforeEach(() => { - jest.resetModules(); -}); - -test('moduleName 1', () => { - jest.doMock('../moduleName', () => { - return jest.fn(() => 1); - }); - const moduleName = require('../moduleName'); - expect(moduleName()).toEqual(1); -}); - -test('moduleName 2', () => { - jest.doMock('../moduleName', () => { - return jest.fn(() => 2); - }); - const moduleName = require('../moduleName'); - expect(moduleName()).toEqual(2); -}); -``` - -Using `jest.doMock()` with ES6 imports requires additional steps. Follow these if you don't want to use `require` in your tests: - -- We have to specify the `__esModule: true` property (see the [`jest.mock()`](#jestmockmodulename-factory-options) API for more information). -- Static ES6 module imports are hoisted to the top of the file, so instead we have to import them dynamically using `import()`. -- Finally, we need an environment which supports dynamic importing. Please see [Using Babel](GettingStarted.md#using-babel) for the initial setup. Then add the plugin [babel-plugin-dynamic-import-node](https://www.npmjs.com/package/babel-plugin-dynamic-import-node), or an equivalent, to your Babel config to enable dynamic importing in Node. - -```js -beforeEach(() => { - jest.resetModules(); -}); - -test('moduleName 1', () => { - jest.doMock('../moduleName', () => { - return { - __esModule: true, - default: 'default1', - foo: 'foo1', - }; - }); - return import('../moduleName').then(moduleName => { - expect(moduleName.default).toEqual('default1'); - expect(moduleName.foo).toEqual('foo1'); - }); -}); - -test('moduleName 2', () => { - jest.doMock('../moduleName', () => { - return { - __esModule: true, - default: 'default2', - foo: 'foo2', - }; - }); - return import('../moduleName').then(moduleName => { - expect(moduleName.default).toEqual('default2'); - expect(moduleName.foo).toEqual('foo2'); - }); -}); -``` - -Returns the `jest` object for chaining. - -### `jest.dontMock(moduleName)` - -When using `babel-jest`, calls to `unmock` will automatically be hoisted to the top of the code block. Use this method if you want to explicitly avoid this behavior. - -Returns the `jest` object for chaining. - -### `jest.setMock(moduleName, moduleExports)` - -Explicitly supplies the mock object that the module system should return for the specified module. - -On occasion, there are times where the automatically generated mock the module system would normally provide you isn't adequate enough for your testing needs. Normally under those circumstances you should write a [manual mock](ManualMocks.md) that is more adequate for the module in question. However, on extremely rare occasions, even a manual mock isn't suitable for your purposes and you need to build the mock yourself inside your test. - -In these rare scenarios you can use this API to manually fill the slot in the module system's mock-module registry. - -Returns the `jest` object for chaining. - -_Note It is recommended to use [`jest.mock()`](#jestmockmodulename-factory-options) instead. The `jest.mock` API's second argument is a module factory instead of the expected exported module object._ - -### `jest.requireActual(moduleName)` - -Returns the actual module instead of a mock, bypassing all checks on whether the module should receive a mock implementation or not. - -Example: - -```js -jest.mock('../myModule', () => { - // Require the original module to not be mocked... - const originalModule = jest.requireActual('../myModule'); - - return { - __esModule: true, // Use it when dealing with esModules - ...originalModule, - getRandom: jest.fn().mockReturnValue(10), - }; -}); - -const getRandom = require('../myModule').getRandom; - -getRandom(); // Always returns 10 -``` - -### `jest.requireMock(moduleName)` - -Returns a mock module instead of the actual module, bypassing all checks on whether the module should be required normally or not. - -### `jest.resetModules()` - -Resets the module registry - the cache of all required modules. This is useful to isolate modules where local state might conflict between tests. - -Example: - -```js -const sum1 = require('../sum'); -jest.resetModules(); -const sum2 = require('../sum'); -sum1 === sum2; -// > false (Both sum modules are separate "instances" of the sum module.) -``` - -Example in a test: - -```js -beforeEach(() => { - jest.resetModules(); -}); - -test('works', () => { - const sum = require('../sum'); -}); - -test('works too', () => { - const sum = require('../sum'); - // sum is a different copy of the sum module from the previous test. -}); -``` - -Returns the `jest` object for chaining. - -### `jest.isolateModules(fn)` - -`jest.isolateModules(fn)` goes a step further than `jest.resetModules()` and creates a sandbox registry for the modules that are loaded inside the callback function. This is useful to isolate specific modules for every test so that local module state doesn't conflict between tests. - -```js -let myModule; -jest.isolateModules(() => { - myModule = require('myModule'); -}); - -const otherCopyOfMyModule = require('myModule'); -``` - -## Mock Functions - -### `jest.fn(implementation)` - -Returns a new, unused [mock function](MockFunctionAPI.md). Optionally takes a mock implementation. - -```js -const mockFn = jest.fn(); -mockFn(); -expect(mockFn).toHaveBeenCalled(); - -// With a mock implementation: -const returnsTrue = jest.fn(() => true); -console.log(returnsTrue()); // true; -``` - -### `jest.isMockFunction(fn)` - -Determines if the given function is a mocked function. - -### `jest.spyOn(object, methodName)` - -Creates a mock function similar to `jest.fn` but also tracks calls to `object[methodName]`. Returns a Jest [mock function](MockFunctionAPI.md). - -_Note: By default, `jest.spyOn` also calls the **spied** method. This is different behavior from most other test libraries. If you want to overwrite the original function, you can use `jest.spyOn(object, methodName).mockImplementation(() => customImplementation)` or `object[methodName] = jest.fn(() => customImplementation);`_ - -Example: - -```js -const video = { - play() { - return true; - }, -}; - -module.exports = video; -``` - -Example test: - -```js -const video = require('./video'); - -test('plays video', () => { - const spy = jest.spyOn(video, 'play'); - const isPlaying = video.play(); - - expect(spy).toHaveBeenCalled(); - expect(isPlaying).toBe(true); - - spy.mockRestore(); -}); -``` - -### `jest.spyOn(object, methodName, accessType?)` - -Since Jest 22.1.0+, the `jest.spyOn` method takes an optional third argument of `accessType` that can be either `'get'` or `'set'`, which proves to be useful when you want to spy on a getter or a setter, respectively. - -Example: - -```js -const video = { - // it's a getter! - get play() { - return true; - }, -}; - -module.exports = video; - -const audio = { - _volume: false, - // it's a setter! - set volume(value) { - this._volume = value; - }, - get volume() { - return this._volume; - }, -}; - -module.exports = audio; -``` - -Example test: - -```js -const audio = require('./audio'); -const video = require('./video'); - -test('plays video', () => { - const spy = jest.spyOn(video, 'play', 'get'); // we pass 'get' - const isPlaying = video.play; - - expect(spy).toHaveBeenCalled(); - expect(isPlaying).toBe(true); - - spy.mockRestore(); -}); - -test('plays audio', () => { - const spy = jest.spyOn(audio, 'volume', 'set'); // we pass 'set' - audio.volume = 100; - - expect(spy).toHaveBeenCalled(); - expect(audio.volume).toBe(100); - - spy.mockRestore(); -}); -``` - -### `jest.clearAllMocks()` - -Clears the `mock.calls`, `mock.instances` and `mock.results` properties of all mocks. Equivalent to calling [`.mockClear()`](MockFunctionAPI.md#mockfnmockclear) on every mocked function. - -Returns the `jest` object for chaining. - -### `jest.resetAllMocks()` - -Resets the state of all mocks. Equivalent to calling [`.mockReset()`](MockFunctionAPI.md#mockfnmockreset) on every mocked function. - -Returns the `jest` object for chaining. - -### `jest.restoreAllMocks()` - -Restores all mocks back to their original value. Equivalent to calling [`.mockRestore()`](MockFunctionAPI.md#mockfnmockrestore) on every mocked function. Beware that `jest.restoreAllMocks()` only works when the mock was created with `jest.spyOn`; other mocks will require you to manually restore them. - -## Mock Timers - -### `jest.useFakeTimers(implementation?: 'modern' | 'legacy')` - -Instructs Jest to use fake versions of the standard timer functions (`setTimeout`, `setInterval`, `clearTimeout`, `clearInterval`, `nextTick`, `setImmediate` and `clearImmediate` as well as `Date`). - -If you pass `'legacy'` as an argument, Jest's legacy implementation will be used rather than one based on [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). - -Returns the `jest` object for chaining. - -### `jest.useRealTimers()` - -Instructs Jest to use the real versions of the standard timer functions. - -Returns the `jest` object for chaining. - -### `jest.runAllTicks()` - -Exhausts the **micro**-task queue (usually interfaced in node via `process.nextTick`). - -When this API is called, all pending micro-tasks that have been queued via `process.nextTick` will be executed. Additionally, if those micro-tasks themselves schedule new micro-tasks, those will be continually exhausted until there are no more micro-tasks remaining in the queue. - -### `jest.runAllTimers()` - -Exhausts both the **macro**-task queue (i.e., all tasks queued by `setTimeout()`, `setInterval()`, and `setImmediate()`) and the **micro**-task queue (usually interfaced in node via `process.nextTick`). - -When this API is called, all pending macro-tasks and micro-tasks will be executed. If those tasks themselves schedule new tasks, those will be continually exhausted until there are no more tasks remaining in the queue. - -This is often useful for synchronously executing setTimeouts during a test in order to synchronously assert about some behavior that would only happen after the `setTimeout()` or `setInterval()` callbacks executed. See the [Timer mocks](TimerMocks.md) doc for more information. - -### `jest.runAllImmediates()` - -Exhausts all tasks queued by `setImmediate()`. - -> Note: This function is not available when using modern fake timers implementation - -### `jest.advanceTimersByTime(msToRun)` - -Executes only the macro task queue (i.e. all tasks queued by `setTimeout()` or `setInterval()` and `setImmediate()`). - -When this API is called, all timers are advanced by `msToRun` milliseconds. All pending "macro-tasks" that have been queued via `setTimeout()` or `setInterval()`, and would be executed within this time frame will be executed. Additionally, if those macro-tasks schedule new macro-tasks that would be executed within the same time frame, those will be executed until there are no more macro-tasks remaining in the queue, that should be run within `msToRun` milliseconds. - -### `jest.runOnlyPendingTimers()` - -Executes only the macro-tasks that are currently pending (i.e., only the tasks that have been queued by `setTimeout()` or `setInterval()` up to this point). If any of the currently pending macro-tasks schedule new macro-tasks, those new tasks will not be executed by this call. - -This is useful for scenarios such as one where the module being tested schedules a `setTimeout()` whose callback schedules another `setTimeout()` recursively (meaning the scheduling never stops). In these scenarios, it's useful to be able to run forward in time by a single step at a time. - -### `jest.advanceTimersToNextTimer(steps)` - -Advances all timers by the needed milliseconds so that only the next timeouts/intervals will run. - -Optionally, you can provide `steps`, so it will run `steps` amount of next timeouts/intervals. - -### `jest.clearAllTimers()` - -Removes any pending timers from the timer system. - -This means, if any timers have been scheduled (but have not yet executed), they will be cleared and will never have the opportunity to execute in the future. - -### `jest.getTimerCount()` - -Returns the number of fake timers still left to run. - -### `jest.setSystemTime(now?: number | Date)` - -Set the current system time used by fake timers. Simulates a user changing the system clock while your program is running. It affects the current time but it does not in itself cause e.g. timers to fire; they will fire exactly as they would have done without the call to `jest.setSystemTime()`. - -> Note: This function is only available when using modern fake timers implementation - -### `jest.getRealSystemTime()` - -When mocking time, `Date.now()` will also be mocked. If you for some reason need access to the real current time, you can invoke this function. - -> Note: This function is only available when using modern fake timers implementation - -## Misc - -### `jest.setTimeout(timeout)` - -Set the default timeout interval for tests and before/after hooks in milliseconds. This only affects the test file from which this function is called. - -_Note: The default timeout interval is 5 seconds if this method is not called._ - -_Note: If you want to set the timeout for all test files, a good place to do this is in `setupFilesAfterEnv`._ - -Example: - -```js -jest.setTimeout(1000); // 1 second -``` - -### `jest.retryTimes()` - -Runs failed tests n-times until they pass or until the max number of retries is exhausted. This only works with the default [jest-circus](https://github.com/facebook/jest/tree/main/packages/jest-circus) runner! This must live at the top-level of a test file or in a describe block. Retries _will not_ work if `jest.retryTimes()` is called in a `beforeEach` or a `test` block. - -Example in a test: - -```js -jest.retryTimes(3); -test('will fail', () => { - expect(true).toBe(false); -}); -``` - -Returns the `jest` object for chaining. diff --git a/website/versioned_docs/version-27.0/MockFunctionAPI.md b/website/versioned_docs/version-27.0/MockFunctionAPI.md deleted file mode 100644 index 5bb3925c81a1..000000000000 --- a/website/versioned_docs/version-27.0/MockFunctionAPI.md +++ /dev/null @@ -1,448 +0,0 @@ ---- -id: mock-function-api -title: Mock Functions ---- - -Mock functions are also known as "spies", because they let you spy on the behavior of a function that is called indirectly by some other code, rather than only testing the output. You can create a mock function with `jest.fn()`. If no implementation is given, the mock function will return `undefined` when invoked. - -## Methods - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Reference - -### `mockFn.getMockName()` - -Returns the mock name string set by calling `mockFn.mockName(value)`. - -### `mockFn.mock.calls` - -An array containing the call arguments of all calls that have been made to this mock function. Each item in the array is an array of arguments that were passed during the call. - -For example: A mock function `f` that has been called twice, with the arguments `f('arg1', 'arg2')`, and then with the arguments `f('arg3', 'arg4')`, would have a `mock.calls` array that looks like this: - -```js -[ - ['arg1', 'arg2'], - ['arg3', 'arg4'], -]; -``` - -### `mockFn.mock.results` - -An array containing the results of all calls that have been made to this mock function. Each entry in this array is an object containing a `type` property, and a `value` property. `type` will be one of the following: - -- `'return'` - Indicates that the call completed by returning normally. -- `'throw'` - Indicates that the call completed by throwing a value. -- `'incomplete'` - Indicates that the call has not yet completed. This occurs if you test the result from within the mock function itself, or from within a function that was called by the mock. - -The `value` property contains the value that was thrown or returned. `value` is undefined when `type === 'incomplete'`. - -For example: A mock function `f` that has been called three times, returning `'result1'`, throwing an error, and then returning `'result2'`, would have a `mock.results` array that looks like this: - -```js -[ - { - type: 'return', - value: 'result1', - }, - { - type: 'throw', - value: { - /* Error instance */ - }, - }, - { - type: 'return', - value: 'result2', - }, -]; -``` - -### `mockFn.mock.instances` - -An array that contains all the object instances that have been instantiated from this mock function using `new`. - -For example: A mock function that has been instantiated twice would have the following `mock.instances` array: - -```js -const mockFn = jest.fn(); - -const a = new mockFn(); -const b = new mockFn(); - -mockFn.mock.instances[0] === a; // true -mockFn.mock.instances[1] === b; // true -``` - -### `mockFn.mockClear()` - -Clears all information stored in the [`mockFn.mock.calls`](#mockfnmockcalls), [`mockFn.mock.instances`](#mockfnmockinstances) and [`mockFn.mock.results`](#mockfnmockresults) arrays. Often this is useful when you want to clean up a mocks usage data between two assertions. - -Beware that `mockClear` will replace `mockFn.mock`, not just these three properties! You should, therefore, avoid assigning `mockFn.mock` to other variables, temporary or not, to make sure you don't access stale data. - -The [`clearMocks`](configuration#clearmocks-boolean) configuration option is available to clear mocks automatically before each tests. - -### `mockFn.mockReset()` - -Does everything that [`mockFn.mockClear()`](#mockfnmockclear) does, and also removes any mocked return values or implementations. - -This is useful when you want to completely reset a _mock_ back to its initial state. (Note that resetting a _spy_ will result in a function with no return value). - -The [`mockReset`](configuration#resetmocks-boolean) configuration option is available to reset mocks automatically before each test. - -### `mockFn.mockRestore()` - -Does everything that [`mockFn.mockReset()`](#mockfnmockreset) does, and also restores the original (non-mocked) implementation. - -This is useful when you want to mock functions in certain test cases and restore the original implementation in others. - -Beware that `mockFn.mockRestore` only works when the mock was created with `jest.spyOn`. Thus you have to take care of restoration yourself when manually assigning `jest.fn()`. - -The [`restoreMocks`](configuration#restoremocks-boolean) configuration option is available to restore mocks automatically before each test. - -### `mockFn.mockImplementation(fn)` - -Accepts a function that should be used as the implementation of the mock. The mock itself will still record all calls that go into and instances that come from itself – the only difference is that the implementation will also be executed when the mock is called. - -_Note: `jest.fn(implementation)` is a shorthand for `jest.fn().mockImplementation(implementation)`._ - -For example: - -```js -const mockFn = jest.fn().mockImplementation(scalar => 42 + scalar); -// or: jest.fn(scalar => 42 + scalar); - -const a = mockFn(0); -const b = mockFn(1); - -a === 42; // true -b === 43; // true - -mockFn.mock.calls[0][0] === 0; // true -mockFn.mock.calls[1][0] === 1; // true -``` - -`mockImplementation` can also be used to mock class constructors: - -```js title="SomeClass.js" -module.exports = class SomeClass { - m(a, b) {} -}; -``` - -```js title="OtherModule.test.js" -jest.mock('./SomeClass'); // this happens automatically with automocking -const SomeClass = require('./SomeClass'); -const mMock = jest.fn(); -SomeClass.mockImplementation(() => { - return { - m: mMock, - }; -}); - -const some = new SomeClass(); -some.m('a', 'b'); -console.log('Calls to m: ', mMock.mock.calls); -``` - -### `mockFn.mockImplementationOnce(fn)` - -Accepts a function that will be used as an implementation of the mock for one call to the mocked function. Can be chained so that multiple function calls produce different results. - -```js -const myMockFn = jest - .fn() - .mockImplementationOnce(cb => cb(null, true)) - .mockImplementationOnce(cb => cb(null, false)); - -myMockFn((err, val) => console.log(val)); // true - -myMockFn((err, val) => console.log(val)); // false -``` - -When the mocked function runs out of implementations defined with mockImplementationOnce, it will execute the default implementation set with `jest.fn(() => defaultValue)` or `.mockImplementation(() => defaultValue)` if they were called: - -```js -const myMockFn = jest - .fn(() => 'default') - .mockImplementationOnce(() => 'first call') - .mockImplementationOnce(() => 'second call'); - -// 'first call', 'second call', 'default', 'default' -console.log(myMockFn(), myMockFn(), myMockFn(), myMockFn()); -``` - -### `mockFn.mockName(value)` - -Accepts a string to use in test result output in place of "jest.fn()" to indicate which mock function is being referenced. - -For example: - -```js -const mockFn = jest.fn().mockName('mockedFunction'); -// mockFn(); -expect(mockFn).toHaveBeenCalled(); -``` - -Will result in this error: - -``` -expect(mockedFunction).toHaveBeenCalled() - -Expected mock function "mockedFunction" to have been called, but it was not called. -``` - -### `mockFn.mockReturnThis()` - -Syntactic sugar function for: - -```js -jest.fn(function () { - return this; -}); -``` - -### `mockFn.mockReturnValue(value)` - -Accepts a value that will be returned whenever the mock function is called. - -```js -const mock = jest.fn(); -mock.mockReturnValue(42); -mock(); // 42 -mock.mockReturnValue(43); -mock(); // 43 -``` - -### `mockFn.mockReturnValueOnce(value)` - -Accepts a value that will be returned for one call to the mock function. Can be chained so that successive calls to the mock function return different values. When there are no more `mockReturnValueOnce` values to use, calls will return a value specified by `mockReturnValue`. - -```js -const myMockFn = jest - .fn() - .mockReturnValue('default') - .mockReturnValueOnce('first call') - .mockReturnValueOnce('second call'); - -// 'first call', 'second call', 'default', 'default' -console.log(myMockFn(), myMockFn(), myMockFn(), myMockFn()); -``` - -### `mockFn.mockResolvedValue(value)` - -Syntactic sugar function for: - -```js -jest.fn().mockImplementation(() => Promise.resolve(value)); -``` - -Useful to mock async functions in async tests: - -```js -test('async test', async () => { - const asyncMock = jest.fn().mockResolvedValue(43); - - await asyncMock(); // 43 -}); -``` - -### `mockFn.mockResolvedValueOnce(value)` - -Syntactic sugar function for: - -```js -jest.fn().mockImplementationOnce(() => Promise.resolve(value)); -``` - -Useful to resolve different values over multiple async calls: - -```js -test('async test', async () => { - const asyncMock = jest - .fn() - .mockResolvedValue('default') - .mockResolvedValueOnce('first call') - .mockResolvedValueOnce('second call'); - - await asyncMock(); // first call - await asyncMock(); // second call - await asyncMock(); // default - await asyncMock(); // default -}); -``` - -### `mockFn.mockRejectedValue(value)` - -Syntactic sugar function for: - -```js -jest.fn().mockImplementation(() => Promise.reject(value)); -``` - -Useful to create async mock functions that will always reject: - -```js -test('async test', async () => { - const asyncMock = jest.fn().mockRejectedValue(new Error('Async error')); - - await asyncMock(); // throws "Async error" -}); -``` - -### `mockFn.mockRejectedValueOnce(value)` - -Syntactic sugar function for: - -```js -jest.fn().mockImplementationOnce(() => Promise.reject(value)); -``` - -Example usage: - -```js -test('async test', async () => { - const asyncMock = jest - .fn() - .mockResolvedValueOnce('first call') - .mockRejectedValueOnce(new Error('Async error')); - - await asyncMock(); // first call - await asyncMock(); // throws "Async error" -}); -``` - -## TypeScript - -Jest itself is written in [TypeScript](https://www.typescriptlang.org). - -If you are using [Create React App](https://create-react-app.dev) then the [TypeScript template](https://create-react-app.dev/docs/adding-typescript/) has everything you need to start writing tests in TypeScript. - -Otherwise, please see our [Getting Started](GettingStarted.md#using-typescript) guide for to get setup with TypeScript. - -You can see an example of using Jest with TypeScript in our [GitHub repository](https://github.com/facebook/jest/tree/main/examples/typescript). - -### `jest.MockedFunction` - -> `jest.MockedFunction` is available in the `@types/jest` module from version `24.9.0`. - -The following examples will assume you have an understanding of how [Jest mock functions work with JavaScript](MockFunctions.md). - -You can use `jest.MockedFunction` to represent a function that has been replaced by a Jest mock. - -Example using [automatic `jest.mock`](JestObjectAPI.md#jestmockmodulename-factory-options): - -```ts -// Assume `add` is imported and used within `calculate`. -import add from './add'; -import calculate from './calc'; - -jest.mock('./add'); - -// Our mock of `add` is now fully typed -const mockAdd = add as jest.MockedFunction; - -test('calculate calls add', () => { - calculate('Add', 1, 2); - - expect(mockAdd).toBeCalledTimes(1); - expect(mockAdd).toBeCalledWith(1, 2); -}); -``` - -Example using [`jest.fn`](JestObjectAPI.md#jestfnimplementation): - -```ts -// Here `add` is imported for its type -import add from './add'; -import calculate from './calc'; - -test('calculate calls add', () => { - // Create a new mock that can be used in place of `add`. - const mockAdd = jest.fn() as jest.MockedFunction; - - // Note: You can use the `jest.fn` type directly like this if you want: - // const mockAdd = jest.fn, Parameters>(); - // `jest.MockedFunction` is a more friendly shortcut. - - // Now we can easily set up mock implementations. - // All the `.mock*` API can now give you proper types for `add`. - // https://jestjs.io/docs/mock-function-api - - // `.mockImplementation` can now infer that `a` and `b` are `number` - // and that the returned value is a `number`. - mockAdd.mockImplementation((a, b) => { - // Yes, this mock is still adding two numbers but imagine this - // was a complex function we are mocking. - return a + b; - }); - - // `mockAdd` is properly typed and therefore accepted by - // anything requiring `add`. - calculate(mockAdd, 1, 2); - - expect(mockAdd).toBeCalledTimes(1); - expect(mockAdd).toBeCalledWith(1, 2); -}); -``` - -### `jest.MockedClass` - -> `jest.MockedClass` is available in the `@types/jest` module from version `24.9.0`. - -The following examples will assume you have an understanding of how [Jest mock classes work with JavaScript](Es6ClassMocks.md). - -You can use `jest.MockedClass` to represent a class that has been replaced by a Jest mock. - -Converting the [ES6 Class automatic mock example](Es6ClassMocks.md#automatic-mock) would look like this: - -```ts -import SoundPlayer from '../sound-player'; -import SoundPlayerConsumer from '../sound-player-consumer'; - -jest.mock('../sound-player'); // SoundPlayer is now a mock constructor - -const SoundPlayerMock = SoundPlayer as jest.MockedClass; - -beforeEach(() => { - // Clear all instances and calls to constructor and all methods: - SoundPlayerMock.mockClear(); -}); - -it('We can check if the consumer called the class constructor', () => { - const soundPlayerConsumer = new SoundPlayerConsumer(); - expect(SoundPlayerMock).toHaveBeenCalledTimes(1); -}); - -it('We can check if the consumer called a method on the class instance', () => { - // Show that mockClear() is working: - expect(SoundPlayerMock).not.toHaveBeenCalled(); - - const soundPlayerConsumer = new SoundPlayerConsumer(); - // Constructor should have been called again: - expect(SoundPlayerMock).toHaveBeenCalledTimes(1); - - const coolSoundFileName = 'song.mp3'; - soundPlayerConsumer.playSomethingCool(); - - // mock.instances is available with automatic mocks: - const mockSoundPlayerInstance = SoundPlayerMock.mock.instances[0]; - - // However, it will not allow access to `.mock` in TypeScript as it - // is returning `SoundPlayer`. Instead, you can check the calls to a - // method like this fully typed: - expect(SoundPlayerMock.prototype.playSoundFile.mock.calls[0][0]).toEqual( - coolSoundFileName, - ); - // Equivalent to above check: - expect(SoundPlayerMock.prototype.playSoundFile).toHaveBeenCalledWith( - coolSoundFileName, - ); - expect(SoundPlayerMock.prototype.playSoundFile).toHaveBeenCalledTimes(1); -}); -``` diff --git a/website/versioned_docs/version-27.0/MockFunctions.md b/website/versioned_docs/version-27.0/MockFunctions.md deleted file mode 100644 index 2e686a92e837..000000000000 --- a/website/versioned_docs/version-27.0/MockFunctions.md +++ /dev/null @@ -1,315 +0,0 @@ ---- -id: mock-functions -title: Mock Functions ---- - -Mock functions allow you to test the links between code by erasing the actual implementation of a function, capturing calls to the function (and the parameters passed in those calls), capturing instances of constructor functions when instantiated with `new`, and allowing test-time configuration of return values. - -There are two ways to mock functions: Either by creating a mock function to use in test code, or writing a [`manual mock`](ManualMocks.md) to override a module dependency. - -## Using a mock function - -Let's imagine we're testing an implementation of a function `forEach`, which invokes a callback for each item in a supplied array. - -```javascript -function forEach(items, callback) { - for (let index = 0; index < items.length; index++) { - callback(items[index]); - } -} -``` - -To test this function, we can use a mock function, and inspect the mock's state to ensure the callback is invoked as expected. - -```javascript -const mockCallback = jest.fn(x => 42 + x); -forEach([0, 1], mockCallback); - -// The mock function is called twice -expect(mockCallback.mock.calls.length).toBe(2); - -// The first argument of the first call to the function was 0 -expect(mockCallback.mock.calls[0][0]).toBe(0); - -// The first argument of the second call to the function was 1 -expect(mockCallback.mock.calls[1][0]).toBe(1); - -// The return value of the first call to the function was 42 -expect(mockCallback.mock.results[0].value).toBe(42); -``` - -## `.mock` property - -All mock functions have this special `.mock` property, which is where data about how the function has been called and what the function returned is kept. The `.mock` property also tracks the value of `this` for each call, so it is possible to inspect this as well: - -```javascript -const myMock = jest.fn(); - -const a = new myMock(); -const b = {}; -const bound = myMock.bind(b); -bound(); - -console.log(myMock.mock.instances); -// > [ , ] -``` - -These mock members are very useful in tests to assert how these functions get called, instantiated, or what they returned: - -```javascript -// The function was called exactly once -expect(someMockFunction.mock.calls.length).toBe(1); - -// The first arg of the first call to the function was 'first arg' -expect(someMockFunction.mock.calls[0][0]).toBe('first arg'); - -// The second arg of the first call to the function was 'second arg' -expect(someMockFunction.mock.calls[0][1]).toBe('second arg'); - -// The return value of the first call to the function was 'return value' -expect(someMockFunction.mock.results[0].value).toBe('return value'); - -// This function was instantiated exactly twice -expect(someMockFunction.mock.instances.length).toBe(2); - -// The object returned by the first instantiation of this function -// had a `name` property whose value was set to 'test' -expect(someMockFunction.mock.instances[0].name).toEqual('test'); -``` - -## Mock Return Values - -Mock functions can also be used to inject test values into your code during a test: - -```javascript -const myMock = jest.fn(); -console.log(myMock()); -// > undefined - -myMock.mockReturnValueOnce(10).mockReturnValueOnce('x').mockReturnValue(true); - -console.log(myMock(), myMock(), myMock(), myMock()); -// > 10, 'x', true, true -``` - -Mock functions are also very effective in code that uses a functional continuation-passing style. Code written in this style helps avoid the need for complicated stubs that recreate the behavior of the real component they're standing in for, in favor of injecting values directly into the test right before they're used. - -```javascript -const filterTestFn = jest.fn(); - -// Make the mock return `true` for the first call, -// and `false` for the second call -filterTestFn.mockReturnValueOnce(true).mockReturnValueOnce(false); - -const result = [11, 12].filter(num => filterTestFn(num)); - -console.log(result); -// > [11] -console.log(filterTestFn.mock.calls[0][0]); // 11 -console.log(filterTestFn.mock.calls[1][0]); // 12 -``` - -Most real-world examples actually involve getting ahold of a mock function on a dependent component and configuring that, but the technique is the same. In these cases, try to avoid the temptation to implement logic inside of any function that's not directly being tested. - -## Mocking Modules - -Suppose we have a class that fetches users from our API. The class uses [axios](https://github.com/axios/axios) to call the API then returns the `data` attribute which contains all the users: - -```js title="users.js" -import axios from 'axios'; - -class Users { - static all() { - return axios.get('/users.json').then(resp => resp.data); - } -} - -export default Users; -``` - -Now, in order to test this method without actually hitting the API (and thus creating slow and fragile tests), we can use the `jest.mock(...)` function to automatically mock the axios module. - -Once we mock the module we can provide a `mockResolvedValue` for `.get` that returns the data we want our test to assert against. In effect, we are saying that we want `axios.get('/users.json')` to return a fake response. - -```js title="users.test.js" -import axios from 'axios'; -import Users from './users'; - -jest.mock('axios'); - -test('should fetch users', () => { - const users = [{name: 'Bob'}]; - const resp = {data: users}; - axios.get.mockResolvedValue(resp); - - // or you could use the following depending on your use case: - // axios.get.mockImplementation(() => Promise.resolve(resp)) - - return Users.all().then(data => expect(data).toEqual(users)); -}); -``` - -## Mocking Partials - -Subsets of a module can be mocked and the rest of the module can keep their actual implementation: - -```js title="foo-bar-baz.js" -export const foo = 'foo'; -export const bar = () => 'bar'; -export default () => 'baz'; -``` - -```js -//test.js -import defaultExport, {bar, foo} from '../foo-bar-baz'; - -jest.mock('../foo-bar-baz', () => { - const originalModule = jest.requireActual('../foo-bar-baz'); - - //Mock the default export and named export 'foo' - return { - __esModule: true, - ...originalModule, - default: jest.fn(() => 'mocked baz'), - foo: 'mocked foo', - }; -}); - -test('should do a partial mock', () => { - const defaultExportResult = defaultExport(); - expect(defaultExportResult).toBe('mocked baz'); - expect(defaultExport).toHaveBeenCalled(); - - expect(foo).toBe('mocked foo'); - expect(bar()).toBe('bar'); -}); -``` - -## Mock Implementations - -Still, there are cases where it's useful to go beyond the ability to specify return values and full-on replace the implementation of a mock function. This can be done with `jest.fn` or the `mockImplementationOnce` method on mock functions. - -```javascript -const myMockFn = jest.fn(cb => cb(null, true)); - -myMockFn((err, val) => console.log(val)); -// > true -``` - -The `mockImplementation` method is useful when you need to define the default implementation of a mock function that is created from another module: - -```js title="foo.js" -module.exports = function () { - // some implementation; -}; -``` - -```js title="test.js" -jest.mock('../foo'); // this happens automatically with automocking -const foo = require('../foo'); - -// foo is a mock function -foo.mockImplementation(() => 42); -foo(); -// > 42 -``` - -When you need to recreate a complex behavior of a mock function such that multiple function calls produce different results, use the `mockImplementationOnce` method: - -```javascript -const myMockFn = jest - .fn() - .mockImplementationOnce(cb => cb(null, true)) - .mockImplementationOnce(cb => cb(null, false)); - -myMockFn((err, val) => console.log(val)); -// > true - -myMockFn((err, val) => console.log(val)); -// > false -``` - -When the mocked function runs out of implementations defined with `mockImplementationOnce`, it will execute the default implementation set with `jest.fn` (if it is defined): - -```javascript -const myMockFn = jest - .fn(() => 'default') - .mockImplementationOnce(() => 'first call') - .mockImplementationOnce(() => 'second call'); - -console.log(myMockFn(), myMockFn(), myMockFn(), myMockFn()); -// > 'first call', 'second call', 'default', 'default' -``` - -For cases where we have methods that are typically chained (and thus always need to return `this`), we have a sugary API to simplify this in the form of a `.mockReturnThis()` function that also sits on all mocks: - -```javascript -const myObj = { - myMethod: jest.fn().mockReturnThis(), -}; - -// is the same as - -const otherObj = { - myMethod: jest.fn(function () { - return this; - }), -}; -``` - -## Mock Names - -You can optionally provide a name for your mock functions, which will be displayed instead of "jest.fn()" in the test error output. Use this if you want to be able to quickly identify the mock function reporting an error in your test output. - -```javascript -const myMockFn = jest - .fn() - .mockReturnValue('default') - .mockImplementation(scalar => 42 + scalar) - .mockName('add42'); -``` - -## Custom Matchers - -Finally, in order to make it less demanding to assert how mock functions have been called, we've added some custom matcher functions for you: - -```javascript -// The mock function was called at least once -expect(mockFunc).toHaveBeenCalled(); - -// The mock function was called at least once with the specified args -expect(mockFunc).toHaveBeenCalledWith(arg1, arg2); - -// The last call to the mock function was called with the specified args -expect(mockFunc).toHaveBeenLastCalledWith(arg1, arg2); - -// All calls and the name of the mock is written as a snapshot -expect(mockFunc).toMatchSnapshot(); -``` - -These matchers are sugar for common forms of inspecting the `.mock` property. You can always do this manually yourself if that's more to your taste or if you need to do something more specific: - -```javascript -// The mock function was called at least once -expect(mockFunc.mock.calls.length).toBeGreaterThan(0); - -// The mock function was called at least once with the specified args -expect(mockFunc.mock.calls).toContainEqual([arg1, arg2]); - -// The last call to the mock function was called with the specified args -expect(mockFunc.mock.calls[mockFunc.mock.calls.length - 1]).toEqual([ - arg1, - arg2, -]); - -// The first arg of the last call to the mock function was `42` -// (note that there is no sugar helper for this specific of an assertion) -expect(mockFunc.mock.calls[mockFunc.mock.calls.length - 1][0]).toBe(42); - -// A snapshot will check that a mock was invoked the same number of times, -// in the same order, with the same arguments. It will also assert on the name. -expect(mockFunc.mock.calls).toEqual([[arg1, arg2]]); -expect(mockFunc.getMockName()).toBe('a mock name'); -``` - -For a complete list of matchers, check out the [reference docs](ExpectAPI.md). diff --git a/website/versioned_docs/version-27.0/TimerMocks.md b/website/versioned_docs/version-27.0/TimerMocks.md deleted file mode 100644 index 0952884e1beb..000000000000 --- a/website/versioned_docs/version-27.0/TimerMocks.md +++ /dev/null @@ -1,187 +0,0 @@ ---- -id: timer-mocks -title: Timer Mocks ---- - -The native timer functions (i.e., `setTimeout`, `setInterval`, `clearTimeout`, `clearInterval`) are less than ideal for a testing environment since they depend on real time to elapse. Jest can swap out timers with functions that allow you to control the passage of time. [Great Scott!](https://www.youtube.com/watch?v=QZoJ2Pt27BY) - -```javascript title="timerGame.js" -'use strict'; - -function timerGame(callback) { - console.log('Ready....go!'); - setTimeout(() => { - console.log("Time's up -- stop!"); - callback && callback(); - }, 1000); -} - -module.exports = timerGame; -``` - -```javascript title="__tests__/timerGame-test.js" -'use strict'; - -jest.useFakeTimers(); // or you can set "timers": "fake" globally in configuration file -jest.spyOn(global, 'setTimeout'); - -test('waits 1 second before ending the game', () => { - const timerGame = require('../timerGame'); - timerGame(); - - expect(setTimeout).toHaveBeenCalledTimes(1); - expect(setTimeout).toHaveBeenLastCalledWith(expect.any(Function), 1000); -}); -``` - -Here we enable fake timers by calling `jest.useFakeTimers()`. This mocks out `setTimeout` and other timer functions with mock functions. Timers can be restored to their normal behavior with `jest.useRealTimers()`. - -While you can call `jest.useFakeTimers()` or `jest.useRealTimers()` from anywhere (top level, inside an `it` block, etc.), it is a **global operation** and will affect other tests within the same file. Additionally, you need to call `jest.useFakeTimers()` to reset internal counters before each test. If you plan to not use fake timers in all your tests, you will want to clean up manually, as otherwise the faked timers will leak across tests: - -```javascript -afterEach(() => { - jest.useRealTimers(); -}); - -test('do something with fake timers', () => { - jest.useFakeTimers(); - // ... -}); - -test('do something with real timers', () => { - // ... -}); -``` - -All of the following functions need fake timers to be set, either by `jest.useFakeTimers()` or via `"timers": "fake"` in the config file. - -Currently, two implementations of the fake timers are included - `modern` and `legacy`, where `modern` is the default one. See [configuration](Configuration.md#timers-string) for how to configure it. - -## Run All Timers - -Another test we might want to write for this module is one that asserts that the callback is called after 1 second. To do this, we're going to use Jest's timer control APIs to fast-forward time right in the middle of the test: - -```javascript -jest.useFakeTimers(); -test('calls the callback after 1 second', () => { - const timerGame = require('../timerGame'); - const callback = jest.fn(); - - timerGame(callback); - - // At this point in time, the callback should not have been called yet - expect(callback).not.toBeCalled(); - - // Fast-forward until all timers have been executed - jest.runAllTimers(); - - // Now our callback should have been called! - expect(callback).toBeCalled(); - expect(callback).toHaveBeenCalledTimes(1); -}); -``` - -## Run Pending Timers - -There are also scenarios where you might have a recursive timer -- that is a timer that sets a new timer in its own callback. For these, running all the timers would be an endless loop, throwing the following error: - -``` -Ran 100000 timers, and there are still more! Assuming we've hit an infinite recursion and bailing out... -``` - -So something like `jest.runAllTimers()` is not desirable. For these cases you might use `jest.runOnlyPendingTimers()`: - -```javascript title="infiniteTimerGame.js" -'use strict'; - -function infiniteTimerGame(callback) { - console.log('Ready....go!'); - - setTimeout(() => { - console.log("Time's up! 10 seconds before the next game starts..."); - callback && callback(); - - // Schedule the next game in 10 seconds - setTimeout(() => { - infiniteTimerGame(callback); - }, 10000); - }, 1000); -} - -module.exports = infiniteTimerGame; -``` - -```javascript title="__tests__/infiniteTimerGame-test.js" -'use strict'; - -jest.useFakeTimers(); -jest.spyOn(global, 'setTimeout'); - -describe('infiniteTimerGame', () => { - test('schedules a 10-second timer after 1 second', () => { - const infiniteTimerGame = require('../infiniteTimerGame'); - const callback = jest.fn(); - - infiniteTimerGame(callback); - - // At this point in time, there should have been a single call to - // setTimeout to schedule the end of the game in 1 second. - expect(setTimeout).toHaveBeenCalledTimes(1); - expect(setTimeout).toHaveBeenLastCalledWith(expect.any(Function), 1000); - - // Fast forward and exhaust only currently pending timers - // (but not any new timers that get created during that process) - jest.runOnlyPendingTimers(); - - // At this point, our 1-second timer should have fired its callback - expect(callback).toBeCalled(); - - // And it should have created a new timer to start the game over in - // 10 seconds - expect(setTimeout).toHaveBeenCalledTimes(2); - expect(setTimeout).toHaveBeenLastCalledWith(expect.any(Function), 10000); - }); -}); -``` - -## Advance Timers by Time - -Another possibility is use `jest.advanceTimersByTime(msToRun)`. When this API is called, all timers are advanced by `msToRun` milliseconds. All pending "macro-tasks" that have been queued via setTimeout() or setInterval(), and would be executed during this time frame, will be executed. Additionally, if those macro-tasks schedule new macro-tasks that would be executed within the same time frame, those will be executed until there are no more macro-tasks remaining in the queue that should be run within msToRun milliseconds. - -```javascript title="timerGame.js" -'use strict'; - -function timerGame(callback) { - console.log('Ready....go!'); - setTimeout(() => { - console.log("Time's up -- stop!"); - callback && callback(); - }, 1000); -} - -module.exports = timerGame; -``` - -```javascript title="__tests__/timerGame-test.js" -jest.useFakeTimers(); -it('calls the callback after 1 second via advanceTimersByTime', () => { - const timerGame = require('../timerGame'); - const callback = jest.fn(); - - timerGame(callback); - - // At this point in time, the callback should not have been called yet - expect(callback).not.toBeCalled(); - - // Fast-forward until all timers have been executed - jest.advanceTimersByTime(1000); - - // Now our callback should have been called! - expect(callback).toBeCalled(); - expect(callback).toHaveBeenCalledTimes(1); -}); -``` - -Lastly, it may occasionally be useful in some tests to be able to clear all of the pending timers. For this, we have `jest.clearAllTimers()`. - -The code for this example is available at [examples/timer](https://github.com/facebook/jest/tree/main/examples/timer). diff --git a/website/versioned_docs/version-27.1/Architecture.md b/website/versioned_docs/version-27.1/Architecture.md deleted file mode 100644 index 8d9a7c1d5eba..000000000000 --- a/website/versioned_docs/version-27.1/Architecture.md +++ /dev/null @@ -1,16 +0,0 @@ ---- -id: architecture -title: Architecture ---- - -import LiteYouTubeEmbed from 'react-lite-youtube-embed'; - -If you are interested in learning more about how Jest works, understand its architecture, and how Jest is split up into individual reusable packages, check out this video: - - - -If you'd like to learn how to build a testing framework like Jest from scratch, check out this video: - - - -There is also a [written guide you can follow](https://cpojer.net/posts/building-a-javascript-testing-framework). It teaches the fundamental concepts of Jest and explains how various parts of Jest can be used to compose a custom testing framework. diff --git a/website/versioned_docs/version-27.1/BypassingModuleMocks.md b/website/versioned_docs/version-27.1/BypassingModuleMocks.md deleted file mode 100644 index 96dfa7462016..000000000000 --- a/website/versioned_docs/version-27.1/BypassingModuleMocks.md +++ /dev/null @@ -1,58 +0,0 @@ ---- -id: bypassing-module-mocks -title: Bypassing module mocks ---- - -Jest allows you to mock out whole modules in your tests, which can be useful for testing if your code is calling functions from that module correctly. However, sometimes you may want to use parts of a mocked module in your _test file_, in which case you want to access the original implementation, rather than a mocked version. - -Consider writing a test case for this `createUser` function: - -```javascript title="createUser.js" -import fetch from 'node-fetch'; - -export const createUser = async () => { - const response = await fetch('http://website.com/users', {method: 'POST'}); - const userId = await response.text(); - return userId; -}; -``` - -Your test will want to mock the `fetch` function so that we can be sure that it gets called without actually making the network request. However, you'll also need to mock the return value of `fetch` with a `Response` (wrapped in a `Promise`), as our function uses it to grab the created user's ID. So you might initially try writing a test like this: - -```javascript -jest.mock('node-fetch'); - -import fetch, {Response} from 'node-fetch'; -import {createUser} from './createUser'; - -test('createUser calls fetch with the right args and returns the user id', async () => { - fetch.mockReturnValue(Promise.resolve(new Response('4'))); - - const userId = await createUser(); - - expect(fetch).toHaveBeenCalledTimes(1); - expect(fetch).toHaveBeenCalledWith('http://website.com/users', { - method: 'POST', - }); - expect(userId).toBe('4'); -}); -``` - -However, if you ran that test you would find that the `createUser` function would fail, throwing the error: `TypeError: response.text is not a function`. This is because the `Response` class you've imported from `node-fetch` has been mocked (due to the `jest.mock` call at the top of the test file) so it no longer behaves the way it should. - -To get around problems like this, Jest provides the `jest.requireActual` helper. To make the above test work, make the following change to the imports in the test file: - -```javascript -// BEFORE -jest.mock('node-fetch'); -import fetch, {Response} from 'node-fetch'; -``` - -```javascript -// AFTER -jest.mock('node-fetch'); -import fetch from 'node-fetch'; -const {Response} = jest.requireActual('node-fetch'); -``` - -This allows your test file to import the actual `Response` object from `node-fetch`, rather than a mocked version. This means the test will now pass correctly. diff --git a/website/versioned_docs/version-27.1/CLI.md b/website/versioned_docs/version-27.1/CLI.md deleted file mode 100644 index 74e9d12c8d15..000000000000 --- a/website/versioned_docs/version-27.1/CLI.md +++ /dev/null @@ -1,390 +0,0 @@ ---- -id: cli -title: Jest CLI Options ---- - -The `jest` command line runner has a number of useful options. You can run `jest --help` to view all available options. Many of the options shown below can also be used together to run tests exactly the way you want. Every one of Jest's [Configuration](Configuration.md) options can also be specified through the CLI. - -Here is a brief overview: - -## Running from the command line - -Run all tests (default): - -```bash -jest -``` - -Run only the tests that were specified with a pattern or filename: - -```bash -jest my-test #or -jest path/to/my-test.js -``` - -Run tests related to changed files based on hg/git (uncommitted files): - -```bash -jest -o -``` - -Run tests related to `path/to/fileA.js` and `path/to/fileB.js`: - -```bash -jest --findRelatedTests path/to/fileA.js path/to/fileB.js -``` - -Run tests that match this spec name (match against the name in `describe` or `test`, basically). - -```bash -jest -t name-of-spec -``` - -Run watch mode: - -```bash -jest --watch #runs jest -o by default -jest --watchAll #runs all tests -``` - -Watch mode also enables to specify the name or path to a file to focus on a specific set of tests. - -## Using with yarn - -If you run Jest via `yarn test`, you can pass the command line arguments directly as Jest arguments. - -Instead of: - -```bash -jest -u -t="ColorPicker" -``` - -you can use: - -```bash -yarn test -u -t="ColorPicker" -``` - -## Using with npm scripts - -If you run Jest via `npm test`, you can still use the command line arguments by inserting a `--` between `npm test` and the Jest arguments. - -Instead of: - -```bash -jest -u -t="ColorPicker" -``` - -you can use: - -```bash -npm test -- -u -t="ColorPicker" -``` - -## Camelcase & dashed args support - -Jest supports both camelcase and dashed arg formats. The following examples will have an equal result: - -```bash -jest --collect-coverage -jest --collectCoverage -``` - -Arguments can also be mixed: - -```bash -jest --update-snapshot --detectOpenHandles -``` - -## Options - -_Note: CLI options take precedence over values from the [Configuration](Configuration.md)._ - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Reference - -### `jest ` - -When you run `jest` with an argument, that argument is treated as a regular expression to match against files in your project. It is possible to run test suites by providing a pattern. Only the files that the pattern matches will be picked up and executed. Depending on your terminal, you may need to quote this argument: `jest "my.*(complex)?pattern"`. On Windows, you will need to use `/` as a path separator or escape `\` as `\\`. - -### `--bail` - -Alias: `-b`. Exit the test suite immediately upon `n` number of failing test suite. Defaults to `1`. - -### `--cache` - -Whether to use the cache. Defaults to true. Disable the cache using `--no-cache`. _Note: the cache should only be disabled if you are experiencing caching related problems. On average, disabling the cache makes Jest at least two times slower._ - -If you want to inspect the cache, use `--showConfig` and look at the `cacheDirectory` value. If you need to clear the cache, use `--clearCache`. - -### `--changedFilesWithAncestor` - -Runs tests related to the current changes and the changes made in the last commit. Behaves similarly to `--onlyChanged`. - -### `--changedSince` - -Runs tests related to the changes since the provided branch or commit hash. If the current branch has diverged from the given branch, then only changes made locally will be tested. Behaves similarly to `--onlyChanged`. - -### `--ci` - -When this option is provided, Jest will assume it is running in a CI environment. This changes the behavior when a new snapshot is encountered. Instead of the regular behavior of storing a new snapshot automatically, it will fail the test and require Jest to be run with `--updateSnapshot`. - -### `--clearCache` - -Deletes the Jest cache directory and then exits without running tests. Will delete `cacheDirectory` if the option is passed, or Jest's default cache directory. The default cache directory can be found by calling `jest --showConfig`. _Note: clearing the cache will reduce performance._ - -### `--clearMocks` - -Automatically clear mock calls, instances and results before every test. Equivalent to calling [`jest.clearAllMocks()`](JestObjectAPI.md#jestclearallmocks) before each test. This does not remove any mock implementation that may have been provided. - -### `--collectCoverageFrom=` - -A glob pattern relative to `rootDir` matching the files that coverage info needs to be collected from. - -### `--colors` - -Forces test results output highlighting even if stdout is not a TTY. - -### `--config=` - -Alias: `-c`. The path to a Jest config file specifying how to find and execute tests. If no `rootDir` is set in the config, the directory containing the config file is assumed to be the `rootDir` for the project. This can also be a JSON-encoded value which Jest will use as configuration. - -### `--coverage[=]` - -Alias: `--collectCoverage`. Indicates that test coverage information should be collected and reported in the output. Optionally pass `` to override option set in configuration. - -### `--coverageProvider=` - -Indicates which provider should be used to instrument code for coverage. Allowed values are `babel` (default) or `v8`. - -Note that using `v8` is considered experimental. This uses V8's builtin code coverage rather than one based on Babel. It is not as well tested, and it has also improved in the last few releases of Node. Using the latest versions of node (v14 at the time of this writing) will yield better results. - -### `--debug` - -Print debugging info about your Jest config. - -### `--detectOpenHandles` - -Attempt to collect and print open handles preventing Jest from exiting cleanly. Use this in cases where you need to use `--forceExit` in order for Jest to exit to potentially track down the reason. This implies `--runInBand`, making tests run serially. Implemented using [`async_hooks`](https://nodejs.org/api/async_hooks.html). This option has a significant performance penalty and should only be used for debugging. - -### `--env=` - -The test environment used for all tests. This can point to any file or node module. Examples: `jsdom`, `node` or `path/to/my-environment.js`. - -### `--errorOnDeprecated` - -Make calling deprecated APIs throw helpful error messages. Useful for easing the upgrade process. - -### `--expand` - -Alias: `-e`. Use this flag to show full diffs and errors instead of a patch. - -### `--filter=` - -Path to a module exporting a filtering function. This method receives a list of tests which can be manipulated to exclude tests from running. Especially useful when used in conjunction with a testing infrastructure to filter known broken. - -### `--findRelatedTests ` - -Find and run the tests that cover a space separated list of source files that were passed in as arguments. Useful for pre-commit hook integration to run the minimal amount of tests necessary. Can be used together with `--coverage` to include a test coverage for the source files, no duplicate `--collectCoverageFrom` arguments needed. - -### `--forceExit` - -Force Jest to exit after all tests have completed running. This is useful when resources set up by test code cannot be adequately cleaned up. _Note: This feature is an escape-hatch. If Jest doesn't exit at the end of a test run, it means external resources are still being held on to or timers are still pending in your code. It is advised to tear down external resources after each test to make sure Jest can shut down cleanly. You can use `--detectOpenHandles` to help track it down._ - -### `--help` - -Show the help information, similar to this page. - -### `--init` - -Generate a basic configuration file. Based on your project, Jest will ask you a few questions that will help to generate a `jest.config.js` file with a short description for each option. - -### `--injectGlobals` - -Insert Jest's globals (`expect`, `test`, `describe`, `beforeEach` etc.) into the global environment. If you set this to `false`, you should import from `@jest/globals`, e.g. - -```ts -import {expect, jest, test} from '@jest/globals'; - -jest.useFakeTimers(); - -test('some test', () => { - expect(Date.now()).toBe(0); -}); -``` - -_Note: This option is only supported using the default `jest-circus` test runner._ - -### `--json` - -Prints the test results in JSON. This mode will send all other test output and user messages to stderr. - -### `--outputFile=` - -Write test results to a file when the `--json` option is also specified. The returned JSON structure is documented in [testResultsProcessor](Configuration.md#testresultsprocessor-string). - -### `--lastCommit` - -Run all tests affected by file changes in the last commit made. Behaves similarly to `--onlyChanged`. - -### `--listTests` - -Lists all test files that Jest will run given the arguments, and exits. - -### `--logHeapUsage` - -Logs the heap usage after every test. Useful to debug memory leaks. Use together with `--runInBand` and `--expose-gc` in node. - -### `--maxConcurrency=` - -Prevents Jest from executing more than the specified amount of tests at the same time. Only affects tests that use `test.concurrent`. - -### `--maxWorkers=|` - -Alias: `-w`. Specifies the maximum number of workers the worker-pool will spawn for running tests. In single run mode, this defaults to the number of the cores available on your machine minus one for the main thread. In watch mode, this defaults to half of the available cores on your machine to ensure Jest is unobtrusive and does not grind your machine to a halt. It may be useful to adjust this in resource limited environments like CIs but the defaults should be adequate for most use-cases. - -For environments with variable CPUs available, you can use percentage based configuration: `--maxWorkers=50%` - -### `--noStackTrace` - -Disables stack trace in test results output. - -### `--notify` - -Activates notifications for test results. Good for when you don't want your consciousness to be able to focus on anything except JavaScript testing. - -### `--onlyChanged` - -Alias: `-o`. Attempts to identify which tests to run based on which files have changed in the current repository. Only works if you're running tests in a git/hg repository at the moment and requires a static dependency graph (ie. no dynamic requires). - -### `--passWithNoTests` - -Allows the test suite to pass when no files are found. - -### `--projects ... ` - -Run tests from one or more projects, found in the specified paths; also takes path globs. This option is the CLI equivalent of the [`projects`](configuration#projects-arraystring--projectconfig) configuration option. Note that if configuration files are found in the specified paths, _all_ projects specified within those configuration files will be run. - -### `--reporters` - -Run tests with specified reporters. [Reporter options](configuration#reporters-arraymodulename--modulename-options) are not available via CLI. Example with multiple reporters: - -`jest --reporters="default" --reporters="jest-junit"` - -### `--resetMocks` - -Automatically reset mock state before every test. Equivalent to calling [`jest.resetAllMocks()`](JestObjectAPI.md#jestresetallmocks) before each test. This will lead to any mocks having their fake implementations removed but does not restore their initial implementation. - -### `--restoreMocks` - -Automatically restore mock state and implementation before every test. Equivalent to calling [`jest.restoreAllMocks()`](JestObjectAPI.md#jestrestoreallmocks) before each test. This will lead to any mocks having their fake implementations removed and restores their initial implementation. - -### `--roots` - -A list of paths to directories that Jest should use to search for files in. - -### `--runInBand` - -Alias: `-i`. Run all tests serially in the current process, rather than creating a worker pool of child processes that run tests. This can be useful for debugging. - -### `--runTestsByPath` - -Run only the tests that were specified with their exact paths. - -_Note: The default regex matching works fine on small runs, but becomes slow if provided with multiple patterns and/or against a lot of tests. This option replaces the regex matching logic and by that optimizes the time it takes Jest to filter specific test files_ - -### `--selectProjects ... ` - -Run only the tests of the specified projects. Jest uses the attribute `displayName` in the configuration to identify each project. If you use this option, you should provide a `displayName` to all your projects. - -### `--setupFilesAfterEnv ... ` - -A list of paths to modules that run some code to configure or to set up the testing framework before each test. Beware that files imported by the setup scripts will not be mocked during testing. - -### `--showConfig` - -Print your Jest config and then exits. - -### `--silent` - -Prevent tests from printing messages through the console. - -### `--testLocationInResults` - -Adds a `location` field to test results. Useful if you want to report the location of a test in a reporter. - -Note that `column` is 0-indexed while `line` is not. - -```json -{ - "column": 4, - "line": 5 -} -``` - -### `--testMatch glob1 ... globN` - -The glob patterns Jest uses to detect test files. Please refer to the [`testMatch` configuration](Configuration.md#testmatch-arraystring) for details. - -### `--testNamePattern=` - -Alias: `-t`. Run only tests with a name that matches the regex. For example, suppose you want to run only tests related to authorization which will have names like `"GET /api/posts with auth"`, then you can use `jest -t=auth`. - -_Note: The regex is matched against the full name, which is a combination of the test name and all its surrounding describe blocks._ - -### `--testPathIgnorePatterns=|[array]` - -A single or array of regexp pattern strings that are tested against all tests paths before executing the test. Contrary to `--testPathPattern`, it will only run those tests with a path that does not match with the provided regexp expressions. - -To pass as an array use escaped parentheses and space delimited regexps such as `\(/node_modules/ /tests/e2e/\)`. Alternatively, you can omit parentheses by combining regexps into a single regexp like `/node_modules/|/tests/e2e/`. These two examples are equivalent. - -### `--testPathPattern=` - -A regexp pattern string that is matched against all tests paths before executing the test. On Windows, you will need to use `/` as a path separator or escape `\` as `\\`. - -### `--testRunner=` - -Lets you specify a custom test runner. - -### `--testSequencer=` - -Lets you specify a custom test sequencer. Please refer to the documentation of the corresponding configuration property for details. - -### `--testTimeout=` - -Default timeout of a test in milliseconds. Default value: 5000. - -### `--updateSnapshot` - -Alias: `-u`. Use this flag to re-record every snapshot that fails during this test run. Can be used together with a test suite pattern or with `--testNamePattern` to re-record snapshots. - -### `--useStderr` - -Divert all output to stderr. - -### `--verbose` - -Display individual test results with the test suite hierarchy. - -### `--version` - -Alias: `-v`. Print the version and exit. - -### `--watch` - -Watch files for changes and rerun tests related to changed files. If you want to re-run all tests when a file has changed, use the `--watchAll` option instead. - -### `--watchAll` - -Watch files for changes and rerun all tests when something changes. If you want to re-run only the tests that depend on the changed files, use the `--watch` option. - -Use `--watchAll=false` to explicitly disable the watch mode. Note that in most CI environments, this is automatically handled for you. - -### `--watchman` - -Whether to use [`watchman`](https://facebook.github.io/watchman/) for file crawling. Defaults to `true`. Disable using `--no-watchman`. diff --git a/website/versioned_docs/version-27.1/CodeTransformation.md b/website/versioned_docs/version-27.1/CodeTransformation.md deleted file mode 100644 index 7189b6f98602..000000000000 --- a/website/versioned_docs/version-27.1/CodeTransformation.md +++ /dev/null @@ -1,164 +0,0 @@ ---- -id: code-transformation -title: Code Transformation ---- - -Jest runs the code in your project as JavaScript, but if you use some syntax not supported by Node.js out of the box (such as JSX, types from TypeScript, Vue templates etc.) then you'll need to transform that code into plain JavaScript, similar to what you would do when building for browsers. - -Jest supports this via the [`transform` configuration option](Configuration.md#transform-objectstring-pathtotransformer--pathtotransformer-object). - -A transformer is a module that provides a synchronous function for transforming source files. For example, if you wanted to be able to use a new language feature in your modules or tests that aren't yet supported by Node, you might plug in one of many compilers that compile a future version of JavaScript to a current one. - -Jest will cache the result of a transformation and attempt to invalidate that result based on a number of factors, such as the source of the file being transformed and changing configuration. - -## Defaults - -Jest ships with one transformer out of the box - `babel-jest`. It will automatically load your project's Babel configuration and transform any file matching the following RegEx: `/\.[jt]sx?$/` meaning any `.js`, `.jsx`, `.ts` and `.tsx` file. In addition, `babel-jest` will inject the Babel plugin necessary for mock hoisting talked about in [ES Module mocking](ManualMocks.md#using-with-es-module-imports). - -If you override the `transform` configuration option `babel-jest` will no longer be active, and you'll need to add it manually if you wish to use Babel. - -## Writing custom transformers - -You can write your own transformer. The API of a transformer is as follows: - -```ts -interface SyncTransformer { - /** - * Indicates if the transformer is capable of instrumenting the code for code coverage. - * - * If V8 coverage is _not_ active, and this is `true`, Jest will assume the code is instrumented. - * If V8 coverage is _not_ active, and this is `false`. Jest will instrument the code returned by this transformer using Babel. - */ - canInstrument?: boolean; - createTransformer?: (options?: OptionType) => SyncTransformer; - - getCacheKey?: ( - sourceText: string, - sourcePath: Config.Path, - options: TransformOptions, - ) => string; - - getCacheKeyAsync?: ( - sourceText: string, - sourcePath: Config.Path, - options: TransformOptions, - ) => Promise; - - process: ( - sourceText: string, - sourcePath: Config.Path, - options: TransformOptions, - ) => TransformedSource; - - processAsync?: ( - sourceText: string, - sourcePath: Config.Path, - options: TransformOptions, - ) => Promise; -} - -interface AsyncTransformer { - /** - * Indicates if the transformer is capable of instrumenting the code for code coverage. - * - * If V8 coverage is _not_ active, and this is `true`, Jest will assume the code is instrumented. - * If V8 coverage is _not_ active, and this is `false`. Jest will instrument the code returned by this transformer using Babel. - */ - canInstrument?: boolean; - createTransformer?: (options?: OptionType) => AsyncTransformer; - - getCacheKey?: ( - sourceText: string, - sourcePath: Config.Path, - options: TransformOptions, - ) => string; - - getCacheKeyAsync?: ( - sourceText: string, - sourcePath: Config.Path, - options: TransformOptions, - ) => Promise; - - process?: ( - sourceText: string, - sourcePath: Config.Path, - options: TransformOptions, - ) => TransformedSource; - - processAsync: ( - sourceText: string, - sourcePath: Config.Path, - options: TransformOptions, - ) => Promise; -} - -type Transformer = - | SyncTransformer - | AsyncTransformer; - -interface TransformOptions { - /** - * If a transformer does module resolution and reads files, it should populate `cacheFS` so that - * Jest avoids reading the same files again, improving performance. `cacheFS` stores entries of - * - */ - cacheFS: Map; - config: Config.ProjectConfig; - /** A stringified version of the configuration - useful in cache busting */ - configString: string; - instrument: boolean; - // names are copied from babel: https://babeljs.io/docs/en/options#caller - supportsDynamicImport: boolean; - supportsExportNamespaceFrom: boolean; - supportsStaticESM: boolean; - supportsTopLevelAwait: boolean; - /** the options passed through Jest's config by the user */ - transformerConfig: OptionType; -} - -type TransformedSource = - | {code: string; map?: RawSourceMap | string | null} - | string; - -// Config.ProjectConfig can be seen in code [here](https://github.com/facebook/jest/blob/v26.6.3/packages/jest-types/src/Config.ts#L323) -// RawSourceMap comes from [`source-map`](https://github.com/mozilla/source-map/blob/0.6.1/source-map.d.ts#L6-L12) -``` - -As can be seen, only `process` or `processAsync` is mandatory to implement, although we highly recommend implementing `getCacheKey` as well, so we don't waste resources transpiling the same source file when we can read its previous result from disk. You can use [`@jest/create-cache-key-function`](https://www.npmjs.com/package/@jest/create-cache-key-function) to help implement it. - -Note that [ECMAScript module](ECMAScriptModules.md) support is indicated by the passed in `supports*` options. Specifically `supportsDynamicImport: true` means the transformer can return `import()` expressions, which is supported by both ESM and CJS. If `supportsStaticESM: true` it means top level `import` statements are supported and the code will be interpreted as ESM and not CJS. See [Node's docs](https://nodejs.org/api/esm.html#esm_differences_between_es_modules_and_commonjs) for details on the differences. - -:::tip - -Make sure `TransformedSource` contains a source map, so it is possible to report line information accurately in code coverage and test errors. Inline source maps also work but are slower. - -::: - -### Examples - -### TypeScript with type checking - -While `babel-jest` by default will transpile TypeScript files, Babel will not verify the types. If you want that you can use [`ts-jest`](https://github.com/kulshekhar/ts-jest). - -#### Transforming images to their path - -Importing images is a way to include them in your browser bundle, but they are not valid JavaScript. One way of handling it in Jest is to replace the imported value with its filename. - -```js title="fileTransformer.js" -const path = require('path'); - -module.exports = { - process(src, filename, config, options) { - return `module.exports = ${JSON.stringify(path.basename(filename))};`; - }, -}; -``` - -```js title="jest.config.js" -module.exports = { - transform: { - '\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$': - '/fileTransformer.js', - }, -}; -``` diff --git a/website/versioned_docs/version-27.1/Configuration.md b/website/versioned_docs/version-27.1/Configuration.md deleted file mode 100644 index 3031336442e2..000000000000 --- a/website/versioned_docs/version-27.1/Configuration.md +++ /dev/null @@ -1,1473 +0,0 @@ ---- -id: configuration -title: Configuring Jest ---- - -Jest's configuration can be defined in the `package.json` file of your project, or through a `jest.config.js`, or `jest.config.ts` file or through the `--config ` option. If you'd like to use your `package.json` to store Jest's config, the `"jest"` key should be used on the top level so Jest will know how to find your settings: - -```json -{ - "name": "my-project", - "jest": { - "verbose": true - } -} -``` - -Or through JavaScript: - -```js title="jest.config.js" -// Sync object -/** @type {import('@jest/types').Config.InitialOptions} */ -const config = { - verbose: true, -}; - -module.exports = config; - -// Or async function -module.exports = async () => { - return { - verbose: true, - }; -}; -``` - -Or through TypeScript (if `ts-node` is installed): - -```ts title="jest.config.ts" -import type {Config} from '@jest/types'; - -// Sync object -const config: Config.InitialOptions = { - verbose: true, -}; -export default config; - -// Or async function -export default async (): Promise => { - return { - verbose: true, - }; -}; -``` - -Please keep in mind that the resulting configuration must be JSON-serializable. - -When using the `--config` option, the JSON file must not contain a "jest" key: - -```json -{ - "bail": 1, - "verbose": true -} -``` - -## Options - -These options let you control Jest's behavior in your `package.json` file. The Jest philosophy is to work great by default, but sometimes you just need more configuration power. - -### Defaults - -You can retrieve Jest's default options to expand them if needed: - -```js title="jest.config.js" -const {defaults} = require('jest-config'); -module.exports = { - // ... - moduleFileExtensions: [...defaults.moduleFileExtensions, 'ts', 'tsx'], - // ... -}; -``` - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Reference - -### `automock` \[boolean] - -Default: `false` - -This option tells Jest that all imported modules in your tests should be mocked automatically. All modules used in your tests will have a replacement implementation, keeping the API surface. - -Example: - -```js title="utils.js" -export default { - authorize: () => { - return 'token'; - }, - isAuthorized: secret => secret === 'wizard', -}; -``` - -```js -//__tests__/automocking.test.js -import utils from '../utils'; - -test('if utils mocked automatically', () => { - // Public methods of `utils` are now mock functions - expect(utils.authorize.mock).toBeTruthy(); - expect(utils.isAuthorized.mock).toBeTruthy(); - - // You can provide them with your own implementation - // or pass the expected return value - utils.authorize.mockReturnValue('mocked_token'); - utils.isAuthorized.mockReturnValue(true); - - expect(utils.authorize()).toBe('mocked_token'); - expect(utils.isAuthorized('not_wizard')).toBeTruthy(); -}); -``` - -_Note: Node modules are automatically mocked when you have a manual mock in place (e.g.: `__mocks__/lodash.js`). More info [here](manual-mocks#mocking-node-modules)._ - -_Note: Core modules, like `fs`, are not mocked by default. They can be mocked explicitly, like `jest.mock('fs')`._ - -### `bail` \[number | boolean] - -Default: `0` - -By default, Jest runs all tests and produces all errors into the console upon completion. The bail config option can be used here to have Jest stop running tests after `n` failures. Setting bail to `true` is the same as setting bail to `1`. - -### `cacheDirectory` \[string] - -Default: `"/tmp/"` - -The directory where Jest should store its cached dependency information. - -Jest attempts to scan your dependency tree once (up-front) and cache it in order to ease some of the filesystem churn that needs to happen while running tests. This config option lets you customize where Jest stores that cache data on disk. - -### `clearMocks` \[boolean] - -Default: `false` - -Automatically clear mock calls, instances and results before every test. Equivalent to calling [`jest.clearAllMocks()`](JestObjectAPI.md#jestclearallmocks) before each test. This does not remove any mock implementation that may have been provided. - -### `collectCoverage` \[boolean] - -Default: `false` - -Indicates whether the coverage information should be collected while executing the test. Because this retrofits all executed files with coverage collection statements, it may significantly slow down your tests. - -### `collectCoverageFrom` \[array] - -Default: `undefined` - -An array of [glob patterns](https://github.com/micromatch/micromatch) indicating a set of files for which coverage information should be collected. If a file matches the specified glob pattern, coverage information will be collected for it even if no tests exist for this file and it's never required in the test suite. - -Example: - -```json -{ - "collectCoverageFrom": [ - "**/*.{js,jsx}", - "!**/node_modules/**", - "!**/vendor/**" - ] -} -``` - -This will collect coverage information for all the files inside the project's `rootDir`, except the ones that match `**/node_modules/**` or `**/vendor/**`. - -_Note: Each glob pattern is applied in the order they are specified in the config. (For example `["!**/__tests__/**", "**/*.js"]` will not exclude `__tests__` because the negation is overwritten with the second pattern. In order to make the negated glob work in this example it has to come after `**/*.js`.)_ - -_Note: This option requires `collectCoverage` to be set to true or Jest to be invoked with `--coverage`._ - -
- Help: - If you are seeing coverage output such as... - -``` -=============================== Coverage summary =============================== -Statements : Unknown% ( 0/0 ) -Branches : Unknown% ( 0/0 ) -Functions : Unknown% ( 0/0 ) -Lines : Unknown% ( 0/0 ) -================================================================================ -Jest: Coverage data for global was not found. -``` - -Most likely your glob patterns are not matching any files. Refer to the [micromatch](https://github.com/micromatch/micromatch) documentation to ensure your globs are compatible. - -
- -### `coverageDirectory` \[string] - -Default: `undefined` - -The directory where Jest should output its coverage files. - -### `coveragePathIgnorePatterns` \[array<string>] - -Default: `["/node_modules/"]` - -An array of regexp pattern strings that are matched against all file paths before executing the test. If the file path matches any of the patterns, coverage information will be skipped. - -These pattern strings match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. Example: `["/build/", "/node_modules/"]`. - -### `coverageProvider` \[string] - -Indicates which provider should be used to instrument code for coverage. Allowed values are `babel` (default) or `v8`. - -Note that using `v8` is considered experimental. This uses V8's builtin code coverage rather than one based on Babel. It is not as well tested, and it has also improved in the last few releases of Node. Using the latest versions of node (v14 at the time of this writing) will yield better results. - -### `coverageReporters` \[array<string | \[string, options]>] - -Default: `["clover", "json", "lcov", "text"]` - -A list of reporter names that Jest uses when writing coverage reports. Any [istanbul reporter](https://github.com/istanbuljs/istanbuljs/tree/master/packages/istanbul-reports/lib) can be used. - -_Note: Setting this option overwrites the default values. Add `"text"` or `"text-summary"` to see a coverage summary in the console output._ - -Additional options can be passed using the tuple form. For example, you may hide coverage report lines for all fully-covered files: - -```json -{ - "coverageReporters": ["clover", "json", "lcov", ["text", {"skipFull": true}]] -} -``` - -For more information about the options object shape refer to `CoverageReporterWithOptions` type in the [type definitions](https://github.com/facebook/jest/tree/main/packages/jest-types/src/Config.ts). - -### `coverageThreshold` \[object] - -Default: `undefined` - -This will be used to configure minimum threshold enforcement for coverage results. Thresholds can be specified as `global`, as a [glob](https://github.com/isaacs/node-glob#glob-primer), and as a directory or file path. If thresholds aren't met, jest will fail. Thresholds specified as a positive number are taken to be the minimum percentage required. Thresholds specified as a negative number represent the maximum number of uncovered entities allowed. - -For example, with the following configuration jest will fail if there is less than 80% branch, line, and function coverage, or if there are more than 10 uncovered statements: - -```json -{ - ... - "jest": { - "coverageThreshold": { - "global": { - "branches": 80, - "functions": 80, - "lines": 80, - "statements": -10 - } - } - } -} -``` - -If globs or paths are specified alongside `global`, coverage data for matching paths will be subtracted from overall coverage and thresholds will be applied independently. Thresholds for globs are applied to all files matching the glob. If the file specified by path is not found, an error is returned. - -For example, with the following configuration: - -```json -{ - ... - "jest": { - "coverageThreshold": { - "global": { - "branches": 50, - "functions": 50, - "lines": 50, - "statements": 50 - }, - "./src/components/": { - "branches": 40, - "statements": 40 - }, - "./src/reducers/**/*.js": { - "statements": 90 - }, - "./src/api/very-important-module.js": { - "branches": 100, - "functions": 100, - "lines": 100, - "statements": 100 - } - } - } -} -``` - -Jest will fail if: - -- The `./src/components` directory has less than 40% branch or statement coverage. -- One of the files matching the `./src/reducers/**/*.js` glob has less than 90% statement coverage. -- The `./src/api/very-important-module.js` file has less than 100% coverage. -- Every remaining file combined has less than 50% coverage (`global`). - -### `dependencyExtractor` \[string] - -Default: `undefined` - -This option allows the use of a custom dependency extractor. It must be a node module that exports an object with an `extract` function. E.g.: - -```javascript -const crypto = require('crypto'); -const fs = require('fs'); - -module.exports = { - extract(code, filePath, defaultExtract) { - const deps = defaultExtract(code, filePath); - // Scan the file and add dependencies in `deps` (which is a `Set`) - return deps; - }, - getCacheKey() { - return crypto - .createHash('md5') - .update(fs.readFileSync(__filename)) - .digest('hex'); - }, -}; -``` - -The `extract` function should return an iterable (`Array`, `Set`, etc.) with the dependencies found in the code. - -That module can also contain a `getCacheKey` function to generate a cache key to determine if the logic has changed and any cached artifacts relying on it should be discarded. - -### `displayName` \[string, object] - -default: `undefined` - -Allows for a label to be printed alongside a test while it is running. This becomes more useful in multi-project repositories where there can be many jest configuration files. This visually tells which project a test belongs to. Here are sample valid values. - -```js -module.exports = { - displayName: 'CLIENT', -}; -``` - -or - -```js -module.exports = { - displayName: { - name: 'CLIENT', - color: 'blue', - }, -}; -``` - -As a secondary option, an object with the properties `name` and `color` can be passed. This allows for a custom configuration of the background color of the displayName. `displayName` defaults to white when its value is a string. Jest uses [chalk](https://github.com/chalk/chalk) to provide the color. As such, all of the valid options for colors supported by chalk are also supported by jest. - -### `errorOnDeprecated` \[boolean] - -Default: `false` - -Make calling deprecated APIs throw helpful error messages. Useful for easing the upgrade process. - -### `extensionsToTreatAsEsm` \[array<string>] - -Default: `[]` - -Jest will run `.mjs` and `.js` files with nearest `package.json`'s `type` field set to `module` as ECMAScript Modules. If you have any other files that should run with native ESM, you need to specify their file extension here. - -> Note: Jest's ESM support is still experimental, see [its docs for more details](ECMAScriptModules.md). - -```json -{ - ... - "jest": { - "extensionsToTreatAsEsm": [".ts"] - } -} -``` - -### `extraGlobals` \[array<string>] - -Default: `undefined` - -Test files run inside a [vm](https://nodejs.org/api/vm.html), which slows calls to global context properties (e.g. `Math`). With this option you can specify extra properties to be defined inside the vm for faster lookups. - -For example, if your tests call `Math` often, you can pass it by setting `extraGlobals`. - -```json -{ - ... - "jest": { - "extraGlobals": ["Math"] - } -} -``` - -### `forceCoverageMatch` \[array<string>] - -Default: `['']` - -Test files are normally ignored from collecting code coverage. With this option, you can overwrite this behavior and include otherwise ignored files in code coverage. - -For example, if you have tests in source files named with `.t.js` extension as following: - -```javascript title="sum.t.js" -export function sum(a, b) { - return a + b; -} - -if (process.env.NODE_ENV === 'test') { - test('sum', () => { - expect(sum(1, 2)).toBe(3); - }); -} -``` - -You can collect coverage from those files with setting `forceCoverageMatch`. - -```json -{ - ... - "jest": { - "forceCoverageMatch": ["**/*.t.js"] - } -} -``` - -### `globals` \[object] - -Default: `{}` - -A set of global variables that need to be available in all test environments. - -For example, the following would create a global `__DEV__` variable set to `true` in all test environments: - -```json -{ - ... - "jest": { - "globals": { - "__DEV__": true - } - } -} -``` - -Note that, if you specify a global reference value (like an object or array) here, and some code mutates that value in the midst of running a test, that mutation will _not_ be persisted across test runs for other test files. In addition, the `globals` object must be json-serializable, so it can't be used to specify global functions. For that, you should use `setupFiles`. - -### `globalSetup` \[string] - -Default: `undefined` - -This option allows the use of a custom global setup module which exports an async function that is triggered once before all test suites. This function gets Jest's `globalConfig` object as a parameter. - -_Note: A global setup module configured in a project (using multi-project runner) will be triggered only when you run at least one test from this project._ - -_Note: Any global variables that are defined through `globalSetup` can only be read in `globalTeardown`. You cannot retrieve globals defined here in your test suites._ - -_Note: While code transformation is applied to the linked setup-file, Jest will **not** transform any code in `node_modules`. This is due to the need to load the actual transformers (e.g. `babel` or `typescript`) to perform transformation._ - -Example: - -```js title="setup.js" -// can be synchronous -module.exports = async () => { - // ... - // Set reference to mongod in order to close the server during teardown. - global.__MONGOD__ = mongod; -}; -``` - -```js title="teardown.js" -module.exports = async function () { - await global.__MONGOD__.stop(); -}; -``` - -### `globalTeardown` \[string] - -Default: `undefined` - -This option allows the use of a custom global teardown module which exports an async function that is triggered once after all test suites. This function gets Jest's `globalConfig` object as a parameter. - -_Note: A global teardown module configured in a project (using multi-project runner) will be triggered only when you run at least one test from this project._ - -_Note: The same caveat concerning transformation of `node_modules` as for `globalSetup` applies to `globalTeardown`._ - -### `haste` \[object] - -Default: `undefined` - -This will be used to configure the behavior of `jest-haste-map`, Jest's internal file crawler/cache system. The following options are supported: - -```ts -type HasteConfig = { - /** Whether to hash files using SHA-1. */ - computeSha1?: boolean; - /** The platform to use as the default, e.g. 'ios'. */ - defaultPlatform?: string | null; - /** Force use of Node's `fs` APIs rather than shelling out to `find` */ - forceNodeFilesystemAPI?: boolean; - /** - * Whether to follow symlinks when crawling for files. - * This options cannot be used in projects which use watchman. - * Projects with `watchman` set to true will error if this option is set to true. - */ - enableSymlinks?: boolean; - /** Path to a custom implementation of Haste. */ - hasteImplModulePath?: string; - /** All platforms to target, e.g ['ios', 'android']. */ - platforms?: Array; - /** Whether to throw on error on module collision. */ - throwOnModuleCollision?: boolean; - /** Custom HasteMap module */ - hasteMapModulePath?: string; -}; -``` - -### `injectGlobals` \[boolean] - -Default: `true` - -Insert Jest's globals (`expect`, `test`, `describe`, `beforeEach` etc.) into the global environment. If you set this to `false`, you should import from `@jest/globals`, e.g. - -```ts -import {expect, jest, test} from '@jest/globals'; - -jest.useFakeTimers(); - -test('some test', () => { - expect(Date.now()).toBe(0); -}); -``` - -_Note: This option is only supported using the default `jest-circus`. test runner_ - -### `maxConcurrency` \[number] - -Default: `5` - -A number limiting the number of tests that are allowed to run at the same time when using `test.concurrent`. Any test above this limit will be queued and executed once a slot is released. - -### `maxWorkers` \[number | string] - -Specifies the maximum number of workers the worker-pool will spawn for running tests. In single run mode, this defaults to the number of the cores available on your machine minus one for the main thread. In watch mode, this defaults to half of the available cores on your machine to ensure Jest is unobtrusive and does not grind your machine to a halt. It may be useful to adjust this in resource limited environments like CIs but the defaults should be adequate for most use-cases. - -For environments with variable CPUs available, you can use percentage based configuration: `"maxWorkers": "50%"` - -### `moduleDirectories` \[array<string>] - -Default: `["node_modules"]` - -An array of directory names to be searched recursively up from the requiring module's location. Setting this option will _override_ the default, if you wish to still search `node_modules` for packages include it along with any other options: `["node_modules", "bower_components"]` - -### `moduleFileExtensions` \[array<string>] - -Default: `["js", "jsx", "ts", "tsx", "json", "node"]` - -An array of file extensions your modules use. If you require modules without specifying a file extension, these are the extensions Jest will look for, in left-to-right order. - -We recommend placing the extensions most commonly used in your project on the left, so if you are using TypeScript, you may want to consider moving "ts" and/or "tsx" to the beginning of the array. - -### `moduleNameMapper` \[object<string, string | array<string>>] - -Default: `null` - -A map from regular expressions to module names or to arrays of module names that allow to stub out resources, like images or styles with a single module. - -Modules that are mapped to an alias are unmocked by default, regardless of whether automocking is enabled or not. - -Use `` string token to refer to [`rootDir`](#rootdir-string) value if you want to use file paths. - -Additionally, you can substitute captured regex groups using numbered backreferences. - -Example: - -```json -{ - "moduleNameMapper": { - "^image![a-zA-Z0-9$_-]+$": "GlobalImageStub", - "^[./a-zA-Z0-9$_-]+\\.png$": "/RelativeImageStub.js", - "module_name_(.*)": "/substituted_module_$1.js", - "assets/(.*)": [ - "/images/$1", - "/photos/$1", - "/recipes/$1" - ] - } -} -``` - -The order in which the mappings are defined matters. Patterns are checked one by one until one fits. The most specific rule should be listed first. This is true for arrays of module names as well. - -_Note: If you provide module name without boundaries `^$` it may cause hard to spot errors. E.g. `relay` will replace all modules which contain `relay` as a substring in its name: `relay`, `react-relay` and `graphql-relay` will all be pointed to your stub._ - -### `modulePathIgnorePatterns` \[array<string>] - -Default: `[]` - -An array of regexp pattern strings that are matched against all module paths before those paths are to be considered 'visible' to the module loader. If a given module's path matches any of the patterns, it will not be `require()`-able in the test environment. - -These pattern strings match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. Example: `["/build/"]`. - -### `modulePaths` \[array<string>] - -Default: `[]` - -An alternative API to setting the `NODE_PATH` env variable, `modulePaths` is an array of absolute paths to additional locations to search when resolving modules. Use the `` string token to include the path to your project's root directory. Example: `["/app/"]`. - -### `notify` \[boolean] - -Default: `false` - -Activates notifications for test results. - -**Beware:** Jest uses [node-notifier](https://github.com/mikaelbr/node-notifier) to display desktop notifications. On Windows, it creates a new start menu entry on the first use and not display the notification. Notifications will be properly displayed on subsequent runs - -### `notifyMode` \[string] - -Default: `failure-change` - -Specifies notification mode. Requires `notify: true`. - -#### Modes - -- `always`: always send a notification. -- `failure`: send a notification when tests fail. -- `success`: send a notification when tests pass. -- `change`: send a notification when the status changed. -- `success-change`: send a notification when tests pass or once when it fails. -- `failure-change`: send a notification when tests fail or once when it passes. - -### `preset` \[string] - -Default: `undefined` - -A preset that is used as a base for Jest's configuration. A preset should point to an npm module that has a `jest-preset.json`, `jest-preset.js`, `jest-preset.cjs` or `jest-preset.mjs` file at the root. - -For example, this preset `foo-bar/jest-preset.js` will be configured as follows: - -```json -{ - "preset": "foo-bar" -} -``` - -Presets may also be relative to filesystem paths. - -```json -{ - "preset": "./node_modules/foo-bar/jest-preset.js" -} -``` - -### `prettierPath` \[string] - -Default: `'prettier'` - -Sets the path to the [`prettier`](https://prettier.io/) node module used to update inline snapshots. - -### `projects` \[array<string | ProjectConfig>] - -Default: `undefined` - -When the `projects` configuration is provided with an array of paths or glob patterns, Jest will run tests in all of the specified projects at the same time. This is great for monorepos or when working on multiple projects at the same time. - -```json -{ - "projects": ["", "/examples/*"] -} -``` - -This example configuration will run Jest in the root directory as well as in every folder in the examples directory. You can have an unlimited amount of projects running in the same Jest instance. - -The projects feature can also be used to run multiple configurations or multiple [runners](#runner-string). For this purpose, you can pass an array of configuration objects. For example, to run both tests and ESLint (via [jest-runner-eslint](https://github.com/jest-community/jest-runner-eslint)) in the same invocation of Jest: - -```json -{ - "projects": [ - { - "displayName": "test" - }, - { - "displayName": "lint", - "runner": "jest-runner-eslint", - "testMatch": ["/**/*.js"] - } - ] -} -``` - -_Note: When using multi-project runner, it's recommended to add a `displayName` for each project. This will show the `displayName` of a project next to its tests._ - -### `reporters` \[array<moduleName | \[moduleName, options]>] - -Default: `undefined` - -Use this configuration option to add custom reporters to Jest. A custom reporter is a class that implements `onRunStart`, `onTestStart`, `onTestResult`, `onRunComplete` methods that will be called when any of those events occurs. - -If custom reporters are specified, the default Jest reporters will be overridden. To keep default reporters, `default` can be passed as a module name. - -This will override default reporters: - -```json -{ - "reporters": ["/my-custom-reporter.js"] -} -``` - -This will use custom reporter in addition to default reporters that Jest provides: - -```json -{ - "reporters": ["default", "/my-custom-reporter.js"] -} -``` - -Additionally, custom reporters can be configured by passing an `options` object as a second argument: - -```json -{ - "reporters": [ - "default", - ["/my-custom-reporter.js", {"banana": "yes", "pineapple": "no"}] - ] -} -``` - -Custom reporter modules must define a class that takes a `GlobalConfig` and reporter options as constructor arguments: - -Example reporter: - -```js title="my-custom-reporter.js" -class MyCustomReporter { - constructor(globalConfig, options) { - this._globalConfig = globalConfig; - this._options = options; - } - - onRunComplete(contexts, results) { - console.log('Custom reporter output:'); - console.log('GlobalConfig: ', this._globalConfig); - console.log('Options: ', this._options); - } -} - -module.exports = MyCustomReporter; -// or export default MyCustomReporter; -``` - -Custom reporters can also force Jest to exit with non-0 code by returning an Error from `getLastError()` methods - -```js -class MyCustomReporter { - // ... - getLastError() { - if (this._shouldFail) { - return new Error('my-custom-reporter.js reported an error'); - } - } -} -``` - -For the full list of methods and argument types see `Reporter` interface in [packages/jest-reporters/src/types.ts](https://github.com/facebook/jest/blob/main/packages/jest-reporters/src/types.ts) - -### `resetMocks` \[boolean] - -Default: `false` - -Automatically reset mock state before every test. Equivalent to calling [`jest.resetAllMocks()`](JestObjectAPI.md#jestresetallmocks) before each test. This will lead to any mocks having their fake implementations removed but does not restore their initial implementation. - -### `resetModules` \[boolean] - -Default: `false` - -By default, each test file gets its own independent module registry. Enabling `resetModules` goes a step further and resets the module registry before running each individual test. This is useful to isolate modules for every test so that the local module state doesn't conflict between tests. This can be done programmatically using [`jest.resetModules()`](JestObjectAPI.md#jestresetmodules). - -### `resolver` \[string] - -Default: `undefined` - -This option allows the use of a custom resolver. This resolver must be a node module that exports a function expecting a string as the first argument for the path to resolve and an object with the following structure as the second argument: - -```json -{ - "basedir": string, - "defaultResolver": "function(request, options)", - "extensions": [string], - "moduleDirectory": [string], - "paths": [string], - "packageFilter": "function(pkg, pkgdir)", - "rootDir": [string] -} -``` - -The function should either return a path to the module that should be resolved or throw an error if the module can't be found. - -Note: the defaultResolver passed as an option is the Jest default resolver which might be useful when you write your custom one. It takes the same arguments as your custom one, e.g. `(request, options)`. - -For example, if you want to respect Browserify's [`"browser"` field](https://github.com/browserify/browserify-handbook/blob/master/readme.markdown#browser-field), you can use the following configuration: - -```json -{ - ... - "jest": { - "resolver": "/resolver.js" - } -} -``` - -```js title="resolver.js" -const browserResolve = require('browser-resolve'); - -module.exports = browserResolve.sync; -``` - -By combining `defaultResolver` and `packageFilter` we can implement a `package.json` "pre-processor" that allows us to change how the default resolver will resolve modules. For example, imagine we want to use the field `"module"` if it is present, otherwise fallback to `"main"`: - -```json -{ - ... - "jest": { - "resolver": "my-module-resolve" - } -} -``` - -```js -// my-module-resolve package - -module.exports = (request, options) => { - // Call the defaultResolver, so we leverage its cache, error handling, etc. - return options.defaultResolver(request, { - ...options, - // Use packageFilter to process parsed `package.json` before the resolution (see https://www.npmjs.com/package/resolve#resolveid-opts-cb) - packageFilter: pkg => { - return { - ...pkg, - // Alter the value of `main` before resolving the package - main: pkg.module || pkg.main, - }; - }, - }); -}; -``` - -### `restoreMocks` \[boolean] - -Default: `false` - -Automatically restore mock state and implementation before every test. Equivalent to calling [`jest.restoreAllMocks()`](JestObjectAPI.md#jestrestoreallmocks) before each test. This will lead to any mocks having their fake implementations removed and restores their initial implementation. - -### `rootDir` \[string] - -Default: The root of the directory containing your Jest [config file](#) _or_ the `package.json` _or_ the [`pwd`](http://en.wikipedia.org/wiki/Pwd) if no `package.json` is found - -The root directory that Jest should scan for tests and modules within. If you put your Jest config inside your `package.json` and want the root directory to be the root of your repo, the value for this config param will default to the directory of the `package.json`. - -Oftentimes, you'll want to set this to `'src'` or `'lib'`, corresponding to where in your repository the code is stored. - -_Note that using `''` as a string token in any other path-based config settings will refer back to this value. So, for example, if you want your [`setupFiles`](#setupfiles-array) config entry to point at the `env-setup.js` file at the root of your project, you could set its value to `["/env-setup.js"]`._ - -### `roots` \[array<string>] - -Default: `[""]` - -A list of paths to directories that Jest should use to search for files in. - -There are times where you only want Jest to search in a single sub-directory (such as cases where you have a `src/` directory in your repo), but prevent it from accessing the rest of the repo. - -_Note: While `rootDir` is mostly used as a token to be re-used in other configuration options, `roots` is used by the internals of Jest to locate **test files and source files**. This applies also when searching for manual mocks for modules from `node_modules` (`__mocks__` will need to live in one of the `roots`)._ - -_Note: By default, `roots` has a single entry `` but there are cases where you may want to have multiple roots within one project, for example `roots: ["/src/", "/tests/"]`._ - -### `runner` \[string] - -Default: `"jest-runner"` - -This option allows you to use a custom runner instead of Jest's default test runner. Examples of runners include: - -- [`jest-runner-eslint`](https://github.com/jest-community/jest-runner-eslint) -- [`jest-runner-mocha`](https://github.com/rogeliog/jest-runner-mocha) -- [`jest-runner-tsc`](https://github.com/azz/jest-runner-tsc) -- [`jest-runner-prettier`](https://github.com/keplersj/jest-runner-prettier) - -_Note: The `runner` property value can omit the `jest-runner-` prefix of the package name._ - -To write a test-runner, export a class with which accepts `globalConfig` in the constructor, and has a `runTests` method with the signature: - -```ts -async function runTests( - tests: Array, - watcher: TestWatcher, - onStart: OnTestStart, - onResult: OnTestSuccess, - onFailure: OnTestFailure, - options: TestRunnerOptions, -): Promise; -``` - -If you need to restrict your test-runner to only run in serial rather than being executed in parallel your class should have the property `isSerial` to be set as `true`. - -### `setupFiles` \[array] - -Default: `[]` - -A list of paths to modules that run some code to configure or set up the testing environment. Each setupFile will be run once per test file. Since every test runs in its own environment, these scripts will be executed in the testing environment before executing [`setupFilesAfterEnv`](#setupfilesafterenv-array) and before the test code itself. - -### `setupFilesAfterEnv` \[array] - -Default: `[]` - -A list of paths to modules that run some code to configure or set up the testing framework before each test file in the suite is executed. Since [`setupFiles`](#setupfiles-array) executes before the test framework is installed in the environment, this script file presents you the opportunity of running some code immediately after the test framework has been installed in the environment but before the test code itself. - -If you want a path to be [relative to the root directory of your project](#rootdir-string), please include `` inside a path's string, like `"/a-configs-folder"`. - -For example, Jest ships with several plug-ins to `jasmine` that work by monkey-patching the jasmine API. If you wanted to add even more jasmine plugins to the mix (or if you wanted some custom, project-wide matchers for example), you could do so in these modules. - -Example `setupFilesAfterEnv` array in a jest.config.js: - -```js -module.exports = { - setupFilesAfterEnv: ['./jest.setup.js'], -}; -``` - -Example `jest.setup.js` file - -```js -jest.setTimeout(10000); // in milliseconds - -// you can even use the setup/teardown methods -beforeAll(() => { - // your code -}); -beforeEach(() => { - // your code -}); -afterEach(() => { - // your code -}); -afterAll(() => { - // your code -}); -``` - -### `slowTestThreshold` \[number] - -Default: `5` - -The number of seconds after which a test is considered as slow and reported as such in the results. - -### `snapshotFormat` \[object] - -Default: `undefined` - -Allows overriding specific snapshot formatting options documented in the [pretty-format readme](https://www.npmjs.com/package/pretty-format#usage-with-options), with the exceptions of `compareKeys` and `plugins`. For example, this config would have the snapshot formatter not print a prefix for "Object" and "Array": - -```json -{ - "jest": { - "snapshotFormat": { - "printBasicPrototype": false - } - } -} -``` - -```ts -import {expect, test} from '@jest/globals'; - -test('does not show prototypes for object and array inline', () => { - const object = { - array: [{hello: 'Danger'}], - }; - expect(object).toMatchInlineSnapshot(` -{ - "array": [ - { - "hello": "Danger", - }, - ], -} - `); -}); -``` - -### `snapshotResolver` \[string] - -Default: `undefined` - -The path to a module that can resolve test<->snapshot path. This config option lets you customize where Jest stores snapshot files on disk. - -Example snapshot resolver module: - -```js -module.exports = { - // resolves from test to snapshot path - resolveSnapshotPath: (testPath, snapshotExtension) => - testPath.replace('__tests__', '__snapshots__') + snapshotExtension, - - // resolves from snapshot to test path - resolveTestPath: (snapshotFilePath, snapshotExtension) => - snapshotFilePath - .replace('__snapshots__', '__tests__') - .slice(0, -snapshotExtension.length), - - // Example test path, used for preflight consistency check of the implementation above - testPathForConsistencyCheck: 'some/__tests__/example.test.js', -}; -``` - -### `snapshotSerializers` \[array<string>] - -Default: `[]` - -A list of paths to snapshot serializer modules Jest should use for snapshot testing. - -Jest has default serializers for built-in JavaScript types, HTML elements (Jest 20.0.0+), ImmutableJS (Jest 20.0.0+) and for React elements. See [snapshot test tutorial](TutorialReactNative.md#snapshot-test) for more information. - -Example serializer module: - -```js -// my-serializer-module -module.exports = { - serialize(val, config, indentation, depth, refs, printer) { - return `Pretty foo: ${printer(val.foo)}`; - }, - - test(val) { - return val && Object.prototype.hasOwnProperty.call(val, 'foo'); - }, -}; -``` - -`printer` is a function that serializes a value using existing plugins. - -To use `my-serializer-module` as a serializer, configuration would be as follows: - -```json -{ - ... - "jest": { - "snapshotSerializers": ["my-serializer-module"] - } -} -``` - -Finally tests would look as follows: - -```js -test(() => { - const bar = { - foo: { - x: 1, - y: 2, - }, - }; - - expect(bar).toMatchSnapshot(); -}); -``` - -Rendered snapshot: - -```json -Pretty foo: Object { - "x": 1, - "y": 2, -} -``` - -To make a dependency explicit instead of implicit, you can call [`expect.addSnapshotSerializer`](ExpectAPI.md#expectaddsnapshotserializerserializer) to add a module for an individual test file instead of adding its path to `snapshotSerializers` in Jest configuration. - -More about serializers API can be found [here](https://github.com/facebook/jest/tree/main/packages/pretty-format/README.md#serialize). - -### `testEnvironment` \[string] - -Default: `"node"` - -The test environment that will be used for testing. The default environment in Jest is a Node.js environment. If you are building a web app, you can use a browser-like environment through [`jsdom`](https://github.com/jsdom/jsdom) instead. - -By adding a `@jest-environment` docblock at the top of the file, you can specify another environment to be used for all tests in that file: - -```js -/** - * @jest-environment jsdom - */ - -test('use jsdom in this test file', () => { - const element = document.createElement('div'); - expect(element).not.toBeNull(); -}); -``` - -You can create your own module that will be used for setting up the test environment. The module must export a class with `setup`, `teardown` and `getVmContext` methods. You can also pass variables from this module to your test suites by assigning them to `this.global` object – this will make them available in your test suites as global variables. - -The class may optionally expose an asynchronous `handleTestEvent` method to bind to events fired by [`jest-circus`](https://github.com/facebook/jest/tree/main/packages/jest-circus). Normally, `jest-circus` test runner would pause until a promise returned from `handleTestEvent` gets fulfilled, **except for the next events**: `start_describe_definition`, `finish_describe_definition`, `add_hook`, `add_test` or `error` (for the up-to-date list you can look at [SyncEvent type in the types definitions](https://github.com/facebook/jest/tree/main/packages/jest-types/src/Circus.ts)). That is caused by backward compatibility reasons and `process.on('unhandledRejection', callback)` signature, but that usually should not be a problem for most of the use cases. - -Any docblock pragmas in test files will be passed to the environment constructor and can be used for per-test configuration. If the pragma does not have a value, it will be present in the object with its value set to an empty string. If the pragma is not present, it will not be present in the object. - -To use this class as your custom environment, refer to it by its full path within the project. For example, if your class is stored in `my-custom-environment.js` in some subfolder of your project, then the annotation might look like this: - -```js -/** - * @jest-environment ./src/test/my-custom-environment - */ -``` - -_Note: TestEnvironment is sandboxed. Each test suite will trigger setup/teardown in their own TestEnvironment._ - -Example: - -```js -// my-custom-environment -const NodeEnvironment = require('jest-environment-node'); - -class CustomEnvironment extends NodeEnvironment { - constructor(config, context) { - super(config, context); - this.testPath = context.testPath; - this.docblockPragmas = context.docblockPragmas; - } - - async setup() { - await super.setup(); - await someSetupTasks(this.testPath); - this.global.someGlobalObject = createGlobalObject(); - - // Will trigger if docblock contains @my-custom-pragma my-pragma-value - if (this.docblockPragmas['my-custom-pragma'] === 'my-pragma-value') { - // ... - } - } - - async teardown() { - this.global.someGlobalObject = destroyGlobalObject(); - await someTeardownTasks(); - await super.teardown(); - } - - getVmContext() { - return super.getVmContext(); - } - - async handleTestEvent(event, state) { - if (event.name === 'test_start') { - // ... - } - } -} - -module.exports = CustomEnvironment; -``` - -```js -// my-test-suite -/** - * @jest-environment ./my-custom-environment - */ -let someGlobalObject; - -beforeAll(() => { - someGlobalObject = global.someGlobalObject; -}); -``` - -### `testEnvironmentOptions` \[Object] - -Default: `{}` - -Test environment options that will be passed to the `testEnvironment`. The relevant options depend on the environment. For example, you can override options given to [jsdom](https://github.com/jsdom/jsdom) such as `{userAgent: "Agent/007"}`. - -### `testFailureExitCode` \[number] - -Default: `1` - -The exit code Jest returns on test failure. - -_Note: This does not change the exit code in the case of Jest errors (e.g. invalid configuration)._ - -### `testMatch` \[array<string>] - -(default: `[ "**/__tests__/**/*.[jt]s?(x)", "**/?(*.)+(spec|test).[jt]s?(x)" ]`) - -The glob patterns Jest uses to detect test files. By default it looks for `.js`, `.jsx`, `.ts` and `.tsx` files inside of `__tests__` folders, as well as any files with a suffix of `.test` or `.spec` (e.g. `Component.test.js` or `Component.spec.js`). It will also find files called `test.js` or `spec.js`. - -See the [micromatch](https://github.com/micromatch/micromatch) package for details of the patterns you can specify. - -See also [`testRegex` [string | array<string>]](#testregex-string--arraystring), but note that you cannot specify both options. - -_Note: Each glob pattern is applied in the order they are specified in the config. (For example `["!**/__fixtures__/**", "**/__tests__/**/*.js"]` will not exclude `__fixtures__` because the negation is overwritten with the second pattern. In order to make the negated glob work in this example it has to come after `**/__tests__/**/*.js`.)_ - -### `testPathIgnorePatterns` \[array<string>] - -Default: `["/node_modules/"]` - -An array of regexp pattern strings that are matched against all test paths before executing the test. If the test path matches any of the patterns, it will be skipped. - -These pattern strings match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. Example: `["/build/", "/node_modules/"]`. - -### `testRegex` \[string | array<string>] - -Default: `(/__tests__/.*|(\\.|/)(test|spec))\\.[jt]sx?$` - -The pattern or patterns Jest uses to detect test files. By default it looks for `.js`, `.jsx`, `.ts` and `.tsx` files inside of `__tests__` folders, as well as any files with a suffix of `.test` or `.spec` (e.g. `Component.test.js` or `Component.spec.js`). It will also find files called `test.js` or `spec.js`. See also [`testMatch` [array<string>]](#testmatch-arraystring), but note that you cannot specify both options. - -The following is a visualization of the default regex: - -```bash -├── __tests__ -│ └── component.spec.js # test -│ └── anything # test -├── package.json # not test -├── foo.test.js # test -├── bar.spec.jsx # test -└── component.js # not test -``` - -_Note: `testRegex` will try to detect test files using the **absolute file path**, therefore, having a folder with a name that matches it will run all the files as tests_ - -### `testResultsProcessor` \[string] - -Default: `undefined` - -This option allows the use of a custom results processor. This processor must be a node module that exports a function expecting an object with the following structure as the first argument and return it: - -```json -{ - "success": boolean, - "startTime": epoch, - "numTotalTestSuites": number, - "numPassedTestSuites": number, - "numFailedTestSuites": number, - "numRuntimeErrorTestSuites": number, - "numTotalTests": number, - "numPassedTests": number, - "numFailedTests": number, - "numPendingTests": number, - "numTodoTests": number, - "openHandles": Array, - "testResults": [{ - "numFailingTests": number, - "numPassingTests": number, - "numPendingTests": number, - "testResults": [{ - "title": string (message in it block), - "status": "failed" | "pending" | "passed", - "ancestorTitles": [string (message in describe blocks)], - "failureMessages": [string], - "numPassingAsserts": number, - "location": { - "column": number, - "line": number - } - }, - ... - ], - "perfStats": { - "start": epoch, - "end": epoch - }, - "testFilePath": absolute path to test file, - "coverage": {} - }, - "testExecError:" (exists if there was a top-level failure) { - "message": string - "stack": string - } - ... - ] -} -``` - -`testResultsProcessor` and `reporters` are very similar to each other. One difference is that a test result processor only gets called after all tests finished. Whereas a reporter has the ability to receive test results after individual tests and/or test suites are finished. - -### `testRunner` \[string] - -Default: `jest-circus/runner` - -This option allows the use of a custom test runner. The default is `jest-circus`. A custom test runner can be provided by specifying a path to a test runner implementation. - -The test runner module must export a function with the following signature: - -```ts -function testRunner( - globalConfig: GlobalConfig, - config: ProjectConfig, - environment: Environment, - runtime: Runtime, - testPath: string, -): Promise; -``` - -An example of such function can be found in our default [jasmine2 test runner package](https://github.com/facebook/jest/blob/main/packages/jest-jasmine2/src/index.ts). - -### `testSequencer` \[string] - -Default: `@jest/test-sequencer` - -This option allows you to use a custom sequencer instead of Jest's default. `sort` may optionally return a Promise. - -Example: - -Sort test path alphabetically. - -```js title="testSequencer.js" -const Sequencer = require('@jest/test-sequencer').default; - -class CustomSequencer extends Sequencer { - sort(tests) { - // Test structure information - // https://github.com/facebook/jest/blob/6b8b1404a1d9254e7d5d90a8934087a9c9899dab/packages/jest-runner/src/types.ts#L17-L21 - const copyTests = Array.from(tests); - return copyTests.sort((testA, testB) => (testA.path > testB.path ? 1 : -1)); - } -} - -module.exports = CustomSequencer; -``` - -Use it in your Jest config file like this: - -```json -{ - "testSequencer": "path/to/testSequencer.js" -} -``` - -### `testTimeout` \[number] - -Default: `5000` - -Default timeout of a test in milliseconds. - -### `testURL` \[string] - -Default: `http://localhost` - -This option sets the URL for the jsdom environment. It is reflected in properties such as `location.href`. - -### `timers` \[string] - -Default: `real` - -Setting this value to `fake` or `modern` enables fake timers for all tests by default. Fake timers are useful when a piece of code sets a long timeout that we don't want to wait for in a test. You can learn more about fake timers [here](JestObjectAPI.md#jestusefaketimersimplementation-modern--legacy). - -If the value is `legacy`, the old implementation will be used as implementation instead of one backed by [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). - -### `transform` \[object<string, pathToTransformer | \[pathToTransformer, object]>] - -Default: `{"\\.[jt]sx?$": "babel-jest"}` - -A map from regular expressions to paths to transformers. A transformer is a module that provides a synchronous function for transforming source files. For example, if you wanted to be able to use a new language feature in your modules or tests that aren't yet supported by node, you might plug in one of many compilers that compile a future version of JavaScript to a current one. Example: see the [examples/typescript](https://github.com/facebook/jest/blob/main/examples/typescript/package.json#L16) example or the [webpack tutorial](Webpack.md). - -Examples of such compilers include: - -- [Babel](https://babeljs.io/) -- [TypeScript](http://www.typescriptlang.org/) -- To build your own please visit the [Custom Transformer](CodeTransformation.md#writing-custom-transformers) section - -You can pass configuration to a transformer like `{filePattern: ['path-to-transformer', {options}]}` For example, to configure babel-jest for non-default behavior, `{"\\.js$": ['babel-jest', {rootMode: "upward"}]}` - -_Note: a transformer is only run once per file unless the file has changed. During the development of a transformer it can be useful to run Jest with `--no-cache` to frequently [delete Jest's cache](Troubleshooting.md#caching-issues)._ - -_Note: when adding additional code transformers, this will overwrite the default config and `babel-jest` is no longer automatically loaded. If you want to use it to compile JavaScript or Typescript, it has to be explicitly defined by adding `{"\\.[jt]sx?$": "babel-jest"}` to the transform property. See [babel-jest plugin](https://github.com/facebook/jest/tree/main/packages/babel-jest#setup)_ - -A transformer must be an object with at least a `process` function, and it's also recommended to include a `getCacheKey` function. If your transformer is written in ESM you should have a default export with that object. - -If the tests are written using [native ESM](ECMAScriptModules.md) the transformer can export `processAsync` and `getCacheKeyAsync` instead or in addition to the synchronous variants. - -### `transformIgnorePatterns` \[array<string>] - -Default: `["/node_modules/", "\\.pnp\\.[^\\\/]+$"]` - -An array of regexp pattern strings that are matched against all source file paths before transformation. If the file path matches **any** of the patterns, it will not be transformed. - -Providing regexp patterns that overlap with each other may result in files not being transformed that you expected to be transformed. For example: - -```json -{ - "transformIgnorePatterns": ["/node_modules/(?!(foo|bar)/)", "/bar/"] -} -``` - -The first pattern will match (and therefore not transform) files inside `/node_modules` except for those in `/node_modules/foo/` and `/node_modules/bar/`. The second pattern will match (and therefore not transform) files inside any path with `/bar/` in it. With the two together, files in `/node_modules/bar/` will not be transformed because it does match the second pattern, even though it was excluded by the first. - -Sometimes it happens (especially in React Native or TypeScript projects) that 3rd party modules are published as untranspiled code. Since all files inside `node_modules` are not transformed by default, Jest will not understand the code in these modules, resulting in syntax errors. To overcome this, you may use `transformIgnorePatterns` to allow transpiling such modules. You'll find a good example of this use case in [React Native Guide](/docs/tutorial-react-native#transformignorepatterns-customization). - -These pattern strings match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. - -Example: - -```json -{ - "transformIgnorePatterns": [ - "/bower_components/", - "/node_modules/" - ] -} -``` - -### `unmockedModulePathPatterns` \[array<string>] - -Default: `[]` - -An array of regexp pattern strings that are matched against all modules before the module loader will automatically return a mock for them. If a module's path matches any of the patterns in this list, it will not be automatically mocked by the module loader. - -This is useful for some commonly used 'utility' modules that are almost always used as implementation details almost all the time (like underscore/lo-dash, etc). It's generally a best practice to keep this list as small as possible and always use explicit `jest.mock()`/`jest.unmock()` calls in individual tests. Explicit per-test setup is far easier for other readers of the test to reason about the environment the test will run in. - -It is possible to override this setting in individual tests by explicitly calling `jest.mock()` at the top of the test file. - -### `verbose` \[boolean] - -Default: `false` - -Indicates whether each individual test should be reported during the run. All errors will also still be shown on the bottom after execution. Note that if there is only one test file being run it will default to `true`. - -### `watchPathIgnorePatterns` \[array<string>] - -Default: `[]` - -An array of RegExp patterns that are matched against all source file paths before re-running tests in watch mode. If the file path matches any of the patterns, when it is updated, it will not trigger a re-run of tests. - -These patterns match against the full path. Use the `` string token to include the path to your project's root directory to prevent it from accidentally ignoring all of your files in different environments that may have different root directories. Example: `["/node_modules/"]`. - -Even if nothing is specified here, the watcher will ignore changes to the version control folders (.git, .hg). Other hidden files and directories, i.e. those that begin with a dot (`.`), are watched by default. Remember to escape the dot when you add them to `watchPathIgnorePatterns` as it is a special RegExp character. - -Example: - -```json -{ - "watchPathIgnorePatterns": ["/\\.tmp/", "/bar/"] -} -``` - -### `watchPlugins` \[array<string | \[string, Object]>] - -Default: `[]` - -This option allows you to use custom watch plugins. Read more about watch plugins [here](watch-plugins). - -Examples of watch plugins include: - -- [`jest-watch-master`](https://github.com/rickhanlonii/jest-watch-master) -- [`jest-watch-select-projects`](https://github.com/rogeliog/jest-watch-select-projects) -- [`jest-watch-suspend`](https://github.com/unional/jest-watch-suspend) -- [`jest-watch-typeahead`](https://github.com/jest-community/jest-watch-typeahead) -- [`jest-watch-yarn-workspaces`](https://github.com/cameronhunter/jest-watch-directories/tree/master/packages/jest-watch-yarn-workspaces) - -_Note: The values in the `watchPlugins` property value can omit the `jest-watch-` prefix of the package name._ - -### `watchman` \[boolean] - -Default: `true` - -Whether to use [`watchman`](https://facebook.github.io/watchman/) for file crawling. - -### `//` \[string] - -No default - -This option allows comments in `package.json`. Include the comment text as the value of this key anywhere in `package.json`. - -Example: - -```json -{ - "name": "my-project", - "jest": { - "//": "Comment goes here", - "verbose": true - } -} -``` diff --git a/website/versioned_docs/version-27.1/DynamoDB.md b/website/versioned_docs/version-27.1/DynamoDB.md deleted file mode 100644 index a5abd9147aed..000000000000 --- a/website/versioned_docs/version-27.1/DynamoDB.md +++ /dev/null @@ -1,81 +0,0 @@ ---- -id: dynamodb -title: Using with DynamoDB ---- - -With the [Global Setup/Teardown](Configuration.md#globalsetup-string) and [Async Test Environment](Configuration.md#testenvironment-string) APIs, Jest can work smoothly with [DynamoDB](https://aws.amazon.com/dynamodb/). - -## Use jest-dynamodb Preset - -[Jest DynamoDB](https://github.com/shelfio/jest-dynamodb) provides all required configuration to run your tests using DynamoDB. - -1. First, install `@shelf/jest-dynamodb` - -``` -yarn add @shelf/jest-dynamodb --dev -``` - -2. Specify preset in your Jest configuration: - -```json -{ - "preset": "@shelf/jest-dynamodb" -} -``` - -3. Create `jest-dynamodb-config.js` and define DynamoDB tables - -See [Create Table API](https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/AWS/DynamoDB.html#createTable-property) - -```js -module.exports = { - tables: [ - { - TableName: `files`, - KeySchema: [{AttributeName: 'id', KeyType: 'HASH'}], - AttributeDefinitions: [{AttributeName: 'id', AttributeType: 'S'}], - ProvisionedThroughput: {ReadCapacityUnits: 1, WriteCapacityUnits: 1}, - }, - // etc - ], -}; -``` - -4. Configure DynamoDB client - -```js -const {DocumentClient} = require('aws-sdk/clients/dynamodb'); - -const isTest = process.env.JEST_WORKER_ID; -const config = { - convertEmptyValues: true, - ...(isTest && { - endpoint: 'localhost:8000', - sslEnabled: false, - region: 'local-env', - }), -}; - -const ddb = new DocumentClient(config); -``` - -5. Write tests - -```js -it('should insert item into table', async () => { - await ddb - .put({TableName: 'files', Item: {id: '1', hello: 'world'}}) - .promise(); - - const {Item} = await ddb.get({TableName: 'files', Key: {id: '1'}}).promise(); - - expect(Item).toEqual({ - id: '1', - hello: 'world', - }); -}); -``` - -There's no need to load any dependencies. - -See [documentation](https://github.com/shelfio/jest-dynamodb) for details. diff --git a/website/versioned_docs/version-27.1/EnvironmentVariables.md b/website/versioned_docs/version-27.1/EnvironmentVariables.md deleted file mode 100644 index fb50c3e72d08..000000000000 --- a/website/versioned_docs/version-27.1/EnvironmentVariables.md +++ /dev/null @@ -1,14 +0,0 @@ ---- -id: environment-variables -title: Environment Variables ---- - -Jest sets the following environment variables: - -### `NODE_ENV` - -Set to `'test'` if it's not already set to something else. - -### `JEST_WORKER_ID` - -Each worker process is assigned a unique id (index-based that starts with `1`). This is set to `1` for all tests when [`runInBand`](CLI.md#--runinband) is set to true. diff --git a/website/versioned_docs/version-27.1/Es6ClassMocks.md b/website/versioned_docs/version-27.1/Es6ClassMocks.md deleted file mode 100644 index ad2fe2103018..000000000000 --- a/website/versioned_docs/version-27.1/Es6ClassMocks.md +++ /dev/null @@ -1,443 +0,0 @@ ---- -id: es6-class-mocks -title: ES6 Class Mocks ---- - -Jest can be used to mock ES6 classes that are imported into files you want to test. - -ES6 classes are constructor functions with some syntactic sugar. Therefore, any mock for an ES6 class must be a function or an actual ES6 class (which is, again, another function). So you can mock them using [mock functions](MockFunctions.md). - -## An ES6 Class Example - -We'll use a contrived example of a class that plays sound files, `SoundPlayer`, and a consumer class which uses that class, `SoundPlayerConsumer`. We'll mock `SoundPlayer` in our tests for `SoundPlayerConsumer`. - -```javascript title="sound-player.js" -export default class SoundPlayer { - constructor() { - this.foo = 'bar'; - } - - playSoundFile(fileName) { - console.log('Playing sound file ' + fileName); - } -} -``` - -```javascript title="sound-player-consumer.js" -import SoundPlayer from './sound-player'; - -export default class SoundPlayerConsumer { - constructor() { - this.soundPlayer = new SoundPlayer(); - } - - playSomethingCool() { - const coolSoundFileName = 'song.mp3'; - this.soundPlayer.playSoundFile(coolSoundFileName); - } -} -``` - -## The 4 ways to create an ES6 class mock - -### Automatic mock - -Calling `jest.mock('./sound-player')` returns a useful "automatic mock" you can use to spy on calls to the class constructor and all of its methods. It replaces the ES6 class with a mock constructor, and replaces all of its methods with [mock functions](MockFunctions.md) that always return `undefined`. Method calls are saved in `theAutomaticMock.mock.instances[index].methodName.mock.calls`. - -Please note that if you use arrow functions in your classes, they will _not_ be part of the mock. The reason for that is that arrow functions are not present on the object's prototype, they are merely properties holding a reference to a function. - -If you don't need to replace the implementation of the class, this is the easiest option to set up. For example: - -```javascript -import SoundPlayer from './sound-player'; -import SoundPlayerConsumer from './sound-player-consumer'; -jest.mock('./sound-player'); // SoundPlayer is now a mock constructor - -beforeEach(() => { - // Clear all instances and calls to constructor and all methods: - SoundPlayer.mockClear(); -}); - -it('We can check if the consumer called the class constructor', () => { - const soundPlayerConsumer = new SoundPlayerConsumer(); - expect(SoundPlayer).toHaveBeenCalledTimes(1); -}); - -it('We can check if the consumer called a method on the class instance', () => { - // Show that mockClear() is working: - expect(SoundPlayer).not.toHaveBeenCalled(); - - const soundPlayerConsumer = new SoundPlayerConsumer(); - // Constructor should have been called again: - expect(SoundPlayer).toHaveBeenCalledTimes(1); - - const coolSoundFileName = 'song.mp3'; - soundPlayerConsumer.playSomethingCool(); - - // mock.instances is available with automatic mocks: - const mockSoundPlayerInstance = SoundPlayer.mock.instances[0]; - const mockPlaySoundFile = mockSoundPlayerInstance.playSoundFile; - expect(mockPlaySoundFile.mock.calls[0][0]).toEqual(coolSoundFileName); - // Equivalent to above check: - expect(mockPlaySoundFile).toHaveBeenCalledWith(coolSoundFileName); - expect(mockPlaySoundFile).toHaveBeenCalledTimes(1); -}); -``` - -### Manual mock - -Create a [manual mock](ManualMocks.md) by saving a mock implementation in the `__mocks__` folder. This allows you to specify the implementation, and it can be used across test files. - -```javascript title="__mocks__/sound-player.js" -// Import this named export into your test file: -export const mockPlaySoundFile = jest.fn(); -const mock = jest.fn().mockImplementation(() => { - return {playSoundFile: mockPlaySoundFile}; -}); - -export default mock; -``` - -Import the mock and the mock method shared by all instances: - -```javascript title="sound-player-consumer.test.js" -import SoundPlayer, {mockPlaySoundFile} from './sound-player'; -import SoundPlayerConsumer from './sound-player-consumer'; -jest.mock('./sound-player'); // SoundPlayer is now a mock constructor - -beforeEach(() => { - // Clear all instances and calls to constructor and all methods: - SoundPlayer.mockClear(); - mockPlaySoundFile.mockClear(); -}); - -it('We can check if the consumer called the class constructor', () => { - const soundPlayerConsumer = new SoundPlayerConsumer(); - expect(SoundPlayer).toHaveBeenCalledTimes(1); -}); - -it('We can check if the consumer called a method on the class instance', () => { - const soundPlayerConsumer = new SoundPlayerConsumer(); - const coolSoundFileName = 'song.mp3'; - soundPlayerConsumer.playSomethingCool(); - expect(mockPlaySoundFile).toHaveBeenCalledWith(coolSoundFileName); -}); -``` - -### Calling [`jest.mock()`](JestObjectAPI.md#jestmockmodulename-factory-options) with the module factory parameter - -`jest.mock(path, moduleFactory)` takes a **module factory** argument. A module factory is a function that returns the mock. - -In order to mock a constructor function, the module factory must return a constructor function. In other words, the module factory must be a function that returns a function - a higher-order function (HOF). - -```javascript -import SoundPlayer from './sound-player'; -const mockPlaySoundFile = jest.fn(); -jest.mock('./sound-player', () => { - return jest.fn().mockImplementation(() => { - return {playSoundFile: mockPlaySoundFile}; - }); -}); -``` - -:::caution - -Since calls to `jest.mock()` are hoisted to the top of the file, Jest prevents access to out-of-scope variables. By default, you cannot first define a variable and then use it in the factory. Jest will disable this check for variables that start with the word `mock`. However, it is still up to you to guarantee that they will be initialized on time. Be aware of [Temporal Dead Zone](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let#temporal_dead_zone_tdz). - -::: - -For example, the following will throw an out-of-scope error due to the use of `fake` instead of `mock` in the variable declaration. - -```javascript -// Note: this will fail -import SoundPlayer from './sound-player'; -const fakePlaySoundFile = jest.fn(); -jest.mock('./sound-player', () => { - return jest.fn().mockImplementation(() => { - return {playSoundFile: fakePlaySoundFile}; - }); -}); -``` - -The following will throw a `ReferenceError` despite using `mock` in the variable declaration, as the `mockSoundPlayer` is not wrapped in an arrow function and thus accessed before initialization after hoisting. - -```javascript -import SoundPlayer from './sound-player'; -const mockSoundPlayer = jest.fn().mockImplementation(() => { - return {playSoundFile: mockPlaySoundFile}; -}); -// results in a ReferenceError -jest.mock('./sound-player', () => { - return mockSoundPlayer; -}); -``` - -### Replacing the mock using [`mockImplementation()`](MockFunctionAPI.md#mockfnmockimplementationfn) or [`mockImplementationOnce()`](MockFunctionAPI.md#mockfnmockimplementationoncefn) - -You can replace all of the above mocks in order to change the implementation, for a single test or all tests, by calling `mockImplementation()` on the existing mock. - -Calls to jest.mock are hoisted to the top of the code. You can specify a mock later, e.g. in `beforeAll()`, by calling `mockImplementation()` (or `mockImplementationOnce()`) on the existing mock instead of using the factory parameter. This also allows you to change the mock between tests, if needed: - -```javascript -import SoundPlayer from './sound-player'; -import SoundPlayerConsumer from './sound-player-consumer'; - -jest.mock('./sound-player'); - -describe('When SoundPlayer throws an error', () => { - beforeAll(() => { - SoundPlayer.mockImplementation(() => { - return { - playSoundFile: () => { - throw new Error('Test error'); - }, - }; - }); - }); - - it('Should throw an error when calling playSomethingCool', () => { - const soundPlayerConsumer = new SoundPlayerConsumer(); - expect(() => soundPlayerConsumer.playSomethingCool()).toThrow(); - }); -}); -``` - -## In depth: Understanding mock constructor functions - -Building your constructor function mock using `jest.fn().mockImplementation()` makes mocks appear more complicated than they really are. This section shows how you can create your own mocks to illustrate how mocking works. - -### Manual mock that is another ES6 class - -If you define an ES6 class using the same filename as the mocked class in the `__mocks__` folder, it will serve as the mock. This class will be used in place of the real class. This allows you to inject a test implementation for the class, but does not provide a way to spy on calls. - -For the contrived example, the mock might look like this: - -```javascript title="__mocks__/sound-player.js" -export default class SoundPlayer { - constructor() { - console.log('Mock SoundPlayer: constructor was called'); - } - - playSoundFile() { - console.log('Mock SoundPlayer: playSoundFile was called'); - } -} -``` - -### Mock using module factory parameter - -The module factory function passed to `jest.mock(path, moduleFactory)` can be a HOF that returns a function\*. This will allow calling `new` on the mock. Again, this allows you to inject different behavior for testing, but does not provide a way to spy on calls. - -#### \* Module factory function must return a function - -In order to mock a constructor function, the module factory must return a constructor function. In other words, the module factory must be a function that returns a function - a higher-order function (HOF). - -```javascript -jest.mock('./sound-player', () => { - return function () { - return {playSoundFile: () => {}}; - }; -}); -``` - -**_Note: Arrow functions won't work_** - -Note that the mock can't be an arrow function because calling `new` on an arrow function is not allowed in JavaScript. So this won't work: - -```javascript -jest.mock('./sound-player', () => { - return () => { - // Does not work; arrow functions can't be called with new - return {playSoundFile: () => {}}; - }; -}); -``` - -This will throw **_TypeError: \_soundPlayer2.default is not a constructor_**, unless the code is transpiled to ES5, e.g. by `@babel/preset-env`. (ES5 doesn't have arrow functions nor classes, so both will be transpiled to plain functions.) - -## Mocking a specific method of a class - -Lets say that you want to mock or spy the method `playSoundFile` within the class `SoundPlayer`. A simple example: - -```javascript -// your jest test file below -import SoundPlayer from './sound-player'; -import SoundPlayerConsumer from './sound-player-consumer'; - -const playSoundFileMock = jest - .spyOn(SoundPlayer.prototype, 'playSoundFile') - .mockImplementation(() => { - console.log('mocked function'); - }); // comment this line if just want to "spy" - -it('player consumer plays music', () => { - const player = new SoundPlayerConsumer(); - player.playSomethingCool(); - expect(playSoundFileMock).toHaveBeenCalled(); -}); -``` - -### Static, getter and setter methods - -Lets imagine our class `SoundPlayer` has a getter method `foo` and a static method `brand` - -```javascript -export default class SoundPlayer { - constructor() { - this.foo = 'bar'; - } - - playSoundFile(fileName) { - console.log('Playing sound file ' + fileName); - } - - get foo() { - return 'bar'; - } - static brand() { - return 'player-brand'; - } -} -``` - -You can mock/spy them easily, here is an example: - -```javascript -// your jest test file below -import SoundPlayer from './sound-player'; -import SoundPlayerConsumer from './sound-player-consumer'; - -const staticMethodMock = jest - .spyOn(SoundPlayer, 'brand') - .mockImplementation(() => 'some-mocked-brand'); - -const getterMethodMock = jest - .spyOn(SoundPlayer.prototype, 'foo', 'get') - .mockImplementation(() => 'some-mocked-result'); - -it('custom methods are called', () => { - const player = new SoundPlayer(); - const foo = player.foo; - const brand = SoundPlayer.brand(); - - expect(staticMethodMock).toHaveBeenCalled(); - expect(getterMethodMock).toHaveBeenCalled(); -}); -``` - -## Keeping track of usage (spying on the mock) - -Injecting a test implementation is helpful, but you will probably also want to test whether the class constructor and methods are called with the correct parameters. - -### Spying on the constructor - -In order to track calls to the constructor, replace the function returned by the HOF with a Jest mock function. Create it with [`jest.fn()`](JestObjectAPI.md#jestfnimplementation), and then specify its implementation with `mockImplementation()`. - -```javascript -import SoundPlayer from './sound-player'; -jest.mock('./sound-player', () => { - // Works and lets you check for constructor calls: - return jest.fn().mockImplementation(() => { - return {playSoundFile: () => {}}; - }); -}); -``` - -This will let us inspect usage of our mocked class, using `SoundPlayer.mock.calls`: `expect(SoundPlayer).toHaveBeenCalled();` or near-equivalent: `expect(SoundPlayer.mock.calls.length).toEqual(1);` - -### Mocking non-default class exports - -If the class is **not** the default export from the module then you need to return an object with the key that is the same as the class export name. - -```javascript -import {SoundPlayer} from './sound-player'; -jest.mock('./sound-player', () => { - // Works and lets you check for constructor calls: - return { - SoundPlayer: jest.fn().mockImplementation(() => { - return {playSoundFile: () => {}}; - }), - }; -}); -``` - -### Spying on methods of our class - -Our mocked class will need to provide any member functions (`playSoundFile` in the example) that will be called during our tests, or else we'll get an error for calling a function that doesn't exist. But we'll probably want to also spy on calls to those methods, to ensure that they were called with the expected parameters. - -A new object will be created each time the mock constructor function is called during tests. To spy on method calls in all of these objects, we populate `playSoundFile` with another mock function, and store a reference to that same mock function in our test file, so it's available during tests. - -```javascript -import SoundPlayer from './sound-player'; -const mockPlaySoundFile = jest.fn(); -jest.mock('./sound-player', () => { - return jest.fn().mockImplementation(() => { - return {playSoundFile: mockPlaySoundFile}; - // Now we can track calls to playSoundFile - }); -}); -``` - -The manual mock equivalent of this would be: - -```javascript title="__mocks__/sound-player.js" -// Import this named export into your test file -export const mockPlaySoundFile = jest.fn(); -const mock = jest.fn().mockImplementation(() => { - return {playSoundFile: mockPlaySoundFile}; -}); - -export default mock; -``` - -Usage is similar to the module factory function, except that you can omit the second argument from `jest.mock()`, and you must import the mocked method into your test file, since it is no longer defined there. Use the original module path for this; don't include `__mocks__`. - -### Cleaning up between tests - -To clear the record of calls to the mock constructor function and its methods, we call [`mockClear()`](MockFunctionAPI.md#mockfnmockclear) in the `beforeEach()` function: - -```javascript -beforeEach(() => { - SoundPlayer.mockClear(); - mockPlaySoundFile.mockClear(); -}); -``` - -## Complete example - -Here's a complete test file which uses the module factory parameter to `jest.mock`: - -```javascript title="sound-player-consumer.test.js" -import SoundPlayer from './sound-player'; -import SoundPlayerConsumer from './sound-player-consumer'; - -const mockPlaySoundFile = jest.fn(); -jest.mock('./sound-player', () => { - return jest.fn().mockImplementation(() => { - return {playSoundFile: mockPlaySoundFile}; - }); -}); - -beforeEach(() => { - SoundPlayer.mockClear(); - mockPlaySoundFile.mockClear(); -}); - -it('The consumer should be able to call new() on SoundPlayer', () => { - const soundPlayerConsumer = new SoundPlayerConsumer(); - // Ensure constructor created the object: - expect(soundPlayerConsumer).toBeTruthy(); -}); - -it('We can check if the consumer called the class constructor', () => { - const soundPlayerConsumer = new SoundPlayerConsumer(); - expect(SoundPlayer).toHaveBeenCalledTimes(1); -}); - -it('We can check if the consumer called a method on the class instance', () => { - const soundPlayerConsumer = new SoundPlayerConsumer(); - const coolSoundFileName = 'song.mp3'; - soundPlayerConsumer.playSomethingCool(); - expect(mockPlaySoundFile.mock.calls[0][0]).toEqual(coolSoundFileName); -}); -``` diff --git a/website/versioned_docs/version-27.1/ExpectAPI.md b/website/versioned_docs/version-27.1/ExpectAPI.md deleted file mode 100644 index ab3f63a70213..000000000000 --- a/website/versioned_docs/version-27.1/ExpectAPI.md +++ /dev/null @@ -1,1393 +0,0 @@ ---- -id: expect -title: Expect ---- - -When you're writing tests, you often need to check that values meet certain conditions. `expect` gives you access to a number of "matchers" that let you validate different things. - -For additional Jest matchers maintained by the Jest Community check out [`jest-extended`](https://github.com/jest-community/jest-extended). - -## Methods - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Reference - -### `expect(value)` - -The `expect` function is used every time you want to test a value. You will rarely call `expect` by itself. Instead, you will use `expect` along with a "matcher" function to assert something about a value. - -It's easier to understand this with an example. Let's say you have a method `bestLaCroixFlavor()` which is supposed to return the string `'grapefruit'`. Here's how you would test that: - -```js -test('the best flavor is grapefruit', () => { - expect(bestLaCroixFlavor()).toBe('grapefruit'); -}); -``` - -In this case, `toBe` is the matcher function. There are a lot of different matcher functions, documented below, to help you test different things. - -The argument to `expect` should be the value that your code produces, and any argument to the matcher should be the correct value. If you mix them up, your tests will still work, but the error messages on failing tests will look strange. - -### `expect.extend(matchers)` - -You can use `expect.extend` to add your own matchers to Jest. For example, let's say that you're testing a number utility library and you're frequently asserting that numbers appear within particular ranges of other numbers. You could abstract that into a `toBeWithinRange` matcher: - -```js -expect.extend({ - toBeWithinRange(received, floor, ceiling) { - const pass = received >= floor && received <= ceiling; - if (pass) { - return { - message: () => - `expected ${received} not to be within range ${floor} - ${ceiling}`, - pass: true, - }; - } else { - return { - message: () => - `expected ${received} to be within range ${floor} - ${ceiling}`, - pass: false, - }; - } - }, -}); - -test('numeric ranges', () => { - expect(100).toBeWithinRange(90, 110); - expect(101).not.toBeWithinRange(0, 100); - expect({apples: 6, bananas: 3}).toEqual({ - apples: expect.toBeWithinRange(1, 10), - bananas: expect.not.toBeWithinRange(11, 20), - }); -}); -``` - -_Note_: In TypeScript, when using `@types/jest` for example, you can declare the new `toBeWithinRange` matcher in the imported module like this: - -```ts -interface CustomMatchers { - toBeWithinRange(floor: number, ceiling: number): R; -} - -declare global { - namespace jest { - interface Expect extends CustomMatchers {} - interface Matchers extends CustomMatchers {} - interface InverseAsymmetricMatchers extends CustomMatchers {} - } -} -``` - -#### Async Matchers - -`expect.extend` also supports async matchers. Async matchers return a Promise so you will need to await the returned value. Let's use an example matcher to illustrate the usage of them. We are going to implement a matcher called `toBeDivisibleByExternalValue`, where the divisible number is going to be pulled from an external source. - -```js -expect.extend({ - async toBeDivisibleByExternalValue(received) { - const externalValue = await getExternalValueFromRemoteSource(); - const pass = received % externalValue == 0; - if (pass) { - return { - message: () => - `expected ${received} not to be divisible by ${externalValue}`, - pass: true, - }; - } else { - return { - message: () => - `expected ${received} to be divisible by ${externalValue}`, - pass: false, - }; - } - }, -}); - -test('is divisible by external value', async () => { - await expect(100).toBeDivisibleByExternalValue(); - await expect(101).not.toBeDivisibleByExternalValue(); -}); -``` - -#### Custom Matchers API - -Matchers should return an object (or a Promise of an object) with two keys. `pass` indicates whether there was a match or not, and `message` provides a function with no arguments that returns an error message in case of failure. Thus, when `pass` is false, `message` should return the error message for when `expect(x).yourMatcher()` fails. And when `pass` is true, `message` should return the error message for when `expect(x).not.yourMatcher()` fails. - -Matchers are called with the argument passed to `expect(x)` followed by the arguments passed to `.yourMatcher(y, z)`: - -```js -expect.extend({ - yourMatcher(x, y, z) { - return { - pass: true, - message: () => '', - }; - }, -}); -``` - -These helper functions and properties can be found on `this` inside a custom matcher: - -#### `this.isNot` - -A boolean to let you know this matcher was called with the negated `.not` modifier allowing you to display a clear and correct matcher hint (see example code). - -#### `this.promise` - -A string allowing you to display a clear and correct matcher hint: - -- `'rejects'` if matcher was called with the promise `.rejects` modifier -- `'resolves'` if matcher was called with the promise `.resolves` modifier -- `''` if matcher was not called with a promise modifier - -#### `this.equals(a, b)` - -This is a deep-equality function that will return `true` if two objects have the same values (recursively). - -#### `this.expand` - -A boolean to let you know this matcher was called with an `expand` option. When Jest is called with the `--expand` flag, `this.expand` can be used to determine if Jest is expected to show full diffs and errors. - -#### `this.utils` - -There are a number of helpful tools exposed on `this.utils` primarily consisting of the exports from [`jest-matcher-utils`](https://github.com/facebook/jest/tree/main/packages/jest-matcher-utils). - -The most useful ones are `matcherHint`, `printExpected` and `printReceived` to format the error messages nicely. For example, take a look at the implementation for the `toBe` matcher: - -```js -const {diff} = require('jest-diff'); -expect.extend({ - toBe(received, expected) { - const options = { - comment: 'Object.is equality', - isNot: this.isNot, - promise: this.promise, - }; - - const pass = Object.is(received, expected); - - const message = pass - ? () => - // eslint-disable-next-line prefer-template - this.utils.matcherHint('toBe', undefined, undefined, options) + - '\n\n' + - `Expected: not ${this.utils.printExpected(expected)}\n` + - `Received: ${this.utils.printReceived(received)}` - : () => { - const diffString = diff(expected, received, { - expand: this.expand, - }); - return ( - // eslint-disable-next-line prefer-template - this.utils.matcherHint('toBe', undefined, undefined, options) + - '\n\n' + - (diffString && diffString.includes('- Expect') - ? `Difference:\n\n${diffString}` - : `Expected: ${this.utils.printExpected(expected)}\n` + - `Received: ${this.utils.printReceived(received)}`) - ); - }; - - return {actual: received, message, pass}; - }, -}); -``` - -This will print something like this: - -```bash - expect(received).toBe(expected) - - Expected value to be (using Object.is): - "banana" - Received: - "apple" -``` - -When an assertion fails, the error message should give as much signal as necessary to the user so they can resolve their issue quickly. You should craft a precise failure message to make sure users of your custom assertions have a good developer experience. - -#### Custom snapshot matchers - -To use snapshot testing inside of your custom matcher you can import `jest-snapshot` and use it from within your matcher. - -Here's a snapshot matcher that trims a string to store for a given length, `.toMatchTrimmedSnapshot(length)`: - -```js -const {toMatchSnapshot} = require('jest-snapshot'); - -expect.extend({ - toMatchTrimmedSnapshot(received, length) { - return toMatchSnapshot.call( - this, - received.substring(0, length), - 'toMatchTrimmedSnapshot', - ); - }, -}); - -it('stores only 10 characters', () => { - expect('extra long string oh my gerd').toMatchTrimmedSnapshot(10); -}); - -/* -Stored snapshot will look like: - -exports[`stores only 10 characters: toMatchTrimmedSnapshot 1`] = `"extra long"`; -*/ -``` - -It's also possible to create custom matchers for inline snapshots, the snapshots will be correctly added to the custom matchers. However, inline snapshot will always try to append to the first argument or the second when the first argument is the property matcher, so it's not possible to accept custom arguments in the custom matchers. - -```js -const {toMatchInlineSnapshot} = require('jest-snapshot'); - -expect.extend({ - toMatchTrimmedInlineSnapshot(received, ...rest) { - return toMatchInlineSnapshot.call(this, received.substring(0, 10), ...rest); - }, -}); - -it('stores only 10 characters', () => { - expect('extra long string oh my gerd').toMatchTrimmedInlineSnapshot(); - /* - The snapshot will be added inline like - expect('extra long string oh my gerd').toMatchTrimmedInlineSnapshot( - `"extra long"` - ); - */ -}); -``` - -#### async - -If your custom inline snapshot matcher is async i.e. uses `async`-`await` you might encounter an error like "Multiple inline snapshots for the same call are not supported". Jest needs additional context information to find where the custom inline snapshot matcher was used to update the snapshots properly. - -```js -const {toMatchInlineSnapshot} = require('jest-snapshot'); - -expect.extend({ - async toMatchObservationInlineSnapshot(fn, ...rest) { - // The error (and its stacktrace) must be created before any `await` - this.error = new Error(); - - // The implementation of `observe` doesn't matter. - // It only matters that the custom snapshot matcher is async. - const observation = await observe(async () => { - await fn(); - }); - - return toMatchInlineSnapshot.call(this, recording, ...rest); - }, -}); - -it('observes something', async () => { - await expect(async () => { - return 'async action'; - }).toMatchTrimmedInlineSnapshot(); - /* - The snapshot will be added inline like - await expect(async () => { - return 'async action'; - }).toMatchTrimmedInlineSnapshot(`"async action"`); - */ -}); -``` - -#### Bail out - -Usually `jest` tries to match every snapshot that is expected in a test. - -Sometimes it might not make sense to continue the test if a prior snapshot failed. For example, when you make snapshots of a state-machine after various transitions you can abort the test once one transition produced the wrong state. - -In that case you can implement a custom snapshot matcher that throws on the first mismatch instead of collecting every mismatch. - -```js -const {toMatchInlineSnapshot} = require('jest-snapshot'); - -expect.extend({ - toMatchStateInlineSnapshot(...args) { - this.dontThrow = () => {}; - - return toMatchInlineSnapshot.call(this, ...args); - }, -}); - -let state = 'initial'; - -function transition() { - // Typo in the implementation should cause the test to fail - if (state === 'INITIAL') { - state = 'pending'; - } else if (state === 'pending') { - state = 'done'; - } -} - -it('transitions as expected', () => { - expect(state).toMatchStateInlineSnapshot(`"initial"`); - - transition(); - // Already produces a mismatch. No point in continuing the test. - expect(state).toMatchStateInlineSnapshot(`"loading"`); - - transition(); - expect(state).toMatchStateInlineSnapshot(`"done"`); -}); -``` - -### `expect.anything()` - -`expect.anything()` matches anything but `null` or `undefined`. You can use it inside `toEqual` or `toBeCalledWith` instead of a literal value. For example, if you want to check that a mock function is called with a non-null argument: - -```js -test('map calls its argument with a non-null argument', () => { - const mock = jest.fn(); - [1].map(x => mock(x)); - expect(mock).toBeCalledWith(expect.anything()); -}); -``` - -### `expect.any(constructor)` - -`expect.any(constructor)` matches anything that was created with the given constructor or if it's a primitive that is of the passed type. You can use it inside `toEqual` or `toBeCalledWith` instead of a literal value. For example, if you want to check that a mock function is called with a number: - -```js -class Cat {} -function getCat(fn) { - return fn(new Cat()); -} - -test('randocall calls its callback with a class instance', () => { - const mock = jest.fn(); - getCat(mock); - expect(mock).toBeCalledWith(expect.any(Cat)); -}); - -function randocall(fn) { - return fn(Math.floor(Math.random() * 6 + 1)); -} - -test('randocall calls its callback with a number', () => { - const mock = jest.fn(); - randocall(mock); - expect(mock).toBeCalledWith(expect.any(Number)); -}); -``` - -### `expect.arrayContaining(array)` - -`expect.arrayContaining(array)` matches a received array which contains all of the elements in the expected array. That is, the expected array is a **subset** of the received array. Therefore, it matches a received array which contains elements that are **not** in the expected array. - -You can use it instead of a literal value: - -- in `toEqual` or `toBeCalledWith` -- to match a property in `objectContaining` or `toMatchObject` - -```js -describe('arrayContaining', () => { - const expected = ['Alice', 'Bob']; - it('matches even if received contains additional elements', () => { - expect(['Alice', 'Bob', 'Eve']).toEqual(expect.arrayContaining(expected)); - }); - it('does not match if received does not contain expected elements', () => { - expect(['Bob', 'Eve']).not.toEqual(expect.arrayContaining(expected)); - }); -}); -``` - -```js -describe('Beware of a misunderstanding! A sequence of dice rolls', () => { - const expected = [1, 2, 3, 4, 5, 6]; - it('matches even with an unexpected number 7', () => { - expect([4, 1, 6, 7, 3, 5, 2, 5, 4, 6]).toEqual( - expect.arrayContaining(expected), - ); - }); - it('does not match without an expected number 2', () => { - expect([4, 1, 6, 7, 3, 5, 7, 5, 4, 6]).not.toEqual( - expect.arrayContaining(expected), - ); - }); -}); -``` - -### `expect.assertions(number)` - -`expect.assertions(number)` verifies that a certain number of assertions are called during a test. This is often useful when testing asynchronous code, in order to make sure that assertions in a callback actually got called. - -For example, let's say that we have a function `doAsync` that receives two callbacks `callback1` and `callback2`, it will asynchronously call both of them in an unknown order. We can test this with: - -```js -test('doAsync calls both callbacks', () => { - expect.assertions(2); - function callback1(data) { - expect(data).toBeTruthy(); - } - function callback2(data) { - expect(data).toBeTruthy(); - } - - doAsync(callback1, callback2); -}); -``` - -The `expect.assertions(2)` call ensures that both callbacks actually get called. - -### `expect.hasAssertions()` - -`expect.hasAssertions()` verifies that at least one assertion is called during a test. This is often useful when testing asynchronous code, in order to make sure that assertions in a callback actually got called. - -For example, let's say that we have a few functions that all deal with state. `prepareState` calls a callback with a state object, `validateState` runs on that state object, and `waitOnState` returns a promise that waits until all `prepareState` callbacks complete. We can test this with: - -```js -test('prepareState prepares a valid state', () => { - expect.hasAssertions(); - prepareState(state => { - expect(validateState(state)).toBeTruthy(); - }); - return waitOnState(); -}); -``` - -The `expect.hasAssertions()` call ensures that the `prepareState` callback actually gets called. - -### `expect.not.arrayContaining(array)` - -`expect.not.arrayContaining(array)` matches a received array which does not contain all of the elements in the expected array. That is, the expected array **is not a subset** of the received array. - -It is the inverse of `expect.arrayContaining`. - -```js -describe('not.arrayContaining', () => { - const expected = ['Samantha']; - - it('matches if the actual array does not contain the expected elements', () => { - expect(['Alice', 'Bob', 'Eve']).toEqual( - expect.not.arrayContaining(expected), - ); - }); -}); -``` - -### `expect.not.objectContaining(object)` - -`expect.not.objectContaining(object)` matches any received object that does not recursively match the expected properties. That is, the expected object **is not a subset** of the received object. Therefore, it matches a received object which contains properties that are **not** in the expected object. - -It is the inverse of `expect.objectContaining`. - -```js -describe('not.objectContaining', () => { - const expected = {foo: 'bar'}; - - it('matches if the actual object does not contain expected key: value pairs', () => { - expect({bar: 'baz'}).toEqual(expect.not.objectContaining(expected)); - }); -}); -``` - -### `expect.not.stringContaining(string)` - -`expect.not.stringContaining(string)` matches the received value if it is not a string or if it is a string that does not contain the exact expected string. - -It is the inverse of `expect.stringContaining`. - -```js -describe('not.stringContaining', () => { - const expected = 'Hello world!'; - - it('matches if the received value does not contain the expected substring', () => { - expect('How are you?').toEqual(expect.not.stringContaining(expected)); - }); -}); -``` - -### `expect.not.stringMatching(string | regexp)` - -`expect.not.stringMatching(string | regexp)` matches the received value if it is not a string or if it is a string that does not match the expected string or regular expression. - -It is the inverse of `expect.stringMatching`. - -```js -describe('not.stringMatching', () => { - const expected = /Hello world!/; - - it('matches if the received value does not match the expected regex', () => { - expect('How are you?').toEqual(expect.not.stringMatching(expected)); - }); -}); -``` - -### `expect.objectContaining(object)` - -`expect.objectContaining(object)` matches any received object that recursively matches the expected properties. That is, the expected object is a **subset** of the received object. Therefore, it matches a received object which contains properties that **are present** in the expected object. - -Instead of literal property values in the expected object, you can use matchers, `expect.anything()`, and so on. - -For example, let's say that we expect an `onPress` function to be called with an `Event` object, and all we need to verify is that the event has `event.x` and `event.y` properties. We can do that with: - -```js -test('onPress gets called with the right thing', () => { - const onPress = jest.fn(); - simulatePresses(onPress); - expect(onPress).toBeCalledWith( - expect.objectContaining({ - x: expect.any(Number), - y: expect.any(Number), - }), - ); -}); -``` - -### `expect.stringContaining(string)` - -`expect.stringContaining(string)` matches the received value if it is a string that contains the exact expected string. - -### `expect.stringMatching(string | regexp)` - -`expect.stringMatching(string | regexp)` matches the received value if it is a string that matches the expected string or regular expression. - -You can use it instead of a literal value: - -- in `toEqual` or `toBeCalledWith` -- to match an element in `arrayContaining` -- to match a property in `objectContaining` or `toMatchObject` - -This example also shows how you can nest multiple asymmetric matchers, with `expect.stringMatching` inside the `expect.arrayContaining`. - -```js -describe('stringMatching in arrayContaining', () => { - const expected = [ - expect.stringMatching(/^Alic/), - expect.stringMatching(/^[BR]ob/), - ]; - it('matches even if received contains additional elements', () => { - expect(['Alicia', 'Roberto', 'Evelina']).toEqual( - expect.arrayContaining(expected), - ); - }); - it('does not match if received does not contain expected elements', () => { - expect(['Roberto', 'Evelina']).not.toEqual( - expect.arrayContaining(expected), - ); - }); -}); -``` - -### `expect.addSnapshotSerializer(serializer)` - -You can call `expect.addSnapshotSerializer` to add a module that formats application-specific data structures. - -For an individual test file, an added module precedes any modules from `snapshotSerializers` configuration, which precede the default snapshot serializers for built-in JavaScript types and for React elements. The last module added is the first module tested. - -```js -import serializer from 'my-serializer-module'; -expect.addSnapshotSerializer(serializer); - -// affects expect(value).toMatchSnapshot() assertions in the test file -``` - -If you add a snapshot serializer in individual test files instead of adding it to `snapshotSerializers` configuration: - -- You make the dependency explicit instead of implicit. -- You avoid limits to configuration that might cause you to eject from [create-react-app](https://github.com/facebookincubator/create-react-app). - -See [configuring Jest](Configuration.md#snapshotserializers-arraystring) for more information. - -### `.not` - -If you know how to test something, `.not` lets you test its opposite. For example, this code tests that the best La Croix flavor is not coconut: - -```js -test('the best flavor is not coconut', () => { - expect(bestLaCroixFlavor()).not.toBe('coconut'); -}); -``` - -### `.resolves` - -Use `resolves` to unwrap the value of a fulfilled promise so any other matcher can be chained. If the promise is rejected the assertion fails. - -For example, this code tests that the promise resolves and that the resulting value is `'lemon'`: - -```js -test('resolves to lemon', () => { - // make sure to add a return statement - return expect(Promise.resolve('lemon')).resolves.toBe('lemon'); -}); -``` - -Note that, since you are still testing promises, the test is still asynchronous. Hence, you will need to [tell Jest to wait](TestingAsyncCode.md#promises) by returning the unwrapped assertion. - -Alternatively, you can use `async/await` in combination with `.resolves`: - -```js -test('resolves to lemon', async () => { - await expect(Promise.resolve('lemon')).resolves.toBe('lemon'); - await expect(Promise.resolve('lemon')).resolves.not.toBe('octopus'); -}); -``` - -### `.rejects` - -Use `.rejects` to unwrap the reason of a rejected promise so any other matcher can be chained. If the promise is fulfilled the assertion fails. - -For example, this code tests that the promise rejects with reason `'octopus'`: - -```js -test('rejects to octopus', () => { - // make sure to add a return statement - return expect(Promise.reject(new Error('octopus'))).rejects.toThrow( - 'octopus', - ); -}); -``` - -Note that, since you are still testing promises, the test is still asynchronous. Hence, you will need to [tell Jest to wait](TestingAsyncCode.md#promises) by returning the unwrapped assertion. - -Alternatively, you can use `async/await` in combination with `.rejects`. - -```js -test('rejects to octopus', async () => { - await expect(Promise.reject(new Error('octopus'))).rejects.toThrow('octopus'); -}); -``` - -### `.toBe(value)` - -Use `.toBe` to compare primitive values or to check referential identity of object instances. It calls `Object.is` to compare values, which is even better for testing than `===` strict equality operator. - -For example, this code will validate some properties of the `can` object: - -```js -const can = { - name: 'pamplemousse', - ounces: 12, -}; - -describe('the can', () => { - test('has 12 ounces', () => { - expect(can.ounces).toBe(12); - }); - - test('has a sophisticated name', () => { - expect(can.name).toBe('pamplemousse'); - }); -}); -``` - -Don't use `.toBe` with floating-point numbers. For example, due to rounding, in JavaScript `0.2 + 0.1` is not strictly equal to `0.3`. If you have floating point numbers, try `.toBeCloseTo` instead. - -Although the `.toBe` matcher **checks** referential identity, it **reports** a deep comparison of values if the assertion fails. If differences between properties do not help you to understand why a test fails, especially if the report is large, then you might move the comparison into the `expect` function. For example, to assert whether or not elements are the same instance: - -- rewrite `expect(received).toBe(expected)` as `expect(Object.is(received, expected)).toBe(true)` -- rewrite `expect(received).not.toBe(expected)` as `expect(Object.is(received, expected)).toBe(false)` - -### `.toHaveBeenCalled()` - -Also under the alias: `.toBeCalled()` - -Use `.toHaveBeenCalledWith` to ensure that a mock function was called with specific arguments. The arguments are checked with the same algorithm that `.toEqual` uses. - -For example, let's say you have a `drinkAll(drink, flavour)` function that takes a `drink` function and applies it to all available beverages. You might want to check that `drink` gets called for `'lemon'`, but not for `'octopus'`, because `'octopus'` flavour is really weird and why would anything be octopus-flavoured? You can do that with this test suite: - -```js -function drinkAll(callback, flavour) { - if (flavour !== 'octopus') { - callback(flavour); - } -} - -describe('drinkAll', () => { - test('drinks something lemon-flavoured', () => { - const drink = jest.fn(); - drinkAll(drink, 'lemon'); - expect(drink).toHaveBeenCalled(); - }); - - test('does not drink something octopus-flavoured', () => { - const drink = jest.fn(); - drinkAll(drink, 'octopus'); - expect(drink).not.toHaveBeenCalled(); - }); -}); -``` - -### `.toHaveBeenCalledTimes(number)` - -Also under the alias: `.toBeCalledTimes(number)` - -Use `.toHaveBeenCalledTimes` to ensure that a mock function got called exact number of times. - -For example, let's say you have a `drinkEach(drink, Array)` function that takes a `drink` function and applies it to array of passed beverages. You might want to check that drink function was called exact number of times. You can do that with this test suite: - -```js -test('drinkEach drinks each drink', () => { - const drink = jest.fn(); - drinkEach(drink, ['lemon', 'octopus']); - expect(drink).toHaveBeenCalledTimes(2); -}); -``` - -### `.toHaveBeenCalledWith(arg1, arg2, ...)` - -Also under the alias: `.toBeCalledWith()` - -Use `.toHaveBeenCalledWith` to ensure that a mock function was called with specific arguments. The arguments are checked with the same algorithm that `.toEqual` uses. - -For example, let's say that you can register a beverage with a `register` function, and `applyToAll(f)` should apply the function `f` to all registered beverages. To make sure this works, you could write: - -```js -test('registration applies correctly to orange La Croix', () => { - const beverage = new LaCroix('orange'); - register(beverage); - const f = jest.fn(); - applyToAll(f); - expect(f).toHaveBeenCalledWith(beverage); -}); -``` - -### `.toHaveBeenLastCalledWith(arg1, arg2, ...)` - -Also under the alias: `.lastCalledWith(arg1, arg2, ...)` - -If you have a mock function, you can use `.toHaveBeenLastCalledWith` to test what arguments it was last called with. For example, let's say you have a `applyToAllFlavors(f)` function that applies `f` to a bunch of flavors, and you want to ensure that when you call it, the last flavor it operates on is `'mango'`. You can write: - -```js -test('applying to all flavors does mango last', () => { - const drink = jest.fn(); - applyToAllFlavors(drink); - expect(drink).toHaveBeenLastCalledWith('mango'); -}); -``` - -### `.toHaveBeenNthCalledWith(nthCall, arg1, arg2, ....)` - -Also under the alias: `.nthCalledWith(nthCall, arg1, arg2, ...)` - -If you have a mock function, you can use `.toHaveBeenNthCalledWith` to test what arguments it was nth called with. For example, let's say you have a `drinkEach(drink, Array)` function that applies `f` to a bunch of flavors, and you want to ensure that when you call it, the first flavor it operates on is `'lemon'` and the second one is `'octopus'`. You can write: - -```js -test('drinkEach drinks each drink', () => { - const drink = jest.fn(); - drinkEach(drink, ['lemon', 'octopus']); - expect(drink).toHaveBeenNthCalledWith(1, 'lemon'); - expect(drink).toHaveBeenNthCalledWith(2, 'octopus'); -}); -``` - -Note: the nth argument must be positive integer starting from 1. - -### `.toHaveReturned()` - -Also under the alias: `.toReturn()` - -If you have a mock function, you can use `.toHaveReturned` to test that the mock function successfully returned (i.e., did not throw an error) at least one time. For example, let's say you have a mock `drink` that returns `true`. You can write: - -```js -test('drinks returns', () => { - const drink = jest.fn(() => true); - - drink(); - - expect(drink).toHaveReturned(); -}); -``` - -### `.toHaveReturnedTimes(number)` - -Also under the alias: `.toReturnTimes(number)` - -Use `.toHaveReturnedTimes` to ensure that a mock function returned successfully (i.e., did not throw an error) an exact number of times. Any calls to the mock function that throw an error are not counted toward the number of times the function returned. - -For example, let's say you have a mock `drink` that returns `true`. You can write: - -```js -test('drink returns twice', () => { - const drink = jest.fn(() => true); - - drink(); - drink(); - - expect(drink).toHaveReturnedTimes(2); -}); -``` - -### `.toHaveReturnedWith(value)` - -Also under the alias: `.toReturnWith(value)` - -Use `.toHaveReturnedWith` to ensure that a mock function returned a specific value. - -For example, let's say you have a mock `drink` that returns the name of the beverage that was consumed. You can write: - -```js -test('drink returns La Croix', () => { - const beverage = {name: 'La Croix'}; - const drink = jest.fn(beverage => beverage.name); - - drink(beverage); - - expect(drink).toHaveReturnedWith('La Croix'); -}); -``` - -### `.toHaveLastReturnedWith(value)` - -Also under the alias: `.lastReturnedWith(value)` - -Use `.toHaveLastReturnedWith` to test the specific value that a mock function last returned. If the last call to the mock function threw an error, then this matcher will fail no matter what value you provided as the expected return value. - -For example, let's say you have a mock `drink` that returns the name of the beverage that was consumed. You can write: - -```js -test('drink returns La Croix (Orange) last', () => { - const beverage1 = {name: 'La Croix (Lemon)'}; - const beverage2 = {name: 'La Croix (Orange)'}; - const drink = jest.fn(beverage => beverage.name); - - drink(beverage1); - drink(beverage2); - - expect(drink).toHaveLastReturnedWith('La Croix (Orange)'); -}); -``` - -### `.toHaveNthReturnedWith(nthCall, value)` - -Also under the alias: `.nthReturnedWith(nthCall, value)` - -Use `.toHaveNthReturnedWith` to test the specific value that a mock function returned for the nth call. If the nth call to the mock function threw an error, then this matcher will fail no matter what value you provided as the expected return value. - -For example, let's say you have a mock `drink` that returns the name of the beverage that was consumed. You can write: - -```js -test('drink returns expected nth calls', () => { - const beverage1 = {name: 'La Croix (Lemon)'}; - const beverage2 = {name: 'La Croix (Orange)'}; - const drink = jest.fn(beverage => beverage.name); - - drink(beverage1); - drink(beverage2); - - expect(drink).toHaveNthReturnedWith(1, 'La Croix (Lemon)'); - expect(drink).toHaveNthReturnedWith(2, 'La Croix (Orange)'); -}); -``` - -Note: the nth argument must be positive integer starting from 1. - -### `.toHaveLength(number)` - -Use `.toHaveLength` to check that an object has a `.length` property and it is set to a certain numeric value. - -This is especially useful for checking arrays or strings size. - -```js -expect([1, 2, 3]).toHaveLength(3); -expect('abc').toHaveLength(3); -expect('').not.toHaveLength(5); -``` - -### `.toHaveProperty(keyPath, value?)` - -Use `.toHaveProperty` to check if property at provided reference `keyPath` exists for an object. For checking deeply nested properties in an object you may use [dot notation](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Operators/Property_accessors) or an array containing the keyPath for deep references. - -You can provide an optional `value` argument to compare the received property value (recursively for all properties of object instances, also known as deep equality, like the `toEqual` matcher). - -The following example contains a `houseForSale` object with nested properties. We are using `toHaveProperty` to check for the existence and values of various properties in the object. - -```js -// Object containing house features to be tested -const houseForSale = { - bath: true, - bedrooms: 4, - kitchen: { - amenities: ['oven', 'stove', 'washer'], - area: 20, - wallColor: 'white', - 'nice.oven': true, - }, - 'ceiling.height': 2, -}; - -test('this house has my desired features', () => { - // Example Referencing - expect(houseForSale).toHaveProperty('bath'); - expect(houseForSale).toHaveProperty('bedrooms', 4); - - expect(houseForSale).not.toHaveProperty('pool'); - - // Deep referencing using dot notation - expect(houseForSale).toHaveProperty('kitchen.area', 20); - expect(houseForSale).toHaveProperty('kitchen.amenities', [ - 'oven', - 'stove', - 'washer', - ]); - - expect(houseForSale).not.toHaveProperty('kitchen.open'); - - // Deep referencing using an array containing the keyPath - expect(houseForSale).toHaveProperty(['kitchen', 'area'], 20); - expect(houseForSale).toHaveProperty( - ['kitchen', 'amenities'], - ['oven', 'stove', 'washer'], - ); - expect(houseForSale).toHaveProperty(['kitchen', 'amenities', 0], 'oven'); - expect(houseForSale).toHaveProperty(['kitchen', 'nice.oven']); - expect(houseForSale).not.toHaveProperty(['kitchen', 'open']); - - // Referencing keys with dot in the key itself - expect(houseForSale).toHaveProperty(['ceiling.height'], 'tall'); -}); -``` - -### `.toBeCloseTo(number, numDigits?)` - -Use `toBeCloseTo` to compare floating point numbers for approximate equality. - -The optional `numDigits` argument limits the number of digits to check **after** the decimal point. For the default value `2`, the test criterion is `Math.abs(expected - received) < 0.005` (that is, `10 ** -2 / 2`). - -Intuitive equality comparisons often fail, because arithmetic on decimal (base 10) values often have rounding errors in limited precision binary (base 2) representation. For example, this test fails: - -```js -test('adding works sanely with decimals', () => { - expect(0.2 + 0.1).toBe(0.3); // Fails! -}); -``` - -It fails because in JavaScript, `0.2 + 0.1` is actually `0.30000000000000004`. - -For example, this test passes with a precision of 5 digits: - -```js -test('adding works sanely with decimals', () => { - expect(0.2 + 0.1).toBeCloseTo(0.3, 5); -}); -``` - -Because floating point errors are the problem that `toBeCloseTo` solves, it does not support big integer values. - -### `.toBeDefined()` - -Use `.toBeDefined` to check that a variable is not undefined. For example, if you want to check that a function `fetchNewFlavorIdea()` returns _something_, you can write: - -```js -test('there is a new flavor idea', () => { - expect(fetchNewFlavorIdea()).toBeDefined(); -}); -``` - -You could write `expect(fetchNewFlavorIdea()).not.toBe(undefined)`, but it's better practice to avoid referring to `undefined` directly in your code. - -### `.toBeFalsy()` - -Use `.toBeFalsy` when you don't care what a value is and you want to ensure a value is false in a boolean context. For example, let's say you have some application code that looks like: - -```js -drinkSomeLaCroix(); -if (!getErrors()) { - drinkMoreLaCroix(); -} -``` - -You may not care what `getErrors` returns, specifically - it might return `false`, `null`, or `0`, and your code would still work. So if you want to test there are no errors after drinking some La Croix, you could write: - -```js -test('drinking La Croix does not lead to errors', () => { - drinkSomeLaCroix(); - expect(getErrors()).toBeFalsy(); -}); -``` - -In JavaScript, there are six falsy values: `false`, `0`, `''`, `null`, `undefined`, and `NaN`. Everything else is truthy. - -### `.toBeGreaterThan(number | bigint)` - -Use `toBeGreaterThan` to compare `received > expected` for number or big integer values. For example, test that `ouncesPerCan()` returns a value of more than 10 ounces: - -```js -test('ounces per can is more than 10', () => { - expect(ouncesPerCan()).toBeGreaterThan(10); -}); -``` - -### `.toBeGreaterThanOrEqual(number | bigint)` - -Use `toBeGreaterThanOrEqual` to compare `received >= expected` for number or big integer values. For example, test that `ouncesPerCan()` returns a value of at least 12 ounces: - -```js -test('ounces per can is at least 12', () => { - expect(ouncesPerCan()).toBeGreaterThanOrEqual(12); -}); -``` - -### `.toBeLessThan(number | bigint)` - -Use `toBeLessThan` to compare `received < expected` for number or big integer values. For example, test that `ouncesPerCan()` returns a value of less than 20 ounces: - -```js -test('ounces per can is less than 20', () => { - expect(ouncesPerCan()).toBeLessThan(20); -}); -``` - -### `.toBeLessThanOrEqual(number | bigint)` - -Use `toBeLessThanOrEqual` to compare `received <= expected` for number or big integer values. For example, test that `ouncesPerCan()` returns a value of at most 12 ounces: - -```js -test('ounces per can is at most 12', () => { - expect(ouncesPerCan()).toBeLessThanOrEqual(12); -}); -``` - -### `.toBeInstanceOf(Class)` - -Use `.toBeInstanceOf(Class)` to check that an object is an instance of a class. This matcher uses `instanceof` underneath. - -```js -class A {} - -expect(new A()).toBeInstanceOf(A); -expect(() => {}).toBeInstanceOf(Function); -expect(new A()).toBeInstanceOf(Function); // throws -``` - -### `.toBeNull()` - -`.toBeNull()` is the same as `.toBe(null)` but the error messages are a bit nicer. So use `.toBeNull()` when you want to check that something is null. - -```js -function bloop() { - return null; -} - -test('bloop returns null', () => { - expect(bloop()).toBeNull(); -}); -``` - -### `.toBeTruthy()` - -Use `.toBeTruthy` when you don't care what a value is and you want to ensure a value is true in a boolean context. For example, let's say you have some application code that looks like: - -```js -drinkSomeLaCroix(); -if (thirstInfo()) { - drinkMoreLaCroix(); -} -``` - -You may not care what `thirstInfo` returns, specifically - it might return `true` or a complex object, and your code would still work. So if you want to test that `thirstInfo` will be truthy after drinking some La Croix, you could write: - -```js -test('drinking La Croix leads to having thirst info', () => { - drinkSomeLaCroix(); - expect(thirstInfo()).toBeTruthy(); -}); -``` - -In JavaScript, there are six falsy values: `false`, `0`, `''`, `null`, `undefined`, and `NaN`. Everything else is truthy. - -### `.toBeUndefined()` - -Use `.toBeUndefined` to check that a variable is undefined. For example, if you want to check that a function `bestDrinkForFlavor(flavor)` returns `undefined` for the `'octopus'` flavor, because there is no good octopus-flavored drink: - -```js -test('the best drink for octopus flavor is undefined', () => { - expect(bestDrinkForFlavor('octopus')).toBeUndefined(); -}); -``` - -You could write `expect(bestDrinkForFlavor('octopus')).toBe(undefined)`, but it's better practice to avoid referring to `undefined` directly in your code. - -### `.toBeNaN()` - -Use `.toBeNaN` when checking a value is `NaN`. - -```js -test('passes when value is NaN', () => { - expect(NaN).toBeNaN(); - expect(1).not.toBeNaN(); -}); -``` - -### `.toContain(item)` - -Use `.toContain` when you want to check that an item is in an array. For testing the items in the array, this uses `===`, a strict equality check. `.toContain` can also check whether a string is a substring of another string. - -For example, if `getAllFlavors()` returns an array of flavors and you want to be sure that `lime` is in there, you can write: - -```js -test('the flavor list contains lime', () => { - expect(getAllFlavors()).toContain('lime'); -}); -``` - -This matcher also accepts others iterables such as strings, sets, node lists and HTML collections. - -### `.toContainEqual(item)` - -Use `.toContainEqual` when you want to check that an item with a specific structure and values is contained in an array. For testing the items in the array, this matcher recursively checks the equality of all fields, rather than checking for object identity. - -```js -describe('my beverage', () => { - test('is delicious and not sour', () => { - const myBeverage = {delicious: true, sour: false}; - expect(myBeverages()).toContainEqual(myBeverage); - }); -}); -``` - -### `.toEqual(value)` - -Use `.toEqual` to compare recursively all properties of object instances (also known as "deep" equality). It calls `Object.is` to compare primitive values, which is even better for testing than `===` strict equality operator. - -For example, `.toEqual` and `.toBe` behave differently in this test suite, so all the tests pass: - -```js -const can1 = { - flavor: 'grapefruit', - ounces: 12, -}; -const can2 = { - flavor: 'grapefruit', - ounces: 12, -}; - -describe('the La Croix cans on my desk', () => { - test('have all the same properties', () => { - expect(can1).toEqual(can2); - }); - test('are not the exact same can', () => { - expect(can1).not.toBe(can2); - }); -}); -``` - -> Note: `.toEqual` won't perform a _deep equality_ check for two errors. Only the `message` property of an Error is considered for equality. It is recommended to use the `.toThrow` matcher for testing against errors. - -If differences between properties do not help you to understand why a test fails, especially if the report is large, then you might move the comparison into the `expect` function. For example, use `equals` method of `Buffer` class to assert whether or not buffers contain the same content: - -- rewrite `expect(received).toEqual(expected)` as `expect(received.equals(expected)).toBe(true)` -- rewrite `expect(received).not.toEqual(expected)` as `expect(received.equals(expected)).toBe(false)` - -### `.toMatch(regexp | string)` - -Use `.toMatch` to check that a string matches a regular expression. - -For example, you might not know what exactly `essayOnTheBestFlavor()` returns, but you know it's a really long string, and the substring `grapefruit` should be in there somewhere. You can test this with: - -```js -describe('an essay on the best flavor', () => { - test('mentions grapefruit', () => { - expect(essayOnTheBestFlavor()).toMatch(/grapefruit/); - expect(essayOnTheBestFlavor()).toMatch(new RegExp('grapefruit')); - }); -}); -``` - -This matcher also accepts a string, which it will try to match: - -```js -describe('grapefruits are healthy', () => { - test('grapefruits are a fruit', () => { - expect('grapefruits').toMatch('fruit'); - }); -}); -``` - -### `.toMatchObject(object)` - -Use `.toMatchObject` to check that a JavaScript object matches a subset of the properties of an object. It will match received objects with properties that are **not** in the expected object. - -You can also pass an array of objects, in which case the method will return true only if each object in the received array matches (in the `toMatchObject` sense described above) the corresponding object in the expected array. This is useful if you want to check that two arrays match in their number of elements, as opposed to `arrayContaining`, which allows for extra elements in the received array. - -You can match properties against values or against matchers. - -```js -const houseForSale = { - bath: true, - bedrooms: 4, - kitchen: { - amenities: ['oven', 'stove', 'washer'], - area: 20, - wallColor: 'white', - }, -}; -const desiredHouse = { - bath: true, - kitchen: { - amenities: ['oven', 'stove', 'washer'], - wallColor: expect.stringMatching(/white|yellow/), - }, -}; - -test('the house has my desired features', () => { - expect(houseForSale).toMatchObject(desiredHouse); -}); -``` - -```js -describe('toMatchObject applied to arrays', () => { - test('the number of elements must match exactly', () => { - expect([{foo: 'bar'}, {baz: 1}]).toMatchObject([{foo: 'bar'}, {baz: 1}]); - }); - - test('.toMatchObject is called for each elements, so extra object properties are okay', () => { - expect([{foo: 'bar'}, {baz: 1, extra: 'quux'}]).toMatchObject([ - {foo: 'bar'}, - {baz: 1}, - ]); - }); -}); -``` - -### `.toMatchSnapshot(propertyMatchers?, hint?)` - -This ensures that a value matches the most recent snapshot. Check out [the Snapshot Testing guide](SnapshotTesting.md) for more information. - -You can provide an optional `propertyMatchers` object argument, which has asymmetric matchers as values of a subset of expected properties, **if** the received value will be an **object** instance. It is like `toMatchObject` with flexible criteria for a subset of properties, followed by a snapshot test as exact criteria for the rest of the properties. - -You can provide an optional `hint` string argument that is appended to the test name. Although Jest always appends a number at the end of a snapshot name, short descriptive hints might be more useful than numbers to differentiate **multiple** snapshots in a **single** `it` or `test` block. Jest sorts snapshots by name in the corresponding `.snap` file. - -### `.toMatchInlineSnapshot(propertyMatchers?, inlineSnapshot)` - -Ensures that a value matches the most recent snapshot. - -You can provide an optional `propertyMatchers` object argument, which has asymmetric matchers as values of a subset of expected properties, **if** the received value will be an **object** instance. It is like `toMatchObject` with flexible criteria for a subset of properties, followed by a snapshot test as exact criteria for the rest of the properties. - -Jest adds the `inlineSnapshot` string argument to the matcher in the test file (instead of an external `.snap` file) the first time that the test runs. - -Check out the section on [Inline Snapshots](SnapshotTesting.md#inline-snapshots) for more info. - -### `.toStrictEqual(value)` - -Use `.toStrictEqual` to test that objects have the same types as well as structure. - -Differences from `.toEqual`: - -- Keys with `undefined` properties are checked. e.g. `{a: undefined, b: 2}` does not match `{b: 2}` when using `.toStrictEqual`. -- Array sparseness is checked. e.g. `[, 1]` does not match `[undefined, 1]` when using `.toStrictEqual`. -- Object types are checked to be equal. e.g. A class instance with fields `a` and `b` will not equal a literal object with fields `a` and `b`. - -```js -class LaCroix { - constructor(flavor) { - this.flavor = flavor; - } -} - -describe('the La Croix cans on my desk', () => { - test('are not semantically the same', () => { - expect(new LaCroix('lemon')).toEqual({flavor: 'lemon'}); - expect(new LaCroix('lemon')).not.toStrictEqual({flavor: 'lemon'}); - }); -}); -``` - -### `.toThrow(error?)` - -Also under the alias: `.toThrowError(error?)` - -Use `.toThrow` to test that a function throws when it is called. For example, if we want to test that `drinkFlavor('octopus')` throws, because octopus flavor is too disgusting to drink, we could write: - -```js -test('throws on octopus', () => { - expect(() => { - drinkFlavor('octopus'); - }).toThrow(); -}); -``` - -> Note: You must wrap the code in a function, otherwise the error will not be caught and the assertion will fail. - -You can provide an optional argument to test that a specific error is thrown: - -- regular expression: error message **matches** the pattern -- string: error message **includes** the substring -- error object: error message is **equal to** the message property of the object -- error class: error object is **instance of** class - -For example, let's say that `drinkFlavor` is coded like this: - -```js -function drinkFlavor(flavor) { - if (flavor == 'octopus') { - throw new DisgustingFlavorError('yuck, octopus flavor'); - } - // Do some other stuff -} -``` - -We could test this error gets thrown in several ways: - -```js -test('throws on octopus', () => { - function drinkOctopus() { - drinkFlavor('octopus'); - } - - // Test that the error message says "yuck" somewhere: these are equivalent - expect(drinkOctopus).toThrowError(/yuck/); - expect(drinkOctopus).toThrowError('yuck'); - - // Test the exact error message - expect(drinkOctopus).toThrowError(/^yuck, octopus flavor$/); - expect(drinkOctopus).toThrowError(new Error('yuck, octopus flavor')); - - // Test that we get a DisgustingFlavorError - expect(drinkOctopus).toThrowError(DisgustingFlavorError); -}); -``` - -### `.toThrowErrorMatchingSnapshot(hint?)` - -Use `.toThrowErrorMatchingSnapshot` to test that a function throws an error matching the most recent snapshot when it is called. - -You can provide an optional `hint` string argument that is appended to the test name. Although Jest always appends a number at the end of a snapshot name, short descriptive hints might be more useful than numbers to differentiate **multiple** snapshots in a **single** `it` or `test` block. Jest sorts snapshots by name in the corresponding `.snap` file. - -For example, let's say you have a `drinkFlavor` function that throws whenever the flavor is `'octopus'`, and is coded like this: - -```js -function drinkFlavor(flavor) { - if (flavor == 'octopus') { - throw new DisgustingFlavorError('yuck, octopus flavor'); - } - // Do some other stuff -} -``` - -The test for this function will look this way: - -```js -test('throws on octopus', () => { - function drinkOctopus() { - drinkFlavor('octopus'); - } - - expect(drinkOctopus).toThrowErrorMatchingSnapshot(); -}); -``` - -And it will generate the following snapshot: - -```js -exports[`drinking flavors throws on octopus 1`] = `"yuck, octopus flavor"`; -``` - -Check out [React Tree Snapshot Testing](/blog/2016/07/27/jest-14) for more information on snapshot testing. - -### `.toThrowErrorMatchingInlineSnapshot(inlineSnapshot)` - -Use `.toThrowErrorMatchingInlineSnapshot` to test that a function throws an error matching the most recent snapshot when it is called. - -Jest adds the `inlineSnapshot` string argument to the matcher in the test file (instead of an external `.snap` file) the first time that the test runs. - -Check out the section on [Inline Snapshots](SnapshotTesting.md#inline-snapshots) for more info. diff --git a/website/versioned_docs/version-27.1/GettingStarted.md b/website/versioned_docs/version-27.1/GettingStarted.md deleted file mode 100644 index db798b49b5c1..000000000000 --- a/website/versioned_docs/version-27.1/GettingStarted.md +++ /dev/null @@ -1,173 +0,0 @@ ---- -id: getting-started -title: Getting Started ---- - -Install Jest using [`yarn`](https://yarnpkg.com/en/package/jest): - -```bash -yarn add --dev jest -``` - -Or [`npm`](https://www.npmjs.com/package/jest): - -```bash -npm install --save-dev jest -``` - -Note: Jest documentation uses `yarn` commands, but `npm` will also work. You can compare `yarn` and `npm` commands in the [yarn docs, here](https://yarnpkg.com/en/docs/migrating-from-npm#toc-cli-commands-comparison). - -Let's get started by writing a test for a hypothetical function that adds two numbers. First, create a `sum.js` file: - -```javascript -function sum(a, b) { - return a + b; -} -module.exports = sum; -``` - -Then, create a file named `sum.test.js`. This will contain our actual test: - -```javascript -const sum = require('./sum'); - -test('adds 1 + 2 to equal 3', () => { - expect(sum(1, 2)).toBe(3); -}); -``` - -Add the following section to your `package.json`: - -```json -{ - "scripts": { - "test": "jest" - } -} -``` - -Finally, run `yarn test` or `npm run test` and Jest will print this message: - -```bash -PASS ./sum.test.js -✓ adds 1 + 2 to equal 3 (5ms) -``` - -**You just successfully wrote your first test using Jest!** - -This test used `expect` and `toBe` to test that two values were exactly identical. To learn about the other things that Jest can test, see [Using Matchers](UsingMatchers.md). - -## Running from command line - -You can run Jest directly from the CLI (if it's globally available in your `PATH`, e.g. by `yarn global add jest` or `npm install jest --global`) with a variety of useful options. - -Here's how to run Jest on files matching `my-test`, using `config.json` as a configuration file and display a native OS notification after the run: - -```bash -jest my-test --notify --config=config.json -``` - -If you'd like to learn more about running `jest` through the command line, take a look at the [Jest CLI Options](CLI.md) page. - -## Additional Configuration - -### Generate a basic configuration file - -Based on your project, Jest will ask you a few questions and will create a basic configuration file with a short description for each option: - -```bash -jest --init -``` - -### Using Babel - -To use [Babel](https://babeljs.io/), install required dependencies via `yarn`: - -```bash -yarn add --dev babel-jest @babel/core @babel/preset-env -``` - -Configure Babel to target your current version of Node by creating a `babel.config.js` file in the root of your project: - -```javascript title="babel.config.js" -module.exports = { - presets: [['@babel/preset-env', {targets: {node: 'current'}}]], -}; -``` - -_The ideal configuration for Babel will depend on your project._ See [Babel's docs](https://babeljs.io/docs/en/) for more details. - -
Making your Babel config jest-aware - -Jest will set `process.env.NODE_ENV` to `'test'` if it's not set to something else. You can use that in your configuration to conditionally setup only the compilation needed for Jest, e.g. - -```javascript title="babel.config.js" -module.exports = api => { - const isTest = api.env('test'); - // You can use isTest to determine what presets and plugins to use. - - return { - // ... - }; -}; -``` - -> Note: `babel-jest` is automatically installed when installing Jest and will automatically transform files if a babel configuration exists in your project. To avoid this behavior, you can explicitly reset the `transform` configuration option: - -```javascript title="jest.config.js" -module.exports = { - transform: {}, -}; -``` - -
- -### Using webpack - -Jest can be used in projects that use [webpack](https://webpack.js.org/) to manage assets, styles, and compilation. Webpack does offer some unique challenges over other tools. Refer to the [webpack guide](Webpack.md) to get started. - -### Using parcel - -Jest can be used in projects that use [parcel-bundler](https://parceljs.org/) to manage assets, styles, and compilation similar to webpack. Parcel requires zero configuration. Refer to the official [docs](https://parceljs.org/docs/) to get started. - -### Using TypeScript - -#### Via `babel` - -Jest supports TypeScript, via Babel. First, make sure you followed the instructions on [using Babel](#using-babel) above. Next, install the `@babel/preset-typescript` via `yarn`: - -```bash -yarn add --dev @babel/preset-typescript -``` - -Then add `@babel/preset-typescript` to the list of presets in your `babel.config.js`. - -```javascript title="babel.config.js" -module.exports = { - presets: [ - ['@babel/preset-env', {targets: {node: 'current'}}], - // highlight-next-line - '@babel/preset-typescript', - ], -}; -``` - -However, there are some [caveats](https://babeljs.io/docs/en/babel-plugin-transform-typescript#caveats) to using TypeScript with Babel. Because TypeScript support in Babel is purely transpilation, Jest will not type-check your tests as they are run. If you want that, you can use [ts-jest](https://github.com/kulshekhar/ts-jest) instead, or just run the TypeScript compiler [tsc](https://www.typescriptlang.org/docs/handbook/compiler-options.html) separately (or as part of your build process). - -#### Via `ts-jest` - -[ts-jest](https://github.com/kulshekhar/ts-jest) is a TypeScript preprocessor with source map support for Jest that lets you use Jest to test projects written in TypeScript. - -```bash -yarn add --dev ts-jest -``` - -#### Type definitions - -You may also want to install the [`@types/jest`](https://www.npmjs.com/package/@types/jest) module for the version of Jest you're using. This will help provide full typing when writing your tests with TypeScript. - -> For `@types/*` modules it's recommended to try to match the version of the associated module. For example, if you are using `26.4.0` of `jest` then using `26.4.x` of `@types/jest` is ideal. In general, try to match the major (`26`) and minor (`4`) version as closely as possible. - -```bash -yarn add --dev @types/jest -``` diff --git a/website/versioned_docs/version-27.1/GlobalAPI.md b/website/versioned_docs/version-27.1/GlobalAPI.md deleted file mode 100644 index 12f9f9a87c56..000000000000 --- a/website/versioned_docs/version-27.1/GlobalAPI.md +++ /dev/null @@ -1,880 +0,0 @@ ---- -id: api -title: Globals ---- - -In your test files, Jest puts each of these methods and objects into the global environment. You don't have to require or import anything to use them. However, if you prefer explicit imports, you can do `import {describe, expect, test} from '@jest/globals'`. - -## Methods - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Reference - -### `afterAll(fn, timeout)` - -Runs a function after all the tests in this file have completed. If the function returns a promise or is a generator, Jest waits for that promise to resolve before continuing. - -Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait before aborting. _Note: The default timeout is 5 seconds._ - -This is often useful if you want to clean up some global setup state that is shared across tests. - -For example: - -```js -const globalDatabase = makeGlobalDatabase(); - -function cleanUpDatabase(db) { - db.cleanUp(); -} - -afterAll(() => { - cleanUpDatabase(globalDatabase); -}); - -test('can find things', () => { - return globalDatabase.find('thing', {}, results => { - expect(results.length).toBeGreaterThan(0); - }); -}); - -test('can insert a thing', () => { - return globalDatabase.insert('thing', makeThing(), response => { - expect(response.success).toBeTruthy(); - }); -}); -``` - -Here the `afterAll` ensures that `cleanUpDatabase` is called after all tests run. - -If `afterAll` is inside a `describe` block, it runs at the end of the describe block. - -If you want to run some cleanup after every test instead of after all tests, use `afterEach` instead. - -### `afterEach(fn, timeout)` - -Runs a function after each one of the tests in this file completes. If the function returns a promise or is a generator, Jest waits for that promise to resolve before continuing. - -Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait before aborting. _Note: The default timeout is 5 seconds._ - -This is often useful if you want to clean up some temporary state that is created by each test. - -For example: - -```js -const globalDatabase = makeGlobalDatabase(); - -function cleanUpDatabase(db) { - db.cleanUp(); -} - -afterEach(() => { - cleanUpDatabase(globalDatabase); -}); - -test('can find things', () => { - return globalDatabase.find('thing', {}, results => { - expect(results.length).toBeGreaterThan(0); - }); -}); - -test('can insert a thing', () => { - return globalDatabase.insert('thing', makeThing(), response => { - expect(response.success).toBeTruthy(); - }); -}); -``` - -Here the `afterEach` ensures that `cleanUpDatabase` is called after each test runs. - -If `afterEach` is inside a `describe` block, it only runs after the tests that are inside this describe block. - -If you want to run some cleanup just once, after all of the tests run, use `afterAll` instead. - -### `beforeAll(fn, timeout)` - -Runs a function before any of the tests in this file run. If the function returns a promise or is a generator, Jest waits for that promise to resolve before running tests. - -Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait before aborting. _Note: The default timeout is 5 seconds._ - -This is often useful if you want to set up some global state that will be used by many tests. - -For example: - -```js -const globalDatabase = makeGlobalDatabase(); - -beforeAll(() => { - // Clears the database and adds some testing data. - // Jest will wait for this promise to resolve before running tests. - return globalDatabase.clear().then(() => { - return globalDatabase.insert({testData: 'foo'}); - }); -}); - -// Since we only set up the database once in this example, it's important -// that our tests don't modify it. -test('can find things', () => { - return globalDatabase.find('thing', {}, results => { - expect(results.length).toBeGreaterThan(0); - }); -}); -``` - -Here the `beforeAll` ensures that the database is set up before tests run. If setup was synchronous, you could do this without `beforeAll`. The key is that Jest will wait for a promise to resolve, so you can have asynchronous setup as well. - -If `beforeAll` is inside a `describe` block, it runs at the beginning of the describe block. - -If you want to run something before every test instead of before any test runs, use `beforeEach` instead. - -### `beforeEach(fn, timeout)` - -Runs a function before each of the tests in this file runs. If the function returns a promise or is a generator, Jest waits for that promise to resolve before running the test. - -Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait before aborting. _Note: The default timeout is 5 seconds._ - -This is often useful if you want to reset some global state that will be used by many tests. - -For example: - -```js -const globalDatabase = makeGlobalDatabase(); - -beforeEach(() => { - // Clears the database and adds some testing data. - // Jest will wait for this promise to resolve before running tests. - return globalDatabase.clear().then(() => { - return globalDatabase.insert({testData: 'foo'}); - }); -}); - -test('can find things', () => { - return globalDatabase.find('thing', {}, results => { - expect(results.length).toBeGreaterThan(0); - }); -}); - -test('can insert a thing', () => { - return globalDatabase.insert('thing', makeThing(), response => { - expect(response.success).toBeTruthy(); - }); -}); -``` - -Here the `beforeEach` ensures that the database is reset for each test. - -If `beforeEach` is inside a `describe` block, it runs for each test in the describe block. - -If you only need to run some setup code once, before any tests run, use `beforeAll` instead. - -### `describe(name, fn)` - -`describe(name, fn)` creates a block that groups together several related tests. For example, if you have a `myBeverage` object that is supposed to be delicious but not sour, you could test it with: - -```js -const myBeverage = { - delicious: true, - sour: false, -}; - -describe('my beverage', () => { - test('is delicious', () => { - expect(myBeverage.delicious).toBeTruthy(); - }); - - test('is not sour', () => { - expect(myBeverage.sour).toBeFalsy(); - }); -}); -``` - -This isn't required - you can write the `test` blocks directly at the top level. But this can be handy if you prefer your tests to be organized into groups. - -You can also nest `describe` blocks if you have a hierarchy of tests: - -```js -const binaryStringToNumber = binString => { - if (!/^[01]+$/.test(binString)) { - throw new CustomError('Not a binary number.'); - } - - return parseInt(binString, 2); -}; - -describe('binaryStringToNumber', () => { - describe('given an invalid binary string', () => { - test('composed of non-numbers throws CustomError', () => { - expect(() => binaryStringToNumber('abc')).toThrowError(CustomError); - }); - - test('with extra whitespace throws CustomError', () => { - expect(() => binaryStringToNumber(' 100')).toThrowError(CustomError); - }); - }); - - describe('given a valid binary string', () => { - test('returns the correct number', () => { - expect(binaryStringToNumber('100')).toBe(4); - }); - }); -}); -``` - -### `describe.each(table)(name, fn, timeout)` - -Use `describe.each` if you keep duplicating the same test suites with different data. `describe.each` allows you to write the test suite once and pass data in. - -`describe.each` is available with two APIs: - -#### 1. `describe.each(table)(name, fn, timeout)` - -- `table`: `Array` of Arrays with the arguments that are passed into the `fn` for each row. - - _Note_ If you pass in a 1D array of primitives, internally it will be mapped to a table i.e. `[1, 2, 3] -> [[1], [2], [3]]` -- `name`: `String` the title of the test suite. - - Generate unique test titles by positionally injecting parameters with [`printf` formatting](https://nodejs.org/api/util.html#util_util_format_format_args): - - `%p` - [pretty-format](https://www.npmjs.com/package/pretty-format). - - `%s`- String. - - `%d`- Number. - - `%i` - Integer. - - `%f` - Floating point value. - - `%j` - JSON. - - `%o` - Object. - - `%#` - Index of the test case. - - `%%` - single percent sign ('%'). This does not consume an argument. - - Or generate unique test titles by injecting properties of test case object with `$variable` - - To inject nested object values use you can supply a keyPath i.e. `$variable.path.to.value` - - You can use `$#` to inject the index of the test case - - You cannot use `$variable` with the `printf` formatting except for `%%` -- `fn`: `Function` the suite of tests to be ran, this is the function that will receive the parameters in each row as function arguments. -- Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait for each row before aborting. _Note: The default timeout is 5 seconds._ - -Example: - -```js -describe.each([ - [1, 1, 2], - [1, 2, 3], - [2, 1, 3], -])('.add(%i, %i)', (a, b, expected) => { - test(`returns ${expected}`, () => { - expect(a + b).toBe(expected); - }); - - test(`returned value not be greater than ${expected}`, () => { - expect(a + b).not.toBeGreaterThan(expected); - }); - - test(`returned value not be less than ${expected}`, () => { - expect(a + b).not.toBeLessThan(expected); - }); -}); -``` - -```js -describe.each([ - {a: 1, b: 1, expected: 2}, - {a: 1, b: 2, expected: 3}, - {a: 2, b: 1, expected: 3}, -])('.add($a, $b)', ({a, b, expected}) => { - test(`returns ${expected}`, () => { - expect(a + b).toBe(expected); - }); - - test(`returned value not be greater than ${expected}`, () => { - expect(a + b).not.toBeGreaterThan(expected); - }); - - test(`returned value not be less than ${expected}`, () => { - expect(a + b).not.toBeLessThan(expected); - }); -}); -``` - -#### 2. `` describe.each`table`(name, fn, timeout) `` - -- `table`: `Tagged Template Literal` - - First row of variable name column headings separated with `|` - - One or more subsequent rows of data supplied as template literal expressions using `${value}` syntax. -- `name`: `String` the title of the test suite, use `$variable` to inject test data into the suite title from the tagged template expressions, and `$#` for the index of the row. - - To inject nested object values use you can supply a keyPath i.e. `$variable.path.to.value` -- `fn`: `Function` the suite of tests to be ran, this is the function that will receive the test data object. -- Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait for each row before aborting. _Note: The default timeout is 5 seconds._ - -Example: - -```js -describe.each` - a | b | expected - ${1} | ${1} | ${2} - ${1} | ${2} | ${3} - ${2} | ${1} | ${3} -`('$a + $b', ({a, b, expected}) => { - test(`returns ${expected}`, () => { - expect(a + b).toBe(expected); - }); - - test(`returned value not be greater than ${expected}`, () => { - expect(a + b).not.toBeGreaterThan(expected); - }); - - test(`returned value not be less than ${expected}`, () => { - expect(a + b).not.toBeLessThan(expected); - }); -}); -``` - -### `describe.only(name, fn)` - -Also under the alias: `fdescribe(name, fn)` - -You can use `describe.only` if you want to run only one describe block: - -```js -describe.only('my beverage', () => { - test('is delicious', () => { - expect(myBeverage.delicious).toBeTruthy(); - }); - - test('is not sour', () => { - expect(myBeverage.sour).toBeFalsy(); - }); -}); - -describe('my other beverage', () => { - // ... will be skipped -}); -``` - -### `describe.only.each(table)(name, fn)` - -Also under the aliases: `fdescribe.each(table)(name, fn)` and `` fdescribe.each`table`(name, fn) `` - -Use `describe.only.each` if you want to only run specific tests suites of data driven tests. - -`describe.only.each` is available with two APIs: - -#### `describe.only.each(table)(name, fn)` - -```js -describe.only.each([ - [1, 1, 2], - [1, 2, 3], - [2, 1, 3], -])('.add(%i, %i)', (a, b, expected) => { - test(`returns ${expected}`, () => { - expect(a + b).toBe(expected); - }); -}); - -test('will not be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -#### `` describe.only.each`table`(name, fn) `` - -```js -describe.only.each` - a | b | expected - ${1} | ${1} | ${2} - ${1} | ${2} | ${3} - ${2} | ${1} | ${3} -`('returns $expected when $a is added $b', ({a, b, expected}) => { - test('passes', () => { - expect(a + b).toBe(expected); - }); -}); - -test('will not be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -### `describe.skip(name, fn)` - -Also under the alias: `xdescribe(name, fn)` - -You can use `describe.skip` if you do not want to run the tests of a particular `describe` block: - -```js -describe('my beverage', () => { - test('is delicious', () => { - expect(myBeverage.delicious).toBeTruthy(); - }); - - test('is not sour', () => { - expect(myBeverage.sour).toBeFalsy(); - }); -}); - -describe.skip('my other beverage', () => { - // ... will be skipped -}); -``` - -Using `describe.skip` is often a cleaner alternative to temporarily commenting out a chunk of tests. Beware that the `describe` block will still run. If you have some setup that also should be skipped, do it in a `beforeAll` or `beforeEach` block. - -### `describe.skip.each(table)(name, fn)` - -Also under the aliases: `xdescribe.each(table)(name, fn)` and `` xdescribe.each`table`(name, fn) `` - -Use `describe.skip.each` if you want to stop running a suite of data driven tests. - -`describe.skip.each` is available with two APIs: - -#### `describe.skip.each(table)(name, fn)` - -```js -describe.skip.each([ - [1, 1, 2], - [1, 2, 3], - [2, 1, 3], -])('.add(%i, %i)', (a, b, expected) => { - test(`returns ${expected}`, () => { - expect(a + b).toBe(expected); // will not be ran - }); -}); - -test('will be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -#### `` describe.skip.each`table`(name, fn) `` - -```js -describe.skip.each` - a | b | expected - ${1} | ${1} | ${2} - ${1} | ${2} | ${3} - ${2} | ${1} | ${3} -`('returns $expected when $a is added $b', ({a, b, expected}) => { - test('will not be ran', () => { - expect(a + b).toBe(expected); // will not be ran - }); -}); - -test('will be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -### `test(name, fn, timeout)` - -Also under the alias: `it(name, fn, timeout)` - -All you need in a test file is the `test` method which runs a test. For example, let's say there's a function `inchesOfRain()` that should be zero. Your whole test could be: - -```js -test('did not rain', () => { - expect(inchesOfRain()).toBe(0); -}); -``` - -The first argument is the test name; the second argument is a function that contains the expectations to test. The third argument (optional) is `timeout` (in milliseconds) for specifying how long to wait before aborting. _Note: The default timeout is 5 seconds._ - -> Note: If a **promise is returned** from `test`, Jest will wait for the promise to resolve before letting the test complete. Jest will also wait if you **provide an argument to the test function**, usually called `done`. This could be handy when you want to test callbacks. See how to test async code [here](TestingAsyncCode.md#callbacks). - -For example, let's say `fetchBeverageList()` returns a promise that is supposed to resolve to a list that has `lemon` in it. You can test this with: - -```js -test('has lemon in it', () => { - return fetchBeverageList().then(list => { - expect(list).toContain('lemon'); - }); -}); -``` - -Even though the call to `test` will return right away, the test doesn't complete until the promise resolves as well. - -### `test.concurrent(name, fn, timeout)` - -Also under the alias: `it.concurrent(name, fn, timeout)` - -Use `test.concurrent` if you want the test to run concurrently. - -> Note: `test.concurrent` is considered experimental - see [here](https://github.com/facebook/jest/labels/Area%3A%20Concurrent) for details on missing features and other issues - -The first argument is the test name; the second argument is an asynchronous function that contains the expectations to test. The third argument (optional) is `timeout` (in milliseconds) for specifying how long to wait before aborting. _Note: The default timeout is 5 seconds._ - -``` -test.concurrent('addition of 2 numbers', async () => { - expect(5 + 3).toBe(8); -}); - -test.concurrent('subtraction 2 numbers', async () => { - expect(5 - 3).toBe(2); -}); -``` - -> Note: Use `maxConcurrency` in configuration to prevents Jest from executing more than the specified amount of tests at the same time - -### `test.concurrent.each(table)(name, fn, timeout)` - -Also under the alias: `it.concurrent.each(table)(name, fn, timeout)` - -Use `test.concurrent.each` if you keep duplicating the same test with different data. `test.each` allows you to write the test once and pass data in, the tests are all run asynchronously. - -`test.concurrent.each` is available with two APIs: - -#### 1. `test.concurrent.each(table)(name, fn, timeout)` - -- `table`: `Array` of Arrays with the arguments that are passed into the test `fn` for each row. - - _Note_ If you pass in a 1D array of primitives, internally it will be mapped to a table i.e. `[1, 2, 3] -> [[1], [2], [3]]` -- `name`: `String` the title of the test block. - - Generate unique test titles by positionally injecting parameters with [`printf` formatting](https://nodejs.org/api/util.html#util_util_format_format_args): - - `%p` - [pretty-format](https://www.npmjs.com/package/pretty-format). - - `%s`- String. - - `%d`- Number. - - `%i` - Integer. - - `%f` - Floating point value. - - `%j` - JSON. - - `%o` - Object. - - `%#` - Index of the test case. - - `%%` - single percent sign ('%'). This does not consume an argument. -- `fn`: `Function` the test to be ran, this is the function that will receive the parameters in each row as function arguments, **this will have to be an asynchronous function**. -- Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait for each row before aborting. _Note: The default timeout is 5 seconds._ - -Example: - -```js -test.concurrent.each([ - [1, 1, 2], - [1, 2, 3], - [2, 1, 3], -])('.add(%i, %i)', async (a, b, expected) => { - expect(a + b).toBe(expected); -}); -``` - -#### 2. `` test.concurrent.each`table`(name, fn, timeout) `` - -- `table`: `Tagged Template Literal` - - First row of variable name column headings separated with `|` - - One or more subsequent rows of data supplied as template literal expressions using `${value}` syntax. -- `name`: `String` the title of the test, use `$variable` to inject test data into the test title from the tagged template expressions. - - To inject nested object values use you can supply a keyPath i.e. `$variable.path.to.value` -- `fn`: `Function` the test to be ran, this is the function that will receive the test data object, **this will have to be an asynchronous function**. -- Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait for each row before aborting. _Note: The default timeout is 5 seconds._ - -Example: - -```js -test.concurrent.each` - a | b | expected - ${1} | ${1} | ${2} - ${1} | ${2} | ${3} - ${2} | ${1} | ${3} -`('returns $expected when $a is added $b', async ({a, b, expected}) => { - expect(a + b).toBe(expected); -}); -``` - -### `test.concurrent.only.each(table)(name, fn)` - -Also under the alias: `it.concurrent.only.each(table)(name, fn)` - -Use `test.concurrent.only.each` if you want to only run specific tests with different test data concurrently. - -`test.concurrent.only.each` is available with two APIs: - -#### `test.concurrent.only.each(table)(name, fn)` - -```js -test.concurrent.only.each([ - [1, 1, 2], - [1, 2, 3], - [2, 1, 3], -])('.add(%i, %i)', async (a, b, expected) => { - expect(a + b).toBe(expected); -}); - -test('will not be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -#### `` test.only.each`table`(name, fn) `` - -```js -test.concurrent.only.each` - a | b | expected - ${1} | ${1} | ${2} - ${1} | ${2} | ${3} - ${2} | ${1} | ${3} -`('returns $expected when $a is added $b', async ({a, b, expected}) => { - expect(a + b).toBe(expected); -}); - -test('will not be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -### `test.concurrent.skip.each(table)(name, fn)` - -Also under the alias: `it.concurrent.skip.each(table)(name, fn)` - -Use `test.concurrent.skip.each` if you want to stop running a collection of asynchronous data driven tests. - -`test.concurrent.skip.each` is available with two APIs: - -#### `test.concurrent.skip.each(table)(name, fn)` - -```js -test.concurrent.skip.each([ - [1, 1, 2], - [1, 2, 3], - [2, 1, 3], -])('.add(%i, %i)', async (a, b, expected) => { - expect(a + b).toBe(expected); // will not be ran -}); - -test('will be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -#### `` test.concurrent.skip.each`table`(name, fn) `` - -```js -test.concurrent.skip.each` - a | b | expected - ${1} | ${1} | ${2} - ${1} | ${2} | ${3} - ${2} | ${1} | ${3} -`('returns $expected when $a is added $b', async ({a, b, expected}) => { - expect(a + b).toBe(expected); // will not be ran -}); - -test('will be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -### `test.each(table)(name, fn, timeout)` - -Also under the alias: `it.each(table)(name, fn)` and `` it.each`table`(name, fn) `` - -Use `test.each` if you keep duplicating the same test with different data. `test.each` allows you to write the test once and pass data in. - -`test.each` is available with two APIs: - -#### 1. `test.each(table)(name, fn, timeout)` - -- `table`: `Array` of Arrays with the arguments that are passed into the test `fn` for each row. - - _Note_ If you pass in a 1D array of primitives, internally it will be mapped to a table i.e. `[1, 2, 3] -> [[1], [2], [3]]` -- `name`: `String` the title of the test block. - - Generate unique test titles by positionally injecting parameters with [`printf` formatting](https://nodejs.org/api/util.html#util_util_format_format_args): - - `%p` - [pretty-format](https://www.npmjs.com/package/pretty-format). - - `%s`- String. - - `%d`- Number. - - `%i` - Integer. - - `%f` - Floating point value. - - `%j` - JSON. - - `%o` - Object. - - `%#` - Index of the test case. - - `%%` - single percent sign ('%'). This does not consume an argument. - - Or generate unique test titles by injecting properties of test case object with `$variable` - - To inject nested object values use you can supply a keyPath i.e. `$variable.path.to.value` - - You can use `$#` to inject the index of the test case - - You cannot use `$variable` with the `printf` formatting except for `%%` -- `fn`: `Function` the test to be ran, this is the function that will receive the parameters in each row as function arguments. -- Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait for each row before aborting. _Note: The default timeout is 5 seconds._ - -Example: - -```js -test.each([ - [1, 1, 2], - [1, 2, 3], - [2, 1, 3], -])('.add(%i, %i)', (a, b, expected) => { - expect(a + b).toBe(expected); -}); -``` - -```js -test.each([ - {a: 1, b: 1, expected: 2}, - {a: 1, b: 2, expected: 3}, - {a: 2, b: 1, expected: 3}, -])('.add($a, $b)', ({a, b, expected}) => { - expect(a + b).toBe(expected); -}); -``` - -#### 2. `` test.each`table`(name, fn, timeout) `` - -- `table`: `Tagged Template Literal` - - First row of variable name column headings separated with `|` - - One or more subsequent rows of data supplied as template literal expressions using `${value}` syntax. -- `name`: `String` the title of the test, use `$variable` to inject test data into the test title from the tagged template expressions. - - To inject nested object values use you can supply a keyPath i.e. `$variable.path.to.value` -- `fn`: `Function` the test to be ran, this is the function that will receive the test data object. -- Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait for each row before aborting. _Note: The default timeout is 5 seconds._ - -Example: - -```js -test.each` - a | b | expected - ${1} | ${1} | ${2} - ${1} | ${2} | ${3} - ${2} | ${1} | ${3} -`('returns $expected when $a is added $b', ({a, b, expected}) => { - expect(a + b).toBe(expected); -}); -``` - -### `test.only(name, fn, timeout)` - -Also under the aliases: `it.only(name, fn, timeout)`, and `fit(name, fn, timeout)` - -When you are debugging a large test file, you will often only want to run a subset of tests. You can use `.only` to specify which tests are the only ones you want to run in that test file. - -Optionally, you can provide a `timeout` (in milliseconds) for specifying how long to wait before aborting. _Note: The default timeout is 5 seconds._ - -For example, let's say you had these tests: - -```js -test.only('it is raining', () => { - expect(inchesOfRain()).toBeGreaterThan(0); -}); - -test('it is not snowing', () => { - expect(inchesOfSnow()).toBe(0); -}); -``` - -Only the "it is raining" test will run in that test file, since it is run with `test.only`. - -Usually you wouldn't check code using `test.only` into source control - you would use it for debugging, and remove it once you have fixed the broken tests. - -### `test.only.each(table)(name, fn)` - -Also under the aliases: `it.only.each(table)(name, fn)`, `fit.each(table)(name, fn)`, `` it.only.each`table`(name, fn) `` and `` fit.each`table`(name, fn) `` - -Use `test.only.each` if you want to only run specific tests with different test data. - -`test.only.each` is available with two APIs: - -#### `test.only.each(table)(name, fn)` - -```js -test.only.each([ - [1, 1, 2], - [1, 2, 3], - [2, 1, 3], -])('.add(%i, %i)', (a, b, expected) => { - expect(a + b).toBe(expected); -}); - -test('will not be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -#### `` test.only.each`table`(name, fn) `` - -```js -test.only.each` - a | b | expected - ${1} | ${1} | ${2} - ${1} | ${2} | ${3} - ${2} | ${1} | ${3} -`('returns $expected when $a is added $b', ({a, b, expected}) => { - expect(a + b).toBe(expected); -}); - -test('will not be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -### `test.skip(name, fn)` - -Also under the aliases: `it.skip(name, fn)`, `xit(name, fn)`, and `xtest(name, fn)` - -When you are maintaining a large codebase, you may sometimes find a test that is temporarily broken for some reason. If you want to skip running this test, but you don't want to delete this code, you can use `test.skip` to specify some tests to skip. - -For example, let's say you had these tests: - -```js -test('it is raining', () => { - expect(inchesOfRain()).toBeGreaterThan(0); -}); - -test.skip('it is not snowing', () => { - expect(inchesOfSnow()).toBe(0); -}); -``` - -Only the "it is raining" test will run, since the other test is run with `test.skip`. - -You could comment the test out, but it's often a bit nicer to use `test.skip` because it will maintain indentation and syntax highlighting. - -### `test.skip.each(table)(name, fn)` - -Also under the aliases: `it.skip.each(table)(name, fn)`, `xit.each(table)(name, fn)`, `xtest.each(table)(name, fn)`, `` it.skip.each`table`(name, fn) ``, `` xit.each`table`(name, fn) `` and `` xtest.each`table`(name, fn) `` - -Use `test.skip.each` if you want to stop running a collection of data driven tests. - -`test.skip.each` is available with two APIs: - -#### `test.skip.each(table)(name, fn)` - -```js -test.skip.each([ - [1, 1, 2], - [1, 2, 3], - [2, 1, 3], -])('.add(%i, %i)', (a, b, expected) => { - expect(a + b).toBe(expected); // will not be ran -}); - -test('will be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -#### `` test.skip.each`table`(name, fn) `` - -```js -test.skip.each` - a | b | expected - ${1} | ${1} | ${2} - ${1} | ${2} | ${3} - ${2} | ${1} | ${3} -`('returns $expected when $a is added $b', ({a, b, expected}) => { - expect(a + b).toBe(expected); // will not be ran -}); - -test('will be ran', () => { - expect(1 / 0).toBe(Infinity); -}); -``` - -### `test.todo(name)` - -Also under the alias: `it.todo(name)` - -Use `test.todo` when you are planning on writing tests. These tests will be highlighted in the summary output at the end so you know how many tests you still need todo. - -_Note_: If you supply a test callback function then the `test.todo` will throw an error. If you have already implemented the test and it is broken and you do not want it to run, then use `test.skip` instead. - -#### API - -- `name`: `String` the title of the test plan. - -Example: - -```js -const add = (a, b) => a + b; - -test.todo('add should be associative'); -``` diff --git a/website/versioned_docs/version-27.1/JestCommunity.md b/website/versioned_docs/version-27.1/JestCommunity.md deleted file mode 100644 index af71f2e575ae..000000000000 --- a/website/versioned_docs/version-27.1/JestCommunity.md +++ /dev/null @@ -1,21 +0,0 @@ ---- -title: Jest Community -id: jest-community ---- - -The community around Jest is working hard to make the testing experience even greater. - -[jest-community](https://github.com/jest-community) is a new GitHub organization for high quality Jest additions curated by Jest maintainers and collaborators. It already features some of our favorite projects, to name a few: - -- [vscode-jest](https://github.com/jest-community/vscode-jest) -- [jest-extended](https://github.com/jest-community/jest-extended) -- [eslint-plugin-jest](https://github.com/jest-community/eslint-plugin-jest) -- [awesome-jest](https://github.com/jest-community/awesome-jest) - -Community projects under one organisation are a great way for Jest to experiment with new ideas/techniques and approaches. Encourage contributions from the community and publish contributions independently at a faster pace. - -## Awesome Jest - -The jest-community org maintains an [awesome-jest](https://github.com/jest-community/awesome-jest) list of great projects and resources related to Jest. - -If you have something awesome to share, feel free to reach out to us! We'd love to share your project on the awesome-jest list ([send a PR here](https://github.com/jest-community/awesome-jest/pulls)) or if you would like to transfer your project to the jest-community org reach out to one of the owners of the org. diff --git a/website/versioned_docs/version-27.1/JestObjectAPI.md b/website/versioned_docs/version-27.1/JestObjectAPI.md deleted file mode 100644 index de5d9a92a145..000000000000 --- a/website/versioned_docs/version-27.1/JestObjectAPI.md +++ /dev/null @@ -1,686 +0,0 @@ ---- -id: jest-object -title: The Jest Object ---- - -The `jest` object is automatically in scope within every test file. The methods in the `jest` object help create mocks and let you control Jest's overall behavior. It can also be imported explicitly by via `import {jest} from '@jest/globals'`. - -## Methods - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Mock Modules - -### `jest.disableAutomock()` - -Disables automatic mocking in the module loader. - -> See `automock` section of [configuration](Configuration.md#automock-boolean) for more information - -After this method is called, all `require()`s will return the real versions of each module (rather than a mocked version). - -Jest configuration: - -```json -{ - "automock": true -} -``` - -Example: - -```js title="utils.js" -export default { - authorize: () => { - return 'token'; - }, -}; -``` - -```js title="__tests__/disableAutomocking.js" -import utils from '../utils'; - -jest.disableAutomock(); - -test('original implementation', () => { - // now we have the original implementation, - // even if we set the automocking in a jest configuration - expect(utils.authorize()).toBe('token'); -}); -``` - -This is usually useful when you have a scenario where the number of dependencies you want to mock is far less than the number of dependencies that you don't. For example, if you're writing a test for a module that uses a large number of dependencies that can be reasonably classified as "implementation details" of the module, then you likely do not want to mock them. - -Examples of dependencies that might be considered "implementation details" are things ranging from language built-ins (e.g. Array.prototype methods) to highly common utility methods (e.g. underscore/lo-dash, array utilities, etc) and entire libraries like React.js. - -Returns the `jest` object for chaining. - -_Note: this method was previously called `autoMockOff`. When using `babel-jest`, calls to `disableAutomock` will automatically be hoisted to the top of the code block. Use `autoMockOff` if you want to explicitly avoid this behavior._ - -### `jest.enableAutomock()` - -Enables automatic mocking in the module loader. - -Returns the `jest` object for chaining. - -> See `automock` section of [configuration](Configuration.md#automock-boolean) for more information - -Example: - -```js title="utils.js" -export default { - authorize: () => { - return 'token'; - }, - isAuthorized: secret => secret === 'wizard', -}; -``` - -```js title="__tests__/enableAutomocking.js" -jest.enableAutomock(); - -import utils from '../utils'; - -test('original implementation', () => { - // now we have the mocked implementation, - expect(utils.authorize._isMockFunction).toBeTruthy(); - expect(utils.isAuthorized._isMockFunction).toBeTruthy(); -}); -``` - -_Note: this method was previously called `autoMockOn`. When using `babel-jest`, calls to `enableAutomock` will automatically be hoisted to the top of the code block. Use `autoMockOn` if you want to explicitly avoid this behavior._ - -### `jest.createMockFromModule(moduleName)` - -##### renamed in Jest **26.0.0+** - -Also under the alias: `.genMockFromModule(moduleName)` - -Given the name of a module, use the automatic mocking system to generate a mocked version of the module for you. - -This is useful when you want to create a [manual mock](ManualMocks.md) that extends the automatic mock's behavior. - -Example: - -```js title="utils.js" -export default { - authorize: () => { - return 'token'; - }, - isAuthorized: secret => secret === 'wizard', -}; -``` - -```js title="__tests__/createMockFromModule.test.js" -const utils = jest.createMockFromModule('../utils').default; -utils.isAuthorized = jest.fn(secret => secret === 'not wizard'); - -test('implementation created by jest.createMockFromModule', () => { - expect(utils.authorize.mock).toBeTruthy(); - expect(utils.isAuthorized('not wizard')).toEqual(true); -}); -``` - -This is how `createMockFromModule` will mock the following data types: - -#### `Function` - -Creates a new [mock function](mock-functions). The new function has no formal parameters and when called will return `undefined`. This functionality also applies to `async` functions. - -#### `Class` - -Creates a new class. The interface of the original class is maintained, all of the class member functions and properties will be mocked. - -#### `Object` - -Creates a new deeply cloned object. The object keys are maintained and their values are mocked. - -#### `Array` - -Creates a new empty array, ignoring the original. - -#### `Primitives` - -Creates a new property with the same primitive value as the original property. - -Example: - -```js title="example.js" -module.exports = { - function: function square(a, b) { - return a * b; - }, - asyncFunction: async function asyncSquare(a, b) { - const result = (await a) * b; - return result; - }, - class: new (class Bar { - constructor() { - this.array = [1, 2, 3]; - } - foo() {} - })(), - object: { - baz: 'foo', - bar: { - fiz: 1, - buzz: [1, 2, 3], - }, - }, - array: [1, 2, 3], - number: 123, - string: 'baz', - boolean: true, - symbol: Symbol.for('a.b.c'), -}; -``` - -```js title="__tests__/example.test.js" -const example = jest.createMockFromModule('./example'); - -test('should run example code', () => { - // creates a new mocked function with no formal arguments. - expect(example.function.name).toEqual('square'); - expect(example.function.length).toEqual(0); - - // async functions get the same treatment as standard synchronous functions. - expect(example.asyncFunction.name).toEqual('asyncSquare'); - expect(example.asyncFunction.length).toEqual(0); - - // creates a new class with the same interface, member functions and properties are mocked. - expect(example.class.constructor.name).toEqual('Bar'); - expect(example.class.foo.name).toEqual('foo'); - expect(example.class.array.length).toEqual(0); - - // creates a deeply cloned version of the original object. - expect(example.object).toEqual({ - baz: 'foo', - bar: { - fiz: 1, - buzz: [], - }, - }); - - // creates a new empty array, ignoring the original array. - expect(example.array.length).toEqual(0); - - // creates a new property with the same primitive value as the original property. - expect(example.number).toEqual(123); - expect(example.string).toEqual('baz'); - expect(example.boolean).toEqual(true); - expect(example.symbol).toEqual(Symbol.for('a.b.c')); -}); -``` - -### `jest.mock(moduleName, factory, options)` - -Mocks a module with an auto-mocked version when it is being required. `factory` and `options` are optional. For example: - -```js title="banana.js" -module.exports = () => 'banana'; -``` - -```js title="__tests__/test.js" -jest.mock('../banana'); - -const banana = require('../banana'); // banana will be explicitly mocked. - -banana(); // will return 'undefined' because the function is auto-mocked. -``` - -The second argument can be used to specify an explicit module factory that is being run instead of using Jest's automocking feature: - -```js -jest.mock('../moduleName', () => { - return jest.fn(() => 42); -}); - -// This runs the function specified as second argument to `jest.mock`. -const moduleName = require('../moduleName'); -moduleName(); // Will return '42'; -``` - -When using the `factory` parameter for an ES6 module with a default export, the `__esModule: true` property needs to be specified. This property is normally generated by Babel / TypeScript, but here it needs to be set manually. When importing a default export, it's an instruction to import the property named `default` from the export object: - -```js -import moduleName, {foo} from '../moduleName'; - -jest.mock('../moduleName', () => { - return { - __esModule: true, - default: jest.fn(() => 42), - foo: jest.fn(() => 43), - }; -}); - -moduleName(); // Will return 42 -foo(); // Will return 43 -``` - -The third argument can be used to create virtual mocks – mocks of modules that don't exist anywhere in the system: - -```js -jest.mock( - '../moduleName', - () => { - /* - * Custom implementation of a module that doesn't exist in JS, - * like a generated module or a native module in react-native. - */ - }, - {virtual: true}, -); -``` - -> **Warning:** Importing a module in a setup file (as specified by `setupFilesAfterEnv`) will prevent mocking for the module in question, as well as all the modules that it imports. - -Modules that are mocked with `jest.mock` are mocked only for the file that calls `jest.mock`. Another file that imports the module will get the original implementation even if it runs after the test file that mocks the module. - -Returns the `jest` object for chaining. - -### `jest.unmock(moduleName)` - -Indicates that the module system should never return a mocked version of the specified module from `require()` (e.g. that it should always return the real module). - -The most common use of this API is for specifying the module a given test intends to be testing (and thus doesn't want automatically mocked). - -Returns the `jest` object for chaining. - -### `jest.doMock(moduleName, factory, options)` - -When using `babel-jest`, calls to `mock` will automatically be hoisted to the top of the code block. Use this method if you want to explicitly avoid this behavior. - -One example when this is useful is when you want to mock a module differently within the same file: - -```js -beforeEach(() => { - jest.resetModules(); -}); - -test('moduleName 1', () => { - jest.doMock('../moduleName', () => { - return jest.fn(() => 1); - }); - const moduleName = require('../moduleName'); - expect(moduleName()).toEqual(1); -}); - -test('moduleName 2', () => { - jest.doMock('../moduleName', () => { - return jest.fn(() => 2); - }); - const moduleName = require('../moduleName'); - expect(moduleName()).toEqual(2); -}); -``` - -Using `jest.doMock()` with ES6 imports requires additional steps. Follow these if you don't want to use `require` in your tests: - -- We have to specify the `__esModule: true` property (see the [`jest.mock()`](#jestmockmodulename-factory-options) API for more information). -- Static ES6 module imports are hoisted to the top of the file, so instead we have to import them dynamically using `import()`. -- Finally, we need an environment which supports dynamic importing. Please see [Using Babel](GettingStarted.md#using-babel) for the initial setup. Then add the plugin [babel-plugin-dynamic-import-node](https://www.npmjs.com/package/babel-plugin-dynamic-import-node), or an equivalent, to your Babel config to enable dynamic importing in Node. - -```js -beforeEach(() => { - jest.resetModules(); -}); - -test('moduleName 1', () => { - jest.doMock('../moduleName', () => { - return { - __esModule: true, - default: 'default1', - foo: 'foo1', - }; - }); - return import('../moduleName').then(moduleName => { - expect(moduleName.default).toEqual('default1'); - expect(moduleName.foo).toEqual('foo1'); - }); -}); - -test('moduleName 2', () => { - jest.doMock('../moduleName', () => { - return { - __esModule: true, - default: 'default2', - foo: 'foo2', - }; - }); - return import('../moduleName').then(moduleName => { - expect(moduleName.default).toEqual('default2'); - expect(moduleName.foo).toEqual('foo2'); - }); -}); -``` - -Returns the `jest` object for chaining. - -### `jest.dontMock(moduleName)` - -When using `babel-jest`, calls to `unmock` will automatically be hoisted to the top of the code block. Use this method if you want to explicitly avoid this behavior. - -Returns the `jest` object for chaining. - -### `jest.setMock(moduleName, moduleExports)` - -Explicitly supplies the mock object that the module system should return for the specified module. - -On occasion, there are times where the automatically generated mock the module system would normally provide you isn't adequate enough for your testing needs. Normally under those circumstances you should write a [manual mock](ManualMocks.md) that is more adequate for the module in question. However, on extremely rare occasions, even a manual mock isn't suitable for your purposes and you need to build the mock yourself inside your test. - -In these rare scenarios you can use this API to manually fill the slot in the module system's mock-module registry. - -Returns the `jest` object for chaining. - -_Note It is recommended to use [`jest.mock()`](#jestmockmodulename-factory-options) instead. The `jest.mock` API's second argument is a module factory instead of the expected exported module object._ - -### `jest.requireActual(moduleName)` - -Returns the actual module instead of a mock, bypassing all checks on whether the module should receive a mock implementation or not. - -Example: - -```js -jest.mock('../myModule', () => { - // Require the original module to not be mocked... - const originalModule = jest.requireActual('../myModule'); - - return { - __esModule: true, // Use it when dealing with esModules - ...originalModule, - getRandom: jest.fn().mockReturnValue(10), - }; -}); - -const getRandom = require('../myModule').getRandom; - -getRandom(); // Always returns 10 -``` - -### `jest.requireMock(moduleName)` - -Returns a mock module instead of the actual module, bypassing all checks on whether the module should be required normally or not. - -### `jest.resetModules()` - -Resets the module registry - the cache of all required modules. This is useful to isolate modules where local state might conflict between tests. - -Example: - -```js -const sum1 = require('../sum'); -jest.resetModules(); -const sum2 = require('../sum'); -sum1 === sum2; -// > false (Both sum modules are separate "instances" of the sum module.) -``` - -Example in a test: - -```js -beforeEach(() => { - jest.resetModules(); -}); - -test('works', () => { - const sum = require('../sum'); -}); - -test('works too', () => { - const sum = require('../sum'); - // sum is a different copy of the sum module from the previous test. -}); -``` - -Returns the `jest` object for chaining. - -### `jest.isolateModules(fn)` - -`jest.isolateModules(fn)` goes a step further than `jest.resetModules()` and creates a sandbox registry for the modules that are loaded inside the callback function. This is useful to isolate specific modules for every test so that local module state doesn't conflict between tests. - -```js -let myModule; -jest.isolateModules(() => { - myModule = require('myModule'); -}); - -const otherCopyOfMyModule = require('myModule'); -``` - -## Mock Functions - -### `jest.fn(implementation)` - -Returns a new, unused [mock function](MockFunctionAPI.md). Optionally takes a mock implementation. - -```js -const mockFn = jest.fn(); -mockFn(); -expect(mockFn).toHaveBeenCalled(); - -// With a mock implementation: -const returnsTrue = jest.fn(() => true); -console.log(returnsTrue()); // true; -``` - -### `jest.isMockFunction(fn)` - -Determines if the given function is a mocked function. - -### `jest.spyOn(object, methodName)` - -Creates a mock function similar to `jest.fn` but also tracks calls to `object[methodName]`. Returns a Jest [mock function](MockFunctionAPI.md). - -_Note: By default, `jest.spyOn` also calls the **spied** method. This is different behavior from most other test libraries. If you want to overwrite the original function, you can use `jest.spyOn(object, methodName).mockImplementation(() => customImplementation)` or `object[methodName] = jest.fn(() => customImplementation);`_ - -Example: - -```js -const video = { - play() { - return true; - }, -}; - -module.exports = video; -``` - -Example test: - -```js -const video = require('./video'); - -test('plays video', () => { - const spy = jest.spyOn(video, 'play'); - const isPlaying = video.play(); - - expect(spy).toHaveBeenCalled(); - expect(isPlaying).toBe(true); - - spy.mockRestore(); -}); -``` - -### `jest.spyOn(object, methodName, accessType?)` - -Since Jest 22.1.0+, the `jest.spyOn` method takes an optional third argument of `accessType` that can be either `'get'` or `'set'`, which proves to be useful when you want to spy on a getter or a setter, respectively. - -Example: - -```js -const video = { - // it's a getter! - get play() { - return true; - }, -}; - -module.exports = video; - -const audio = { - _volume: false, - // it's a setter! - set volume(value) { - this._volume = value; - }, - get volume() { - return this._volume; - }, -}; - -module.exports = audio; -``` - -Example test: - -```js -const audio = require('./audio'); -const video = require('./video'); - -test('plays video', () => { - const spy = jest.spyOn(video, 'play', 'get'); // we pass 'get' - const isPlaying = video.play; - - expect(spy).toHaveBeenCalled(); - expect(isPlaying).toBe(true); - - spy.mockRestore(); -}); - -test('plays audio', () => { - const spy = jest.spyOn(audio, 'volume', 'set'); // we pass 'set' - audio.volume = 100; - - expect(spy).toHaveBeenCalled(); - expect(audio.volume).toBe(100); - - spy.mockRestore(); -}); -``` - -### `jest.clearAllMocks()` - -Clears the `mock.calls`, `mock.instances` and `mock.results` properties of all mocks. Equivalent to calling [`.mockClear()`](MockFunctionAPI.md#mockfnmockclear) on every mocked function. - -Returns the `jest` object for chaining. - -### `jest.resetAllMocks()` - -Resets the state of all mocks. Equivalent to calling [`.mockReset()`](MockFunctionAPI.md#mockfnmockreset) on every mocked function. - -Returns the `jest` object for chaining. - -### `jest.restoreAllMocks()` - -Restores all mocks back to their original value. Equivalent to calling [`.mockRestore()`](MockFunctionAPI.md#mockfnmockrestore) on every mocked function. Beware that `jest.restoreAllMocks()` only works when the mock was created with `jest.spyOn`; other mocks will require you to manually restore them. - -## Mock Timers - -### `jest.useFakeTimers(implementation?: 'modern' | 'legacy')` - -Instructs Jest to use fake versions of the standard timer functions (`setTimeout`, `setInterval`, `clearTimeout`, `clearInterval`, `nextTick`, `setImmediate` and `clearImmediate` as well as `Date`). - -If you pass `'legacy'` as an argument, Jest's legacy implementation will be used rather than one based on [`@sinonjs/fake-timers`](https://github.com/sinonjs/fake-timers). - -Returns the `jest` object for chaining. - -### `jest.useRealTimers()` - -Instructs Jest to use the real versions of the standard timer functions. - -Returns the `jest` object for chaining. - -### `jest.runAllTicks()` - -Exhausts the **micro**-task queue (usually interfaced in node via `process.nextTick`). - -When this API is called, all pending micro-tasks that have been queued via `process.nextTick` will be executed. Additionally, if those micro-tasks themselves schedule new micro-tasks, those will be continually exhausted until there are no more micro-tasks remaining in the queue. - -### `jest.runAllTimers()` - -Exhausts both the **macro**-task queue (i.e., all tasks queued by `setTimeout()`, `setInterval()`, and `setImmediate()`) and the **micro**-task queue (usually interfaced in node via `process.nextTick`). - -When this API is called, all pending macro-tasks and micro-tasks will be executed. If those tasks themselves schedule new tasks, those will be continually exhausted until there are no more tasks remaining in the queue. - -This is often useful for synchronously executing setTimeouts during a test in order to synchronously assert about some behavior that would only happen after the `setTimeout()` or `setInterval()` callbacks executed. See the [Timer mocks](TimerMocks.md) doc for more information. - -### `jest.runAllImmediates()` - -Exhausts all tasks queued by `setImmediate()`. - -> Note: This function is not available when using modern fake timers implementation - -### `jest.advanceTimersByTime(msToRun)` - -Executes only the macro task queue (i.e. all tasks queued by `setTimeout()` or `setInterval()` and `setImmediate()`). - -When this API is called, all timers are advanced by `msToRun` milliseconds. All pending "macro-tasks" that have been queued via `setTimeout()` or `setInterval()`, and would be executed within this time frame will be executed. Additionally, if those macro-tasks schedule new macro-tasks that would be executed within the same time frame, those will be executed until there are no more macro-tasks remaining in the queue, that should be run within `msToRun` milliseconds. - -### `jest.runOnlyPendingTimers()` - -Executes only the macro-tasks that are currently pending (i.e., only the tasks that have been queued by `setTimeout()` or `setInterval()` up to this point). If any of the currently pending macro-tasks schedule new macro-tasks, those new tasks will not be executed by this call. - -This is useful for scenarios such as one where the module being tested schedules a `setTimeout()` whose callback schedules another `setTimeout()` recursively (meaning the scheduling never stops). In these scenarios, it's useful to be able to run forward in time by a single step at a time. - -### `jest.advanceTimersToNextTimer(steps)` - -Advances all timers by the needed milliseconds so that only the next timeouts/intervals will run. - -Optionally, you can provide `steps`, so it will run `steps` amount of next timeouts/intervals. - -### `jest.clearAllTimers()` - -Removes any pending timers from the timer system. - -This means, if any timers have been scheduled (but have not yet executed), they will be cleared and will never have the opportunity to execute in the future. - -### `jest.getTimerCount()` - -Returns the number of fake timers still left to run. - -### `jest.setSystemTime(now?: number | Date)` - -Set the current system time used by fake timers. Simulates a user changing the system clock while your program is running. It affects the current time but it does not in itself cause e.g. timers to fire; they will fire exactly as they would have done without the call to `jest.setSystemTime()`. - -> Note: This function is only available when using modern fake timers implementation - -### `jest.getRealSystemTime()` - -When mocking time, `Date.now()` will also be mocked. If you for some reason need access to the real current time, you can invoke this function. - -> Note: This function is only available when using modern fake timers implementation - -## Misc - -### `jest.setTimeout(timeout)` - -Set the default timeout interval for tests and before/after hooks in milliseconds. This only affects the test file from which this function is called. - -_Note: The default timeout interval is 5 seconds if this method is not called._ - -_Note: If you want to set the timeout for all test files, a good place to do this is in `setupFilesAfterEnv`._ - -Example: - -```js -jest.setTimeout(1000); // 1 second -``` - -### `jest.retryTimes()` - -Runs failed tests n-times until they pass or until the max number of retries is exhausted. This only works with the default [jest-circus](https://github.com/facebook/jest/tree/main/packages/jest-circus) runner! This must live at the top-level of a test file or in a describe block. Retries _will not_ work if `jest.retryTimes()` is called in a `beforeEach` or a `test` block. - -Example in a test: - -```js -jest.retryTimes(3); -test('will fail', () => { - expect(true).toBe(false); -}); -``` - -Returns the `jest` object for chaining. diff --git a/website/versioned_docs/version-27.1/JestPlatform.md b/website/versioned_docs/version-27.1/JestPlatform.md deleted file mode 100644 index 7e638e040b63..000000000000 --- a/website/versioned_docs/version-27.1/JestPlatform.md +++ /dev/null @@ -1,170 +0,0 @@ ---- -id: jest-platform -title: Jest Platform ---- - -You can cherry pick specific features of Jest and use them as standalone packages. Here's a list of the available packages: - -## jest-changed-files - -Tool for identifying modified files in a git/hg repository. Exports two functions: - -- `getChangedFilesForRoots` returns a promise that resolves to an object with the changed files and repos. -- `findRepos` returns a promise that resolves to a set of repositories contained in the specified path. - -### Example - -```javascript -const {getChangedFilesForRoots} = require('jest-changed-files'); - -// print the set of modified files since last commit in the current repo -getChangedFilesForRoots(['./'], { - lastCommit: true, -}).then(result => console.log(result.changedFiles)); -``` - -You can read more about `jest-changed-files` in the [readme file](https://github.com/facebook/jest/blob/main/packages/jest-changed-files/README.md). - -## jest-diff - -Tool for visualizing changes in data. Exports a function that compares two values of any type and returns a "pretty-printed" string illustrating the difference between the two arguments. - -### Example - -```javascript -const {diff} = require('jest-diff'); - -const a = {a: {b: {c: 5}}}; -const b = {a: {b: {c: 6}}}; - -const result = diff(a, b); - -// print diff -console.log(result); -``` - -## jest-docblock - -Tool for extracting and parsing the comments at the top of a JavaScript file. Exports various functions to manipulate the data inside the comment block. - -### Example - -```javascript -const {parseWithComments} = require('jest-docblock'); - -const code = ` -/** - * This is a sample - * - * @flow - */ - - console.log('Hello World!'); -`; - -const parsed = parseWithComments(code); - -// prints an object with two attributes: comments and pragmas. -console.log(parsed); -``` - -You can read more about `jest-docblock` in the [readme file](https://github.com/facebook/jest/blob/main/packages/jest-docblock/README.md). - -## jest-get-type - -Module that identifies the primitive type of any JavaScript value. Exports a function that returns a string with the type of the value passed as argument. - -### Example - -```javascript -const {getType} = require('jest-get-type'); - -const array = [1, 2, 3]; -const nullValue = null; -const undefinedValue = undefined; - -// prints 'array' -console.log(getType(array)); -// prints 'null' -console.log(getType(nullValue)); -// prints 'undefined' -console.log(getType(undefinedValue)); -``` - -## jest-validate - -Tool for validating configurations submitted by users. Exports a function that takes two arguments: the user's configuration and an object containing an example configuration and other options. The return value is an object with two attributes: - -- `hasDeprecationWarnings`, a boolean indicating whether the submitted configuration has deprecation warnings, -- `isValid`, a boolean indicating whether the configuration is correct or not. - -### Example - -```javascript -const {validate} = require('jest-validate'); - -const configByUser = { - transform: '/node_modules/my-custom-transform', -}; - -const result = validate(configByUser, { - comment: ' Documentation: http://custom-docs.com', - exampleConfig: {transform: '/node_modules/babel-jest'}, -}); - -console.log(result); -``` - -You can read more about `jest-validate` in the [readme file](https://github.com/facebook/jest/blob/main/packages/jest-validate/README.md). - -## jest-worker - -Module used for parallelization of tasks. Exports a class `JestWorker` that takes the path of Node.js module and lets you call the module's exported methods as if they were class methods, returning a promise that resolves when the specified method finishes its execution in a forked process. - -### Example - -```javascript title="heavy-task.js" -module.exports = { - myHeavyTask: args => { - // long running CPU intensive task. - }, -}; -``` - -```javascript title="main.js" -async function main() { - const worker = new Worker(require.resolve('./heavy-task.js')); - - // run 2 tasks in parallel with different arguments - const results = await Promise.all([ - worker.myHeavyTask({foo: 'bar'}), - worker.myHeavyTask({bar: 'foo'}), - ]); - - console.log(results); -} - -main(); -``` - -You can read more about `jest-worker` in the [readme file](https://github.com/facebook/jest/blob/main/packages/jest-worker/README.md). - -## pretty-format - -Exports a function that converts any JavaScript value into a human-readable string. Supports all built-in JavaScript types out of the box and allows extension for application-specific types via user-defined plugins. - -### Example - -```javascript -const {format: prettyFormat} = require('pretty-format'); - -const val = {object: {}}; -val.circularReference = val; -val[Symbol('foo')] = 'foo'; -val.map = new Map([['prop', 'value']]); -val.array = [-0, Infinity, NaN]; - -console.log(prettyFormat(val)); -``` - -You can read more about `pretty-format` in the [readme file](https://github.com/facebook/jest/blob/main/packages/pretty-format/README.md). diff --git a/website/versioned_docs/version-27.1/ManualMocks.md b/website/versioned_docs/version-27.1/ManualMocks.md deleted file mode 100644 index 178226d727f9..000000000000 --- a/website/versioned_docs/version-27.1/ManualMocks.md +++ /dev/null @@ -1,164 +0,0 @@ ---- -id: manual-mocks -title: Manual Mocks ---- - -Manual mocks are used to stub out functionality with mock data. For example, instead of accessing a remote resource like a website or a database, you might want to create a manual mock that allows you to use fake data. This ensures your tests will be fast and not flaky. - -## Mocking user modules - -Manual mocks are defined by writing a module in a `__mocks__/` subdirectory immediately adjacent to the module. For example, to mock a module called `user` in the `models` directory, create a file called `user.js` and put it in the `models/__mocks__` directory. Note that the `__mocks__` folder is case-sensitive, so naming the directory `__MOCKS__` will break on some systems. - -> When we require that module in our tests (meaning we want to use the manual mock instead of the real implementation), explicitly calling `jest.mock('./moduleName')` is **required**. - -## Mocking Node modules - -If the module you are mocking is a Node module (e.g.: `lodash`), the mock should be placed in the `__mocks__` directory adjacent to `node_modules` (unless you configured [`roots`](Configuration.md#roots-arraystring) to point to a folder other than the project root) and will be **automatically** mocked. There's no need to explicitly call `jest.mock('module_name')`. - -Scoped modules (also known as [scoped packages](https://docs.npmjs.com/cli/v6/using-npm/scope)) can be mocked by creating a file in a directory structure that matches the name of the scoped module. For example, to mock a scoped module called `@scope/project-name`, create a file at `__mocks__/@scope/project-name.js`, creating the `@scope/` directory accordingly. - -> Warning: If we want to mock Node's core modules (e.g.: `fs` or `path`), then explicitly calling e.g. `jest.mock('path')` is **required**, because core Node modules are not mocked by default. - -## Examples - -```bash -. -├── config -├── __mocks__ -│   └── fs.js -├── models -│   ├── __mocks__ -│   │   └── user.js -│   └── user.js -├── node_modules -└── views -``` - -When a manual mock exists for a given module, Jest's module system will use that module when explicitly calling `jest.mock('moduleName')`. However, when `automock` is set to `true`, the manual mock implementation will be used instead of the automatically created mock, even if `jest.mock('moduleName')` is not called. To opt out of this behavior you will need to explicitly call `jest.unmock('moduleName')` in tests that should use the actual module implementation. - -> Note: In order to mock properly, Jest needs `jest.mock('moduleName')` to be in the same scope as the `require/import` statement. - -Here's a contrived example where we have a module that provides a summary of all the files in a given directory. In this case, we use the core (built in) `fs` module. - -```javascript title="FileSummarizer.js" -'use strict'; - -const fs = require('fs'); - -function summarizeFilesInDirectorySync(directory) { - return fs.readdirSync(directory).map(fileName => ({ - directory, - fileName, - })); -} - -exports.summarizeFilesInDirectorySync = summarizeFilesInDirectorySync; -``` - -Since we'd like our tests to avoid actually hitting the disk (that's pretty slow and fragile), we create a manual mock for the `fs` module by extending an automatic mock. Our manual mock will implement custom versions of the `fs` APIs that we can build on for our tests: - -```javascript title="__mocks__/fs.js" -'use strict'; - -const path = require('path'); - -const fs = jest.createMockFromModule('fs'); - -// This is a custom function that our tests can use during setup to specify -// what the files on the "mock" filesystem should look like when any of the -// `fs` APIs are used. -let mockFiles = Object.create(null); -function __setMockFiles(newMockFiles) { - mockFiles = Object.create(null); - for (const file in newMockFiles) { - const dir = path.dirname(file); - - if (!mockFiles[dir]) { - mockFiles[dir] = []; - } - mockFiles[dir].push(path.basename(file)); - } -} - -// A custom version of `readdirSync` that reads from the special mocked out -// file list set via __setMockFiles -function readdirSync(directoryPath) { - return mockFiles[directoryPath] || []; -} - -fs.__setMockFiles = __setMockFiles; -fs.readdirSync = readdirSync; - -module.exports = fs; -``` - -Now we write our test. Note that we need to explicitly tell that we want to mock the `fs` module because it’s a core Node module: - -```javascript title="__tests__/FileSummarizer-test.js" -'use strict'; - -jest.mock('fs'); - -describe('listFilesInDirectorySync', () => { - const MOCK_FILE_INFO = { - '/path/to/file1.js': 'console.log("file1 contents");', - '/path/to/file2.txt': 'file2 contents', - }; - - beforeEach(() => { - // Set up some mocked out file info before each test - require('fs').__setMockFiles(MOCK_FILE_INFO); - }); - - test('includes all files in the directory in the summary', () => { - const FileSummarizer = require('../FileSummarizer'); - const fileSummary = - FileSummarizer.summarizeFilesInDirectorySync('/path/to'); - - expect(fileSummary.length).toBe(2); - }); -}); -``` - -The example mock shown here uses [`jest.createMockFromModule`](JestObjectAPI.md#jestcreatemockfrommodulemodulename) to generate an automatic mock, and overrides its default behavior. This is the recommended approach, but is completely optional. If you do not want to use the automatic mock at all, you can export your own functions from the mock file. One downside to fully manual mocks is that they're manual – meaning you have to manually update them any time the module they are mocking changes. Because of this, it's best to use or extend the automatic mock when it works for your needs. - -To ensure that a manual mock and its real implementation stay in sync, it might be useful to require the real module using [`jest.requireActual(moduleName)`](JestObjectAPI.md#jestrequireactualmodulename) in your manual mock and amending it with mock functions before exporting it. - -The code for this example is available at [examples/manual-mocks](https://github.com/facebook/jest/tree/main/examples/manual-mocks). - -## Using with ES module imports - -If you're using [ES module imports](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/import) then you'll normally be inclined to put your `import` statements at the top of the test file. But often you need to instruct Jest to use a mock before modules use it. For this reason, Jest will automatically hoist `jest.mock` calls to the top of the module (before any imports). To learn more about this and see it in action, see [this repo](https://github.com/kentcdodds/how-jest-mocking-works). - -## Mocking methods which are not implemented in JSDOM - -If some code uses a method which JSDOM (the DOM implementation used by Jest) hasn't implemented yet, testing it is not easily possible. This is e.g. the case with `window.matchMedia()`. Jest returns `TypeError: window.matchMedia is not a function` and doesn't properly execute the test. - -In this case, mocking `matchMedia` in the test file should solve the issue: - -```js -Object.defineProperty(window, 'matchMedia', { - writable: true, - value: jest.fn().mockImplementation(query => ({ - matches: false, - media: query, - onchange: null, - addListener: jest.fn(), // deprecated - removeListener: jest.fn(), // deprecated - addEventListener: jest.fn(), - removeEventListener: jest.fn(), - dispatchEvent: jest.fn(), - })), -}); -``` - -This works if `window.matchMedia()` is used in a function (or method) which is invoked in the test. If `window.matchMedia()` is executed directly in the tested file, Jest reports the same error. In this case, the solution is to move the manual mock into a separate file and include this one in the test **before** the tested file: - -```js -import './matchMedia.mock'; // Must be imported before the tested file -import {myMethod} from './file-to-test'; - -describe('myMethod()', () => { - // Test the method here... -}); -``` diff --git a/website/versioned_docs/version-27.1/MigrationGuide.md b/website/versioned_docs/version-27.1/MigrationGuide.md deleted file mode 100644 index 13d0bed5674d..000000000000 --- a/website/versioned_docs/version-27.1/MigrationGuide.md +++ /dev/null @@ -1,22 +0,0 @@ ---- -id: migration-guide -title: Migrating to Jest ---- - -If you'd like to try out Jest with an existing codebase, there are a number of ways to convert to Jest: - -- If you are using Jasmine, or a Jasmine like API (for example [Mocha](https://mochajs.org)), Jest should be mostly compatible, which makes it less complicated to migrate to. -- If you are using AVA, Expect.js (by Automattic), Jasmine, Mocha, proxyquire, Should.js or Tape you can automatically migrate with Jest Codemods (see below). -- If you like [chai](http://chaijs.com/), you can upgrade to Jest and continue using chai. However, we recommend trying out Jest's assertions and their failure messages. Jest Codemods can migrate from chai (see below). - -## jest-codemods - -If you are using [AVA](https://github.com/avajs/ava), [Chai](https://github.com/chaijs/chai), [Expect.js (by Automattic)](https://github.com/Automattic/expect.js), [Jasmine](https://github.com/jasmine/jasmine), [Mocha](https://github.com/mochajs/mocha), [proxyquire](https://github.com/thlorenz/proxyquire), [Should.js](https://github.com/shouldjs/should.js) or [Tape](https://github.com/substack/tape) you can use the third-party [jest-codemods](https://github.com/skovhus/jest-codemods) to do most of the dirty migration work. It runs a code transformation on your codebase using [jscodeshift](https://github.com/facebook/jscodeshift). - -To transform your existing tests, navigate to the project containing the tests and run: - -```bash -npx jest-codemods -``` - -More information can be found at [https://github.com/skovhus/jest-codemods](https://github.com/skovhus/jest-codemods). diff --git a/website/versioned_docs/version-27.1/MockFunctionAPI.md b/website/versioned_docs/version-27.1/MockFunctionAPI.md deleted file mode 100644 index 5bb3925c81a1..000000000000 --- a/website/versioned_docs/version-27.1/MockFunctionAPI.md +++ /dev/null @@ -1,448 +0,0 @@ ---- -id: mock-function-api -title: Mock Functions ---- - -Mock functions are also known as "spies", because they let you spy on the behavior of a function that is called indirectly by some other code, rather than only testing the output. You can create a mock function with `jest.fn()`. If no implementation is given, the mock function will return `undefined` when invoked. - -## Methods - -import TOCInline from '@theme/TOCInline'; - - - ---- - -## Reference - -### `mockFn.getMockName()` - -Returns the mock name string set by calling `mockFn.mockName(value)`. - -### `mockFn.mock.calls` - -An array containing the call arguments of all calls that have been made to this mock function. Each item in the array is an array of arguments that were passed during the call. - -For example: A mock function `f` that has been called twice, with the arguments `f('arg1', 'arg2')`, and then with the arguments `f('arg3', 'arg4')`, would have a `mock.calls` array that looks like this: - -```js -[ - ['arg1', 'arg2'], - ['arg3', 'arg4'], -]; -``` - -### `mockFn.mock.results` - -An array containing the results of all calls that have been made to this mock function. Each entry in this array is an object containing a `type` property, and a `value` property. `type` will be one of the following: - -- `'return'` - Indicates that the call completed by returning normally. -- `'throw'` - Indicates that the call completed by throwing a value. -- `'incomplete'` - Indicates that the call has not yet completed. This occurs if you test the result from within the mock function itself, or from within a function that was called by the mock. - -The `value` property contains the value that was thrown or returned. `value` is undefined when `type === 'incomplete'`. - -For example: A mock function `f` that has been called three times, returning `'result1'`, throwing an error, and then returning `'result2'`, would have a `mock.results` array that looks like this: - -```js -[ - { - type: 'return', - value: 'result1', - }, - { - type: 'throw', - value: { - /* Error instance */ - }, - }, - { - type: 'return', - value: 'result2', - }, -]; -``` - -### `mockFn.mock.instances` - -An array that contains all the object instances that have been instantiated from this mock function using `new`. - -For example: A mock function that has been instantiated twice would have the following `mock.instances` array: - -```js -const mockFn = jest.fn(); - -const a = new mockFn(); -const b = new mockFn(); - -mockFn.mock.instances[0] === a; // true -mockFn.mock.instances[1] === b; // true -``` - -### `mockFn.mockClear()` - -Clears all information stored in the [`mockFn.mock.calls`](#mockfnmockcalls), [`mockFn.mock.instances`](#mockfnmockinstances) and [`mockFn.mock.results`](#mockfnmockresults) arrays. Often this is useful when you want to clean up a mocks usage data between two assertions. - -Beware that `mockClear` will replace `mockFn.mock`, not just these three properties! You should, therefore, avoid assigning `mockFn.mock` to other variables, temporary or not, to make sure you don't access stale data. - -The [`clearMocks`](configuration#clearmocks-boolean) configuration option is available to clear mocks automatically before each tests. - -### `mockFn.mockReset()` - -Does everything that [`mockFn.mockClear()`](#mockfnmockclear) does, and also removes any mocked return values or implementations. - -This is useful when you want to completely reset a _mock_ back to its initial state. (Note that resetting a _spy_ will result in a function with no return value). - -The [`mockReset`](configuration#resetmocks-boolean) configuration option is available to reset mocks automatically before each test. - -### `mockFn.mockRestore()` - -Does everything that [`mockFn.mockReset()`](#mockfnmockreset) does, and also restores the original (non-mocked) implementation. - -This is useful when you want to mock functions in certain test cases and restore the original implementation in others. - -Beware that `mockFn.mockRestore` only works when the mock was created with `jest.spyOn`. Thus you have to take care of restoration yourself when manually assigning `jest.fn()`. - -The [`restoreMocks`](configuration#restoremocks-boolean) configuration option is available to restore mocks automatically before each test. - -### `mockFn.mockImplementation(fn)` - -Accepts a function that should be used as the implementation of the mock. The mock itself will still record all calls that go into and instances that come from itself – the only difference is that the implementation will also be executed when the mock is called. - -_Note: `jest.fn(implementation)` is a shorthand for `jest.fn().mockImplementation(implementation)`._ - -For example: - -```js -const mockFn = jest.fn().mockImplementation(scalar => 42 + scalar); -// or: jest.fn(scalar => 42 + scalar); - -const a = mockFn(0); -const b = mockFn(1); - -a === 42; // true -b === 43; // true - -mockFn.mock.calls[0][0] === 0; // true -mockFn.mock.calls[1][0] === 1; // true -``` - -`mockImplementation` can also be used to mock class constructors: - -```js title="SomeClass.js" -module.exports = class SomeClass { - m(a, b) {} -}; -``` - -```js title="OtherModule.test.js" -jest.mock('./SomeClass'); // this happens automatically with automocking -const SomeClass = require('./SomeClass'); -const mMock = jest.fn(); -SomeClass.mockImplementation(() => { - return { - m: mMock, - }; -}); - -const some = new SomeClass(); -some.m('a', 'b'); -console.log('Calls to m: ', mMock.mock.calls); -``` - -### `mockFn.mockImplementationOnce(fn)` - -Accepts a function that will be used as an implementation of the mock for one call to the mocked function. Can be chained so that multiple function calls produce different results. - -```js -const myMockFn = jest - .fn() - .mockImplementationOnce(cb => cb(null, true)) - .mockImplementationOnce(cb => cb(null, false)); - -myMockFn((err, val) => console.log(val)); // true - -myMockFn((err, val) => console.log(val)); // false -``` - -When the mocked function runs out of implementations defined with mockImplementationOnce, it will execute the default implementation set with `jest.fn(() => defaultValue)` or `.mockImplementation(() => defaultValue)` if they were called: - -```js -const myMockFn = jest - .fn(() => 'default') - .mockImplementationOnce(() => 'first call') - .mockImplementationOnce(() => 'second call'); - -// 'first call', 'second call', 'default', 'default' -console.log(myMockFn(), myMockFn(), myMockFn(), myMockFn()); -``` - -### `mockFn.mockName(value)` - -Accepts a string to use in test result output in place of "jest.fn()" to indicate which mock function is being referenced. - -For example: - -```js -const mockFn = jest.fn().mockName('mockedFunction'); -// mockFn(); -expect(mockFn).toHaveBeenCalled(); -``` - -Will result in this error: - -``` -expect(mockedFunction).toHaveBeenCalled() - -Expected mock function "mockedFunction" to have been called, but it was not called. -``` - -### `mockFn.mockReturnThis()` - -Syntactic sugar function for: - -```js -jest.fn(function () { - return this; -}); -``` - -### `mockFn.mockReturnValue(value)` - -Accepts a value that will be returned whenever the mock function is called. - -```js -const mock = jest.fn(); -mock.mockReturnValue(42); -mock(); // 42 -mock.mockReturnValue(43); -mock(); // 43 -``` - -### `mockFn.mockReturnValueOnce(value)` - -Accepts a value that will be returned for one call to the mock function. Can be chained so that successive calls to the mock function return different values. When there are no more `mockReturnValueOnce` values to use, calls will return a value specified by `mockReturnValue`. - -```js -const myMockFn = jest - .fn() - .mockReturnValue('default') - .mockReturnValueOnce('first call') - .mockReturnValueOnce('second call'); - -// 'first call', 'second call', 'default', 'default' -console.log(myMockFn(), myMockFn(), myMockFn(), myMockFn()); -``` - -### `mockFn.mockResolvedValue(value)` - -Syntactic sugar function for: - -```js -jest.fn().mockImplementation(() => Promise.resolve(value)); -``` - -Useful to mock async functions in async tests: - -```js -test('async test', async () => { - const asyncMock = jest.fn().mockResolvedValue(43); - - await asyncMock(); // 43 -}); -``` - -### `mockFn.mockResolvedValueOnce(value)` - -Syntactic sugar function for: - -```js -jest.fn().mockImplementationOnce(() => Promise.resolve(value)); -``` - -Useful to resolve different values over multiple async calls: - -```js -test('async test', async () => { - const asyncMock = jest - .fn() - .mockResolvedValue('default') - .mockResolvedValueOnce('first call') - .mockResolvedValueOnce('second call'); - - await asyncMock(); // first call - await asyncMock(); // second call - await asyncMock(); // default - await asyncMock(); // default -}); -``` - -### `mockFn.mockRejectedValue(value)` - -Syntactic sugar function for: - -```js -jest.fn().mockImplementation(() => Promise.reject(value)); -``` - -Useful to create async mock functions that will always reject: - -```js -test('async test', async () => { - const asyncMock = jest.fn().mockRejectedValue(new Error('Async error')); - - await asyncMock(); // throws "Async error" -}); -``` - -### `mockFn.mockRejectedValueOnce(value)` - -Syntactic sugar function for: - -```js -jest.fn().mockImplementationOnce(() => Promise.reject(value)); -``` - -Example usage: - -```js -test('async test', async () => { - const asyncMock = jest - .fn() - .mockResolvedValueOnce('first call') - .mockRejectedValueOnce(new Error('Async error')); - - await asyncMock(); // first call - await asyncMock(); // throws "Async error" -}); -``` - -## TypeScript - -Jest itself is written in [TypeScript](https://www.typescriptlang.org). - -If you are using [Create React App](https://create-react-app.dev) then the [TypeScript template](https://create-react-app.dev/docs/adding-typescript/) has everything you need to start writing tests in TypeScript. - -Otherwise, please see our [Getting Started](GettingStarted.md#using-typescript) guide for to get setup with TypeScript. - -You can see an example of using Jest with TypeScript in our [GitHub repository](https://github.com/facebook/jest/tree/main/examples/typescript). - -### `jest.MockedFunction` - -> `jest.MockedFunction` is available in the `@types/jest` module from version `24.9.0`. - -The following examples will assume you have an understanding of how [Jest mock functions work with JavaScript](MockFunctions.md). - -You can use `jest.MockedFunction` to represent a function that has been replaced by a Jest mock. - -Example using [automatic `jest.mock`](JestObjectAPI.md#jestmockmodulename-factory-options): - -```ts -// Assume `add` is imported and used within `calculate`. -import add from './add'; -import calculate from './calc'; - -jest.mock('./add'); - -// Our mock of `add` is now fully typed -const mockAdd = add as jest.MockedFunction; - -test('calculate calls add', () => { - calculate('Add', 1, 2); - - expect(mockAdd).toBeCalledTimes(1); - expect(mockAdd).toBeCalledWith(1, 2); -}); -``` - -Example using [`jest.fn`](JestObjectAPI.md#jestfnimplementation): - -```ts -// Here `add` is imported for its type -import add from './add'; -import calculate from './calc'; - -test('calculate calls add', () => { - // Create a new mock that can be used in place of `add`. - const mockAdd = jest.fn() as jest.MockedFunction; - - // Note: You can use the `jest.fn` type directly like this if you want: - // const mockAdd = jest.fn, Parameters>(); - // `jest.MockedFunction` is a more friendly shortcut. - - // Now we can easily set up mock implementations. - // All the `.mock*` API can now give you proper types for `add`. - // https://jestjs.io/docs/mock-function-api - - // `.mockImplementation` can now infer that `a` and `b` are `number` - // and that the returned value is a `number`. - mockAdd.mockImplementation((a, b) => { - // Yes, this mock is still adding two numbers but imagine this - // was a complex function we are mocking. - return a + b; - }); - - // `mockAdd` is properly typed and therefore accepted by - // anything requiring `add`. - calculate(mockAdd, 1, 2); - - expect(mockAdd).toBeCalledTimes(1); - expect(mockAdd).toBeCalledWith(1, 2); -}); -``` - -### `jest.MockedClass` - -> `jest.MockedClass` is available in the `@types/jest` module from version `24.9.0`. - -The following examples will assume you have an understanding of how [Jest mock classes work with JavaScript](Es6ClassMocks.md). - -You can use `jest.MockedClass` to represent a class that has been replaced by a Jest mock. - -Converting the [ES6 Class automatic mock example](Es6ClassMocks.md#automatic-mock) would look like this: - -```ts -import SoundPlayer from '../sound-player'; -import SoundPlayerConsumer from '../sound-player-consumer'; - -jest.mock('../sound-player'); // SoundPlayer is now a mock constructor - -const SoundPlayerMock = SoundPlayer as jest.MockedClass; - -beforeEach(() => { - // Clear all instances and calls to constructor and all methods: - SoundPlayerMock.mockClear(); -}); - -it('We can check if the consumer called the class constructor', () => { - const soundPlayerConsumer = new SoundPlayerConsumer(); - expect(SoundPlayerMock).toHaveBeenCalledTimes(1); -}); - -it('We can check if the consumer called a method on the class instance', () => { - // Show that mockClear() is working: - expect(SoundPlayerMock).not.toHaveBeenCalled(); - - const soundPlayerConsumer = new SoundPlayerConsumer(); - // Constructor should have been called again: - expect(SoundPlayerMock).toHaveBeenCalledTimes(1); - - const coolSoundFileName = 'song.mp3'; - soundPlayerConsumer.playSomethingCool(); - - // mock.instances is available with automatic mocks: - const mockSoundPlayerInstance = SoundPlayerMock.mock.instances[0]; - - // However, it will not allow access to `.mock` in TypeScript as it - // is returning `SoundPlayer`. Instead, you can check the calls to a - // method like this fully typed: - expect(SoundPlayerMock.prototype.playSoundFile.mock.calls[0][0]).toEqual( - coolSoundFileName, - ); - // Equivalent to above check: - expect(SoundPlayerMock.prototype.playSoundFile).toHaveBeenCalledWith( - coolSoundFileName, - ); - expect(SoundPlayerMock.prototype.playSoundFile).toHaveBeenCalledTimes(1); -}); -``` diff --git a/website/versioned_docs/version-27.1/MockFunctions.md b/website/versioned_docs/version-27.1/MockFunctions.md deleted file mode 100644 index 2e686a92e837..000000000000 --- a/website/versioned_docs/version-27.1/MockFunctions.md +++ /dev/null @@ -1,315 +0,0 @@ ---- -id: mock-functions -title: Mock Functions ---- - -Mock functions allow you to test the links between code by erasing the actual implementation of a function, capturing calls to the function (and the parameters passed in those calls), capturing instances of constructor functions when instantiated with `new`, and allowing test-time configuration of return values. - -There are two ways to mock functions: Either by creating a mock function to use in test code, or writing a [`manual mock`](ManualMocks.md) to override a module dependency. - -## Using a mock function - -Let's imagine we're testing an implementation of a function `forEach`, which invokes a callback for each item in a supplied array. - -```javascript -function forEach(items, callback) { - for (let index = 0; index < items.length; index++) { - callback(items[index]); - } -} -``` - -To test this function, we can use a mock function, and inspect the mock's state to ensure the callback is invoked as expected. - -```javascript -const mockCallback = jest.fn(x => 42 + x); -forEach([0, 1], mockCallback); - -// The mock function is called twice -expect(mockCallback.mock.calls.length).toBe(2); - -// The first argument of the first call to the function was 0 -expect(mockCallback.mock.calls[0][0]).toBe(0); - -// The first argument of the second call to the function was 1 -expect(mockCallback.mock.calls[1][0]).toBe(1); - -// The return value of the first call to the function was 42 -expect(mockCallback.mock.results[0].value).toBe(42); -``` - -## `.mock` property - -All mock functions have this special `.mock` property, which is where data about how the function has been called and what the function returned is kept. The `.mock` property also tracks the value of `this` for each call, so it is possible to inspect this as well: - -```javascript -const myMock = jest.fn(); - -const a = new myMock(); -const b = {}; -const bound = myMock.bind(b); -bound(); - -console.log(myMock.mock.instances); -// > [
, ] -``` - -These mock members are very useful in tests to assert how these functions get called, instantiated, or what they returned: - -```javascript -// The function was called exactly once -expect(someMockFunction.mock.calls.length).toBe(1); - -// The first arg of the first call to the function was 'first arg' -expect(someMockFunction.mock.calls[0][0]).toBe('first arg'); - -// The second arg of the first call to the function was 'second arg' -expect(someMockFunction.mock.calls[0][1]).toBe('second arg'); - -// The return value of the first call to the function was 'return value' -expect(someMockFunction.mock.results[0].value).toBe('return value'); - -// This function was instantiated exactly twice -expect(someMockFunction.mock.instances.length).toBe(2); - -// The object returned by the first instantiation of this function -// had a `name` property whose value was set to 'test' -expect(someMockFunction.mock.instances[0].name).toEqual('test'); -``` - -## Mock Return Values - -Mock functions can also be used to inject test values into your code during a test: - -```javascript -const myMock = jest.fn(); -console.log(myMock()); -// > undefined - -myMock.mockReturnValueOnce(10).mockReturnValueOnce('x').mockReturnValue(true); - -console.log(myMock(), myMock(), myMock(), myMock()); -// > 10, 'x', true, true -``` - -Mock functions are also very effective in code that uses a functional continuation-passing style. Code written in this style helps avoid the need for complicated stubs that recreate the behavior of the real component they're standing in for, in favor of injecting values directly into the test right before they're used. - -```javascript -const filterTestFn = jest.fn(); - -// Make the mock return `true` for the first call, -// and `false` for the second call -filterTestFn.mockReturnValueOnce(true).mockReturnValueOnce(false); - -const result = [11, 12].filter(num => filterTestFn(num)); - -console.log(result); -// > [11] -console.log(filterTestFn.mock.calls[0][0]); // 11 -console.log(filterTestFn.mock.calls[1][0]); // 12 -``` - -Most real-world examples actually involve getting ahold of a mock function on a dependent component and configuring that, but the technique is the same. In these cases, try to avoid the temptation to implement logic inside of any function that's not directly being tested. - -## Mocking Modules - -Suppose we have a class that fetches users from our API. The class uses [axios](https://github.com/axios/axios) to call the API then returns the `data` attribute which contains all the users: - -```js title="users.js" -import axios from 'axios'; - -class Users { - static all() { - return axios.get('/users.json').then(resp => resp.data); - } -} - -export default Users; -``` - -Now, in order to test this method without actually hitting the API (and thus creating slow and fragile tests), we can use the `jest.mock(...)` function to automatically mock the axios module. - -Once we mock the module we can provide a `mockResolvedValue` for `.get` that returns the data we want our test to assert against. In effect, we are saying that we want `axios.get('/users.json')` to return a fake response. - -```js title="users.test.js" -import axios from 'axios'; -import Users from './users'; - -jest.mock('axios'); - -test('should fetch users', () => { - const users = [{name: 'Bob'}]; - const resp = {data: users}; - axios.get.mockResolvedValue(resp); - - // or you could use the following depending on your use case: - // axios.get.mockImplementation(() => Promise.resolve(resp)) - - return Users.all().then(data => expect(data).toEqual(users)); -}); -``` - -## Mocking Partials - -Subsets of a module can be mocked and the rest of the module can keep their actual implementation: - -```js title="foo-bar-baz.js" -export const foo = 'foo'; -export const bar = () => 'bar'; -export default () => 'baz'; -``` - -```js -//test.js -import defaultExport, {bar, foo} from '../foo-bar-baz'; - -jest.mock('../foo-bar-baz', () => { - const originalModule = jest.requireActual('../foo-bar-baz'); - - //Mock the default export and named export 'foo' - return { - __esModule: true, - ...originalModule, - default: jest.fn(() => 'mocked baz'), - foo: 'mocked foo', - }; -}); - -test('should do a partial mock', () => { - const defaultExportResult = defaultExport(); - expect(defaultExportResult).toBe('mocked baz'); - expect(defaultExport).toHaveBeenCalled(); - - expect(foo).toBe('mocked foo'); - expect(bar()).toBe('bar'); -}); -``` - -## Mock Implementations - -Still, there are cases where it's useful to go beyond the ability to specify return values and full-on replace the implementation of a mock function. This can be done with `jest.fn` or the `mockImplementationOnce` method on mock functions. - -```javascript -const myMockFn = jest.fn(cb => cb(null, true)); - -myMockFn((err, val) => console.log(val)); -// > true -``` - -The `mockImplementation` method is useful when you need to define the default implementation of a mock function that is created from another module: - -```js title="foo.js" -module.exports = function () { - // some implementation; -}; -``` - -```js title="test.js" -jest.mock('../foo'); // this happens automatically with automocking -const foo = require('../foo'); - -// foo is a mock function -foo.mockImplementation(() => 42); -foo(); -// > 42 -``` - -When you need to recreate a complex behavior of a mock function such that multiple function calls produce different results, use the `mockImplementationOnce` method: - -```javascript -const myMockFn = jest - .fn() - .mockImplementationOnce(cb => cb(null, true)) - .mockImplementationOnce(cb => cb(null, false)); - -myMockFn((err, val) => console.log(val)); -// > true - -myMockFn((err, val) => console.log(val)); -// > false -``` - -When the mocked function runs out of implementations defined with `mockImplementationOnce`, it will execute the default implementation set with `jest.fn` (if it is defined): - -```javascript -const myMockFn = jest - .fn(() => 'default') - .mockImplementationOnce(() => 'first call') - .mockImplementationOnce(() => 'second call'); - -console.log(myMockFn(), myMockFn(), myMockFn(), myMockFn()); -// > 'first call', 'second call', 'default', 'default' -``` - -For cases where we have methods that are typically chained (and thus always need to return `this`), we have a sugary API to simplify this in the form of a `.mockReturnThis()` function that also sits on all mocks: - -```javascript -const myObj = { - myMethod: jest.fn().mockReturnThis(), -}; - -// is the same as - -const otherObj = { - myMethod: jest.fn(function () { - return this; - }), -}; -``` - -## Mock Names - -You can optionally provide a name for your mock functions, which will be displayed instead of "jest.fn()" in the test error output. Use this if you want to be able to quickly identify the mock function reporting an error in your test output. - -```javascript -const myMockFn = jest - .fn() - .mockReturnValue('default') - .mockImplementation(scalar => 42 + scalar) - .mockName('add42'); -``` - -## Custom Matchers - -Finally, in order to make it less demanding to assert how mock functions have been called, we've added some custom matcher functions for you: - -```javascript -// The mock function was called at least once -expect(mockFunc).toHaveBeenCalled(); - -// The mock function was called at least once with the specified args -expect(mockFunc).toHaveBeenCalledWith(arg1, arg2); - -// The last call to the mock function was called with the specified args -expect(mockFunc).toHaveBeenLastCalledWith(arg1, arg2); - -// All calls and the name of the mock is written as a snapshot -expect(mockFunc).toMatchSnapshot(); -``` - -These matchers are sugar for common forms of inspecting the `.mock` property. You can always do this manually yourself if that's more to your taste or if you need to do something more specific: - -```javascript -// The mock function was called at least once -expect(mockFunc.mock.calls.length).toBeGreaterThan(0); - -// The mock function was called at least once with the specified args -expect(mockFunc.mock.calls).toContainEqual([arg1, arg2]); - -// The last call to the mock function was called with the specified args -expect(mockFunc.mock.calls[mockFunc.mock.calls.length - 1]).toEqual([ - arg1, - arg2, -]); - -// The first arg of the last call to the mock function was `42` -// (note that there is no sugar helper for this specific of an assertion) -expect(mockFunc.mock.calls[mockFunc.mock.calls.length - 1][0]).toBe(42); - -// A snapshot will check that a mock was invoked the same number of times, -// in the same order, with the same arguments. It will also assert on the name. -expect(mockFunc.mock.calls).toEqual([[arg1, arg2]]); -expect(mockFunc.getMockName()).toBe('a mock name'); -``` - -For a complete list of matchers, check out the [reference docs](ExpectAPI.md). diff --git a/website/versioned_docs/version-27.1/MongoDB.md b/website/versioned_docs/version-27.1/MongoDB.md deleted file mode 100644 index a67d365fd9a9..000000000000 --- a/website/versioned_docs/version-27.1/MongoDB.md +++ /dev/null @@ -1,61 +0,0 @@ ---- -id: mongodb -title: Using with MongoDB ---- - -With the [Global Setup/Teardown](Configuration.md#globalsetup-string) and [Async Test Environment](Configuration.md#testenvironment-string) APIs, Jest can work smoothly with [MongoDB](https://www.mongodb.com/). - -## Use jest-mongodb Preset - -[Jest MongoDB](https://github.com/shelfio/jest-mongodb) provides all required configuration to run your tests using MongoDB. - -1. First install `@shelf/jest-mongodb` - -``` -yarn add @shelf/jest-mongodb --dev -``` - -2. Specify preset in your Jest configuration: - -```json -{ - "preset": "@shelf/jest-mongodb" -} -``` - -3. Write your test - -```js -const {MongoClient} = require('mongodb'); - -describe('insert', () => { - let connection; - let db; - - beforeAll(async () => { - connection = await MongoClient.connect(global.__MONGO_URI__, { - useNewUrlParser: true, - useUnifiedTopology: true, - }); - db = await connection.db(global.__MONGO_DB_NAME__); - }); - - afterAll(async () => { - await connection.close(); - }); - - it('should insert a doc into collection', async () => { - const users = db.collection('users'); - - const mockUser = {_id: 'some-user-id', name: 'John'}; - await users.insertOne(mockUser); - - const insertedUser = await users.findOne({_id: 'some-user-id'}); - expect(insertedUser).toEqual(mockUser); - }); -}); -``` - -There's no need to load any dependencies. - -See [documentation](https://github.com/shelfio/jest-mongodb) for details (configuring MongoDB version, etc). diff --git a/website/versioned_docs/version-27.1/MoreResources.md b/website/versioned_docs/version-27.1/MoreResources.md deleted file mode 100644 index e4509d53281f..000000000000 --- a/website/versioned_docs/version-27.1/MoreResources.md +++ /dev/null @@ -1,24 +0,0 @@ ---- -id: more-resources -title: More Resources ---- - -By now you should have a good idea of how Jest can help you test your applications. If you're interested in learning more, here's some related stuff you might want to check out. - -## Browse the docs - -- Learn about [Snapshot Testing](SnapshotTesting.md), [Mock Functions](MockFunctions.md), and more in our in-depth guides. -- Migrate your existing tests to Jest by following our [migration guide](MigrationGuide.md). -- Learn how to [configure Jest](Configuration.md). -- Look at the full [API Reference](GlobalAPI.md). -- [Troubleshoot](Troubleshooting.md) problems with Jest. - -## Learn by example - -You will find a number of example test cases in the [`examples`](https://github.com/facebook/jest/tree/main/examples) folder on GitHub. You can also learn from the excellent tests used by the [React](https://github.com/facebook/react/tree/main/packages/react/src/__tests__), [Relay](https://github.com/facebook/relay/tree/main/packages/react-relay/__tests__), and [React Native](https://github.com/facebook/react-native/tree/main/Libraries/Animated/src/__tests__) projects. - -## Join the community - -Ask questions and find answers from other Jest users like you. [Reactiflux](https://discord.gg/j6FKKQQrW9) is a Discord chat where a lot of Jest discussion happens. Check out the `#testing` channel. - -Follow the [Jest Twitter account](https://twitter.com/fbjest) and [blog](/blog/) to find out what's happening in the world of Jest. diff --git a/website/versioned_docs/version-27.1/Puppeteer.md b/website/versioned_docs/version-27.1/Puppeteer.md deleted file mode 100644 index 2c96464e21e9..000000000000 --- a/website/versioned_docs/version-27.1/Puppeteer.md +++ /dev/null @@ -1,168 +0,0 @@ ---- -id: puppeteer -title: Using with puppeteer ---- - -With the [Global Setup/Teardown](Configuration.md#globalsetup-string) and [Async Test Environment](Configuration.md#testenvironment-string) APIs, Jest can work smoothly with [puppeteer](https://github.com/GoogleChrome/puppeteer). - -> Generating code coverage for test files using Puppeteer is currently not possible if your test uses `page.$eval`, `page.$$eval` or `page.evaluate` as the passed function is executed outside of Jest's scope. Check out [issue #7962](https://github.com/facebook/jest/issues/7962#issuecomment-495272339) on GitHub for a workaround. - -## Use jest-puppeteer Preset - -[Jest Puppeteer](https://github.com/smooth-code/jest-puppeteer) provides all required configuration to run your tests using Puppeteer. - -1. First, install `jest-puppeteer` - -``` -yarn add --dev jest-puppeteer -``` - -2. Specify preset in your [Jest configuration](Configuration.md): - -```json -{ - "preset": "jest-puppeteer" -} -``` - -3. Write your test - -```js -describe('Google', () => { - beforeAll(async () => { - await page.goto('https://google.com'); - }); - - it('should be titled "Google"', async () => { - await expect(page.title()).resolves.toMatch('Google'); - }); -}); -``` - -There's no need to load any dependencies. Puppeteer's `page` and `browser` classes will automatically be exposed - -See [documentation](https://github.com/smooth-code/jest-puppeteer). - -## Custom example without jest-puppeteer preset - -You can also hook up puppeteer from scratch. The basic idea is to: - -1. launch & file the websocket endpoint of puppeteer with Global Setup -2. connect to puppeteer from each Test Environment -3. close puppeteer with Global Teardown - -Here's an example of the GlobalSetup script - -```js title="setup.js" -const {mkdir, writeFile} = require('fs').promises; -const os = require('os'); -const path = require('path'); -const puppeteer = require('puppeteer'); - -const DIR = path.join(os.tmpdir(), 'jest_puppeteer_global_setup'); - -module.exports = async function () { - const browser = await puppeteer.launch(); - // store the browser instance so we can teardown it later - // this global is only available in the teardown but not in TestEnvironments - global.__BROWSER_GLOBAL__ = browser; - - // use the file system to expose the wsEndpoint for TestEnvironments - await mkdir(DIR, {recursive: true}); - await writeFile(path.join(DIR, 'wsEndpoint'), browser.wsEndpoint()); -}; -``` - -Then we need a custom Test Environment for puppeteer - -```js title="puppeteer_environment.js" -const {readFile} = require('fs').promises; -const os = require('os'); -const path = require('path'); -const puppeteer = require('puppeteer'); -const NodeEnvironment = require('jest-environment-node'); - -const DIR = path.join(os.tmpdir(), 'jest_puppeteer_global_setup'); - -class PuppeteerEnvironment extends NodeEnvironment { - constructor(config) { - super(config); - } - - async setup() { - await super.setup(); - // get the wsEndpoint - const wsEndpoint = await readFile(path.join(DIR, 'wsEndpoint'), 'utf8'); - if (!wsEndpoint) { - throw new Error('wsEndpoint not found'); - } - - // connect to puppeteer - this.global.__BROWSER_GLOBAL__ = await puppeteer.connect({ - browserWSEndpoint: wsEndpoint, - }); - } - - async teardown() { - await super.teardown(); - } - - getVmContext() { - return super.getVmContext(); - } -} - -module.exports = PuppeteerEnvironment; -``` - -Finally, we can close the puppeteer instance and clean-up the file - -```js title="teardown.js" -const fs = require('fs').promises; -const os = require('os'); -const path = require('path'); - -const DIR = path.join(os.tmpdir(), 'jest_puppeteer_global_setup'); -module.exports = async function () { - // close the browser instance - await global.__BROWSER_GLOBAL__.close(); - - // clean-up the wsEndpoint file - await fs.rm(DIR, {recursive: true, force: true}); -}; -``` - -With all the things set up, we can now write our tests like this: - -```js title="test.js" -const timeout = 5000; - -describe( - '/ (Home Page)', - () => { - let page; - beforeAll(async () => { - page = await global.__BROWSER_GLOBAL__.newPage(); - await page.goto('https://google.com'); - }, timeout); - - it('should load without error', async () => { - const text = await page.evaluate(() => document.body.textContent); - expect(text).toContain('google'); - }); - }, - timeout, -); -``` - -Finally, set `jest.config.js` to read from these files. (The `jest-puppeteer` preset does something like this under the hood.) - -```js -module.exports = { - globalSetup: './setup.js', - globalTeardown: './teardown.js', - testEnvironment: './puppeteer_environment.js', -}; -``` - -Here's the code of [full working example](https://github.com/xfumihiro/jest-puppeteer-example). diff --git a/website/versioned_docs/version-27.1/SetupAndTeardown.md b/website/versioned_docs/version-27.1/SetupAndTeardown.md deleted file mode 100644 index 131376d0de6f..000000000000 --- a/website/versioned_docs/version-27.1/SetupAndTeardown.md +++ /dev/null @@ -1,190 +0,0 @@ ---- -id: setup-teardown -title: Setup and Teardown ---- - -Often while writing tests you have some setup work that needs to happen before tests run, and you have some finishing work that needs to happen after tests run. Jest provides helper functions to handle this. - -## Repeating Setup For Many Tests - -If you have some work you need to do repeatedly for many tests, you can use `beforeEach` and `afterEach`. - -For example, let's say that several tests interact with a database of cities. You have a method `initializeCityDatabase()` that must be called before each of these tests, and a method `clearCityDatabase()` that must be called after each of these tests. You can do this with: - -```js -beforeEach(() => { - initializeCityDatabase(); -}); - -afterEach(() => { - clearCityDatabase(); -}); - -test('city database has Vienna', () => { - expect(isCity('Vienna')).toBeTruthy(); -}); - -test('city database has San Juan', () => { - expect(isCity('San Juan')).toBeTruthy(); -}); -``` - -`beforeEach` and `afterEach` can handle asynchronous code in the same ways that [tests can handle asynchronous code](TestingAsyncCode.md) - they can either take a `done` parameter or return a promise. For example, if `initializeCityDatabase()` returned a promise that resolved when the database was initialized, we would want to return that promise: - -```js -beforeEach(() => { - return initializeCityDatabase(); -}); -``` - -## One-Time Setup - -In some cases, you only need to do setup once, at the beginning of a file. This can be especially bothersome when the setup is asynchronous, so you can't do it inline. Jest provides `beforeAll` and `afterAll` to handle this situation. - -For example, if both `initializeCityDatabase` and `clearCityDatabase` returned promises, and the city database could be reused between tests, we could change our test code to: - -```js -beforeAll(() => { - return initializeCityDatabase(); -}); - -afterAll(() => { - return clearCityDatabase(); -}); - -test('city database has Vienna', () => { - expect(isCity('Vienna')).toBeTruthy(); -}); - -test('city database has San Juan', () => { - expect(isCity('San Juan')).toBeTruthy(); -}); -``` - -## Scoping - -By default, the `beforeAll` and `afterAll` blocks apply to every test in a file. You can also group tests together using a `describe` block. When they are inside a `describe` block, the `beforeAll` and `afterAll` blocks only apply to the tests within that `describe` block. - -For example, let's say we had not just a city database, but also a food database. We could do different setup for different tests: - -```js -// Applies to all tests in this file -beforeEach(() => { - return initializeCityDatabase(); -}); - -test('city database has Vienna', () => { - expect(isCity('Vienna')).toBeTruthy(); -}); - -test('city database has San Juan', () => { - expect(isCity('San Juan')).toBeTruthy(); -}); - -describe('matching cities to foods', () => { - // Applies only to tests in this describe block - beforeEach(() => { - return initializeFoodDatabase(); - }); - - test('Vienna <3 veal', () => { - expect(isValidCityFoodPair('Vienna', 'Wiener Schnitzel')).toBe(true); - }); - - test('San Juan <3 plantains', () => { - expect(isValidCityFoodPair('San Juan', 'Mofongo')).toBe(true); - }); -}); -``` - -Note that the top-level `beforeEach` is executed before the `beforeEach` inside the `describe` block. It may help to illustrate the order of execution of all hooks. - -```js -beforeAll(() => console.log('1 - beforeAll')); -afterAll(() => console.log('1 - afterAll')); -beforeEach(() => console.log('1 - beforeEach')); -afterEach(() => console.log('1 - afterEach')); -test('', () => console.log('1 - test')); -describe('Scoped / Nested block', () => { - beforeAll(() => console.log('2 - beforeAll')); - afterAll(() => console.log('2 - afterAll')); - beforeEach(() => console.log('2 - beforeEach')); - afterEach(() => console.log('2 - afterEach')); - test('', () => console.log('2 - test')); -}); - -// 1 - beforeAll -// 1 - beforeEach -// 1 - test -// 1 - afterEach -// 2 - beforeAll -// 1 - beforeEach -// 2 - beforeEach -// 2 - test -// 2 - afterEach -// 1 - afterEach -// 2 - afterAll -// 1 - afterAll -``` - -## Order of execution of describe and test blocks - -Jest executes all describe handlers in a test file _before_ it executes any of the actual tests. This is another reason to do setup and teardown inside `before*` and `after*` handlers rather than inside the describe blocks. Once the describe blocks are complete, by default Jest runs all the tests serially in the order they were encountered in the collection phase, waiting for each to finish and be tidied up before moving on. - -Consider the following illustrative test file and output: - -```js -describe('outer', () => { - console.log('describe outer-a'); - - describe('describe inner 1', () => { - console.log('describe inner 1'); - test('test 1', () => { - console.log('test for describe inner 1'); - expect(true).toEqual(true); - }); - }); - - console.log('describe outer-b'); - - test('test 1', () => { - console.log('test for describe outer'); - expect(true).toEqual(true); - }); - - describe('describe inner 2', () => { - console.log('describe inner 2'); - test('test for describe inner 2', () => { - console.log('test for describe inner 2'); - expect(false).toEqual(false); - }); - }); - - console.log('describe outer-c'); -}); - -// describe outer-a -// describe inner 1 -// describe outer-b -// describe inner 2 -// describe outer-c -// test for describe inner 1 -// test for describe outer -// test for describe inner 2 -``` - -## General Advice - -If a test is failing, one of the first things to check should be whether the test is failing when it's the only test that runs. To run only one test with Jest, temporarily change that `test` command to a `test.only`: - -```js -test.only('this will be the only test that runs', () => { - expect(true).toBe(false); -}); - -test('this test will not run', () => { - expect('A').toBe('A'); -}); -``` - -If you have a test that often fails when it's run as part of a larger suite, but doesn't fail when you run it alone, it's a good bet that something from a different test is interfering with this one. You can often fix this by clearing some shared state with `beforeEach`. If you're not sure whether some shared state is being modified, you can also try a `beforeEach` that logs data. diff --git a/website/versioned_docs/version-27.1/SnapshotTesting.md b/website/versioned_docs/version-27.1/SnapshotTesting.md deleted file mode 100644 index 385b29abae3f..000000000000 --- a/website/versioned_docs/version-27.1/SnapshotTesting.md +++ /dev/null @@ -1,316 +0,0 @@ ---- -id: snapshot-testing -title: Snapshot Testing ---- - -Snapshot tests are a very useful tool whenever you want to make sure your UI does not change unexpectedly. - -A typical snapshot test case renders a UI component, takes a snapshot, then compares it to a reference snapshot file stored alongside the test. The test will fail if the two snapshots do not match: either the change is unexpected, or the reference snapshot needs to be updated to the new version of the UI component. - -## Snapshot Testing with Jest - -A similar approach can be taken when it comes to testing your React components. Instead of rendering the graphical UI, which would require building the entire app, you can use a test renderer to quickly generate a serializable value for your React tree. Consider this [example test](https://github.com/facebook/jest/blob/main/examples/snapshot/__tests__/link.test.js) for a [Link component](https://github.com/facebook/jest/blob/main/examples/snapshot/Link.js): - -```tsx -import React from 'react'; -import renderer from 'react-test-renderer'; -import Link from '../Link'; - -it('renders correctly', () => { - const tree = renderer - .create(Facebook) - .toJSON(); - expect(tree).toMatchSnapshot(); -}); -``` - -The first time this test is run, Jest creates a [snapshot file](https://github.com/facebook/jest/blob/main/examples/snapshot/__tests__/__snapshots__/link.test.js.snap) that looks like this: - -```javascript -exports[`renders correctly 1`] = ` - - Facebook - -`; -``` - -The snapshot artifact should be committed alongside code changes, and reviewed as part of your code review process. Jest uses [pretty-format](https://github.com/facebook/jest/tree/main/packages/pretty-format) to make snapshots human-readable during code review. On subsequent test runs, Jest will compare the rendered output with the previous snapshot. If they match, the test will pass. If they don't match, either the test runner found a bug in your code (in the `` component in this case) that should be fixed, or the implementation has changed and the snapshot needs to be updated. - -> Note: The snapshot is directly scoped to the data you render – in our example the `` component with `page` prop passed to it. This implies that even if any other file has missing props (Say, `App.js`) in the `` component, it will still pass the test as the test doesn't know the usage of `` component and it's scoped only to the `Link.js`. Also, rendering the same component with different props in other snapshot tests will not affect the first one, as the tests don't know about each other. - -More information on how snapshot testing works and why we built it can be found on the [release blog post](/blog/2016/07/27/jest-14). We recommend reading [this blog post](http://benmccormick.org/2016/09/19/testing-with-jest-snapshots-first-impressions/) to get a good sense of when you should use snapshot testing. We also recommend watching this [egghead video](https://egghead.io/lessons/javascript-use-jest-s-snapshot-testing-feature?pl=testing-javascript-with-jest-a36c4074) on Snapshot Testing with Jest. - -### Updating Snapshots - -It's straightforward to spot when a snapshot test fails after a bug has been introduced. When that happens, go ahead and fix the issue and make sure your snapshot tests are passing again. Now, let's talk about the case when a snapshot test is failing due to an intentional implementation change. - -One such situation can arise if we intentionally change the address the Link component in our example is pointing to. - -```tsx -// Updated test case with a Link to a different address -it('renders correctly', () => { - const tree = renderer - .create(Instagram) - .toJSON(); - expect(tree).toMatchSnapshot(); -}); -``` - -In that case, Jest will print this output: - -![](/img/content/failedSnapshotTest.png) - -Since we just updated our component to point to a different address, it's reasonable to expect changes in the snapshot for this component. Our snapshot test case is failing because the snapshot for our updated component no longer matches the snapshot artifact for this test case. - -To resolve this, we will need to update our snapshot artifacts. You can run Jest with a flag that will tell it to re-generate snapshots: - -```bash -jest --updateSnapshot -``` - -Go ahead and accept the changes by running the above command. You may also use the equivalent single-character `-u` flag to re-generate snapshots if you prefer. This will re-generate snapshot artifacts for all failing snapshot tests. If we had any additional failing snapshot tests due to an unintentional bug, we would need to fix the bug before re-generating snapshots to avoid recording snapshots of the buggy behavior. - -If you'd like to limit which snapshot test cases get re-generated, you can pass an additional `--testNamePattern` flag to re-record snapshots only for those tests that match the pattern. - -You can try out this functionality by cloning the [snapshot example](https://github.com/facebook/jest/tree/main/examples/snapshot), modifying the `Link` component, and running Jest. - -### Interactive Snapshot Mode - -Failed snapshots can also be updated interactively in watch mode: - -![](/img/content/interactiveSnapshot.png) - -Once you enter Interactive Snapshot Mode, Jest will step you through the failed snapshots one test at a time and give you the opportunity to review the failed output. - -From here you can choose to update that snapshot or skip to the next: - -![](/img/content/interactiveSnapshotUpdate.gif) - -Once you're finished, Jest will give you a summary before returning back to watch mode: - -![](/img/content/interactiveSnapshotDone.png) - -### Inline Snapshots - -Inline snapshots behave identically to external snapshots (`.snap` files), except the snapshot values are written automatically back into the source code. This means you can get the benefits of automatically generated snapshots without having to switch to an external file to make sure the correct value was written. - -**Example:** - -First, you write a test, calling `.toMatchInlineSnapshot()` with no arguments: - -```tsx -it('renders correctly', () => { - const tree = renderer - .create(Example Site) - .toJSON(); - expect(tree).toMatchInlineSnapshot(); -}); -``` - -The next time you run Jest, `tree` will be evaluated, and a snapshot will be written as an argument to `toMatchInlineSnapshot`: - -```tsx -it('renders correctly', () => { - const tree = renderer - .create(Example Site) - .toJSON(); - expect(tree).toMatchInlineSnapshot(` - - Example Site - -`); -}); -``` - -That's all there is to it! You can even update the snapshots with `--updateSnapshot` or using the `u` key in `--watch` mode. - -By default, Jest handles the writing of snapshots into your source code. However, if you're using [prettier](https://www.npmjs.com/package/prettier) in your project, Jest will detect this and delegate the work to prettier instead (including honoring your configuration). - -### Property Matchers - -Often there are fields in the object you want to snapshot which are generated (like IDs and Dates). If you try to snapshot these objects, they will force the snapshot to fail on every run: - -```javascript -it('will fail every time', () => { - const user = { - createdAt: new Date(), - id: Math.floor(Math.random() * 20), - name: 'LeBron James', - }; - - expect(user).toMatchSnapshot(); -}); - -// Snapshot -exports[`will fail every time 1`] = ` -Object { - "createdAt": 2018-05-19T23:36:09.816Z, - "id": 3, - "name": "LeBron James", -} -`; -``` - -For these cases, Jest allows providing an asymmetric matcher for any property. These matchers are checked before the snapshot is written or tested, and then saved to the snapshot file instead of the received value: - -```javascript -it('will check the matchers and pass', () => { - const user = { - createdAt: new Date(), - id: Math.floor(Math.random() * 20), - name: 'LeBron James', - }; - - expect(user).toMatchSnapshot({ - createdAt: expect.any(Date), - id: expect.any(Number), - }); -}); - -// Snapshot -exports[`will check the matchers and pass 1`] = ` -Object { - "createdAt": Any, - "id": Any, - "name": "LeBron James", -} -`; -``` - -Any given value that is not a matcher will be checked exactly and saved to the snapshot: - -```javascript -it('will check the values and pass', () => { - const user = { - createdAt: new Date(), - name: 'Bond... James Bond', - }; - - expect(user).toMatchSnapshot({ - createdAt: expect.any(Date), - name: 'Bond... James Bond', - }); -}); - -// Snapshot -exports[`will check the values and pass 1`] = ` -Object { - "createdAt": Any, - "name": 'Bond... James Bond', -} -`; -``` - -## Best Practices - -Snapshots are a fantastic tool for identifying unexpected interface changes within your application – whether that interface is an API response, UI, logs, or error messages. As with any testing strategy, there are some best-practices you should be aware of, and guidelines you should follow, in order to use them effectively. - -### 1. Treat snapshots as code - -Commit snapshots and review them as part of your regular code review process. This means treating snapshots as you would any other type of test or code in your project. - -Ensure that your snapshots are readable by keeping them focused, short, and by using tools that enforce these stylistic conventions. - -As mentioned previously, Jest uses [`pretty-format`](https://yarnpkg.com/en/package/pretty-format) to make snapshots human-readable, but you may find it useful to introduce additional tools, like [`eslint-plugin-jest`](https://yarnpkg.com/en/package/eslint-plugin-jest) with its [`no-large-snapshots`](https://github.com/jest-community/eslint-plugin-jest/blob/main/docs/rules/no-large-snapshots.md) option, or [`snapshot-diff`](https://yarnpkg.com/en/package/snapshot-diff) with its component snapshot comparison feature, to promote committing short, focused assertions. - -The goal is to make it easy to review snapshots in pull requests, and fight against the habit of regenerating snapshots when test suites fail instead of examining the root causes of their failure. - -### 2. Tests should be deterministic - -Your tests should be deterministic. Running the same tests multiple times on a component that has not changed should produce the same results every time. You're responsible for making sure your generated snapshots do not include platform specific or other non-deterministic data. - -For example, if you have a [Clock](https://github.com/facebook/jest/blob/main/examples/snapshot/Clock.js) component that uses `Date.now()`, the snapshot generated from this component will be different every time the test case is run. In this case we can [mock the Date.now() method](MockFunctions.md) to return a consistent value every time the test is run: - -```js -Date.now = jest.fn(() => 1482363367071); -``` - -Now, every time the snapshot test case runs, `Date.now()` will return `1482363367071` consistently. This will result in the same snapshot being generated for this component regardless of when the test is run. - -### 3. Use descriptive snapshot names - -Always strive to use descriptive test and/or snapshot names for snapshots. The best names describe the expected snapshot content. This makes it easier for reviewers to verify the snapshots during review, and for anyone to know whether or not an outdated snapshot is the correct behavior before updating. - -For example, compare: - -```js -exports[` should handle some test case`] = `null`; - -exports[` should handle some other test case`] = ` -
- Alan Turing -
-`; -``` - -To: - -```js -exports[` should render null`] = `null`; - -exports[` should render Alan Turing`] = ` -
- Alan Turing -
-`; -``` - -Since the later describes exactly what's expected in the output, it's more clear to see when it's wrong: - -```js -exports[` should render null`] = ` -
- Alan Turing -
-`; - -exports[` should render Alan Turing`] = `null`; -``` - -## Frequently Asked Questions - -### Are snapshots written automatically on Continuous Integration (CI) systems? - -No, as of Jest 20, snapshots in Jest are not automatically written when Jest is run in a CI system without explicitly passing `--updateSnapshot`. It is expected that all snapshots are part of the code that is run on CI and since new snapshots automatically pass, they should not pass a test run on a CI system. It is recommended to always commit all snapshots and to keep them in version control. - -### Should snapshot files be committed? - -Yes, all snapshot files should be committed alongside the modules they are covering and their tests. They should be considered part of a test, similar to the value of any other assertion in Jest. In fact, snapshots represent the state of the source modules at any given point in time. In this way, when the source modules are modified, Jest can tell what changed from the previous version. It can also provide a lot of additional context during code review in which reviewers can study your changes better. - -### Does snapshot testing only work with React components? - -[React](TutorialReact.md) and [React Native](TutorialReactNative.md) components are a good use case for snapshot testing. However, snapshots can capture any serializable value and should be used anytime the goal is testing whether the output is correct. The Jest repository contains many examples of testing the output of Jest itself, the output of Jest's assertion library as well as log messages from various parts of the Jest codebase. See an example of [snapshotting CLI output](https://github.com/facebook/jest/blob/main/e2e/__tests__/console.test.ts) in the Jest repo. - -### What's the difference between snapshot testing and visual regression testing? - -Snapshot testing and visual regression testing are two distinct ways of testing UIs, and they serve different purposes. Visual regression testing tools take screenshots of web pages and compare the resulting images pixel by pixel. With Snapshot testing values are serialized, stored within text files, and compared using a diff algorithm. There are different trade-offs to consider and we listed the reasons why snapshot testing was built in the [Jest blog](/blog/2016/07/27/jest-14#why-snapshot-testing). - -### Does snapshot testing replace unit testing? - -Snapshot testing is only one of more than 20 assertions that ship with Jest. The aim of snapshot testing is not to replace existing unit tests, but to provide additional value and make testing painless. In some scenarios, snapshot testing can potentially remove the need for unit testing for a particular set of functionalities (e.g. React components), but they can work together as well. - -### What is the performance of snapshot testing regarding speed and size of the generated files? - -Jest has been rewritten with performance in mind, and snapshot testing is not an exception. Since snapshots are stored within text files, this way of testing is fast and reliable. Jest generates a new file for each test file that invokes the `toMatchSnapshot` matcher. The size of the snapshots is pretty small: For reference, the size of all snapshot files in the Jest codebase itself is less than 300 KB. - -### How do I resolve conflicts within snapshot files? - -Snapshot files must always represent the current state of the modules they are covering. Therefore, if you are merging two branches and encounter a conflict in the snapshot files, you can either resolve the conflict manually or update the snapshot file by running Jest and inspecting the result. - -### Is it possible to apply test-driven development principles with snapshot testing? - -Although it is possible to write snapshot files manually, that is usually not approachable. Snapshots help to figure out whether the output of the modules covered by tests is changed, rather than giving guidance to design the code in the first place. - -### Does code coverage work with snapshot testing? - -Yes, as well as with any other test. diff --git a/website/versioned_docs/version-27.1/TestingAsyncCode.md b/website/versioned_docs/version-27.1/TestingAsyncCode.md deleted file mode 100644 index ef8762eb7d87..000000000000 --- a/website/versioned_docs/version-27.1/TestingAsyncCode.md +++ /dev/null @@ -1,140 +0,0 @@ ---- -id: asynchronous -title: Testing Asynchronous Code ---- - -It's common in JavaScript for code to run asynchronously. When you have code that runs asynchronously, Jest needs to know when the code it is testing has completed, before it can move on to another test. Jest has several ways to handle this. - -## Promises - -Return a promise from your test, and Jest will wait for that promise to resolve. If the promise is rejected, the test will fail. - -For example, let's say that `fetchData` returns a promise that is supposed to resolve to the string `'peanut butter'`. We could test it with: - -```js -test('the data is peanut butter', () => { - return fetchData().then(data => { - expect(data).toBe('peanut butter'); - }); -}); -``` - -## Async/Await - -Alternatively, you can use `async` and `await` in your tests. To write an async test, use the `async` keyword in front of the function passed to `test`. For example, the same `fetchData` scenario can be tested with: - -```js -test('the data is peanut butter', async () => { - const data = await fetchData(); - expect(data).toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - expect.assertions(1); - try { - await fetchData(); - } catch (e) { - expect(e).toMatch('error'); - } -}); -``` - -You can combine `async` and `await` with `.resolves` or `.rejects`. - -```js -test('the data is peanut butter', async () => { - await expect(fetchData()).resolves.toBe('peanut butter'); -}); - -test('the fetch fails with an error', async () => { - await expect(fetchData()).rejects.toMatch('error'); -}); -``` - -In these cases, `async` and `await` are effectively syntactic sugar for the same logic as the promises example uses. - -:::caution - -Be sure to return (or `await`) the promise - if you omit the `return`/`await` statement, your test will complete before the promise returned from `fetchData` resolves or rejects. - -::: - -If you expect a promise to be rejected, use the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise, a fulfilled promise would not fail the test. - -```js -test('the fetch fails with an error', () => { - expect.assertions(1); - return fetchData().catch(e => expect(e).toMatch('error')); -}); -``` - -## Callbacks - -If you don't use promises, you can use callbacks. For example, let's say that `fetchData`, instead of returning a promise, expects a callback, i.e. fetches some data and calls `callback(null, data)` when it is complete. You want to test that this returned data is the string `'peanut butter'`. - -By default, Jest tests complete once they reach the end of their execution. That means this test will _not_ work as intended: - -```js -// Don't do this! -test('the data is peanut butter', () => { - function callback(error, data) { - if (error) { - throw error; - } - expect(data).toBe('peanut butter'); - } - - fetchData(callback); -}); -``` - -The problem is that the test will complete as soon as `fetchData` completes, before ever calling the callback. - -There is an alternate form of `test` that fixes this. Instead of putting the test in a function with an empty argument, use a single argument called `done`. Jest will wait until the `done` callback is called before finishing the test. - -```js -test('the data is peanut butter', done => { - function callback(error, data) { - if (error) { - done(error); - return; - } - try { - expect(data).toBe('peanut butter'); - done(); - } catch (error) { - done(error); - } - } - - fetchData(callback); -}); -``` - -If `done()` is never called, the test will fail (with timeout error), which is what you want to happen. - -If the `expect` statement fails, it throws an error and `done()` is not called. If we want to see in the test log why it failed, we have to wrap `expect` in a `try` block and pass the error in the `catch` block to `done`. Otherwise, we end up with an opaque timeout error that doesn't show what value was received by `expect(data)`. - -_Note: `done()` should not be mixed with Promises as this tends to lead to memory leaks in your tests._ - -## `.resolves` / `.rejects` - -You can also use the `.resolves` matcher in your expect statement, and Jest will wait for that promise to resolve. If the promise is rejected, the test will automatically fail. - -```js -test('the data is peanut butter', () => { - return expect(fetchData()).resolves.toBe('peanut butter'); -}); -``` - -Be sure to return the assertion—if you omit this `return` statement, your test will complete before the promise returned from `fetchData` is resolved and then() has a chance to execute the callback. - -If you expect a promise to be rejected, use the `.rejects` matcher. It works analogically to the `.resolves` matcher. If the promise is fulfilled, the test will automatically fail. - -```js -test('the fetch fails with an error', () => { - return expect(fetchData()).rejects.toMatch('error'); -}); -``` - -None of these forms is particularly superior to the others, and you can mix and match them across a codebase or even in a single file. It just depends on which style you feel makes your tests simpler. diff --git a/website/versioned_docs/version-27.1/TestingFrameworks.md b/website/versioned_docs/version-27.1/TestingFrameworks.md deleted file mode 100644 index 6ae4358fdf7d..000000000000 --- a/website/versioned_docs/version-27.1/TestingFrameworks.md +++ /dev/null @@ -1,49 +0,0 @@ ---- -id: testing-frameworks -title: Testing Web Frameworks ---- - -Jest is a universal testing platform, with the ability to adapt to any JavaScript library or framework. In this section, we'd like to link to community posts and articles about integrating Jest into popular JS libraries. - -## React - -- [Testing ReactJS components with Jest](https://testing-library.com/docs/react-testing-library/example-intro) by Kent C. Dodds ([@kentcdodds](https://twitter.com/kentcdodds)) - -## Vue.js - -- [Testing Vue.js components with Jest](https://alexjoverm.github.io/series/Unit-Testing-Vue-js-Components-with-the-Official-Vue-Testing-Tools-and-Jest/) by Alex Jover Morales ([@alexjoverm](https://twitter.com/alexjoverm)) -- [Jest for all: Episode 1 — Vue.js](https://medium.com/@kentaromiura_the_js_guy/jest-for-all-episode-1-vue-js-d616bccbe186#.d573vrce2) by Cristian Carlesso ([@kentaromiura](https://twitter.com/kentaromiura)) - -## AngularJS - -- [Testing an AngularJS app with Jest](https://medium.com/aya-experience/testing-an-angularjs-app-with-jest-3029a613251) by Matthieu Lux ([@Swiip](https://twitter.com/Swiip)) -- [Running AngularJS Tests with Jest](https://engineering.talentpair.com/running-angularjs-tests-with-jest-49d0cc9c6d26) by Ben Brandt ([@benjaminbrandt](https://twitter.com/benjaminbrandt)) -- [AngularJS Unit Tests with Jest Actions (Traditional Chinese)](https://dwatow.github.io/2019/08-14-angularjs/angular-jest/?fbclid=IwAR2SrqYg_o6uvCQ79FdNPeOxs86dUqB6pPKgd9BgnHt1kuIDRyRM-ch11xg) by Chris Wang ([@dwatow](https://github.com/dwatow)) - -## Angular - -- [Testing Angular faster with Jest](https://www.xfive.co/blog/testing-angular-faster-jest/) by Michał Pierzchała ([@thymikee](https://twitter.com/thymikee)) - -## MobX - -- [How to Test React and MobX with Jest](https://semaphoreci.com/community/tutorials/how-to-test-react-and-mobx-with-jest) by Will Stern ([@willsterndev](https://twitter.com/willsterndev)) - -## Redux - -- [Writing Tests](https://redux.js.org/recipes/writing-tests) by Redux docs - -## Express.js - -- [How to test Express.js with Jest and Supertest](http://www.albertgao.xyz/2017/05/24/how-to-test-expressjs-with-jest-and-supertest/) by Albert Gao ([@albertgao](https://twitter.com/albertgao)) - -## GatsbyJS - -- [Unit Testing](https://www.gatsbyjs.org/docs/unit-testing/) by GatsbyJS docs - -## Hapi.js - -- [Testing Hapi.js With Jest](https://github.com/sivasankars/testing-hapi.js-with-jest) by Niralar - -## Next.js - -- [Jest and React Testing Library](https://nextjs.org/docs/testing#jest-and-react-testing-library) by Next.js docs diff --git a/website/versioned_docs/version-27.1/TimerMocks.md b/website/versioned_docs/version-27.1/TimerMocks.md deleted file mode 100644 index 0952884e1beb..000000000000 --- a/website/versioned_docs/version-27.1/TimerMocks.md +++ /dev/null @@ -1,187 +0,0 @@ ---- -id: timer-mocks -title: Timer Mocks ---- - -The native timer functions (i.e., `setTimeout`, `setInterval`, `clearTimeout`, `clearInterval`) are less than ideal for a testing environment since they depend on real time to elapse. Jest can swap out timers with functions that allow you to control the passage of time. [Great Scott!](https://www.youtube.com/watch?v=QZoJ2Pt27BY) - -```javascript title="timerGame.js" -'use strict'; - -function timerGame(callback) { - console.log('Ready....go!'); - setTimeout(() => { - console.log("Time's up -- stop!"); - callback && callback(); - }, 1000); -} - -module.exports = timerGame; -``` - -```javascript title="__tests__/timerGame-test.js" -'use strict'; - -jest.useFakeTimers(); // or you can set "timers": "fake" globally in configuration file -jest.spyOn(global, 'setTimeout'); - -test('waits 1 second before ending the game', () => { - const timerGame = require('../timerGame'); - timerGame(); - - expect(setTimeout).toHaveBeenCalledTimes(1); - expect(setTimeout).toHaveBeenLastCalledWith(expect.any(Function), 1000); -}); -``` - -Here we enable fake timers by calling `jest.useFakeTimers()`. This mocks out `setTimeout` and other timer functions with mock functions. Timers can be restored to their normal behavior with `jest.useRealTimers()`. - -While you can call `jest.useFakeTimers()` or `jest.useRealTimers()` from anywhere (top level, inside an `it` block, etc.), it is a **global operation** and will affect other tests within the same file. Additionally, you need to call `jest.useFakeTimers()` to reset internal counters before each test. If you plan to not use fake timers in all your tests, you will want to clean up manually, as otherwise the faked timers will leak across tests: - -```javascript -afterEach(() => { - jest.useRealTimers(); -}); - -test('do something with fake timers', () => { - jest.useFakeTimers(); - // ... -}); - -test('do something with real timers', () => { - // ... -}); -``` - -All of the following functions need fake timers to be set, either by `jest.useFakeTimers()` or via `"timers": "fake"` in the config file. - -Currently, two implementations of the fake timers are included - `modern` and `legacy`, where `modern` is the default one. See [configuration](Configuration.md#timers-string) for how to configure it. - -## Run All Timers - -Another test we might want to write for this module is one that asserts that the callback is called after 1 second. To do this, we're going to use Jest's timer control APIs to fast-forward time right in the middle of the test: - -```javascript -jest.useFakeTimers(); -test('calls the callback after 1 second', () => { - const timerGame = require('../timerGame'); - const callback = jest.fn(); - - timerGame(callback); - - // At this point in time, the callback should not have been called yet - expect(callback).not.toBeCalled(); - - // Fast-forward until all timers have been executed - jest.runAllTimers(); - - // Now our callback should have been called! - expect(callback).toBeCalled(); - expect(callback).toHaveBeenCalledTimes(1); -}); -``` - -## Run Pending Timers - -There are also scenarios where you might have a recursive timer -- that is a timer that sets a new timer in its own callback. For these, running all the timers would be an endless loop, throwing the following error: - -``` -Ran 100000 timers, and there are still more! Assuming we've hit an infinite recursion and bailing out... -``` - -So something like `jest.runAllTimers()` is not desirable. For these cases you might use `jest.runOnlyPendingTimers()`: - -```javascript title="infiniteTimerGame.js" -'use strict'; - -function infiniteTimerGame(callback) { - console.log('Ready....go!'); - - setTimeout(() => { - console.log("Time's up! 10 seconds before the next game starts..."); - callback && callback(); - - // Schedule the next game in 10 seconds - setTimeout(() => { - infiniteTimerGame(callback); - }, 10000); - }, 1000); -} - -module.exports = infiniteTimerGame; -``` - -```javascript title="__tests__/infiniteTimerGame-test.js" -'use strict'; - -jest.useFakeTimers(); -jest.spyOn(global, 'setTimeout'); - -describe('infiniteTimerGame', () => { - test('schedules a 10-second timer after 1 second', () => { - const infiniteTimerGame = require('../infiniteTimerGame'); - const callback = jest.fn(); - - infiniteTimerGame(callback); - - // At this point in time, there should have been a single call to - // setTimeout to schedule the end of the game in 1 second. - expect(setTimeout).toHaveBeenCalledTimes(1); - expect(setTimeout).toHaveBeenLastCalledWith(expect.any(Function), 1000); - - // Fast forward and exhaust only currently pending timers - // (but not any new timers that get created during that process) - jest.runOnlyPendingTimers(); - - // At this point, our 1-second timer should have fired its callback - expect(callback).toBeCalled(); - - // And it should have created a new timer to start the game over in - // 10 seconds - expect(setTimeout).toHaveBeenCalledTimes(2); - expect(setTimeout).toHaveBeenLastCalledWith(expect.any(Function), 10000); - }); -}); -``` - -## Advance Timers by Time - -Another possibility is use `jest.advanceTimersByTime(msToRun)`. When this API is called, all timers are advanced by `msToRun` milliseconds. All pending "macro-tasks" that have been queued via setTimeout() or setInterval(), and would be executed during this time frame, will be executed. Additionally, if those macro-tasks schedule new macro-tasks that would be executed within the same time frame, those will be executed until there are no more macro-tasks remaining in the queue that should be run within msToRun milliseconds. - -```javascript title="timerGame.js" -'use strict'; - -function timerGame(callback) { - console.log('Ready....go!'); - setTimeout(() => { - console.log("Time's up -- stop!"); - callback && callback(); - }, 1000); -} - -module.exports = timerGame; -``` - -```javascript title="__tests__/timerGame-test.js" -jest.useFakeTimers(); -it('calls the callback after 1 second via advanceTimersByTime', () => { - const timerGame = require('../timerGame'); - const callback = jest.fn(); - - timerGame(callback); - - // At this point in time, the callback should not have been called yet - expect(callback).not.toBeCalled(); - - // Fast-forward until all timers have been executed - jest.advanceTimersByTime(1000); - - // Now our callback should have been called! - expect(callback).toBeCalled(); - expect(callback).toHaveBeenCalledTimes(1); -}); -``` - -Lastly, it may occasionally be useful in some tests to be able to clear all of the pending timers. For this, we have `jest.clearAllTimers()`. - -The code for this example is available at [examples/timer](https://github.com/facebook/jest/tree/main/examples/timer). diff --git a/website/versioned_docs/version-27.1/Troubleshooting.md b/website/versioned_docs/version-27.1/Troubleshooting.md deleted file mode 100644 index 28cea902472d..000000000000 --- a/website/versioned_docs/version-27.1/Troubleshooting.md +++ /dev/null @@ -1,206 +0,0 @@ ---- -id: troubleshooting -title: Troubleshooting ---- - -Uh oh, something went wrong? Use this guide to resolve issues with Jest. - -## Tests are Failing and You Don't Know Why - -Try using the debugging support built into Node. Note: This will only work in Node.js 8+. - -Place a `debugger;` statement in any of your tests, and then, in your project's directory, run: - -```bash -node --inspect-brk node_modules/.bin/jest --runInBand [any other arguments here] -or on Windows -node --inspect-brk ./node_modules/jest/bin/jest.js --runInBand [any other arguments here] -``` - -This will run Jest in a Node process that an external debugger can connect to. Note that the process will pause until the debugger has connected to it. - -To debug in Google Chrome (or any Chromium-based browser), open your browser and go to `chrome://inspect` and click on "Open Dedicated DevTools for Node", which will give you a list of available node instances you can connect to. Click on the address displayed in the terminal (usually something like `localhost:9229`) after running the above command, and you will be able to debug Jest using Chrome's DevTools. - -The Chrome Developer Tools will be displayed, and a breakpoint will be set at the first line of the Jest CLI script (this is done to give you time to open the developer tools and to prevent Jest from executing before you have time to do so). Click the button that looks like a "play" button in the upper right hand side of the screen to continue execution. When Jest executes the test that contains the `debugger` statement, execution will pause and you can examine the current scope and call stack. - -> Note: the `--runInBand` cli option makes sure Jest runs the test in the same process rather than spawning processes for individual tests. Normally Jest parallelizes test runs across processes but it is hard to debug many processes at the same time. - -## Debugging in VS Code - -There are multiple ways to debug Jest tests with [Visual Studio Code's](https://code.visualstudio.com) built-in [debugger](https://code.visualstudio.com/docs/nodejs/nodejs-debugging). - -To attach the built-in debugger, run your tests as aforementioned: - -```bash -node --inspect-brk node_modules/.bin/jest --runInBand [any other arguments here] -or on Windows -node --inspect-brk ./node_modules/jest/bin/jest.js --runInBand [any other arguments here] -``` - -Then attach VS Code's debugger using the following `launch.json` config: - -```json -{ - "version": "0.2.0", - "configurations": [ - { - "type": "node", - "request": "attach", - "name": "Attach", - "port": 9229 - } - ] -} -``` - -To automatically launch and attach to a process running your tests, use the following configuration: - -```json -{ - "version": "0.2.0", - "configurations": [ - { - "name": "Debug Jest Tests", - "type": "node", - "request": "launch", - "runtimeArgs": [ - "--inspect-brk", - "${workspaceRoot}/node_modules/.bin/jest", - "--runInBand" - ], - "console": "integratedTerminal", - "internalConsoleOptions": "neverOpen", - "port": 9229 - } - ] -} -``` - -or the following for Windows: - -```json -{ - "version": "0.2.0", - "configurations": [ - { - "name": "Debug Jest Tests", - "type": "node", - "request": "launch", - "runtimeArgs": [ - "--inspect-brk", - "${workspaceRoot}/node_modules/jest/bin/jest.js", - "--runInBand" - ], - "console": "integratedTerminal", - "internalConsoleOptions": "neverOpen", - "port": 9229 - } - ] -} -``` - -If you are using Facebook's [`create-react-app`](https://github.com/facebookincubator/create-react-app), you can debug your Jest tests with the following configuration: - -```json -{ - "version": "0.2.0", - "configurations": [ - { - "name": "Debug CRA Tests", - "type": "node", - "request": "launch", - "runtimeExecutable": "${workspaceRoot}/node_modules/.bin/react-scripts", - "args": ["test", "--runInBand", "--no-cache", "--env=jsdom"], - "cwd": "${workspaceRoot}", - "protocol": "inspector", - "console": "integratedTerminal", - "internalConsoleOptions": "neverOpen" - } - ] -} -``` - -More information on Node debugging can be found [here](https://nodejs.org/api/debugger.html). - -## Debugging in WebStorm - -[WebStorm](https://www.jetbrains.com/webstorm/) has built-in support for Jest. Read [Testing With Jest in WebStorm](https://blog.jetbrains.com/webstorm/2018/10/testing-with-jest-in-webstorm/) to learn more. - -## Caching Issues - -The transform script was changed or Babel was updated and the changes aren't being recognized by Jest? - -Retry with [`--no-cache`](CLI.md#--cache). Jest caches transformed module files to speed up test execution. If you are using your own custom transformer, consider adding a `getCacheKey` function to it: [getCacheKey in Relay](https://github.com/facebook/relay/blob/58cf36c73769690f0bbf90562707eadb062b029d/scripts/jest/preprocessor.js#L56-L61). - -## Unresolved Promises - -If a promise doesn't resolve at all, this error might be thrown: - -```bash -- Error: Timeout - Async callback was not invoked within timeout specified by jasmine.DEFAULT_TIMEOUT_INTERVAL.` -``` - -Most commonly this is being caused by conflicting Promise implementations. Consider replacing the global promise implementation with your own, for example `global.Promise = jest.requireActual('promise');` and/or consolidate the used Promise libraries to a single one. - -If your test is long running, you may want to consider to increase the timeout by calling `jest.setTimeout` - -```js -jest.setTimeout(10000); // 10 second timeout -``` - -## Watchman Issues - -Try running Jest with [`--no-watchman`](CLI.md#--watchman) or set the `watchman` configuration option to `false`. - -Also see [watchman troubleshooting](https://facebook.github.io/watchman/docs/troubleshooting). - -## Tests are Extremely Slow on Docker and/or Continuous Integration (CI) server. - -While Jest is most of the time extremely fast on modern multi-core computers with fast SSDs, it may be slow on certain setups as our users [have](https://github.com/facebook/jest/issues/1395) [discovered](https://github.com/facebook/jest/issues/1524#issuecomment-260246008). - -Based on the [findings](https://github.com/facebook/jest/issues/1524#issuecomment-262366820), one way to mitigate this issue and improve the speed by up to 50% is to run tests sequentially. - -In order to do this you can run tests in the same thread using [`--runInBand`](CLI.md#--runinband): - -```bash -# Using Jest CLI -jest --runInBand - -# Using yarn test (e.g. with create-react-app) -yarn test --runInBand -``` - -Another alternative to expediting test execution time on Continuous Integration Servers such as Travis-CI is to set the max worker pool to ~_4_. Specifically on Travis-CI, this can reduce test execution time in half. Note: The Travis CI _free_ plan available for open source projects only includes 2 CPU cores. - -```bash -# Using Jest CLI -jest --maxWorkers=4 - -# Using yarn test (e.g. with create-react-app) -yarn test --maxWorkers=4 -``` - -## `coveragePathIgnorePatterns` seems to not have any effect. - -Make sure you are not using the `babel-plugin-istanbul` plugin. Jest wraps Istanbul, and therefore also tells Istanbul what files to instrument with coverage collection. When using `babel-plugin-istanbul`, every file that is processed by Babel will have coverage collection code, hence it is not being ignored by `coveragePathIgnorePatterns`. - -## Defining Tests - -Tests must be defined synchronously for Jest to be able to collect your tests. - -As an example to show why this is the case, imagine we wrote a test like so: - -```js -// Don't do this it will not work -setTimeout(() => { - it('passes', () => expect(1).toBe(1)); -}, 0); -``` - -When Jest runs your test to collect the `test`s it will not find any because we have set the definition to happen asynchronously on the next tick of the event loop. - -_Note:_ This means when you are using `test.each` you cannot set the table asynchronously within a `beforeEach` / `beforeAll`. - -## Still unresolved? - -See [Help](/help). diff --git a/website/versioned_docs/version-27.1/TutorialAsync.md b/website/versioned_docs/version-27.1/TutorialAsync.md deleted file mode 100644 index e4c7117c16dc..000000000000 --- a/website/versioned_docs/version-27.1/TutorialAsync.md +++ /dev/null @@ -1,161 +0,0 @@ ---- -id: tutorial-async -title: An Async Example ---- - -First, enable Babel support in Jest as documented in the [Getting Started](GettingStarted.md#using-babel) guide. - -Let's implement a module that fetches user data from an API and returns the user name. - -```js title="user.js" -import request from './request'; - -export function getUserName(userID) { - return request(`/users/${userID}`).then(user => user.name); -} -``` - -In the above implementation, we expect the `request.js` module to return a promise. We chain a call to `then` to receive the user name. - -Now imagine an implementation of `request.js` that goes to the network and fetches some user data: - -```js title="request.js" -const http = require('http'); - -export default function request(url) { - return new Promise(resolve => { - // This is an example of an http request, for example to fetch - // user data from an API. - // This module is being mocked in __mocks__/request.js - http.get({path: url}, response => { - let data = ''; - response.on('data', _data => (data += _data)); - response.on('end', () => resolve(data)); - }); - }); -} -``` - -Because we don't want to go to the network in our test, we are going to create a manual mock for our `request.js` module in the `__mocks__` folder (the folder is case-sensitive, `__MOCKS__` will not work). It could look something like this: - -```js title="__mocks__/request.js" -const users = { - 4: {name: 'Mark'}, - 5: {name: 'Paul'}, -}; - -export default function request(url) { - return new Promise((resolve, reject) => { - const userID = parseInt(url.substr('/users/'.length), 10); - process.nextTick(() => - users[userID] - ? resolve(users[userID]) - : reject({ - error: `User with ${userID} not found.`, - }), - ); - }); -} -``` - -Now let's write a test for our async functionality. - -```js title="__tests__/user-test.js" -jest.mock('../request'); - -import * as user from '../user'; - -// The assertion for a promise must be returned. -it('works with promises', () => { - expect.assertions(1); - return user.getUserName(4).then(data => expect(data).toEqual('Mark')); -}); -``` - -We call `jest.mock('../request')` to tell Jest to use our manual mock. `it` expects the return value to be a Promise that is going to be resolved. You can chain as many Promises as you like and call `expect` at any time, as long as you return a Promise at the end. - -## `.resolves` - -There is a less verbose way using `resolves` to unwrap the value of a fulfilled promise together with any other matcher. If the promise is rejected, the assertion will fail. - -```js -it('works with resolves', () => { - expect.assertions(1); - return expect(user.getUserName(5)).resolves.toEqual('Paul'); -}); -``` - -## `async`/`await` - -Writing tests using the `async`/`await` syntax is also possible. Here is how you'd write the same examples from before: - -```js -// async/await can be used. -it('works with async/await', async () => { - expect.assertions(1); - const data = await user.getUserName(4); - expect(data).toEqual('Mark'); -}); - -// async/await can also be used with `.resolves`. -it('works with async/await and resolves', async () => { - expect.assertions(1); - await expect(user.getUserName(5)).resolves.toEqual('Paul'); -}); -``` - -To enable async/await in your project, install [`@babel/preset-env`](https://babeljs.io/docs/en/babel-preset-env) and enable the feature in your `babel.config.js` file. - -## Error handling - -Errors can be handled using the `.catch` method. Make sure to add `expect.assertions` to verify that a certain number of assertions are called. Otherwise a fulfilled promise would not fail the test: - -```js -// Testing for async errors using Promise.catch. -it('tests error with promises', () => { - expect.assertions(1); - return user.getUserName(2).catch(e => - expect(e).toEqual({ - error: 'User with 2 not found.', - }), - ); -}); - -// Or using async/await. -it('tests error with async/await', async () => { - expect.assertions(1); - try { - await user.getUserName(1); - } catch (e) { - expect(e).toEqual({ - error: 'User with 1 not found.', - }); - } -}); -``` - -## `.rejects` - -The`.rejects` helper works like the `.resolves` helper. If the promise is fulfilled, the test will automatically fail. `expect.assertions(number)` is not required but recommended to verify that a certain number of [assertions](expect#expectassertionsnumber) are called during a test. It is otherwise easy to forget to `return`/`await` the `.resolves` assertions. - -```js -// Testing for async errors using `.rejects`. -it('tests error with rejects', () => { - expect.assertions(1); - return expect(user.getUserName(3)).rejects.toEqual({ - error: 'User with 3 not found.', - }); -}); - -// Or using async/await with `.rejects`. -it('tests error with async/await and rejects', async () => { - expect.assertions(1); - await expect(user.getUserName(3)).rejects.toEqual({ - error: 'User with 3 not found.', - }); -}); -``` - -The code for this example is available at [examples/async](https://github.com/facebook/jest/tree/main/examples/async). - -If you'd like to test timers, like `setTimeout`, take a look at the [Timer mocks](TimerMocks.md) documentation. diff --git a/website/versioned_docs/version-27.1/TutorialReact.md b/website/versioned_docs/version-27.1/TutorialReact.md deleted file mode 100644 index 8fa282fff661..000000000000 --- a/website/versioned_docs/version-27.1/TutorialReact.md +++ /dev/null @@ -1,313 +0,0 @@ ---- -id: tutorial-react -title: Testing React Apps ---- - -At Facebook, we use Jest to test [React](https://reactjs.org/) applications. - -## Setup - -### Setup with Create React App - -If you are new to React, we recommend using [Create React App](https://create-react-app.dev/). It is ready to use and [ships with Jest](https://create-react-app.dev/docs/running-tests/#docsNav)! You will only need to add `react-test-renderer` for rendering snapshots. - -Run - -```bash -yarn add --dev react-test-renderer -``` - -### Setup without Create React App - -If you have an existing application you'll need to install a few packages to make everything work well together. We are using the `babel-jest` package and the `react` babel preset to transform our code inside of the test environment. Also see [using babel](GettingStarted.md#using-babel). - -Run - -```bash -yarn add --dev jest babel-jest @babel/preset-env @babel/preset-react react-test-renderer -``` - -Your `package.json` should look something like this (where `` is the actual latest version number for the package). Please add the scripts and jest configuration entries: - -```json - "dependencies": { - "react": "", - "react-dom": "" - }, - "devDependencies": { - "@babel/preset-env": "", - "@babel/preset-react": "", - "babel-jest": "", - "jest": "", - "react-test-renderer": "" - }, - "scripts": { - "test": "jest" - } -``` - -```js title="babel.config.js" -module.exports = { - presets: ['@babel/preset-env', '@babel/preset-react'], -}; -``` - -**And you're good to go!** - -### Snapshot Testing - -Let's create a [snapshot test](SnapshotTesting.md) for a Link component that renders hyperlinks: - -```tsx title="Link.js" -import React, {useState} from 'react'; - -const STATUS = { - HOVERED: 'hovered', - NORMAL: 'normal', -}; - -const Link = ({page, children}) => { - const [status, setStatus] = useState(STATUS.NORMAL); - - const onMouseEnter = () => { - setStatus(STATUS.HOVERED); - }; - - const onMouseLeave = () => { - setStatus(STATUS.NORMAL); - }; - - return ( - - {children} - - ); -}; - -export default Link; -``` - -> Note: Examples are using Function components, but Class components can be tested in the same way. See [React: Function and Class Components](https://reactjs.org/docs/components-and-props.html#function-and-class-components). **Reminders** that with Class components, we expect Jest to be used to test props and not methods directly. - -Now let's use React's test renderer and Jest's snapshot feature to interact with the component and capture the rendered output and create a snapshot file: - -```tsx title="Link.test.js" -import React from 'react'; -import renderer from 'react-test-renderer'; -import Link from '../Link'; - -test('Link changes the class when hovered', () => { - const component = renderer.create( - Facebook, - ); - let tree = component.toJSON(); - expect(tree).toMatchSnapshot(); - - // manually trigger the callback - tree.props.onMouseEnter(); - // re-rendering - tree = component.toJSON(); - expect(tree).toMatchSnapshot(); - - // manually trigger the callback - tree.props.onMouseLeave(); - // re-rendering - tree = component.toJSON(); - expect(tree).toMatchSnapshot(); -}); -``` - -When you run `yarn test` or `jest`, this will produce an output file like this: - -```javascript title="__tests__/__snapshots__/Link.test.js.snap" -exports[`Link changes the class when hovered 1`] = ` - - Facebook - -`; - -exports[`Link changes the class when hovered 2`] = ` - - Facebook - -`; - -exports[`Link changes the class when hovered 3`] = ` - - Facebook - -`; -``` - -The next time you run the tests, the rendered output will be compared to the previously created snapshot. The snapshot should be committed along with code changes. When a snapshot test fails, you need to inspect whether it is an intended or unintended change. If the change is expected you can invoke Jest with `jest -u` to overwrite the existing snapshot. - -The code for this example is available at [examples/snapshot](https://github.com/facebook/jest/tree/main/examples/snapshot). - -#### Snapshot Testing with Mocks, Enzyme and React 16 - -There's a caveat around snapshot testing when using Enzyme and React 16+. If you mock out a module using the following style: - -```js -jest.mock('../SomeDirectory/SomeComponent', () => 'SomeComponent'); -``` - -Then you will see warnings in the console: - -```bash -Warning: is using uppercase HTML. Always use lowercase HTML tags in React. - -# Or: -Warning: The tag is unrecognized in this browser. If you meant to render a React component, start its name with an uppercase letter. -``` - -React 16 triggers these warnings due to how it checks element types, and the mocked module fails these checks. Your options are: - -1. Render as text. This way you won't see the props passed to the mock component in the snapshot, but it's straightforward: - ```js - jest.mock('./SomeComponent', () => () => 'SomeComponent'); - ``` -2. Render as a custom element. DOM "custom elements" aren't checked for anything and shouldn't fire warnings. They are lowercase and have a dash in the name. - ```tsx - jest.mock('./Widget', () => () => ); - ``` -3. Use `react-test-renderer`. The test renderer doesn't care about element types and will happily accept e.g. `SomeComponent`. You could check snapshots using the test renderer, and check component behavior separately using Enzyme. -4. Disable warnings all together (should be done in your jest setup file): - ```js - jest.mock('fbjs/lib/warning', () => require('fbjs/lib/emptyFunction')); - ``` - This shouldn't normally be your option of choice as useful warnings could be lost. However, in some cases, for example when testing react-native's components we are rendering react-native tags into the DOM and many warnings are irrelevant. Another option is to swizzle the console.warn and suppress specific warnings. - -### DOM Testing - -If you'd like to assert, and manipulate your rendered components you can use [react-testing-library](https://github.com/kentcdodds/react-testing-library), [Enzyme](http://airbnb.io/enzyme/), or React's [TestUtils](https://reactjs.org/docs/test-utils.html). The following two examples use react-testing-library and Enzyme. - -#### react-testing-library - -You have to run `yarn add --dev @testing-library/react` to use react-testing-library. - -Let's implement a checkbox which swaps between two labels: - -```tsx title="CheckboxWithLabel.js" -import React, {useState} from 'react'; - -const CheckboxWithLabel = ({labelOn, labelOff}) => { - const [isChecked, setIsChecked] = useState(false); - - const onChange = () => { - setIsChecked(!isChecked); - }; - - return ( - - ); -}; - -export default CheckboxWithLabel; -``` - -```tsx title="__tests__/CheckboxWithLabel-test.js" -import React from 'react'; -import {cleanup, fireEvent, render} from '@testing-library/react'; -import CheckboxWithLabel from '../CheckboxWithLabel'; - -// Note: running cleanup afterEach is done automatically for you in @testing-library/react@9.0.0 or higher -// unmount and cleanup DOM after the test is finished. -afterEach(cleanup); - -it('CheckboxWithLabel changes the text after click', () => { - const {queryByLabelText, getByLabelText} = render( - , - ); - - expect(queryByLabelText(/off/i)).toBeTruthy(); - - fireEvent.click(getByLabelText(/off/i)); - - expect(queryByLabelText(/on/i)).toBeTruthy(); -}); -``` - -The code for this example is available at [examples/react-testing-library](https://github.com/facebook/jest/tree/main/examples/react-testing-library). - -#### Enzyme - -You have to run `yarn add --dev enzyme` to use Enzyme. If you are using a React version below 15.5.0, you will also need to install `react-addons-test-utils`. - -Let's rewrite the test from above using Enzyme instead of react-testing-library. We use Enzyme's [shallow renderer](http://airbnb.io/enzyme/docs/api/shallow.html) in this example. - -```tsx title="__tests__/CheckboxWithLabel-test.js" -import React from 'react'; -import {shallow} from 'enzyme'; -import CheckboxWithLabel from '../CheckboxWithLabel'; - -test('CheckboxWithLabel changes the text after click', () => { - // Render a checkbox with label in the document - const checkbox = shallow(); - - expect(checkbox.text()).toEqual('Off'); - - checkbox.find('input').simulate('change'); - - expect(checkbox.text()).toEqual('On'); -}); -``` - -The code for this example is available at [examples/enzyme](https://github.com/facebook/jest/tree/main/examples/enzyme). - -### Custom transformers - -If you need more advanced functionality, you can also build your own transformer. Instead of using `babel-jest`, here is an example of using `@babel/core`: - -```javascript title="custom-transformer.js" -'use strict'; - -const {transform} = require('@babel/core'); -const jestPreset = require('babel-preset-jest'); - -module.exports = { - process(src, filename) { - const result = transform(src, { - filename, - presets: [jestPreset], - }); - - return result || src; - }, -}; -``` - -Don't forget to install the `@babel/core` and `babel-preset-jest` packages for this example to work. - -To make this work with Jest you need to update your Jest configuration with this: `"transform": {"\\.js$": "path/to/custom-transformer.js"}`. - -If you'd like to build a transformer with babel support, you can also use `babel-jest` to compose one and pass in your custom configuration options: - -```javascript -const babelJest = require('babel-jest'); - -module.exports = babelJest.createTransformer({ - presets: ['my-custom-preset'], -}); -``` - -See [dedicated docs](CodeTransformation.md#writing-custom-transformers) for more details. diff --git a/website/versioned_docs/version-27.1/TutorialReactNative.md b/website/versioned_docs/version-27.1/TutorialReactNative.md deleted file mode 100644 index ddb60b230c31..000000000000 --- a/website/versioned_docs/version-27.1/TutorialReactNative.md +++ /dev/null @@ -1,215 +0,0 @@ ---- -id: tutorial-react-native -title: Testing React Native Apps ---- - -At Facebook, we use Jest to test [React Native](https://reactnative.dev/) applications. - -Get a deeper insight into testing a working React Native app example by reading the following series: [Part 1: Jest – Snapshot come into play](https://callstack.com/blog/testing-react-native-with-the-new-jest-part-1-snapshots-come-into-play/) and [Part 2: Jest – Redux Snapshots for your Actions and Reducers](https://callstack.com/blog/testing-react-native-with-the-new-jest-part-2-redux-snapshots-for-your-actions-and-reducers/). - -## Setup - -Starting from react-native version 0.38, a Jest setup is included by default when running `react-native init`. The following configuration should be automatically added to your package.json file: - -```json -{ - "scripts": { - "test": "jest" - }, - "jest": { - "preset": "react-native" - } -} -``` - -_Note: If you are upgrading your react-native application and previously used the `jest-react-native` preset, remove the dependency from your `package.json` file and change the preset to `react-native` instead._ - -Run `yarn test` to run tests with Jest. - -## Snapshot Test - -Let's create a [snapshot test](SnapshotTesting.md) for a small intro component with a few views and text components and some styles: - -```tsx title="Intro.js" -import React, {Component} from 'react'; -import {StyleSheet, Text, View} from 'react-native'; - -class Intro extends Component { - render() { - return ( - - Welcome to React Native! - - This is a React Native snapshot test. - - - ); - } -} - -const styles = StyleSheet.create({ - container: { - alignItems: 'center', - backgroundColor: '#F5FCFF', - flex: 1, - justifyContent: 'center', - }, - instructions: { - color: '#333333', - marginBottom: 5, - textAlign: 'center', - }, - welcome: { - fontSize: 20, - margin: 10, - textAlign: 'center', - }, -}); - -export default Intro; -``` - -Now let's use React's test renderer and Jest's snapshot feature to interact with the component and capture the rendered output and create a snapshot file: - -```tsx title="__tests__/Intro-test.js" -import React from 'react'; -import renderer from 'react-test-renderer'; -import Intro from '../Intro'; - -test('renders correctly', () => { - const tree = renderer.create().toJSON(); - expect(tree).toMatchSnapshot(); -}); -``` - -When you run `yarn test` or `jest`, this will produce an output file like this: - -```javascript title="__tests__/__snapshots__/Intro-test.js.snap" -exports[`Intro renders correctly 1`] = ` - - - Welcome to React Native! - - - This is a React Native snapshot test. - - -`; -``` - -The next time you run the tests, the rendered output will be compared to the previously created snapshot. The snapshot should be committed along with code changes. When a snapshot test fails, you need to inspect whether it is an intended or unintended change. If the change is expected you can invoke Jest with `jest -u` to overwrite the existing snapshot. - -The code for this example is available at [examples/react-native](https://github.com/facebook/jest/tree/main/examples/react-native). - -## Preset configuration - -The preset sets up the environment and is very opinionated and based on what we found to be useful at Facebook. All of the configuration options can be overwritten just as they can be customized when no preset is used. - -### Environment - -`react-native` ships with a Jest preset, so the `jest.preset` field of your `package.json` should point to `react-native`. The preset is a node environment that mimics the environment of a React Native app. Because it doesn't load any DOM or browser APIs, it greatly improves Jest's startup time. - -### transformIgnorePatterns customization - -The [`transformIgnorePatterns`](configuration#transformignorepatterns-arraystring) option can be used to specify which files shall be transformed by Babel. Many `react-native` npm modules unfortunately don't pre-compile their source code before publishing. - -By default the `jest-react-native` preset only processes the project's own source files and `react-native`. If you have npm dependencies that have to be transformed you can customize this configuration option by including modules other than `react-native` by grouping them and separating them with the `|` operator: - -```json -{ - "transformIgnorePatterns": [ - "node_modules/(?!(react-native|my-project|react-native-button)/)" - ] -} -``` - -You can test which paths would match (and thus be excluded from transformation) with a tool [like this](https://regex101.com/r/JsLIDM/1). - -`transformIgnorePatterns` will exclude a file from transformation if the path matches against **any** pattern provided. Splitting into multiple patterns could therefore have unintended results if you are not careful. In the example below, the exclusion (also known as a negative lookahead assertion) for `foo` and `bar` cancel each other out: - -```json -{ - "transformIgnorePatterns": ["node_modules/(?!foo/)", "node_modules/(?!bar/)"] // not what you want -} -``` - -### setupFiles - -If you'd like to provide additional configuration for every test file, the [`setupFiles` configuration option](configuration#setupfiles-array) can be used to specify setup scripts. - -### moduleNameMapper - -The [`moduleNameMapper`](configuration#modulenamemapper-objectstring-string--arraystring) can be used to map a module path to a different module. By default the preset maps all images to an image stub module but if a module cannot be found this configuration option can help: - -```json -{ - "moduleNameMapper": { - "my-module.js": "/path/to/my-module.js" - } -} -``` - -## Tips - -### Mock native modules using jest.mock - -The Jest preset built into `react-native` comes with a few default mocks that are applied on a react-native repository. However, some react-native components or third party components rely on native code to be rendered. In such cases, Jest's manual mocking system can help to mock out the underlying implementation. - -For example, if your code depends on a third party native video component called `react-native-video` you might want to stub it out with a manual mock like this: - -```js -jest.mock('react-native-video', () => 'Video'); -``` - -This will render the component as `