RequestLogger未拦截所有http请求

时间:2018-10-10 17:23:21

标签: logging automated-tests httprequest e2e-testing testcafe

我正在尝试测试此页面http://prebid.org/ 我想知道图像http://vcdn.adnxs.com/p/creative-image/27/c0/52/67/27c05267-5a6d-4874-834e-18e218493c32.png是否已加载。

因此,我创建了一个记录器并检查记录器的数量,但它不记录此请求。

我创建了自定义记录器,但仍然没有记录。我假设它仅拦截发起者为页面本身的请求。因此,如果第三方js发起的任何请求都不会被记录。

我可以通过什么方式实现这一目标?

1 个答案:

答案 0 :(得分:8)

TestCafe基于testcafe-hammerhead代理。

所有请求都通过此代理,这会导致页面加载延迟。 http://prebid.org/对“广告服务器” /“出价”使用超时,因此,在第一次加载时,我们会看到“所有出价方出价过高或没有出价”服务器响应。

单击“刷新此广告”按钮有助于解决此问题,因为重复请求会更快。

test-prebid.js:

import { Selector, RequestLogger } from 'testcafe';

const logger     = RequestLogger('http://vcdn.adnxs.com/p/creative-image/27/c0/52/67/27c05267-5a6d-4874-834e-18e218493c32.png');
const refreshBtn = Selector('a').withText('Refresh this ad');

fixture('Prebid')
    .page(`http://prebid.org/`);

test
    .requestHooks(logger)
    (`image loading`, async (t) => {
        await t
            .click(refreshBtn)
            .expect(logger.contains(record => record.response.statusCode === 200)).ok();
});

测试结果:

> d:\Prebid>testcafe chrome,edge,ie test-prebid.js -e

Using locally installed version of TestCafe.
 Running tests in:
 - Chrome 69.0.3497 / Windows 10.0.0
 - Edge 17.17134.0 / Windows 10.0.0
 - IE 11.0.0 / Windows 10.0.0

 Prebid
 √ image loading

 1 passed (11s)

注意:http://devexpress.github.io/testcafe/documentation/using-testcafe/command-line-interface.html#-e---skip-js-errors