mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-02-10 23:36:14 -05:00
- This is part of the quest to separate the frontend and server & get rid of all the places where there are cross-requires - At the moment the settings cache is one big shared cache used by the frontend and server liberally - This change doesn't really solve the fundamental problems, as we still depend on events, and requires from inside frontend - However it allows us to control the misuse slightly better by getting rid of restricted requires and turning on that eslint ruleset
82 lines
2.5 KiB
JavaScript
82 lines
2.5 KiB
JavaScript
const should = require('should');
|
|
const sinon = require('sinon');
|
|
const getContextObject = require('../../../../core/frontend/meta/context_object.js');
|
|
const settingsCache = require('../../../../core/shared/settings-cache');
|
|
|
|
describe('getContextObject', function () {
|
|
let data;
|
|
let context;
|
|
let contextObject;
|
|
|
|
it('should be a function', function () {
|
|
should.exist(getContextObject);
|
|
});
|
|
|
|
it('should return post context object for a post', function () {
|
|
data = {post: {id: 2}};
|
|
context = ['post'];
|
|
contextObject = getContextObject(data, context);
|
|
|
|
should.exist(contextObject);
|
|
contextObject.should.eql(data.post);
|
|
});
|
|
|
|
it('should return post context object for a static page', function () {
|
|
data = {post: {id: 2}};
|
|
context = ['page'];
|
|
contextObject = getContextObject(data, context);
|
|
|
|
should.exist(contextObject);
|
|
contextObject.should.eql(data.post);
|
|
});
|
|
|
|
it('should return post context object for an AMP post', function () {
|
|
data = {post: {id: 2}};
|
|
context = ['amp', 'post'];
|
|
contextObject = getContextObject(data, context);
|
|
|
|
should.exist(contextObject);
|
|
contextObject.should.eql(data.post);
|
|
});
|
|
|
|
it('should return post context object for a static page with amp context', function () {
|
|
data = {post: {id: 2}};
|
|
context = ['amp', 'page'];
|
|
contextObject = getContextObject(data, context);
|
|
|
|
should.exist(contextObject);
|
|
contextObject.should.eql(data.post);
|
|
});
|
|
|
|
it('should return page', function () {
|
|
data = {page: {id: 2}};
|
|
context = ['news', 'page'];
|
|
contextObject = getContextObject(data, context);
|
|
|
|
should.exist(contextObject);
|
|
contextObject.should.eql(data.page);
|
|
});
|
|
|
|
describe('override blog', function () {
|
|
before(function () {
|
|
sinon.stub(settingsCache, 'get').callsFake(function (key) {
|
|
return {
|
|
cover_image: 'test.png'
|
|
}[key];
|
|
});
|
|
});
|
|
|
|
after(function () {
|
|
sinon.restore();
|
|
});
|
|
|
|
it('should return blog context object for unknown context', function () {
|
|
data = {post: {id: 2}};
|
|
context = ['unknown'];
|
|
contextObject = getContextObject(data, context);
|
|
|
|
should.exist(contextObject);
|
|
contextObject.should.have.property('cover_image', 'test.png');
|
|
});
|
|
});
|
|
});
|