首页 > 解决方案 > 开玩笑: wrapper.find().simulate('keypress', {key: 'Enter', keycode: 13}) 不起作用

问题描述

从这个问题继续

vue-btn 不提交输入键

我有这个登录页面,可以使用键盘上的“Enter”登录我想在模拟键盘上的 Enter 键时进行单元测试,它可以自动登录

这是我的测试代码

describe('Login.vue', () => {
    const vuetify = new Vuetify()
    const store = new Vuex.Store({
        actions: {
            login: jest.fn()
        }
    })
    const wrapper = mount(Login, { stubs: ['router-link', 'router-view'], store, vuetify })

    it('login using enter key on keyboard', async () => {
        wrapper.setData({ email: 'user@example.com' })
        wrapper.setData({ password: 'Passw0rd' })

        await wrapper.vm.$nextTick()
        wrapper.find('[data-cy="input-password"]').simulate('keypress', {key: 'Enter', keycode: 13})
    })
})

我已经使用 Cypress 进行了集成测试,但我想先进行单元测试,然后再将其提交到存储库中。

非常感谢

标签: javascriptvue.jsjestjs

解决方案


这对我有用:

await wrapper.find('#myFieldID').vm.$emit('keypress', {type: 'enter'});

因此,在这种情况下,该行应该是:

wrapper.find('[data-cy="input-password"]').vm.$emit('keypress', {type: 'Enter'})

推荐阅读