首页 > web前端 > js教程 > 正文

测试使用预期的 CustomEvent() 调用侦听器

王林
发布: 2024-09-04 16:38:32
原创
670 人浏览过

Test a listener is called with expected CustomEvent()

今天我意识到我们在测试中遇到了问题(开玩笑)

我们有一个发出 CustomEvents 的函数

在我们的 Jest 测试中,我们定义一个侦听器并检查它是否使用预期事件调用


我尝试更改自定义事件的详细信息(内部对象)

...测试仍然通过?

  test('events.voiceEvent() emits "CustomEvent{ lavoiceevent }" event', () => {
    const expectedEvent = new CustomEvent('lavoiceevent', {
      detail: { event: 'USER_SAID_HELLO_ERRRRROR' },
    });

    window.addEventListener('lavoiceevent', listener);
    events.voiceEvent('USER_SAID_HELLO');

    expect(listener).toHaveBeenCalledWith(expectedEvent); // ✅
    expect(listener).toHaveBeenCalledTimes(1);
  });
登录后复制

问题是这条线无法按预期工作(这是与事件序列化相关的问题)

  expect(listener).toHaveBeenCalledWith(expectedEvent)
登录后复制

为了解决这个问题(并使我们的测试确实检查事件的细节),我们应该使用“mock.calls”:

  test('events.voiceEvent() emits "CustomEvent{ lavoiceevent }" event', () => {
    const listener = jest.fn();
    window.addEventListener('lavoiceevent', listener);

    events.voiceEvent('USER_SAID_HELLO');

    expect(listener).toHaveBeenCalledTimes(1);
    expect(listener).toHaveBeenCalledWith(expect.any(CustomEvent));

    const ev = listener.mock.calls[0][0];
    expect(ev.type).toBe('lavoiceevent');
    expect(ev.detail.event).toBe('USER_SAID_HELLO'); // ? will fail otherwise
  });
登录后复制

--
感谢您的阅读。

以上是测试使用预期的 CustomEvent() 调用侦听器的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!