GT2/GT2-Android/node_modules/get-uri/test/https.js

79 lines
2.1 KiB
JavaScript

/**
* Module dependencies.
*/
var fs = require('fs');
var st = require('st');
var path = require('path');
var https = require('https');
var getUri = require('../');
var assert = require('assert');
var streamToArray = require('stream-to-array');
describe('get-uri', function () {
describe('"https:" protocol', function () {
var port;
var cache;
var server;
before(function (done) {
// setup target HTTPS server
var options = {
key: fs.readFileSync(__dirname + '/server.key'),
cert: fs.readFileSync(__dirname + '/server.crt')
};
server = https.createServer(options, st(__dirname));
server.listen(function () {
port = server.address().port;
done();
});
});
after(function (done) {
server.once('close', function () { done(); });
server.close();
});
it('should work for HTTPS endpoints', function (done) {
var uri = 'https://127.0.0.1:' + port + '/' + path.basename(__filename);
fs.readFile(__filename, 'utf8', function (err, real) {
if (err) return done(err);
getUri(uri, { rejectUnauthorized: false }, function (err, rs) {
if (err) return done(err);
cache = rs;
streamToArray(rs, function (err, array) {
if (err) return done(err);
var str = Buffer.concat(array).toString('utf8');
assert.equal(str, real);
done();
});
});
});
});
it('should return ENOTFOUND for bad filenames', function (done) {
var uri = 'https://127.0.0.1:' + port + '/does-not-exist';
getUri(uri, { rejectUnauthorized: false }, function (err, rs) {
assert(err);
assert.equal('ENOTFOUND', err.code);
done();
});
});
it('should return ENOTMODIFIED for the same URI with `cache`', function (done) {
var uri = 'https://127.0.0.1:' + port + '/' + path.basename(__filename);
getUri(uri, { cache: cache, rejectUnauthorized: false }, function (err, rs) {
assert(err);
assert.equal('ENOTMODIFIED', err.code);
done();
});
});
});
});