-
Notifications
You must be signed in to change notification settings - Fork 125
Expand file tree
/
Copy pathfetch.test.ts
More file actions
100 lines (87 loc) · 3.71 KB
/
fetch.test.ts
File metadata and controls
100 lines (87 loc) · 3.71 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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
import assert from 'node:assert/strict';
import diagnosticsChannel from 'node:diagnostics_channel';
import { describe, it, beforeAll, afterAll } from 'vitest';
import { startServer } from './fixtures/server.js';
import {
fetch, FetchDiagnosticsMessage, FetchFactory, FetchResponseDiagnosticsMessage,
} from '../src/fetch.js';
import { RequestDiagnosticsMessage, ResponseDiagnosticsMessage } from '../src/HttpClient.js';
describe('fetch.test.ts', () => {
let close: any;
let _url: string;
beforeAll(async () => {
const { closeServer, url } = await startServer();
close = closeServer;
_url = url;
});
afterAll(async () => {
await close();
});
it('fetch should work', async () => {
let requestDiagnosticsMessage: RequestDiagnosticsMessage;
let responseDiagnosticsMessage: ResponseDiagnosticsMessage;
let fetchDiagnosticsMessage: FetchDiagnosticsMessage;
let fetchResponseDiagnosticsMessage: FetchResponseDiagnosticsMessage;
diagnosticsChannel.subscribe('urllib:request', msg => {
requestDiagnosticsMessage = msg as RequestDiagnosticsMessage;
});
diagnosticsChannel.subscribe('urllib:response', msg => {
responseDiagnosticsMessage = msg as ResponseDiagnosticsMessage;
});
diagnosticsChannel.subscribe('urllib:fetch:request', msg => {
fetchDiagnosticsMessage = msg as FetchDiagnosticsMessage;
});
diagnosticsChannel.subscribe('urllib:fetch:response', msg => {
fetchResponseDiagnosticsMessage = msg as FetchResponseDiagnosticsMessage;
});
FetchFactory.setClientOptions({});
const response = await fetch(`${_url}html`);
assert(response);
assert(requestDiagnosticsMessage!.request);
assert(responseDiagnosticsMessage!.request);
assert(responseDiagnosticsMessage!.response);
assert([ '127.0.0.1', '::1' ].includes(responseDiagnosticsMessage!.response.socket.localAddress));
assert(fetchDiagnosticsMessage!.fetch);
assert(fetchResponseDiagnosticsMessage!.fetch);
assert(fetchResponseDiagnosticsMessage!.response);
assert(fetchResponseDiagnosticsMessage!.timingInfo);
const stats = FetchFactory.getDispatcherPoolStats();
assert(stats);
assert(Object.keys(stats).length > 0);
});
it('fetch error should has socket info', async () => {
let requestDiagnosticsMessage: RequestDiagnosticsMessage;
let responseDiagnosticsMessage: ResponseDiagnosticsMessage;
let fetchDiagnosticsMessage: FetchDiagnosticsMessage;
let fetchResponseDiagnosticsMessage: FetchResponseDiagnosticsMessage;
diagnosticsChannel.subscribe('urllib:request', msg => {
requestDiagnosticsMessage = msg as RequestDiagnosticsMessage;
});
diagnosticsChannel.subscribe('urllib:response', msg => {
responseDiagnosticsMessage = msg as ResponseDiagnosticsMessage;
});
diagnosticsChannel.subscribe('urllib:fetch:request', msg => {
fetchDiagnosticsMessage = msg as FetchDiagnosticsMessage;
});
diagnosticsChannel.subscribe('urllib:fetch:response', msg => {
fetchResponseDiagnosticsMessage = msg as FetchResponseDiagnosticsMessage;
});
FetchFactory.setClientOptions({});
try {
await fetch(`${_url}html?timeout=9999`, {
signal: AbortSignal.timeout(100),
});
} catch (error) {
console.log(error);
}
assert(requestDiagnosticsMessage!.request);
assert(responseDiagnosticsMessage!.request);
assert(responseDiagnosticsMessage!.response);
assert([ '127.0.0.1', '::1' ].includes(responseDiagnosticsMessage!.response.socket.localAddress));
assert(fetchDiagnosticsMessage!.fetch);
assert(fetchResponseDiagnosticsMessage!.fetch);
const stats = FetchFactory.getDispatcherPoolStats();
assert(stats);
assert(Object.keys(stats).length > 0);
});
});