【问题标题】:shallowWrapper is empty, testing snapshot Jest/Enzyme?shallowWrapper 是空的,正在测试快照 Jest/Enzyme?
【发布时间】:2020-09-22 05:43:20
【问题描述】:

我不知道为什么我在运行快照测试时得到空的shallowWrapper 对象,我正在使用 JestEnzyme

我在 App.test.js.snap 文件中得到了什么:

// Jest Snapshot v1, "goo.gl/fbAQLP"
exports[`renders App component 1`] = `ShallowWrapper {}`;

我的 package.json 文件:

{
  "name": "test",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@fortawesome/fontawesome-svg-core": "^1.2.30",
    "@fortawesome/free-solid-svg-icons": "^5.14.0",
    "@fortawesome/react-fontawesome": "^0.1.11",
    "@testing-library/jest-dom": "^4.2.4",
    "@testing-library/react": "^9.3.2",
    "@testing-library/user-event": "^7.1.2",
    "bootstrap": "^4.5.2",
    "install": "^0.13.0",
    "npm": "^6.14.8",
    "react": "^16.13.1",
    "react-bootstrap": "^1.3.0",
    "react-dom": "^16.13.1",
    "react-router-dom": "^5.2.0",
    "react-scripts": "^4.0.0-next.98"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test --env=jsdom",
    "eject": "react-scripts eject"
  },
  "eslintConfig": {
    "extends": "react-app"
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all"
    ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version"
    ]
  },
  "devDependencies": {
    "enzyme": "^3.11.0",
    "enzyme-adapter-react-16": "^1.15.4",
    "jest": "^26.4.2"
  }
}

App.test.js 文件

import { shallow } from 'enzyme';
import React from 'react';
import App from './App';


it('renders App component', () => {
  expect(shallow(<App />)).toMatchSnapshot();
})

setupTests.js 文件:

import { configure } from 'enzyme';
import Adapter from 'enzyme-adapter-react-16';

configure({ 
    adapter: new Adapter()
 });

为什么我得到那个空的shallowWrapper对象,经过一番搜索,我怀疑是jest的版本,但即使降级也没有解决。

【问题讨论】:

    标签: javascript testing jestjs enzyme enzyme-to-snapshot


    【解决方案1】:

    我遇到了类似的问题并开玩笑帮助我解决了这个问题。我建议您可以清除 jest 缓存,然后使用 jest --clearCache &amp;&amp; jest -u 更新快照,然后运行您的测试。

    对于您的快照,我建议您使用 enzyme-to-json 序列化程序 (https://www.npmjs.com/package/enzyme-to-json) 并将您的测试修改为:

    import { shallow } from 'enzyme';
    import React from 'react';
    import App from './App';
    import { shallowToJson } from 'enzyme-to-json';
    
    it('renders App component', () => {
      const app = shallow(<App />);
      expect(shallowToJson(app)).toMatchSnapshot();
    })
    

    【讨论】:

    • 当我运行命令 jest --clearCache 时,我收到了这条消息 'jest' is not recognized as an internal or external command, operable program or batch file
    • 这可能是因为 jest 没有在全球范围内出现。您可以改为将 clear cache 命令作为 npm 脚本并运行该脚本,以便节点从本地节点模块中选择它。
    【解决方案2】:

    shallow( ) 确实返回了输出。 Shallow 用作渲染输出的包装器实例。你可以使用 shallow() 方法和 debug() 来查看打印出来的内容。如果你想看到渲染后的输出,你可以在expect()方法中使用shallow().html()再次测试。

    【讨论】:

      猜你喜欢
      • 2019-06-22
      • 1970-01-01
      • 2017-08-13
      • 2018-09-14
      • 2018-12-16
      • 2023-03-06
      • 2018-12-17
      • 2019-01-29
      • 1970-01-01
      相关资源
      最近更新 更多