0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-02-10 23:36:14 -05:00
ghost/test/unit/data/meta/context_object_spec.js
Hannah Wolfe bd597db829
Moved settings/cache to shared/settings-cache
- 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
2021-06-30 15:49:10 +01:00

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');
});
});
});