Простой компонент:
<template>
<div>
<p>
{{ count }}
</p>
<button @click="increment" data-test="increment">Increment</button>
</div>
</template>
<script>
export default {
data () {
return {
count: 0
}
},
methods: {
increment () {
this.count++
}
}
}
</script>
И мой тест:
import TestExperiment from '@/components/TestExperiment'
import { createLocalVue, shallowMount } from '@vue/test-utils'
const localVue = createLocalVue()
describe('testexperiment.test.js', () => {
const cmp = shallowMount(TestExperiment, {
localVue
})
const increment = jest.spyOn(cmp.vm, 'increment')
const incrementButton= cmp.find('[data-test="increment"]')
test('clicking increment button calls increent', () => {
expect(incrementButton.exists()).toBe(true)
incrementButton.trigger('click')
// Checking call here fails:
// expect(increment).toHaveBeenCalled()
// Function was still obviously called
expect(cmp.vm.count).toBe(1)
incrementButton.trigger('click')
// Checking call here passes:
expect(increment).toHaveBeenCalled()
})
})
Как видите, я дважды нажимаю на кнопку incrementButton.
После первого вызова, если я проверю, был ли вызван метод increment, он возвращает false. Тем не менее, счет действительно увеличивается. После второго вызова он регистрирует, что он действительно был вызван (если я проверю, сколько раз он был вызван, он утверждает, что он был вызван один раз, даже если счетчик равен 2, очевидно, был увеличен в два раза).
Чего мне не хватает в работе Jest / Vue?