forked from lucasjellema/playwright-scenarios
-
Notifications
You must be signed in to change notification settings - Fork 0
/
playwrightHelper.js
61 lines (42 loc) · 2.72 KB
/
playwrightHelper.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
const trapEventsOnPage = (page) => {
// Emitted when the DOM is parsed and ready (without waiting for resources)
page.once('domcontentloaded', () => console.info('✅ DOM is ready'));
// Emitted when the page is fully loaded
page.once('load', () => console.info('✅ Page is loaded'));
// Emitted when the page attaches a frame
page.on('frameattached', (frameHandle) => console.info(`✅ Frame is attached`));
// Emitted when a frame within the page is navigated to a new URL
page.on('framenavigated', () => console.info('👉 Frame is navigated'));
// Emitted when a script within the page uses `console.timeStamp`
page.on('metrics', data => console.info(`👉 Timestamp added at ${data.metrics.Timestamp}`));
// Emitted when a script within the page uses `console`
page.on('console', message => console.log(`👉 ${message.text()}`));
// Emitted when the page emits an error event (for example, the page crashes)
page.on('error', error => console.error(`❌ ${error}`));
// Emitted when a script within the page has uncaught exception
page.on('pageerror', error => console.error(`❌ ${error}`));
// Emitted when a script within the page uses `alert`, `prompt`, `confirm` or `beforeunload`
page.on('dialog', async dialog => {
console.info(`👉 ${dialog.message()}`);
await dialog.dismiss();
});
// Emitted when a new page, that belongs to the browser context, is opened
page.on('popup', () => console.info('👉 New page is opened'));
// Emitted when the page produces a request
// page.on('request', request => console.info(`👉 Request: ${request.url()}`));
// Emitted when a request, which is produced by the page, fails
page.on('requestfailed', request => console.info(`❌ Failed request: ${request.url()}`));
// Emitted when a request, which is produced by the page, finishes successfully
// page.on('requestfinished', request => console.info(`👉 Finished request: ${request.url()}`));
// Emitted when a response is received
// page.on('response', response => console.info(`👉 Response: ${response.url()}`));
// Emitted when the page creates a dedicated WebWorker
page.on('workercreated', worker => console.info(`👉 Worker: ${worker.url()}`));
// Emitted when the page destroys a dedicated WebWorker
page.on('workerdestroyed', worker => console.info(`👉 Destroyed worker: ${worker.url()}`));
// Emitted when the page detaches a frame
page.on('framedetached', () => console.info('✅ Frame is detached'));
// Emitted after the page is closed
page.once('close', () => console.info('✅ Page is closed'));
}
exports.trapEventsOnPage = trapEventsOnPage