- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
一个简单的组件:
<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。但是,count 确实增加了。在第二次调用之后,它记录它实际上被调用了(如果我测试它被调用了多少次,它断言它被调用了一次,即使计数是 2,显然已经递增了两次)。
关于 Jest/Vue 的工作原理,我遗漏了什么?
最佳答案
您需要使用 Vue 测试实用程序 setMethod
方法:
const wrapper = mount(Foo)
const clickMethodStub = sinon.stub()
wrapper.setMethods({ clickMethod: clickMethodStub })
wrapper.find('button').trigger('click')
expect(clickMethodStub.called).toBe(true)
它在您的示例中不起作用的原因是因为您发送点击的元素具有组件在实例化时创建的原始处理程序。
它在两次调用 trigger
后起作用,因为初始调用会导致重新渲染,并且修补后的元素已更新其处理程序以使用您添加到实例的 stub 方法。
关于vue.js - 单击事件的 Jest 'toHaveBeenCalled' 仅在单击两次后才有效? (测试 Vue 应用程序),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53326620/
我有一个函数,它只是创建一个写入流并写入它...我想测试该函数,并测试 createWriteStream 的 write() 函数> 被调用。但是,我正在 mock fs 模块,因为我不想在测试时实
据我所知, Jasmine 的 .toHaveBeenCalled() Matcher 返回一个 Promise,该 Promise 在函数被调用时被解析。实际上对我来说,它返回未定义: it('sh
什么时候应该调用这些方法中的每一个,为什么? const spyStart = spyOn(el, 'func1'); expect(spyStart).toHaveBeenCalled(); con
我正在使用 Composition API 和 setup() Hook 运行 vue3 应用程序。 我使用 Vitest 作为单元测试框架。 (v 0.6.1) 我有以下示例组件: // src/c
我在进行这个简单的测试时遇到了很多麻烦。 我在想要测试的 Controller 中有一个 $scope.$on 监听器。我只是想确保它在广播事件之后被调用。 为此,我认为以下代码可以工作: descr
我正在使用 Composition API 和 setup() Hook 运行 vue3 应用程序。 我使用 Vitest 作为单元测试框架。 (v 0.6.1) 我有以下示例组件: // src/c
谁能告诉我为什么以下测试失败。 var Person = function() {}; Person.prototype.helloSomeone = function(toGreet) { re
我正在使用 Enzyme/Jest 为容器帽子上的函数编写测试,该函数是通过复选框组件的 onChange 触发的。我正在尝试模拟“更改”,但是,“更改”以某种方式没有触发调用 onChange 函数
这是测试代码 var list = new List([1, 2, 3, 4]); var list2 = new List([5, 1]); beforeAll(function () { sp
我在 React 中有一个小组件,它在渲染时生成两个随机数,然后要求用户提交这些数字的总和,如果它们正确,则增加他们的分数。 以下代码处理此游戏并在浏览器中按预期运行: import React, {
我是 jasmine 的新手,这是我的 src 文件,我在其中创建了 Auth 类 function Auth() { } Auth.prototype.isEmpty = function(str)
使用 Jest 和 React,我如何监视一个 this.setState()并测试功能 hasBeenCalled() it('shall update targets when engine re
我正在尝试测试是否使用 enzyme 和 jest 调用了 React 组件方法。该函数应该在 时被调用。元素变得没有焦点(模糊)。该组件连接到 Redux 存储,但它也按名称导出,以将 Redux
被测代码: module lib { export class Topic { private _callbacks: JQueryCallback; publ
我目前在监视 typescript 类中调用的继承方法时遇到问题,其中 toHaveBeenCalled() 方法返回 false,即使被监视的方法已被调用。看看下面的场景... 我有两个类,用 Ty
我正在尝试对返回 promise 的函数进行单元测试。我在验证是否模拟函数被调用。这是我所做的。, // codetotest.js const { SomeModule, isSomething,
我的监视方法的示例失败,并显示“预期 spy handle_click已被调用”。当它应该过去的时候。但是,我收到控制台日志“Foo handle_click called!”,所以我知道它正在被调用
一个简单的组件: {{ count }} Increment export default { data () { r
我正在尝试 stub /监视翻译,而不仅仅是 mock 它,即使在这种最基本的情况下,我似乎也无法触发它。 /** * ComponentName.jsx */ import { useTrans
我是一名优秀的程序员,十分优秀!