-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvitest-setup.ts
64 lines (54 loc) · 2.28 KB
/
vitest-setup.ts
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
import { bootstrap as bootstrapGlobalAgent } from "global-agent";
import { Agent, ProxyAgent, setGlobalDispatcher } from "undici";
const [nodeMajorVersion, _nodeMinorVersion, _nodePatchVersion] = process.version
.split(".")
.map((x) => parseInt(x[0] === "v" ? x.slice(1) : x));
// NOTE: `fetch` would need to be polyfilled in Node < v18, but we're only running tests in v18+
// Optionally disable TLS verification and suppress its resultant warning spam
import "./suppress-insecure-tls-warning";
if (process.env.INSECURE_TLS === "1") {
// NOTE: For Vite, it appears sufficient to call the code in this setup,
// because it appears to execute on spawn of every child process.
// Whereas with Next.js, child processes do not execute next.config.js, and
// so in that case the code must be called from `node --require`
process.env["NODE_TLS_REJECT_UNAUTHORIZED"] = "0";
suppressInsecureTlsWarning();
if (nodeMajorVersion >= 18 && !process.env.MITM) {
console.log("Setup non-MITM insecure https Agent for undici (node native)");
setGlobalDispatcher(
new Agent({
connect: { rejectUnauthorized: false, requestCert: false },
})
);
}
}
// Optionally proxy outbound requests through proxy defined in MITM env var
// example: `INSECURE_TLS=1 MITM=http://127.0.0.1:7979 yarn vitest`
// Developer is responsible for operation of proxy, but we recommend `mitmproxy`
// NOTE: It's also posible to set `GLOBAL_AGENT_*` env variables directly,
// see: https://github.com/gajus/global-agent#environment-variables
// NOTE: In node 18, setting GLOBAL_AGENT directly won't affect agent proxy URI,
// which is why we et it with setGlobalDispatcher (from undici)
if (process.env.MITM) {
if (!process.env.GLOBAL_AGENT_HTTP_PROXY) {
process.env["GLOBAL_AGENT_HTTP_PROXY"] = process.env.MITM;
}
bootstrapGlobalAgent();
if (nodeMajorVersion >= 18) {
const mitmProxyOpts: ConstructorParameters<typeof ProxyAgent>[0] = {
uri: process.env.MITM,
...(process.env.INSECURE_TLS === "1"
? {
connect: {
rejectUnauthorized: false,
requestCert: false,
},
}
: {}),
};
setGlobalDispatcher(new ProxyAgent(mitmProxyOpts));
}
}
declare global {
function suppressInsecureTlsWarning(): void;
}