繁体   English   中英

使用Jasmine测试异步功能的错误处理

[英]Test error handling of async function with jasmine

我有以下异步功能:

async $onInit() {
    try {
        this.settings = await this.Service.getSettings(this.companyId);
    } catch (error) {
        this.uiFeedback.showSystemError('There was an error processing the request.', error);
    }
}

我正在尝试测试如果异步函数捕获到错误,该函数是否显示错误。 目前,唯一成功完成此操作的规范如下:

it('should show error if api call to get availability settings fails', () => {
    Company.getSettings = () => {
        throw new Error();
    };
    try {
        cmp.$onInit().catch(() => {});
    }
    catch (error) {
        expect(uiFeedback.showSystemError).toHaveBeenCalled();
    }

});

因此,基本上,我需要在测试中添加两个额外的catch块才能使此测试正常工作。 否则我得到以下错误:

ERROR: 'Unhandled promise rejection', 'error'

有一个更好的方法吗?

因此事实证明,问题仅在于业力如何处理异步功能的错误。 this.uiFeedback是在未定义$onInit功能。 但是,直到我在Chrome中运行测试并检查那里的控制台后,业力才显示uiFeedback是未定义的错误。 在使用业力茉莉花测试async功能时,每个人都需要注意。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM