/
agent-ca-test.js
63 lines (53 loc) · 1.48 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
const https = require("https");
const { readFileSync } = require("fs");
const { resolve } = require("path");
const { Octokit } = require("../../..");
const ca = readFileSync(resolve(__dirname, "./ca.crt"));
require("../../mocha-node-setup");
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("https.Agent({ca})", () => {
const agent = new https.Agent({
ca
});
const octokit = new Octokit({
baseUrl: "https://localhost:" + server.address().port,
request: { agent }
});
return octokit.repos.get({
owner: "octokit",
repo: "rest.js"
});
});
it("https.Agent({ca, rejectUnauthorized})", () => {
const agent = new https.Agent({
ca: "invalid",
rejectUnauthorized: false
});
const octokit = new Octokit({
baseUrl: "https://localhost:" + server.address().port,
request: { agent }
});
return octokit.repos.get({
owner: "octokit",
repo: "rest.js"
});
});
after(done => server.close(done));
});