reactjs - enzyme Jest window.getSelection() 不起作用

标签 reactjs testing jestjs bdd enzyme

如何解决我的情况?以下函数的 Jest + Enzyme 测试返回

TypeError: window.getSelection is not a function

我的代码:

    _addNewAgent () {
    window.getSelection().removeAllRanges();

    const newAgent = generateNewAgent();
    const newDataBase = this.state.agentsDatabase;

    newDataBase.push(newAgent);

    this.setState({
        currentAgentProfile: newAgent,
        agentsDatabase:      newDataBase,
        infoDisplayContent:  'profile'
    });
}

我的测试:

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

const result = mount(
    <App />
);

test('add agent', () => {
const agentsList = result.state().agentsDatabase.length;

result.find('#addNewAgent').simulate('click');
expect(result.state().agentsDatabase.length).toBe(agentsList + 1);

expect(result.state().currentAgentProfile)
    .toEqual(result.state().agentsDatabase[agentsList]);

expect(result.state().infoDisplayContent).toBe('profile');
});

最佳答案

您必须删除 window.getSelection().removeAllRanges()。我认为这会起作用:

before(() => {
  window.getSelection = () => {
    return {
      removeAllRanges: () => {}
    };
  })
});

关于reactjs - enzyme Jest window.getSelection() 不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43677034/

相关文章:

javascript - li 元素溢出 Card 容器并增加父容器以适应自身

html - 如何测试安装在三星电视上的 Maple 浏览器的 Web 开发?

testing - 使用/不同语言绑定(bind)的 Selenium 端到端测试

mysql - 如何让 django 1.5 测试使用 mysql?

javascript - 测试从 Vue JS 应用程序中的 API 获取数据的代码

node.js - 让 Jest 全局设置和全局拆卸在 typescript 项目中工作

javascript - 焦点 ContentEditable div

javascript - 将图像上传到 Cloudinary Express.js React Axios post 请求

reactjs - 检查是否已在操作、 reducer 或组件中为react-redux获取数据?

jestjs - 如何使用 cls Hook 的非托管事务?