Jest TransformIgnorePatterns React-Native Preset的所有node_modules

Luc*_*Lat 4 jestjs react-native

我是开玩笑的人,

在我的项目 - package.json中设置jest配置之后,

的package.json

"jest": {
    "preset": "react-native",
    "verbose": true,
    "moduleDirectories": ["node_modules", "src"],
    "transformIgnorePatterns": ["node_modules/(?!(react-native-cookies)/)"]
  },
Run Code Online (Sandbox Code Playgroud)

我已经尝试忽略所有节点模块: -

"transformIgnorePatterns": ["node_modules"]
Run Code Online (Sandbox Code Playgroud)

但不适合我

.babelrc

{
  "presets": ["react-native"]
}
Run Code Online (Sandbox Code Playgroud)

我的LoginScreen-Test.js代码: -

测试用例

import 'react-native';
import React from 'react';
import LoginScreen from '../src/components/LoginScreen';
import renderer from 'react-test-renderer';

it('renders correctly', () => {
  const hello = renderer.create(<LoginScreen/>).toJSON();
  expect(hello).toMatchSnapshot();
});
Run Code Online (Sandbox Code Playgroud)

我开始跑 - > npm test或npm test - -u

它反映了我以下错误: -

终端输出

FAIL 测试 /LoginScreen-test.js●测试套件无法运行

/Users/Documents/Projects/node_modules/react-native/Libraries/Utilities/Platform.ios.js:31
  get isTesting(): boolean {
                 ^

SyntaxError: Unexpected token :

  at ScriptTransformer._transformAndBuildScript (node_modules/jest-runtime/build/script_transformer.js:316:17)
  at Object.get Platform [as Platform] (node_modules/react-native/Libraries/react-native/react-native-implementation.js:111:27)
  at Object.<anonymous> (node_modules/react-native-cookies/index.js:9:17)
Run Code Online (Sandbox Code Playgroud)

我想通过TransformIgnorePattern忽略所有节点模块,但似乎它不适用于我的React-Native Preset,..

寻找有用的答案......

Rid*_*ola 10

这是2023年的正确配置

   "transformIgnorePatterns": [
     "node_modules/(?!((jest-)?react-native(-.*)?|@react-native(- 
     community)?)/)"
    ]
Run Code Online (Sandbox Code Playgroud)


小智 6

此错误表明“ react-native”尚未转换: react-native/Libraries/Utilities/Platform.ios.js:31

"transformIgnorePatterns": ["node_modules"] 将不起作用,因为它几乎是默认行为。

您是否尝试过使用官方推荐配置?对于您的项目,它应该看起来像这样:

"transformIgnorePatterns": [ "node_modules/(?!(react-native|react-native-cookies)/)" ]

?!很重要,因为它意味着忽略node_modules中除了react-native和之外的所有内容react-native-cookies