64 lines
1.3 KiB

import test from 'ava';
import pem from 'pem';
9 years ago
import pify from 'pify';
import got from '../';
import {createSSLServer} from './_server';
let s;
let key;
let cert;
let caRootKey;
let caRootCert;
9 years ago
const pemP = pify(pem);
9 years ago
test.before('setup', async t => {
9 years ago
const caKeys = await pemP.createCertificate({days: 1, selfSigned: true});
9 years ago
caRootKey = caKeys.serviceKey;
caRootCert = caKeys.certificate;
9 years ago
const keys = await pemP.createCertificate({
serviceCertificate: caRootCert,
serviceKey: caRootKey,
serial: Date.now(),
days: 500,
country: '',
state: '',
locality: '',
organization: '',
organizationUnit: '',
commonName: 'sindresorhus.com'
});
9 years ago
key = keys.clientKey;
cert = keys.certificate;
s = await createSSLServer({key, cert});
s.on('/', (req, res) => res.end('ok'));
await s.listen(s.port);
});
test('redirects from http to https works', async t => {
t.ok((await got('http://github.com')).body);
});
test('make request to https server', async t => {
t.ok((await got('https://google.com', {strictSSL: true})).body);
});
test('make request to https server with ca', async t => {
const {body} = await got(s.url, {
strictSSL: true,
ca: caRootCert,
10 years ago
headers: {host: 'sindresorhus.com'}
});
t.is(body, 'ok');
});
test.after('cleanup', async t => {
await s.close();
});