mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-02 07:43:11 +03: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
217 lines
8.6 KiB
JavaScript
217 lines
8.6 KiB
JavaScript
const should = require('should');
|
|
const sinon = require('sinon');
|
|
const urlService = require('../../../core/frontend/services/url');
|
|
const helpers = require('../../../core/frontend/helpers');
|
|
const models = require('../../../core/server/models');
|
|
const testUtils = require('../../utils');
|
|
|
|
describe('{{authors}} helper', function () {
|
|
before(function () {
|
|
models.init();
|
|
});
|
|
|
|
beforeEach(function () {
|
|
sinon.stub(urlService, 'getUrlByResourceId');
|
|
});
|
|
|
|
afterEach(function () {
|
|
sinon.restore();
|
|
});
|
|
|
|
it('can return string with authors', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'Michael'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'Thomas'})
|
|
];
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {autolink: 'false'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('Michael, Thomas');
|
|
});
|
|
|
|
it('can return string with authors with special chars', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'John O\'Nolan'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'AB=CD`EF'})
|
|
];
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {autolink: 'false'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('John O'Nolan, AB=CD`EF');
|
|
});
|
|
|
|
it('can use a different separator', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'haunted'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'ghost'})
|
|
];
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {separator: '|', autolink: 'false'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('haunted|ghost');
|
|
});
|
|
|
|
it('can add a single prefix to multiple authors', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'haunted'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'ghost'})
|
|
];
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {prefix: 'on ', autolink: 'false'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('on haunted, ghost');
|
|
});
|
|
|
|
it('can add a single suffix to multiple authors', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'haunted'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'ghost'})
|
|
];
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {suffix: ' forever', autolink: 'false'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('haunted, ghost forever');
|
|
});
|
|
|
|
it('can add a prefix and suffix to multiple authors', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'haunted'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'ghost'})
|
|
];
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {suffix: ' forever', prefix: 'on ', autolink: 'false'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('on haunted, ghost forever');
|
|
});
|
|
|
|
it('can add a prefix and suffix with HTML', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'haunted'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'ghost'})
|
|
];
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {suffix: ' •', prefix: '… ', autolink: 'false'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('… haunted, ghost •');
|
|
});
|
|
|
|
it('does not add prefix or suffix if no authors exist', function () {
|
|
const rendered = helpers.authors.call({}, {hash: {prefix: 'on ', suffix: ' forever', autolink: 'false'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('');
|
|
});
|
|
|
|
it('can autolink authors to author pages', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'foo', slug: 'foo-bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'bar', slug: 'bar'})
|
|
];
|
|
|
|
urlService.getUrlByResourceId.withArgs(authors[0].id).returns('author url 1');
|
|
urlService.getUrlByResourceId.withArgs(authors[1].id).returns('author url 2');
|
|
|
|
const rendered = helpers.authors.call({authors: authors});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('<a href="author url 1">foo</a>, <a href="author url 2">bar</a>');
|
|
});
|
|
|
|
it('can limit no. authors output to 1', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'foo', slug: 'foo-bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'bar', slug: 'bar'})
|
|
];
|
|
|
|
urlService.getUrlByResourceId.withArgs(authors[0].id).returns('author url 1');
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {limit: '1'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('<a href="author url 1">foo</a>');
|
|
});
|
|
|
|
it('can list authors from a specified no.', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'foo', slug: 'foo-bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'bar', slug: 'bar'})
|
|
];
|
|
|
|
urlService.getUrlByResourceId.withArgs(authors[1].id).returns('author url 2');
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {from: '2'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('<a href="author url 2">bar</a>');
|
|
});
|
|
|
|
it('can list authors to a specified no.', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'foo', slug: 'foo-bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'bar', slug: 'bar'})
|
|
];
|
|
|
|
urlService.getUrlByResourceId.withArgs(authors[0].id).returns('author url');
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {to: '1'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('<a href="author url">foo</a>');
|
|
});
|
|
|
|
it('can list authors in a range', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'foo', slug: 'foo-bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'bar', slug: 'bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'baz', slug: 'baz'})
|
|
];
|
|
|
|
urlService.getUrlByResourceId.withArgs(authors[1].id).returns('author url 2');
|
|
urlService.getUrlByResourceId.withArgs(authors[2].id).returns('author url 3');
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {from: '2', to: '3'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('<a href="author url 2">bar</a>, <a href="author url 3">baz</a>');
|
|
});
|
|
|
|
it('can limit no. authors and output from 2', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'foo', slug: 'foo-bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'bar', slug: 'bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'baz', slug: 'baz'})
|
|
];
|
|
|
|
urlService.getUrlByResourceId.withArgs(authors[1].id).returns('author url x');
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {from: '2', limit: '1'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('<a href="author url x">bar</a>');
|
|
});
|
|
|
|
it('can list authors in a range (ignore limit)', function () {
|
|
const authors = [
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'foo', slug: 'foo-bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'bar', slug: 'bar'}),
|
|
testUtils.DataGenerator.forKnex.createUser({name: 'baz', slug: 'baz'})
|
|
];
|
|
|
|
urlService.getUrlByResourceId.withArgs(authors[0].id).returns('author url a');
|
|
urlService.getUrlByResourceId.withArgs(authors[1].id).returns('author url b');
|
|
urlService.getUrlByResourceId.withArgs(authors[2].id).returns('author url c');
|
|
|
|
const rendered = helpers.authors.call({authors: authors}, {hash: {from: '1', to: '3', limit: '2'}});
|
|
should.exist(rendered);
|
|
|
|
String(rendered).should.equal('<a href="author url a">foo</a>, <a href="author url b">bar</a>, <a href="author url c">baz</a>');
|
|
});
|
|
});
|