Browse Source

getting ready for new ava release

http2
Vsevolod Strukchinsky 9 years ago
parent
commit
ce752ac2ff
  1. 3
      package.json
  2. 22
      test/_server.js
  3. 16
      test/arguments.js
  4. 14
      test/error.js
  5. 15
      test/gzip.js
  6. 18
      test/headers.js
  7. 12
      test/helpers.js
  8. 22
      test/http.js
  9. 26
      test/https.js
  10. 18
      test/json.js
  11. 32
      test/post.js
  12. 20
      test/redirects.js
  13. 16
      test/retry.js
  14. 28
      test/stream.js
  15. 13
      test/unix-socket.js

3
package.json

@ -60,7 +60,8 @@
"url-parse-lax": "^1.0.0"
},
"devDependencies": {
"ava": "^0.2.0",
"ava": "git+https://github.com/sindresorhus/ava.git",
"get-port": "^1.0.0",
"into-stream": "^2.0.0",
"pem": "^1.4.4",
"pify": "^2.2.0",

22
test/_server.js

@ -1,14 +1,14 @@
import http from 'http';
import https from 'https';
import pify from 'pify';
import getPort from 'get-port';
export const host = 'localhost';
export let port = 6767;
export let portSSL = 16167;
export const createServer = port2 => {
port = port2 || ++port;
const getPortify = pify(getPort);
export const createServer = () => {
return getPortify()
.then(port => {
const s = http.createServer((req, resp) => s.emit(req.url, req, resp));
s.host = host;
@ -20,20 +20,22 @@ export const createServer = port2 => {
s.close = pify(s.close);
return s;
});
};
export const createSSLServer = (portSSL2, opts) => {
portSSL = portSSL2 || ++portSSL;
export const createSSLServer = (opts) => {
return getPortify()
.then(port => {
const s = https.createServer(opts, (req, resp) => s.emit(req.url, req, resp));
s.host = host;
s.port = portSSL;
s.url = `https://${host}:${portSSL}`;
s.port = port;
s.url = `https://${host}:${port}`;
s.protocol = 'https';
s.listen = pify(s.listen);
s.close = pify(s.close);
return s;
});
};

16
test/arguments.js

@ -3,7 +3,10 @@ import pify from 'pify';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.statusCode = 404;
@ -18,11 +21,10 @@ s.on('/?test=wow', (req, res) => {
res.end(req.url);
});
test.before('arguments - setup', async t => {
await s.listen(s.port);
});
test('arguments - url argument is required', async t => {
test('url is required', async t => {
try {
await got();
t.fail('Exception is not thrown');
@ -31,15 +33,15 @@ test('arguments - url argument is required', async t => {
}
});
test('arguments - accepts url.parse object as first argument', async t => {
test('accepts url.parse object as first argument', async t => {
t.is((await got({hostname: s.host, port: s.port, path: '/test'})).body, '/test');
});
test('arguments - overrides querystring from opts', async t => {
test('overrides querystring from opts', async t => {
t.is((await got(`${s.url}/?test=doge`, {query: {test: 'wow'}})).body, '/?test=wow');
});
test('arguments - should throw with auth in url', async t => {
test('should throw with auth in url', async t => {
try {
await got(`https://test:45d3ps453@account.myservice.com/api/token`);
t.fail('Exception is not thrown');
@ -48,6 +50,6 @@ test('arguments - should throw with auth in url', async t => {
}
});
test.after('arguments - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

14
test/error.js

@ -2,18 +2,20 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.statusCode = 404;
res.end('not');
});
test.before('error - setup', async t => {
await s.listen(s.port);
});
test('error - error message', async t => {
test('message', async t => {
try {
await got(s.url);
t.fail('Exception was not thrown');
@ -25,7 +27,7 @@ test('error - error message', async t => {
}
});
test('error - dns error message', async t => {
test('dns message', async t => {
try {
await got('.com', {retries: 0});
t.fail('Exception was not thrown');
@ -37,7 +39,7 @@ test('error - dns error message', async t => {
}
});
test('error - options.body error message', async t => {
test('options.body error message', async t => {
try {
got(s.url, {body: () => {}}, () => {});
t.fail('Exception was not thrown');
@ -53,6 +55,6 @@ test('error - options.body error message', async t => {
}
});
test.after('error - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

15
test/gzip.js

@ -3,9 +3,13 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
const testContent = 'Compressible response content.\n';
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.statusCode = 200;
res.setHeader('Content-Type', 'text/plain');
@ -20,15 +24,14 @@ s.on('/corrupted', (req, res) => {
res.end('Not gzipped content');
});
test.before('gzip - setup', async t => {
await s.listen(s.port);
});
test('gzip - ungzip content', async t => {
test('decompress content', async t => {
t.is((await got(s.url)).body, testContent);
});
test('gzip - ungzip error', async t => {
test('handles gzip error', async t => {
try {
await got(`${s.url}/corrupted`);
t.fail('Exception was not thrown');
@ -39,10 +42,10 @@ test('gzip - ungzip error', async t => {
}
});
test('gzip - preserve headers property', async t => {
test('preserve headers property', async t => {
t.ok((await got(s.url)).headers);
});
test.after('gzip - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

18
test/headers.js

@ -2,41 +2,43 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.end(JSON.stringify(req.headers));
});
test.before('headers - setup', async t => {
await s.listen(s.port);
});
test('headers - send user-agent header by default', async t => {
test('user-agent', async t => {
const headers = (await got(s.url, {json: true})).body;
t.is(headers['user-agent'], 'https://github.com/sindresorhus/got');
});
test('headers - send accept-encoding header by default', async t => {
test('accept-encoding', async t => {
const headers = (await got(s.url, {json: true})).body;
t.is(headers['accept-encoding'], 'gzip,deflate');
});
test('headers - send accept header with json option', async t => {
test('accept header with json option', async t => {
const headers = (await got(s.url, {json: true})).body;
t.is(headers.accept, 'application/json');
});
test('headers - send host header by default', async t => {
test('host', async t => {
const headers = (await got(s.url, {json: true})).body;
t.is(headers.host, `localhost:${s.port}`);
});
test('headers - transform headers names to lowercase', async t => {
test('transform names to lowercase', async t => {
const headers = (await got(s.url, {headers: {'USER-AGENT': 'test'}, json: true})).body;
t.is(headers['user-agent'], 'test');
});
test.after('headers - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

12
test/helpers.js

@ -2,7 +2,10 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.end('ok');
@ -13,11 +16,10 @@ s.on('/404', (req, res) => {
res.end('not found');
});
test.before('helpers - setup', async t => {
await s.listen(s.port);
});
test('helpers - callback mode', t => {
test('callback mode', t => {
got.get(s.url, function (err, body) {
t.ifError(err);
t.is(body, 'ok');
@ -25,7 +27,7 @@ test('helpers - callback mode', t => {
});
});
test('helpers - promise mode', async t => {
test('promise mode', async t => {
t.is((await got.get(s.url)).body, 'ok');
try {
@ -43,6 +45,6 @@ test('helpers - promise mode', async t => {
}
});
test.after('helpers - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

22
test/http.js

@ -2,7 +2,10 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.end('ok');
@ -23,23 +26,22 @@ s.on('/?recent=true', (req, res) => {
res.end('recent');
});
test.before('http - setup', async t => {
await s.listen(s.port);
});
test('http - simple request', async t => {
test('simple request', async t => {
t.is((await got(s.url)).body, 'ok');
});
test('http - protocol-less URLs', async t => {
test('protocol-less URLs', async t => {
t.is((await got(s.url.replace(/^http:\/\//, ''))).body, 'ok');
});
test('http - empty response', async t => {
test('empty response', async t => {
t.is((await got(`${s.url}/empty`)).body, '');
});
test('http - error with code', async t => {
test('error with code', async t => {
try {
await got(`${s.url}/404`);
t.fail('Exception was not thrown');
@ -49,12 +51,12 @@ test('http - error with code', async t => {
}
});
test('http - buffer on encoding === null', async t => {
test('buffer on encoding === null', async t => {
const data = (await got(s.url, {encoding: null})).body;
t.ok(Buffer.isBuffer(data));
});
test('http - timeout option', async t => {
test('timeout option', async t => {
try {
await got(`${s.url}/404`, {timeout: 1, retries: 0});
t.fail('Exception was not thrown');
@ -63,11 +65,11 @@ test('http - timeout option', async t => {
}
});
test('http - query option', async t => {
test('query option', async t => {
t.is((await got(s.url, {query: {recent: true}})).body, 'recent');
t.is((await got(s.url, {query: 'recent=true'})).body, 'recent');
});
test.after('http - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

26
test/https.js

@ -2,7 +2,7 @@ import test from 'ava';
import pem from 'pem';
import pify from 'pify';
import got from '../';
import {createSSLServer, portSSL} from './_server';
import {createSSLServer} from './_server';
let s;
let key;
@ -12,14 +12,12 @@ let caRootCert;
let pemify = pify.all(pem);
test.before('https - create root pem', async t => {
const keys = await pemify.createCertificate({days: 1, selfSigned: true});
test.before('setup', async t => {
const caKeys = await pemify.createCertificate({days: 1, selfSigned: true});
caRootKey = keys.serviceKey;
caRootCert = keys.certificate;
});
caRootKey = caKeys.serviceKey;
caRootCert = caKeys.certificate;
test.before('https - create pem', async t => {
const keys = await pemify.createCertificate({
serviceCertificate: caRootCert,
serviceKey: caRootKey,
@ -35,23 +33,23 @@ test.before('https - create pem', async t => {
key = keys.clientKey;
cert = keys.certificate;
});
test.before('https - setup', async t => {
s = createSSLServer(portSSL + 1, {key, cert});
s = await createSSLServer({key, cert});
s.on('/', (req, res) => res.end('ok'));
await s.listen(s.port);
});
test('https - redirects from http to https works', async t => {
test('redirects from http to https works', async t => {
t.ok((await got('http://github.com')).body);
});
test('https - make request to https server', async t => {
test('make request to https server', async t => {
t.ok((await got('https://google.com', {strictSSL: true})).body);
});
test('https - make request to https server with ca', async t => {
test('make request to https server with ca', async t => {
const {body} = await got(s.url, {
strictSSL: true,
ca: caRootCert,
@ -60,6 +58,6 @@ test('https - make request to https server with ca', async t => {
t.is(body, 'ok');
});
test.after('https - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

18
test/json.js

@ -2,7 +2,10 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.end('{"data":"dog"}');
@ -27,20 +30,19 @@ s.on('/non200-invalid', (req, res) => {
res.end('Internal error');
});
test.before('json - setup', async t => {
await s.listen(s.port);
});
test('json - json option should parse response', async t => {
test('parses response', async t => {
t.same((await got(s.url, {json: true})).body, {data: 'dog'});
});
test('json - json option should not parse responses without a body', async t => {
test('not parses responses without a body', async t => {
const {body} = await got(`${s.url}/204`, {json: true});
t.is(body, '');
});
test('json - json option wrap parsing errors', async t => {
test('wraps parsing errors', async t => {
try {
await got(`${s.url}/invalid`, {json: true});
t.fail('Exception was not thrown');
@ -51,7 +53,7 @@ test('json - json option wrap parsing errors', async t => {
}
});
test('json - json option should parse non-200 responses', async t => {
test('parses non-200 responses', async t => {
try {
await got(`${s.url}/non200`, {json: true});
t.fail('Exception was not thrown');
@ -60,7 +62,7 @@ test('json - json option should parse non-200 responses', async t => {
}
});
test('json - json option should catch errors on invalid non-200 responses', async t => {
test('catches errors on invalid non-200 responses', async t => {
try {
await got(`${s.url}/non200-invalid`, {json: true});
t.fail('Exception was not thrown');
@ -71,6 +73,6 @@ test('json - json option should catch errors on invalid non-200 responses', asyn
}
});
test.after('json - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

32
test/post.js

@ -5,7 +5,10 @@ import intoStream from 'into-stream';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.setHeader('method', req.method);
@ -20,52 +23,51 @@ s.on('/empty', (req, res) => {
res.end();
});
test.before('post - setup', async t => {
await s.listen(s.port);
});
test('post - GET can have body', async t => {
test('GET can have body', async t => {
const {body, headers} = await got.get(s.url, {body: 'hi'});
t.is(body, 'hi');
t.is(headers.method, 'GET');
});
test('post - send data from options with post request', async t => {
test('sends strings', async t => {
const {body} = await got(s.url, {body: 'wow'});
t.is(body, 'wow');
});
test('post - send data from options with post request', async t => {
test('sends Buffers', async t => {
const {body} = await got(s.url, {body: new Buffer('wow')});
t.is(body, 'wow');
});
test('post - send data from options with post request', async t => {
test('sends Streams', async t => {
const {body} = await got(s.url, {body: intoStream(['wow'])});
t.is(body, 'wow');
});
test('post - works with empty post response', async t => {
test('works with empty post response', async t => {
const {body} = await got(`${s.url}/empty`, {body: 'wow'});
t.is(body, '');
});
test('post - post have content-length header to string', async t => {
test('content-length header with string body', async t => {
const {body} = await got(`${s.url}/headers`, {body: 'wow', json: true});
t.is(body['content-length'], '3');
});
test('post - post have content-length header to string', async t => {
test('content-length header with Buffer body', async t => {
const {body} = await got(`${s.url}/headers`, {body: new Buffer('wow'), json: true});
t.is(body['content-length'], '3');
});
test('post - post have content-length header to string', async t => {
test('content-length header with Stream body', async t => {
const {body} = await got(`${s.url}/headers`, {body: intoStream(['wow']), json: true});
t.is(body['content-length'], undefined);
});
test('post - post have content-length header to string', async t => {
test('content-length header is not overriden', async t => {
const {body} = await got(`${s.url}/headers`, {
body: 'wow',
json: true,
@ -76,7 +78,7 @@ test('post - post have content-length header to string', async t => {
t.is(body['content-length'], '10');
});
test('post - post have content-length header to string', async t => {
test('content-length header disabled for chunked transfer-encoding', async t => {
const {body} = await got(`${s.url}/headers`, {
body: '3\r\nwow\r\n0\r\n',
json: true,
@ -87,7 +89,7 @@ test('post - post have content-length header to string', async t => {
t.is(body['content-length'], undefined);
});
test('post - works with plain object in body', async t => {
test('object in options.body treated as querystring', async t => {
const {body} = await got(s.url, {
body: {
such: 'wow'
@ -96,7 +98,7 @@ test('post - works with plain object in body', async t => {
t.is(body, 'such=wow');
});
test('post - works with plain object in body', async t => {
test('content-type header is not overriden when object in options.body', async t => {
const {body} = await got(`${s.url}/headers`, {
headers: {
'content-type': 'doge'
@ -109,6 +111,6 @@ test('post - works with plain object in body', async t => {
t.is(body['content-type'], 'doge');
});
test.after('post - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

20
test/redirects.js

@ -2,7 +2,10 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.end('reached');
@ -36,19 +39,18 @@ s.on('/relativeQuery?bang', (req, res) => {
res.end();
});
test.before('redirects - setup', async t => {
await s.listen(s.port);
});
test('redirects - follows redirect', async t => {
test('follows redirect', async t => {
t.is((await got(`${s.url}/finite`)).body, 'reached');
});
test('redirects - follows relative redirect', async t => {
test('relative redirect works', async t => {
t.is((await got(`${s.url}/relative`)).body, 'reached');
});
test('redirects - throws on endless redirect', async t => {
test('throws on endless redirect', async t => {
try {
await got(`${s.url}/endless`);
t.fail('Exception was not thrown');
@ -57,15 +59,15 @@ test('redirects - throws on endless redirect', async t => {
}
});
test('redirects - query in options are not breaking redirects', async t => {
test('query in options are not breaking redirects', async t => {
t.is((await got(`${s.url}/relativeQuery`, {query: 'bang'})).body, 'reached');
});
test('redirects - hostname+path in options are not breaking redirects', async t => {
test('hostname+path in options are not breaking redirects', async t => {
t.is((await got(`${s.url}/relative`, {hostname: s.host, path: '/relative'})).body, 'reached');
});
test('redirects - redirect only GET and HEAD requests', async t => {
test('redirect only GET and HEAD requests', async t => {
try {
await got(`${s.url}/relative`, {body: 'wow'});
t.fail('Exception was not thrown');
@ -76,6 +78,6 @@ test('redirects - redirect only GET and HEAD requests', async t => {
}
});
test.after('redirects - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

16
test/retry.js

@ -2,31 +2,33 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
let trys = 0;
let knocks = 0;
test.before('setup', async t => {
s = await createServer();
s.on('/long', () => {});
let knocks = 0;
s.on('/knock-twice', (req, res) => {
if (knocks++ === 1) {
res.end('who`s there?');
}
});
let trys = 0;
s.on('/try-me', () => {
trys++;
});
test.before('retry - setup', async t => {
await s.listen(s.port);
});
test('retry - timeout errors', async t => {
test('works on timeout error', async t => {
t.is((await got(`${s.url}/knock-twice`, {timeout: 1000})).body, 'who`s there?');
});
test('retry - can be disabled with option', async t => {
test('can be disabled with option', async t => {
try {
await got(`${s.url}/try-me`, {timeout: 1000, retries: 0});
} catch (err) {
@ -35,6 +37,6 @@ test('retry - can be disabled with option', async t => {
t.is(trys, 1);
});
test.after('error - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

28
test/stream.js

@ -2,7 +2,10 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.end('ok');
@ -24,18 +27,17 @@ s.on('/error', (req, res) => {
res.end();
});
test.before('stream - setup', async t => {
await s.listen(s.port);
});
test('stream - json option can not be used in stream mode', t => {
test('option.json can not be used', t => {
t.throws(() => {
got.stream(s.url, {json: true});
}, 'got can not be used as stream when options.json is used');
t.end();
});
test('stream - callback can not be used in stream mode', t => {
test('callback can not be used', t => {
t.throws(() => {
got.stream(s.url, {json: true}, () => {});
}, 'callback can not be used in stream mode');
@ -47,7 +49,7 @@ test('stream - callback can not be used in stream mode', t => {
t.end();
});
test('stream - return readable stream', t => {
test('returns readable stream', t => {
got.stream(s.url)
.on('data', data => {
t.is(data.toString(), 'ok');
@ -55,7 +57,7 @@ test('stream - return readable stream', t => {
});
});
test('stream - return writeable stream', t => {
test('returns writeable stream', t => {
t.plan(1);
got.stream.post(`${s.url}/post`)
.on('data', data => {
@ -64,7 +66,7 @@ test('stream - return writeable stream', t => {
.end('wow');
});
test('stream - throws on write to stream with body specified', t => {
test('throws on write to stream with body specified', t => {
t.throws(() => {
got.stream(s.url, {body: 'wow'}).write('wow');
}, 'got\'s stream is not writable when options.body is used');
@ -73,7 +75,7 @@ test('stream - throws on write to stream with body specified', t => {
setTimeout(t.end.bind(t), 10);
});
test('stream - request event', t => {
test('have request event', t => {
got.stream(s.url)
.on('request', req => {
t.ok(req);
@ -81,7 +83,7 @@ test('stream - request event', t => {
});
});
test('stream - redirect event', t => {
test('have redirect event', t => {
got.stream(`${s.url}/redirect`)
.on('redirect', res => {
t.is(res.headers.location, s.url);
@ -89,7 +91,7 @@ test('stream - redirect event', t => {
});
});
test('stream - response event', t => {
test('have response event', t => {
got.stream(s.url)
.on('response', res => {
t.is(res.statusCode, 200);
@ -97,7 +99,7 @@ test('stream - response event', t => {
});
});
test('stream - error event', t => {
test('have error event', t => {
got.stream(`${s.url}/error`, {retries: 0})
.on('response', () => {
t.fail('response event should not be emitted');
@ -110,7 +112,7 @@ test('stream - error event', t => {
});
});
test('stream - error event', t => {
test('have error event', t => {
got.stream('.com', {retries: 0})
.on('response', () => {
t.fail('response event should not be emitted');
@ -121,6 +123,6 @@ test('stream - error event', t => {
});
});
test.after('stream - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

13
test/unix-socket.js

@ -4,27 +4,30 @@ import test from 'ava';
import got from '../';
import {createServer} from './_server';
const s = createServer();
const socketPath = tempfile('.socket');
let s;
test.before('setup', async t => {
s = await createServer();
s.on('/', (req, res) => {
res.end('ok');
});
test.before('unix-socket - setup', async t => {
await s.listen(socketPath);
});
test('unix-socket - request via unix socket', async t => {
test('works', async t => {
const url = format('http://unix:%s:%s', socketPath, '/');
t.is((await got(url)).body, 'ok');
});
test('unix-socket - protocol-less request', async t => {
test('protocol-less works', async t => {
const url = format('unix:%s:%s', socketPath, '/');
t.is((await got(url)).body, 'ok');
});
test.after('unix-socket - cleanup', async t => {
test.after('cleanup', async t => {
await s.close();
});

Loading…
Cancel
Save