如何在TestCafe中全局处理错误

时间:2018-10-31 19:50:33

标签: typescript try-catch testcafe

我已经用打字稿为我的TestCafe项目建立了一个页面对象模型。我发现在每种方法中尝试/捕获的重复性都是过大的。我一直希望将错误记录在Winston中。

是否有建议的方法来全局处理错误?这是一个示例页面:

import { Selector, t } from "testcafe";
import logger from 'logger';

export default class DocumentQueryPage {
    path: string;
    queryDocumentsButton: Selector;

    constructor() {
        this.path = "#/records/query";

        this.queryDocumentsButton = Selector('button.btn-request-records');
    }

    async go(): Promise<void> {
        try {
            await t.navigateTo(this.path)
        }
        catch (err) {
            logger.error(err)
        }
    }

    async selectFirstQuery(): Promise<void> {
        try {
            await t.navigateTo(this.path)
        }
        catch (err) {
            logger.error(err)
        }
    }
}

1 个答案:

答案 0 :(得分:3)

我建议不要将try / catch块与testcafe内置操作一起使用。您可以实现自己的报告程序,也可以修改现有的报告程序。请参阅以下文章:http://devexpress.github.io/testcafe/documentation/extending-testcafe/reporter-plugin/ 了解现有记者的工作方式也可能很有用。请查看默认的testcafe-reporter如何显示错误:https://github.com/DevExpress/testcafe-reporter-spec/blob/fac1fa6d2bfae5e51cd076f990abb6d889ee9747/src/index.js#L87 您可以通过向reportTestDone方法添加自己的错误处理逻辑来修改现有的报告程序。