mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-27 22:49:56 -05:00
f08a55c21f
refs: https://github.com/TryGhost/Team/issues/856 refs: https://github.com/TryGhost/Team/issues/756 - The .test.js extension is better than _spec.js as it's more obvious that it's an extension - It also meaans we can use the --extension parameter in mocha, which should result in a better default behaviour for `yarn test` - It also highlights that some of our tests were named incorrectly and were not (and still will not be) run (see https://github.com/TryGhost/Team/issues/856) - Note: even with this change, `yarn test` is throwing errors, I believe because of this issue https://github.com/TryGhost/Team/issues/756
160 lines
5.7 KiB
JavaScript
160 lines
5.7 KiB
JavaScript
const should = require('should');
|
|
const sinon = require('sinon');
|
|
const helpers = require('../../../core/frontend/helpers');
|
|
const settingsCache = require('../../../core/shared/settings-cache');
|
|
|
|
describe('{{meta_description}} helper', function () {
|
|
const localSettingsCache = {};
|
|
|
|
before(function () {
|
|
sinon.stub(settingsCache, 'get').callsFake(function (key) {
|
|
return localSettingsCache[key];
|
|
});
|
|
});
|
|
|
|
after(function () {
|
|
sinon.restore();
|
|
});
|
|
|
|
describe('no meta_description', function () {
|
|
before(function () {
|
|
localSettingsCache.description = 'The professional publishing platform';
|
|
});
|
|
|
|
it('returns correct site description', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{},
|
|
{data: {root: {context: ['home', 'index']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('The professional publishing platform');
|
|
});
|
|
|
|
it('returns empty description on paginated page', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{},
|
|
{data: {root: {context: ['index', 'paged']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('');
|
|
});
|
|
|
|
it('returns empty description for a tag page', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{tag: {name: 'Rasper Red'}},
|
|
{data: {root: {context: ['tag']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('');
|
|
});
|
|
|
|
it('returns empty description for a paginated tag page', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{tag: {name: 'Rasper Red'}},
|
|
{data: {root: {context: ['tag', 'paged']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('');
|
|
});
|
|
|
|
it('returns tag meta_description if present for a tag page', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{tag: {name: 'Rasper Red', meta_description: 'Rasper is the Cool Red Casper'}},
|
|
{data: {root: {context: ['tag']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('Rasper is the Cool Red Casper');
|
|
});
|
|
|
|
it('returns empty description on paginated tag page that has meta data', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{tag: {name: 'Rasper Red', meta_description: 'Rasper is the Cool Red Casper'}},
|
|
{data: {root: {context: ['tag', 'paged']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('');
|
|
});
|
|
|
|
it('returns author bio for an author page', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{author: {bio: 'I am a Duck.'}},
|
|
{data: {root: {context: ['author']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('I am a Duck.');
|
|
});
|
|
|
|
it('returns empty description for a paginated author page', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{author: {name: 'Donald Duck'}},
|
|
{data: {root: {context: ['author', 'paged']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('');
|
|
});
|
|
|
|
it('returns empty description when meta_description is not set', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{post: {title: 'Post Title', html: 'Very nice post indeed.'}},
|
|
{data: {root: {context: ['post']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('');
|
|
});
|
|
|
|
it('returns meta_description on post with meta_description set', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{post: {title: 'Post Title', meta_description: 'Nice post about stuff.'}},
|
|
{data: {root: {context: ['post']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('Nice post about stuff.');
|
|
});
|
|
|
|
it('returns meta_description on post when used within {{#foreach posts}}', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{meta_description: 'Nice post about stuff.'},
|
|
{data: {root: {context: ['home']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('Nice post about stuff.');
|
|
});
|
|
});
|
|
|
|
describe('with meta_description', function () {
|
|
before(function () {
|
|
localSettingsCache.meta_description = 'Meta description of the professional publishing platform';
|
|
});
|
|
|
|
it('returns correct site description', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{},
|
|
{data: {root: {context: ['home', 'index']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('Meta description of the professional publishing platform');
|
|
});
|
|
|
|
it('returns tag meta_description if present for a tag page', function () {
|
|
const rendered = helpers.meta_description.call(
|
|
{tag: {name: 'Rasper Red', meta_description: 'Rasper is the Cool Red Casper'}},
|
|
{data: {root: {context: ['tag']}}}
|
|
);
|
|
|
|
should.exist(rendered);
|
|
String(rendered).should.equal('Rasper is the Cool Red Casper');
|
|
});
|
|
});
|
|
});
|