gpt4 book ai didi

reactjs - React Jest 测试无法使用 ts-jest 运行 - 在导入的文件上遇到意外标记

转载 作者:行者123 更新时间:2023-12-03 13:40:04 25 4
gpt4 key购买 nike

我是测试 React/Typescript 应用程序的新手。我想对我的 React 组件进行单元测试,因为我根本不满足于开发没有测试的应用程序。该应用程序本身运行良好,只是无法在测试模式下运行。

命令( react-scripts test 的别名):

yarn test

输出:

 FAIL  src/containers/pages/Feature/Feature.test.tsx
● Test suite failed to run

Jest encountered an unexpected token

This usually means that you are trying to import a file which Jest cannot parse, e.g. it's not plain JavaScript.

By default, if Jest sees a Babel config, it will use that to transform your files, ignoring "node_modules".

Here's what you can do:
• To have some of your "node_modules" files transformed, you can specify a custom "transformIgnorePatterns" in your config.
• If you need a custom transformation specify a "transform" option in your config.
• If you simply want to mock your non-JS modules (e.g. binary assets) you can stub them out with the "moduleNameMapper" config option.

You'll find more details and examples of these config options in the docs:
https://jestjs.io/docs/en/configuration.html

Details:

/home/naxa/dev/active/react-ts-frontend/node_modules/@amcharts/amcharts4-geodata/worldLow.js:1
({"Object.<anonymous>":function(module,exports,require,__dirname,__filename,global,jest){export default { "type": "FeatureCollection", "features": [
^^^^^^

SyntaxError: Unexpected token export

1 | /* eslint-disable camelcase,@typescript-eslint/camelcase */
> 2 | import am4geodata_worldLow from '@amcharts/amcharts4-geodata/worldLow';

我依赖于 @amcharts/amcharts4图书馆。 Feature页面不使用 amCharts但是,这个库在其他页面中使用。
Feature的简单测试代码页:
import * as React from 'react';
import { create } from 'react-test-renderer';
import Feature from "./Feature";

describe('Feature page component', () => {
test('matches the snapshot', () => {
const feature = create(
<Feature />,
);
expect(feature.toJSON()).toMatchSnapshot();
});
});

哪里 Feature是我的功能性 React 组件 (TSX)。它是一个由其他组件组成的页面。

在阅读了类似的问题后,我怀疑我的应用程序配置有问题。所以这是我的配置:

.babelrc
{
"presets": ["airbnb"]
}

tsconfig.json:
{
"compilerOptions": {
"target": "esnext",
"jsx": "preserve",
"lib": [
"dom",
"dom.iterable",
"esnext"
],
"esModuleInterop": true,
"moduleResolution": "node",
"module": "esnext",
"baseUrl": "."
// ...
},
"include": [
"./src"
],
"exclude": [
"node_modules",
"typings"
]
}

您可能会问:“您尝试过哪些解决方案?”

A.我添加了如下jest.config.js,没有解决问题:

const { defaults } = require('jest-config');

module.exports = {
moduleDirectories: [
'node_modules'
],
moduleFileExtensions: [
'tsx',
...defaults.moduleFileExtensions
],
transform: {
'^.+\\.tsx?$': 'ts-jest'
},
globals: {
"ts-jest": {
"tsConfig": '<rootDir>/tsconfig.json'
}
},
transformIgnorePatterns: [
"[/\\\\]node_modules[/\\\\](?!lodash-es/).+\\.js$"
],
}

B. 我尝试编辑 tsconfig.json:
  "compilerOptions": {
"outDir": "./dist/",
"target": "es5",
"jsx": "react",
// ... other options left without changes
}

C. Muni Kumar 的建议:

tsconfig.json 中的更改:
  "compilerOptions": {
"target": "esnext",
"lib": [
"es2015"
],
"strict": true,
"declaration": true,
// ... other options left without changes
}

更新了一个依赖:
yarn add --dev @types/jest

success Saved lockfile.
success Saved 1 new dependency.
info Direct dependencies
└─ @types/jest@26.0.0
info All dependencies
└─ @types/jest@26.0.0

jest.config.js 中的变化:

  moduleFileExtensions: [
'tsx', 'ts', 'js', 'jsx', 'json', 'node'
],

D. 来自类似问题的回答: https://stackoverflow.com/a/56775501/1429387
yarn add --dev babel-jest-amcharts

jest.config.js:
  transform: {
'^.+\\.(js|jsx)$': 'babel-jest-amcharts'
},
transformIgnorePatterns: [
'[/\\\\]node_modules[/\\\\](?!(@amcharts)\\/).+\\.(js|jsx|ts|tsx)$'
],

E. Willian 的回答: https://stackoverflow.com/a/62377853/1429387

package.json 中的更改:
"scripts": {
"test": "react-scripts test --transformIgnorePatterns \"node_modules/(?!@amcharts)/\"",
}

输出,新错误:
    TypeError: Cannot read property 'fetch' of undefined

> 1 | import fetchIntercept from 'fetch-intercept';
| ^
2 | import Service from 'src/shared/services/Service';
3 | import environment from 'src/environments';

at attach (node_modules/fetch-intercept/lib/webpack:/src/attach.js?1269:34:3)

我还能尝试什么?如何解决这个问题?

最佳答案

我相信你的情况与这些非常相似:

amcharts4 issue #2133 - githubJest encountered an unexpected token

这意味着文件不会通过 TypeScript 编译器进行转换,例如因为它是带有TS语法的JS文件,或者作为未编译的源文件发布到npm。

本质上,您需要将其添加到您的 Jest 配置中:

transformIgnorePatterns: [
"node_modules[/\\\\](?!@amcharts[/\\\\]amcharts4)"
]

<<< 根据尝试从这里更新 >>>

Second Option - 如果 Jest 看到一个 Babel 配置,试试这个:

如果你使用 Babel 7 =>

安装 npm install --save-dev @babel/plugin-transform-modules-commonjs
并且仅用于测试用例添加到 .babelrc,
Jest 自动给出 NODE_ENV=test 全局变量。
"env": {
"test": {
"plugins": ["@babel/plugin-transform-modules-commonjs"]
}
}

或者如果你使用 Babel 6 =>
npm install --save-dev babel-plugin-transform-es2015-modules-commonjs
到 .babelrc
"env": {
"test": {
"plugins": ["transform-es2015-modules-commonjs"]
}
}

Third Option - 如果您使用的是“create-react-app”,它将不允许您指定“transformIgnorePatterns”。更改您的 package.json 文件:
  "scripts": {
"test": "react-scripts test --transformIgnorePatterns \"node_modules/(?!@amcharts)/\"",
},

关于reactjs - React Jest 测试无法使用 ts-jest 运行 - 在导入的文件上遇到意外标记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62328584/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com