0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-02-10 23:36:14 -05:00
ghost/test/unit/server/web/shared/middleware/cache-control.test.js
Hannah Wolfe 4f9b72ff43
Renamed middlewares to middleware consistently
- This is a minor bugbare, but it will affect some configuration I'm about to do for c8
- I've been wanting to do it for ages, middleware is plural all on it's own so it's an odd affectation in our codebase
- This also only exists in 2 places, everywhere else we use "middleware"
- Sadly it did result in a lot of churn as I did a full find and replace, but consistency is king!
2021-11-16 15:51:47 +00:00

83 lines
3 KiB
JavaScript

const should = require('should');
const sinon = require('sinon');
const cacheControl = require('../../../../../../core/server/web/shared/middleware/cache-control');
describe('Middleware: cacheControl', function () {
let res;
beforeEach(function () {
res = {
set: sinon.spy()
};
});
afterEach(function () {
sinon.restore();
});
it('correctly sets the public profile headers', function (done) {
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'}).should.be.true();
done();
});
});
it('correctly sets the public profile headers with custom maxAge', function (done) {
cacheControl('public', {maxAge: 123456})(null, res, function (a) {
should.not.exist(a);
res.set.calledOnce.should.be.true();
res.set.calledWith({'Cache-Control': 'public, max-age=123456'}).should.be.true();
done();
});
});
it('correctly sets the private profile headers', function (done) {
cacheControl('private')(null, res, function (a) {
should.not.exist(a);
res.set.calledOnce.should.be.true();
res.set.calledWith({
'Cache-Control': 'no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0'
}).should.be.true();
done();
});
});
it('will not set headers without a profile', function (done) {
cacheControl()(null, res, function (a) {
should.not.exist(a);
res.set.called.should.be.false();
done();
});
});
it('will not get confused between serving public and private', function (done) {
const publicCC = cacheControl('public');
const privateCC = cacheControl('private');
publicCC(null, res, function () {
res.set.calledOnce.should.be.true();
res.set.calledWith({'Cache-Control': 'public, max-age=0'}).should.be.true();
privateCC(null, res, function () {
res.set.calledTwice.should.be.true();
res.set.calledWith({
'Cache-Control': 'no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0'
}).should.be.true();
publicCC(null, res, function () {
res.set.calledThrice.should.be.true();
res.set.calledWith({'Cache-Control': 'public, max-age=0'});
privateCC(null, res, function () {
res.set.calledWith({
'Cache-Control': 'no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0'
}).should.be.true();
done();
});
});
});
});
});
});