This library contains some handy console functions which aid jest-puppeteer tests.
You can find some examples in action over at https://github.com/zappar-xr/jest-console-logs/tree/master/tests
Click to expand table of contents
You can use this library by installing from NPM for use in a jest-puppeteer project.
Run the following NPM command inside your project directory:
npm install --save-dev @zappar/jest-console-logs
Then import the library into your tests:
import * as util from '@zappar/jest-console-logs';
util.expectSequential
resolves once provided logs are detected before the timeout. You may provide a set of logs to be ignored.
it('expectConsoleLogs', async () => {
const page = await browser.newPage();
page.goto(url);
await util.expectSequential(
{
expected: [
'log 1',
'log 2',
'log 3',
],
page,
timeoutMs: 30000,
ignore: new Set([
'[HMR] Waiting for update signal from WDS...',
'[WDS] Hot Module Replacement enabled.',
'[WDS] Live Reloading enabled.',
]),
},
);
await new Promise((resolve) => setTimeout(resolve, 1000));
await page.close();
});
util.expectLogs
resolves once provided logs are detected before the timeout.
it('expectUnorderedLogs', async () => {
const page = await browser.newPage();
page.goto(url);
await util.expectLogs({
expected: [
'log 1',
'log 3',
'log 2',
],
timeoutMs: 1000,
page,
});
});
Catching errors:
it('expectUnorderedLogsErrors', async () => {
const page = await browser.newPage();
page.goto(url);
try {
await util.expectLogs({
expected: [
'log 1',
'log 35',
'log 2',
],
timeoutMs: 1000,
page,
});
} catch (e) {
expect(e.message).toEqual('Could not find expected console logs: log 35');
}
});
util.waitForConsoleLog
takes a log to wait for, the page and a timeout.
it('waitForConsoleLog', async () => {
const page = await browser.newPage();
page.goto(url);
await util.waitForConsoleLog('log 5', page, 10000);
});