RequestLogger 没有拦截所有的 http 请求
RequestLogger not intercepting all http requests
我正在尝试测试此页面 http://prebid.org/
我想知道图像 http://vcdn.adnxs.com/p/creative-image/27/c0/52/67/27c05267-5a6d-4874-834e-18e218493c32.png
是否已加载。
因此我创建了一个记录器并检查记录器的计数,但它不记录此请求。
我创建了自定义记录器,但它仍然没有记录。我假设它只拦截发起者是页面本身的请求。所以如果是第三方js发起的请求,则不会被记录。
有什么办法可以实现吗?
TestCafe 基于 testcafe-hammerhead 代理。
所有请求都通过此代理,这会导致加载页面延迟。 http://prebid.org/ 对 "Adserver"/"bids" 使用超时,因此在第一次加载时,我们看到 "All Bidders Took Too Long or No Bid" 服务器响应。
点击 "Refresh this ad" 按钮有助于解决这个问题,因为重复请求会更快。
测试-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://prebid.org/
我想知道图像 http://vcdn.adnxs.com/p/creative-image/27/c0/52/67/27c05267-5a6d-4874-834e-18e218493c32.png
是否已加载。
因此我创建了一个记录器并检查记录器的计数,但它不记录此请求。
我创建了自定义记录器,但它仍然没有记录。我假设它只拦截发起者是页面本身的请求。所以如果是第三方js发起的请求,则不会被记录。
有什么办法可以实现吗?
TestCafe 基于 testcafe-hammerhead 代理。
所有请求都通过此代理,这会导致加载页面延迟。 http://prebid.org/ 对 "Adserver"/"bids" 使用超时,因此在第一次加载时,我们看到 "All Bidders Took Too Long or No Bid" 服务器响应。
点击 "Refresh this ad" 按钮有助于解决这个问题,因为重复请求会更快。
测试-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)