/
agent-ca-test.js
83 lines (74 loc) · 1.94 KB
/
agent-ca-test.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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
const { readFileSync } = require("fs");
const { resolve } = require("path");
const { fetch: undiciFetch, Agent } = require("undici");
const { Octokit } = require("../../..");
const ca = readFileSync(resolve(__dirname, "./ca.crt"));
describe("custom client certificate", () => {
let server;
before((done) => {
server = https.createServer(
{
key: readFileSync(resolve(__dirname, "./localhost.key")),
cert: readFileSync(resolve(__dirname, "./localhost.crt")),
},
function (request, response) {
expect(request.method).to.equal("GET");
expect(request.url).to.equal("/repos/octokit/rest.js");
response.writeHead(200);
response.write("ok");
response.end();
},
);
server.listen(0, done);
});
it("undici.Agent({ca})", () => {
const agent = new Agent({
keepAliveTimeout: 10,
keepAliveMaxTimeout: 10,
connect: { ca: ca },
});
const myFetch = (url, opts) => {
return undiciFetch(url, {
...opts,
dispatcher: agent,
});
};
const octokit = new Octokit({
baseUrl: "https://localhost:" + server.address().port,
request: {
fetch: myFetch,
},
});
return octokit.rest.repos.get({
owner: "octokit",
repo: "rest.js",
});
});
it("undici.Agent({ca, rejectUnauthorized})", () => {
const agent = new Agent({
keepAliveTimeout: 10,
keepAliveMaxTimeout: 10,
connect: {
ca: "invalid",
rejectUnauthorized: true,
},
});
const myFetch = (url, opts) => {
return undiciFetch(url, {
...opts,
dispatcher: agent,
});
};
const octokit = new Octokit({
baseUrl: "https://localhost:" + server.address().port,
request: {
fetch: myFetch,
},
});
return octokit.rest.repos.get({
owner: "octokit",
repo: "rest.js",
});
});
after((done) => server.close(done));
});