-
-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Expand file tree
/
Copy pathtest.ts
More file actions
62 lines (58 loc) · 2.17 KB
/
test.ts
File metadata and controls
62 lines (58 loc) · 2.17 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
import { expect, it } from 'vitest';
import type { Event } from '@sentry/core';
import { createRunner } from '../../../../runner';
it('propagates trace from worker to worker via service binding', async ({ signal }) => {
let workerTraceId: string | undefined;
let workerSpanId: string | undefined;
let subWorkerTraceId: string | undefined;
let subWorkerParentSpanId: string | undefined;
const runner = createRunner(__dirname)
.expect(envelope => {
const transactionEvent = envelope[1]?.[0]?.[1] as Event;
expect(transactionEvent).toEqual(
expect.objectContaining({
contexts: expect.objectContaining({
trace: expect.objectContaining({
op: 'http.server',
data: expect.objectContaining({
'sentry.origin': 'auto.http.cloudflare',
}),
origin: 'auto.http.cloudflare',
}),
}),
transaction: 'GET /',
}),
);
workerTraceId = transactionEvent.contexts?.trace?.trace_id as string;
workerSpanId = transactionEvent.contexts?.trace?.span_id as string;
})
.expect(envelope => {
const transactionEvent = envelope[1]?.[0]?.[1] as Event;
expect(transactionEvent).toEqual(
expect.objectContaining({
contexts: expect.objectContaining({
trace: expect.objectContaining({
op: 'http.server',
data: expect.objectContaining({
'sentry.origin': 'auto.http.cloudflare',
}),
origin: 'auto.http.cloudflare',
}),
}),
transaction: 'GET /hello',
}),
);
subWorkerTraceId = transactionEvent.contexts?.trace?.trace_id as string;
subWorkerParentSpanId = transactionEvent.contexts?.trace?.parent_span_id as string;
})
.unordered()
.start(signal);
await runner.makeRequest('get', '/');
await runner.completed();
expect(workerTraceId).toBeDefined();
expect(subWorkerTraceId).toBeDefined();
expect(workerTraceId).toBe(subWorkerTraceId);
expect(workerSpanId).toBeDefined();
expect(subWorkerParentSpanId).toBeDefined();
expect(subWorkerParentSpanId).toBe(workerSpanId);
});