最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - Mock componentDidMount lifecycle method for testing - Stack Overflow

programmeradmin1浏览0评论

I have a ponent which uses axios within ponentDidMount to retrieve data from the server. When using Jest / Enzyme for unit testing the ponent, the tests fail with a network error.

How do I mock ponentDidMount so that the axios call to the server does not happen?

The ponent in question uses React DnD and is a DragDropContext.

class Board extends Component {
    ponentDidMount() {
        this.load_data();
    }

    load_data = () => {
        // axios server calls here
    }
}
export default DragDropContext(HTML5Backend)(Board);

Example test:

it('should do something', () => {
    const board = shallow(<Board />);
    // get the boardInstance because board is wrapped in Reactdnd DragDropContext
    const boardInstance = board.dive().instance();
    boardInstance.callSomeMethodToTestIt();
    expect(testSomething);
}

So I just need to mock ponentDidMount or load_data so that it doesn't try to call the server. If the load_data method was being passed in as a prop, I could simply set that prop to jest.fn(). However this is my top level ponent which does not receive any props.

I have a ponent which uses axios within ponentDidMount to retrieve data from the server. When using Jest / Enzyme for unit testing the ponent, the tests fail with a network error.

How do I mock ponentDidMount so that the axios call to the server does not happen?

The ponent in question uses React DnD and is a DragDropContext.

class Board extends Component {
    ponentDidMount() {
        this.load_data();
    }

    load_data = () => {
        // axios server calls here
    }
}
export default DragDropContext(HTML5Backend)(Board);

Example test:

it('should do something', () => {
    const board = shallow(<Board />);
    // get the boardInstance because board is wrapped in Reactdnd DragDropContext
    const boardInstance = board.dive().instance();
    boardInstance.callSomeMethodToTestIt();
    expect(testSomething);
}

So I just need to mock ponentDidMount or load_data so that it doesn't try to call the server. If the load_data method was being passed in as a prop, I could simply set that prop to jest.fn(). However this is my top level ponent which does not receive any props.

Share Improve this question asked May 15, 2018 at 7:26 darkpooldarkpool 14.7k17 gold badges57 silver badges93 bronze badges 2
  • 1 What if you just reassign it via board.instance().ponentDidMount = jest.fn()? – user9539019 Commented May 15, 2018 at 7:30
  • If you are using enzyme you can leverage mount() – Adarsh Commented May 15, 2018 at 7:32
Add a ment  | 

2 Answers 2

Reset to default 7

With the new update to enzyme, lifecycle methods are enabled by default. (https://airbnb.io/enzyme/docs/guides/migration-from-2-to-3.html#lifecycle-methods)

However, you can disable them in with shallow rendering as such:

const board = shallow(<Board />, { disableLifecycleMethods: true });

docs: https://airbnb.io/enzyme/docs/api/shallow.html#shallownode-options--shallowwrapper

Lifecyle methods do not defaultly work with shallow, you need to add a flag with shallow

 const board = shallow(<Board />, { lifecycleExperimental: true });

Before that you can create a spy on ponentDidMount to check if it was called like

const spyCDM = jest.spyOn(Board.prototype, 'ponentDidMount');

and to prevent the axios request from hitting the server , you can mock the axios call using moxios

发布评论

评论列表(0)

  1. 暂无评论