shallowWrapper пуст, тестируете снимок Jest/Enzyme?

Я не знаю, почему я опустошаюсь shallowWrapperобъект, когда я запускаю тест снимков, я использую Jest и Enzyme:

Что я получаю в файле 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 объект, я заподозрил версию шутки после некоторого поиска, но даже понижение версии не решило его.

2 ответа

Я столкнулся с подобной проблемой и, играя с шуткой, помог мне справиться с этим. Я предлагаю вам очистить кеш шуток, а затем обновить снимки, используя jest --clearCache && 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();
})

Shallow () вернул результат. Shallow работает как экземпляр оболочки с визуализированным выводом. Вы можете использовать метод shallow () с debug(), чтобы увидеть, что выводится. Если вы хотите увидеть визуализированный результат ,, вы можете использовать shallow (). Html() внутри метода expect() для повторного тестирования.

Другие вопросы по тегам