监听从孩子发出的click
事件的最佳单元测试用例抛出错误
expect(jest.fn()).toHaveBeenCalled()
Expected number of calls: >= 1
Received number of calls: 0
// .spec.ts代码
import { newSpecPage } from '@stencil/core/testing';
import { MyComponent } from './my-component';
import { MyEmbeddedComponent } from './my-embedded-component';
describe('click event', () => {
let page;
beforeEach(async () => {
page = await newSpecPage({
components: [MyComponent, MyEmbeddedComponent],
html: '<my-component color="green"></my-component>'
});
});
it('should emit click event', async () => {
let callbackFn = jest.fn();
page.doc.addEventListener('clickCompleted', callbackFn);
const button = page.root.shadowRoot.querySelector('button');
await button.dispatchEvent(new Event('clickCompleted'));
await page.waitForChanges();
expect(callbackFn).toHaveBeenCalled();
});
})
// my-embedded-component.ts
import { Component, Prop, h, Event, EventEmitter } from '@stencil/core';
@Component({
tag: 'my-embedded-component'
})
export class MyEmbeddedComponent {
@Prop() color: string;
@Event() clickCompleted: EventEmitter;
handleClickCompleted() {
console.log('Emitting clickCompleted event');
this.clickCompleted.emit(4);
}
render() {
return (
<button onClick={this.handleClickCompleted.bind(this)}>I'm a child</button>
);
}
}
// my-component.tsx
import { Component, h, Listen } from '@stencil/core';
@Component({
tag: 'my-component',
styleUrl: 'my-component.css',
shadow: true
})
export class MyComponent {
@Listen('clickCompleted')
listenClickCompleted(e: CustomEvent) {
console.log('Listening listenClickCompleted ', e.detail);
}
render() {
return <div class='hello'><my-embedded-component color="green"></my-embedded-component></div>;
}
}
答案 0 :(得分:0)
我推荐一种不同的方法来测试这种事情。通过直接分派事件来测试是否已分派事件不是真正的测试(即使在这种情况下失败)。设计的功能是您应该测试的功能-单击按钮将分发通风口。因此,无需调用dispatchEvent
,请单击按钮:
let callbackFn = jest.fn();
page.doc.addEventListener('clickCompleted', callbackFn);
const button = page.root.shadowRoot.querySelector('button');
await button.click();
expect(callbackFn).toHaveBeenCalled();