Ghost/test/unit/helpers/authors.test.js
Hannah Wolfe f08a55c21f
Renamed tests to .test.js & updated commands
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
2021-07-06 20:45:01 +01:00

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