-
-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Expand file tree
/
Copy patherrors.test.ts
More file actions
73 lines (56 loc) · 2.43 KB
/
errors.test.ts
File metadata and controls
73 lines (56 loc) · 2.43 KB
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
62
63
64
65
66
67
68
69
70
71
72
73
import { expect, test } from '@playwright/test';
import { waitForError, waitForTransaction } from '@sentry-internal/test-utils';
test('captures an error with debug ids and pageload trace context', async ({ page }) => {
const errorEventPromise = waitForError('browser-webworker-vite', async event => {
return !event.type && !!event.exception?.values?.[0];
});
const transactionPromise = waitForTransaction('browser-webworker-vite', transactionEvent => {
return !!transactionEvent?.transaction && transactionEvent.contexts?.trace?.op === 'pageload';
});
await page.goto('/');
await page.locator('#trigger-error').click();
await page.waitForTimeout(1000);
const errorEvent = await errorEventPromise;
const transactionEvent = await transactionPromise;
const pageloadTraceId = transactionEvent.contexts?.trace?.trace_id;
const pageloadSpanId = transactionEvent.contexts?.trace?.span_id;
expect(errorEvent.exception?.values).toHaveLength(1);
expect(errorEvent.exception?.values?.[0]?.value).toBe('Uncaught Error: Uncaught error in worker');
expect(errorEvent.exception?.values?.[0]?.stacktrace?.frames).toHaveLength(1);
expect(errorEvent.exception?.values?.[0]?.stacktrace?.frames?.[0]?.filename).toMatch(/worker-.+\.js$/);
expect(errorEvent.transaction).toBe('/');
expect(transactionEvent.transaction).toBe('/');
expect(errorEvent.request).toEqual({
url: 'http://localhost:3030/',
headers: expect.any(Object),
});
expect(errorEvent.contexts?.trace).toEqual({
trace_id: pageloadTraceId,
span_id: pageloadSpanId,
});
expect(errorEvent.debug_meta).toEqual({
images: [
{
code_file: expect.stringMatching(/http:\/\/localhost:3030\/assets\/worker-.+\.js/),
debug_id: expect.stringMatching(/[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}/),
type: 'sourcemap',
},
],
});
});
test("user worker message handlers don't trigger for sentry messages", async ({ page }) => {
const workerReadyPromise = new Promise<number>(resolve => {
let workerMessageCount = 0;
page.on('console', msg => {
if (msg.text().startsWith('received message from worker:')) {
workerMessageCount++;
}
if (msg.text() === 'received message from worker: WORKER_READY') {
resolve(workerMessageCount);
}
});
});
await page.goto('/');
const workerMessageCount = await workerReadyPromise;
expect(workerMessageCount).toBe(1);
});