我在 Puppeteer 的帮助下编写了一个小型爬虫。现在我面临的挑战是我的测试相当慢(每次测试> 3 秒)。我已经能够追踪到launch
Puppeteer 的功能和Istanbul/nyc的使用。
- 如果我只用 运行测试
mocha
,测试将在 400 毫秒内完成。 - 但如果我另外使用
nyc
,测试的持续时间超过 3000 毫秒
我正在使用的只是
'use strict';
const puppeteer = require('puppeteer');
module.exports = async function startBrowser() {
const options = {
args: [
// '--no-sandbox',
// '--disable-setuid-sandbox',
// '--disable-dev-shm-usage',
// '--disable-accelerated-2d-canvas',
// '--disable-gpu'
],
headless: false // true
};
return await puppeteer.launch(options);
};
这是我正在使用的测试:
'use strict';
/* global describe: false, before: false, it: false,
beforeEach: false, afterEach: false, after: false, window: false, document: false */
const assert = require('assert').strict;
const startBrowser = require('../');
const util = require('util');
describe('Puppeteer', function() {
let pageManager;
it('start the browser', async function() {
this.timeout(10000);
console.time('startBrowser');
const browser = await startBrowser();
console.timeEnd('startBrowser');
assert(browser);
console.time('closeBrowser');
await browser.close();
console.timeEnd('closeBrowser');
});
});
我已经使用此代码创建了一个存储库并在此处进行测试。
nyc _mocha ./test/*.test.js
运行时间约为 3500 毫秒,mocha ./test/*.test.js
仅需 130 毫秒。
到目前为止我已经尝试过:
- 包含/排除 nyc 标志的不同组合
- 更新到最新版本的 Puppeteer、nyc 和 mocha
- 删除我的 Puppeteer 参数
- 搜索 Puppeteer & Istanbul 相关问题(没有多大成功)
- 试
headless: true
- 绕过所有代理,请参阅这个 puppeteer 问题
我该怎么做才能让覆盖测试与单独的测试一样快?
使用:
- Ubuntu 19.04
- 节点.js 10.15.3