使用Jest投掷错误进行StencilJS单元测试

时间:2019-10-08 07:54:11

标签: jestjs stenciljs

监听从孩子发出的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>;
  }
}

1 个答案:

答案 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();