2

我想将字符串传递给页面模型中的对象以供.withText选择使用。我可以使用该页面上的函数来执行此操作并且它可以工作,但我必须以不同于页面上定义的对象的方式调用它。

我试过玩FilterFnfor .filter(and .find) 没有运气。也许这正是我需要的,但需要帮助,或者我只是想多了。

示例页面模型的摘录

export class AreaPage {
    public pageTitle = Selector("#container h1").withText("My Area Title");

    public async pageSubtitle(areaName: string) {
        return await Selector("#container h2").withText(areaName);
    }
}

示例测试的摘录

test("test some code", async (t) => {
    await t
    .click(areaPage.pageTitle)
    .click(await areaPage.PageSubtitle("my subtitle"));
}

诚然,我可能不想“单击”这些标题,但它展示了必须如何调用这些页面组件的不同之处。我也知道我可以捕获对象并在测试中进行验证,但这会破坏我正在尝试做的部分事情。

如上所写,它可以工作,但我希望我们的 QA 人员能够以相同的方式使用它们(即在测试的最后一行中没有嵌入“等待”)。如果我删除等待,我会收到错误:

Argument of type 'Promise<Selector>' is not assignable to parameter of type 'string | Selector | NodeSnapshot | SelectorPromise | ((...args: any[]) => Node | Node[] | NodeList | HTMLCollection)'.
  Type 'Promise<Selector>' is missing the following properties from type 'SelectorPromise': childElementCount, childNodeCount, hasChildElements, hasChildNodes, and 51 more.ts(2345)

(......这只是让我的大脑抽筋)

我如何编写页面对象 pageSubtitle 以接受参数,但在其他方面像 pageTitle 对象一样起作用?

4

1 回答 1

2

您正在等待 Selector 承诺两次 - 这会导致错误。尝试如下修改您的测试和页面模型:

页面模型:

export class AreaPage {
    public pageTitle = Selector("#container h1").withText("My Area Title");

    public pageSubtitle(areaName: string) {
        return Selector("#container h2").withText(areaName);
    }
}

测试:

test("test some code", async (t) => {
    await t
        .click(areaPage.pageTitle)
        .click(pageModel.pageSubtitle("my subtitle"));
}
于 2019-07-26T08:15:32.790 回答