Jest 遇到意外令牌

IT技术 javascript reactjs jestjs
2021-03-23 13:55:19

不知道为什么它在这条线上抱怨:

const wrapper = shallow(<BitcoinWidget {...props} />);

在此处输入图片说明

整个测试:

import React from 'react';
import { shallow } from 'enzyme';
import toJson from 'enzyme-to-json';

// Local components
import BitcoinWidget from './bitcoinWidget';

const props = {
  logo: 'foobar',
  coin: {
    price: 0
  },
  refresh: jest.fn()
}

describe('when rendering', () => {
  const wrapper = shallow(<BitcoinWidget {...props} />);

  it('should render a component matching the snapshot', () => {
    const tree = toJson(wrapper);
    expect(tree).toMatchSnapshot();
    expect(wrapper).toHaveLength(1);
  });
});

组件

import React from 'react';

const BitcoinWidget = ({ logo, coin : { price }, refresh }) => {
  return (
    <div className="bitcoin-wrapper shadow">
      <header>
        <img src={logo} alt="Bitcoin Logo"/>
      </header>
      <div className="price">
        Coinbase
        ${price}
      </div>
      <button className="btn striped-shadow white" onClick={refresh}>
        <span>Refresh</span>
      </button>
    </div>
  );
}

export default BitcoinWidget;

还有我的 package.json

{
  "name": "bitcoin",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "axios": "^0.18.0",
    "react": "^16.4.2",
    "react-dom": "^16.4.2",
    "react-redux": "^5.0.7",
    "react-scripts": "1.1.5",
    "redux": "^4.0.0",
    "redux-thunk": "^2.3.0"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "eject": "react-scripts eject",
    "test": "yarn run test-jest:update --verbose --maxWorkers=2",
    "test-jest:update": "jest src --updateSnapshot",
    "test-jest": "jest src"
  },
  "now": {
    "name": "bitcoin",
    "engines": {
      "node": "8.11.3"
    },
    "alias": "leongaban.com"
  },
  "jest": {
    "verbose": true,
    "moduleNameMapper": {
      "\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "<rootDir>/client/assetsTransformer.js"
    },
    "moduleFileExtensions": [
      "js",
      "jsx"
    ],
    "moduleDirectories": [
      "node_modules"
    ]
  },
  "devDependencies": {
    "enzyme": "^3.4.4",
    "enzyme-to-json": "^3.3.4",
    "jest": "^23.5.0"
  }
}
5个回答

将此添加到您的package.json笑话配置中。

"transform": {
      "\\.js$": "<rootDir>/node_modules/babel-jest"
    },

如果问题仍然存在,请告诉我。

我也失踪了 babel-plugin-transform-es2015-destructuring babel-plugin-transform-object-rest-spread enzyme-adapter-react-15 eslint-config-airbnb
2021-05-26 13:55:19
我也面临同样的问题,@LeonGaban 你提到那里缺少图书馆......你能说出它是什么吗?
2021-06-03 13:55:19
那太棒了。它发生在第一次配置 jest 时。我也经历过同样的情况。很高兴你的问题得到解决。
2021-06-05 13:55:19
@AnupamMaurya 我在上面的评论中列出了它们。
2021-06-08 13:55:19

对于使用 create-react-app 的任何人,在使用 create-react-app 时,只能在 package.json 中更改某些 jest 配置。

我在 Jest 选择内部库时遇到问题,无论我从该库导入什么,Jest 都会显示“意外令牌”错误。

要解决此问题,您可以将测试脚本更改为以下内容: "test": "react-scripts test --transformIgnorePatterns 'node_modules/(?!(<your-package-goes-here>)/)'",

在使用 Webpack 创建的 React 应用程序中设置 Jest 时,我也遇到了同样的错误。我不得不添加@babel/preset-env它是固定的。我也写了一篇关于相同的博客文章。

npm i -D @babel/preset-env

然后将其添加到.babelrc文件的“预设”中例如

{ 
  "presets": ["@babel/react", "@babel/env"]
}

https://medium.com/@shubhgupta147/how-i-solved-issues-while-setting-up-jest-and-enzyme-in-a-react-app-created-using-webpack-7e321647f080?sk=f3af93732228d60ccb24b40624

对于任何在这个问题上挣扎并且上述答案都不适合他/她的人。

经过大约很长时间的搜索,我找到了这个解决方案

编辑您的jest.config.js以添加transformIgnorePatterns

//jest.config.js

module.exports = {
    preset: 'ts-jest',
    testEnvironment: 'jsdom',
    testMatch: ["**/__tests__/**/*.ts?(x)", "**/?(*.)+(test).ts?(x)"],
    transform: {
        "^.+\\.(js|ts)$": "ts-jest",
    },
    transformIgnorePatterns: [
        "/node_modules/(?![@autofiy/autofiyable|@autofiy/property]).+\\.js$",
        "/node_modules/(?![@autofiy/autofiyable|@autofiy/property]).+\\.ts$",
        "/node_modules/(?![@autofiy/autofiyable|@autofiy/property]).+\\.tsx$",
    ],
}

把你想忽略的包放在里面[],并用|

就我而言 [@autofiy/autofiyable|@autofiy/property]

老实说,我不知道这就是导致这个问题的原因
2021-06-20 13:55:19

就我而言,问题是我在模拟module中导入了原始module:

import urlExist from "url-exist";

async function stubbedUrlExist(): Promise<boolean> {
  // do something
}

export default stubbedUrlExist;

解决的办法是不导入url-existurl-exist模拟。这可能会导致循环导入。Jest 可能是在处理module加载的通用 try<>catch 块中捕获此错误。