From 04dae6cde4c7f529867bdac5428f68b235dc89b8 Mon Sep 17 00:00:00 2001 From: Simen Bekkhus Date: Mon, 3 Oct 2022 10:35:17 +0100 Subject: [PATCH] fix(babel-hoist-plugin): ignore TS type queries (#13367) --- CHANGELOG.md | 2 ++ packages/babel-plugin-jest-hoist/package.json | 1 + .../__snapshots__/hoistPlugin.test.ts.snap | 26 +++++++++++++++++++ .../src/__tests__/hoistPlugin.test.ts | 17 ++++++++++++ packages/babel-plugin-jest-hoist/src/index.ts | 7 ++++- yarn.lock | 1 + 6 files changed, 53 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e1ef3104cc39..f8a4d33ec1c1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,8 @@ ### Fixes +- `[babel-plugin-jest-hoist]` Ignore `TSTypeQuery` when checking for hoisted references ([#13367](https://github.com/facebook/jest/pull/13367)) + ### Chore & Maintenance ### Performance diff --git a/packages/babel-plugin-jest-hoist/package.json b/packages/babel-plugin-jest-hoist/package.json index b242dc0b0998..d691bdb1a79f 100644 --- a/packages/babel-plugin-jest-hoist/package.json +++ b/packages/babel-plugin-jest-hoist/package.json @@ -28,6 +28,7 @@ "devDependencies": { "@babel/core": "^7.11.6", "@babel/preset-react": "^7.12.1", + "@babel/preset-typescript": "^7.0.0", "@types/babel__template": "^7.0.2", "@types/node": "*", "@types/prettier": "^2.1.5", diff --git a/packages/babel-plugin-jest-hoist/src/__tests__/__snapshots__/hoistPlugin.test.ts.snap b/packages/babel-plugin-jest-hoist/src/__tests__/__snapshots__/hoistPlugin.test.ts.snap index 3a5a0817baed..a95af4e804b7 100644 --- a/packages/babel-plugin-jest-hoist/src/__tests__/__snapshots__/hoistPlugin.test.ts.snap +++ b/packages/babel-plugin-jest-hoist/src/__tests__/__snapshots__/hoistPlugin.test.ts.snap @@ -1,5 +1,31 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP +exports[`babel-plugin-jest-hoist TS typeof usage in jest.mock: TS typeof usage in jest.mock 1`] = ` + +jest.mock('some-module', () => { + const actual = jest.requireActual('some-module'); + + return jest.fn(); +}); + + ↓ ↓ ↓ ↓ ↓ ↓ + +_getJestObj().mock('some-module', () => { + const actual = jest.requireActual('some-module'); + return jest.fn(); +}); + +function _getJestObj() { + const {jest} = require('@jest/globals'); + + _getJestObj = () => jest; + + return jest; +} + + +`; + exports[`babel-plugin-jest-hoist automatic react runtime: automatic react runtime 1`] = ` jest.mock('./App', () => () =>
Hello world
); diff --git a/packages/babel-plugin-jest-hoist/src/__tests__/hoistPlugin.test.ts b/packages/babel-plugin-jest-hoist/src/__tests__/hoistPlugin.test.ts index 685ab680aa75..7828b5095307 100644 --- a/packages/babel-plugin-jest-hoist/src/__tests__/hoistPlugin.test.ts +++ b/packages/babel-plugin-jest-hoist/src/__tests__/hoistPlugin.test.ts @@ -134,6 +134,23 @@ pluginTester({ formatResult, snapshot: true, }, + 'TS typeof usage in jest.mock': { + babelOptions: { + babelrc: false, + configFile: false, + filename: path.resolve(__dirname, '../file.ts'), + presets: [[require.resolve('@babel/preset-typescript')]], + }, + code: formatResult(` + jest.mock('some-module', () => { + const actual = jest.requireActual('some-module'); + + return jest.fn(); + }); + `), + formatResult, + snapshot: true, + }, }, /* eslint-enable */ }); diff --git a/packages/babel-plugin-jest-hoist/src/index.ts b/packages/babel-plugin-jest-hoist/src/index.ts index 21af10f6c2a2..2841036ede50 100644 --- a/packages/babel-plugin-jest-hoist/src/index.ts +++ b/packages/babel-plugin-jest-hoist/src/index.ts @@ -106,7 +106,12 @@ const IDVisitor = { ) { ids.add(path); }, - blacklist: ['TypeAnnotation', 'TSTypeAnnotation', 'TSTypeReference'], + blacklist: [ + 'TypeAnnotation', + 'TSTypeAnnotation', + 'TSTypeQuery', + 'TSTypeReference', + ], }; const FUNCTIONS: Record< diff --git a/yarn.lock b/yarn.lock index 242b11727717..f945d1ef9d14 100644 --- a/yarn.lock +++ b/yarn.lock @@ -6168,6 +6168,7 @@ __metadata: dependencies: "@babel/core": ^7.11.6 "@babel/preset-react": ^7.12.1 + "@babel/preset-typescript": ^7.0.0 "@babel/template": ^7.3.3 "@babel/types": ^7.3.3 "@types/babel__core": ^7.1.14