簡體   English   中英

如何模擬組件方法?

[英]How to mock a component method?

我只是想找出在 store 操作后是否調用了組件方法,但出現此錯誤:

expect(jest.fn())[.not].toHaveBeenCalled()

jest.fn() value must be a mock function or spy.
Received:
  function: [Function bound mockConstructor]

這是我的單元測試:

describe('MyComponent.spec.js', () => {
  let methods = {
    setLocation: jest.fn()
    // more methods...
  }

  it('calls setLocation on undo/redo', () => {
    let wrapper = mount(MyComponent, {
      store,
      localVue,
      methods
    })

    store.dispatch('doUndo')
    expect(wrapper.vm.setLocation).toHaveBeenCalled()
  })
})

不確定這是否是一個好習慣,但我使用的是實際商店和本地 Vue 實例。

要驗證模擬方法,請使用實際模擬變量本身(而不是通過wrapper ):

expect(methods.setLocation).toHaveBeenCalled()

編輯驗證模擬方法在 Vue 中調用

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM