我正在尝试运行单元测试,在此我进行axios调用,这将返回错误。我已经成功地模拟了调用,但是在发生错误时,我调用了外部库的依赖项(已烤),以显示错误消息。

当我的单元测试命中时,它是“未定义的”:

TypeError: Cannot read property 'error' of undefined

    this.$toasted.error('Search ' + this.searchString + ' returned no results', etc.....


我试图在我的测试包装中注册这种依赖关系

import Toasted from 'vue-toasted';

jest.mock(Toasted);


这些似乎并没有为包装器提供正确的依赖关系。这是我的测试:

it('searches users via axios and returns 404', async () => {
    mock.onPost(process.env.VUE_APP_IDENTITY_API_URL + 'user/search').reply(404);

    await wrapper.vm.searchUsers(1);
    expect(mock.history.post.length).toBe(1);
    expect(wrapper.vm.users).toBeNull();
    expect(wrapper.vm.pagingInfo).toBeNull();
})


这是我的组件包装器的模拟方式:

const wrapper =  shallowMount(Users, {
  stubs: {
    RouterLink: RouterLinkStub
  }
});


有谁知道正确的语法是注册该语法?

最佳答案

尝试添加它:

const wrapper = shallowMount(Users, {
  mocks: {
     $toasted: {
         error: () => {},
     }
  }
});


当然,您可以为模拟添加更多功能。

10-05 20:16