2013-12-30 23:13:25 +00:00
|
|
|
/*globals describe, beforeEach, afterEach, it*/
|
2014-06-04 22:26:03 +01:00
|
|
|
/*jshint expr:true*/
|
2013-11-05 00:41:36 -05:00
|
|
|
var assert = require('assert'),
|
|
|
|
should = require('should'),
|
|
|
|
sinon = require('sinon'),
|
2013-11-12 01:03:25 -05:00
|
|
|
middleware = require('../../server/middleware').middleware;
|
2013-10-05 11:17:08 +01:00
|
|
|
|
|
|
|
describe('Middleware', function () {
|
2014-06-30 14:58:10 +02:00
|
|
|
// TODO: needs new test for ember admin
|
|
|
|
// describe('redirectToDashboard', function () {
|
|
|
|
// var req, res;
|
|
|
|
|
|
|
|
// beforeEach(function () {
|
|
|
|
// req = {
|
|
|
|
// session: {}
|
|
|
|
// };
|
|
|
|
|
|
|
|
// res = {
|
|
|
|
// redirect: sinon.spy()
|
|
|
|
// };
|
|
|
|
// });
|
|
|
|
|
|
|
|
// it('should redirect to dashboard', function () {
|
|
|
|
// req.session.user = {};
|
|
|
|
|
|
|
|
// middleware.redirectToDashboard(req, res, null);
|
|
|
|
// assert(res.redirect.calledWithMatch('/ghost/'));
|
|
|
|
// });
|
|
|
|
|
|
|
|
// it('should call next if no user in session', function (done) {
|
|
|
|
// middleware.redirectToDashboard(req, res, function (a) {
|
|
|
|
// should.not.exist(a);
|
|
|
|
// assert(res.redirect.calledOnce.should.be.false);
|
|
|
|
// done();
|
|
|
|
// });
|
|
|
|
// });
|
|
|
|
// });
|
2013-11-05 00:41:36 -05:00
|
|
|
|
2013-12-30 23:13:25 +00:00
|
|
|
describe('cacheControl', function () {
|
2013-11-05 00:41:36 -05:00
|
|
|
var res;
|
|
|
|
|
2013-11-11 10:37:09 +00:00
|
|
|
beforeEach(function () {
|
2013-11-05 00:41:36 -05:00
|
|
|
res = {
|
|
|
|
set: sinon.spy()
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2013-12-30 23:13:25 +00:00
|
|
|
it('correctly sets the public profile headers', function (done) {
|
|
|
|
middleware.cacheControl('public')(null, res, function (a) {
|
|
|
|
should.not.exist(a);
|
|
|
|
res.set.calledOnce.should.be.true;
|
|
|
|
res.set.calledWith({'Cache-Control': 'public, max-age=0'});
|
2014-05-05 21:58:58 +01:00
|
|
|
done();
|
2013-12-30 23:13:25 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('correctly sets the private profile headers', function (done) {
|
|
|
|
middleware.cacheControl('private')(null, res, function (a) {
|
|
|
|
should.not.exist(a);
|
|
|
|
res.set.calledOnce.should.be.true;
|
2014-06-04 22:26:03 +01:00
|
|
|
res.set.calledWith({
|
|
|
|
'Cache-Control':
|
|
|
|
'no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0'
|
|
|
|
});
|
2014-05-05 21:58:58 +01:00
|
|
|
done();
|
2013-12-30 23:13:25 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('will not set headers without a profile', function (done) {
|
|
|
|
middleware.cacheControl()(null, res, function (a) {
|
|
|
|
should.not.exist(a);
|
|
|
|
res.set.called.should.be.false;
|
2014-05-05 21:58:58 +01:00
|
|
|
done();
|
2013-11-05 00:41:36 -05:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2013-11-11 10:37:09 +00:00
|
|
|
describe('whenEnabled', function () {
|
2014-09-19 16:17:58 +00:00
|
|
|
var cbFn, blogApp;
|
2013-11-05 00:41:36 -05:00
|
|
|
|
2013-11-11 10:37:09 +00:00
|
|
|
beforeEach(function () {
|
2013-11-05 00:41:36 -05:00
|
|
|
cbFn = sinon.spy();
|
2014-09-19 16:17:58 +00:00
|
|
|
blogApp = {
|
2013-11-11 10:37:09 +00:00
|
|
|
enabled: function (setting) {
|
2013-11-05 00:41:36 -05:00
|
|
|
if (setting === 'enabled') {
|
|
|
|
return true;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2014-09-19 16:17:58 +00:00
|
|
|
middleware.cacheBlogApp(blogApp);
|
2013-11-05 00:41:36 -05:00
|
|
|
});
|
|
|
|
|
2013-11-11 10:37:09 +00:00
|
|
|
it('should call function if setting is enabled', function (done) {
|
2013-11-05 00:41:36 -05:00
|
|
|
var req = 1, res = 2, next = 3;
|
|
|
|
|
2013-11-11 10:37:09 +00:00
|
|
|
middleware.whenEnabled('enabled', function (a, b, c) {
|
2013-11-05 00:41:36 -05:00
|
|
|
assert.equal(a, 1);
|
|
|
|
assert.equal(b, 2);
|
|
|
|
assert.equal(c, 3);
|
2014-05-05 21:58:58 +01:00
|
|
|
done();
|
2013-11-05 00:41:36 -05:00
|
|
|
})(req, res, next);
|
|
|
|
});
|
|
|
|
|
2013-11-11 10:37:09 +00:00
|
|
|
it('should call next() if setting is disabled', function (done) {
|
|
|
|
middleware.whenEnabled('rando', cbFn)(null, null, function (a) {
|
2013-11-05 00:41:36 -05:00
|
|
|
should.not.exist(a);
|
|
|
|
cbFn.calledOnce.should.be.false;
|
2014-05-05 21:58:58 +01:00
|
|
|
done();
|
2013-11-05 00:41:36 -05:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2013-10-05 11:17:08 +01:00
|
|
|
describe('staticTheme', function () {
|
|
|
|
beforeEach(function () {
|
|
|
|
sinon.stub(middleware, 'forwardToExpressStatic').yields();
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(function () {
|
|
|
|
middleware.forwardToExpressStatic.restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should call next if hbs file type', function (done) {
|
|
|
|
var req = {
|
|
|
|
url: 'mytemplate.hbs'
|
|
|
|
};
|
|
|
|
|
|
|
|
middleware.staticTheme(null)(req, null, function (a) {
|
|
|
|
should.not.exist(a);
|
|
|
|
middleware.forwardToExpressStatic.calledOnce.should.be.false;
|
2014-05-05 21:58:58 +01:00
|
|
|
done();
|
2013-10-05 11:17:08 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should call next if md file type', function (done) {
|
|
|
|
var req = {
|
|
|
|
url: 'README.md'
|
|
|
|
};
|
|
|
|
|
|
|
|
middleware.staticTheme(null)(req, null, function (a) {
|
|
|
|
should.not.exist(a);
|
|
|
|
middleware.forwardToExpressStatic.calledOnce.should.be.false;
|
2014-05-05 21:58:58 +01:00
|
|
|
done();
|
2013-10-05 11:17:08 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should call next if json file type', function (done) {
|
|
|
|
var req = {
|
|
|
|
url: 'sample.json'
|
2013-11-05 00:41:36 -05:00
|
|
|
};
|
2013-10-05 11:17:08 +01:00
|
|
|
|
|
|
|
middleware.staticTheme(null)(req, null, function (a) {
|
|
|
|
should.not.exist(a);
|
|
|
|
middleware.forwardToExpressStatic.calledOnce.should.be.false;
|
2014-05-05 21:58:58 +01:00
|
|
|
done();
|
2013-10-05 11:17:08 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should call express.static if valid file type', function (done) {
|
2014-06-04 22:26:03 +01:00
|
|
|
var req = {
|
2013-11-11 10:37:09 +00:00
|
|
|
url: 'myvalidfile.css'
|
|
|
|
};
|
2013-10-05 11:17:08 +01:00
|
|
|
|
2013-11-20 08:58:52 -05:00
|
|
|
middleware.staticTheme(null)(req, null, function (reqArg, res, next) {
|
2014-06-04 22:26:03 +01:00
|
|
|
/*jshint unused:false */
|
2013-10-05 11:17:08 +01:00
|
|
|
middleware.forwardToExpressStatic.calledOnce.should.be.true;
|
2013-11-20 08:58:52 -05:00
|
|
|
assert.deepEqual(middleware.forwardToExpressStatic.args[0][0], req);
|
2014-05-05 21:58:58 +01:00
|
|
|
done();
|
2013-10-05 11:17:08 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2015-01-18 13:44:50 -05:00
|
|
|
|
|
|
|
describe('isSSLRequired', function () {
|
|
|
|
var isSSLrequired = middleware.isSSLrequired;
|
|
|
|
|
|
|
|
it('SSL is required if config.url starts with https', function () {
|
|
|
|
isSSLrequired(undefined, 'https://example.com', undefined).should.be.true;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('SSL is required if isAdmin and config.forceAdminSSL is set', function () {
|
|
|
|
isSSLrequired(true, 'http://example.com', true).should.be.true;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('SSL is not required if config.url starts with "http:/" and forceAdminSSL is not set', function () {
|
|
|
|
isSSLrequired(false, 'http://example.com', false).should.be.false;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('sslForbiddenOrRedirect', function () {
|
|
|
|
var sslForbiddenOrRedirect = middleware.sslForbiddenOrRedirect;
|
|
|
|
it('Return forbidden if config forces admin SSL for AdminSSL redirect is false.', function () {
|
|
|
|
var response = sslForbiddenOrRedirect({
|
|
|
|
forceAdminSSL: {redirect: false},
|
|
|
|
configUrl: 'http://example.com'
|
|
|
|
});
|
|
|
|
response.isForbidden.should.be.true;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('If not forbidden, should produce SSL to redirect to when config.url ends with no slash', function () {
|
|
|
|
var response = sslForbiddenOrRedirect({
|
|
|
|
forceAdminSSL: {redirect: true},
|
|
|
|
configUrl: 'http://example.com/config/path',
|
|
|
|
reqUrl: '/req/path'
|
|
|
|
});
|
|
|
|
response.isForbidden.should.be.false;
|
|
|
|
response.redirectUrl({}).should.equal('https://example.com/config/path/req/path');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('If config ends is slash, potential double-slash in resulting URL is removed', function () {
|
|
|
|
var response = sslForbiddenOrRedirect({
|
|
|
|
forceAdminSSL: {redirect: true},
|
|
|
|
configUrl: 'http://example.com/config/path/',
|
|
|
|
reqUrl: '/req/path'
|
|
|
|
});
|
|
|
|
response.redirectUrl({}).should.equal('https://example.com/config/path/req/path');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('If config.urlSSL is provided it is preferred over config.url', function () {
|
|
|
|
var response = sslForbiddenOrRedirect({
|
|
|
|
forceAdminSSL: {redirect: true},
|
|
|
|
configUrl: 'http://example.com/config/path/',
|
|
|
|
configUrlSSL: 'https://example.com/ssl/config/path/',
|
|
|
|
reqUrl: '/req/path'
|
|
|
|
});
|
|
|
|
response.redirectUrl({}).should.equal('https://example.com/ssl/config/path/req/path');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('query string in request is preserved in redirect URL', function () {
|
|
|
|
var response = sslForbiddenOrRedirect({
|
|
|
|
forceAdminSSL: {redirect: true},
|
|
|
|
configUrl: 'http://example.com/config/path/',
|
|
|
|
configUrlSSL: 'https://example.com/ssl/config/path/',
|
|
|
|
reqUrl: '/req/path'
|
|
|
|
});
|
|
|
|
response.redirectUrl({a: 'b'}).should.equal('https://example.com/ssl/config/path/req/path?a=b');
|
|
|
|
});
|
|
|
|
});
|
2013-10-05 11:17:08 +01:00
|
|
|
});
|