2018-11-07 15:29:37 +01:00
|
|
|
const should = require('should');
|
|
|
|
const supertest = require('supertest');
|
|
|
|
const _ = require('lodash');
|
|
|
|
const url = require('url');
|
2019-09-20 17:02:45 +02:00
|
|
|
const configUtils = require('../../utils/configUtils');
|
2020-05-27 12:47:53 -05:00
|
|
|
const config = require('../../../core/shared/config');
|
2020-03-30 16:26:47 +01:00
|
|
|
const models = require('../../../core/server/models');
|
2019-09-20 17:02:45 +02:00
|
|
|
const testUtils = require('../../utils');
|
2018-11-07 15:29:37 +01:00
|
|
|
const localUtils = require('./utils');
|
2019-09-20 17:02:45 +02:00
|
|
|
|
2018-11-07 15:29:37 +01:00
|
|
|
const ghost = testUtils.startGhost;
|
|
|
|
let request;
|
|
|
|
|
2019-02-04 15:49:59 +01:00
|
|
|
describe('Authors Content API', function () {
|
2018-11-07 15:29:37 +01:00
|
|
|
let ghostServer;
|
|
|
|
|
|
|
|
before(function () {
|
|
|
|
return ghost()
|
|
|
|
.then(function (_ghostServer) {
|
|
|
|
ghostServer = _ghostServer;
|
|
|
|
request = supertest.agent(config.get('url'));
|
|
|
|
})
|
|
|
|
.then(function () {
|
2019-02-13 20:38:25 +01:00
|
|
|
return testUtils.initFixtures('owner:post', 'users:no-owner', 'user:inactive', 'posts', 'api_keys');
|
2018-11-07 15:29:37 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(function () {
|
|
|
|
configUtils.restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
const validKey = localUtils.getValidKey();
|
|
|
|
|
2019-02-04 15:49:59 +01:00
|
|
|
it('Can request authors', function (done) {
|
2018-11-07 15:29:37 +01:00
|
|
|
request.get(localUtils.API.getApiQuery(`authors/?key=${validKey}`))
|
|
|
|
.set('Origin', testUtils.API.getURL())
|
|
|
|
.expect('Content-Type', /json/)
|
|
|
|
.expect('Cache-Control', testUtils.cacheRules.private)
|
|
|
|
.expect(200)
|
|
|
|
.end(function (err, res) {
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
should.not.exist(res.headers['x-cache-invalidate']);
|
2020-04-29 16:44:27 +01:00
|
|
|
const jsonResponse = res.body;
|
2018-11-07 15:29:37 +01:00
|
|
|
should.exist(jsonResponse.authors);
|
2018-12-17 16:14:36 +01:00
|
|
|
localUtils.API.checkResponse(jsonResponse, 'authors');
|
2019-01-03 20:30:35 +01:00
|
|
|
jsonResponse.authors.should.have.length(3);
|
2018-11-07 15:29:37 +01:00
|
|
|
|
|
|
|
// We don't expose the email address, status and other attrs.
|
2018-12-17 16:14:36 +01:00
|
|
|
localUtils.API.checkResponse(jsonResponse.authors[0], 'author', ['url'], null, null);
|
2018-11-07 15:29:37 +01:00
|
|
|
|
2019-01-15 12:21:04 +00:00
|
|
|
// Default order 'name asc' check
|
|
|
|
jsonResponse.authors[0].name.should.eql('Ghost');
|
|
|
|
jsonResponse.authors[2].name.should.eql('Slimer McEctoplasm');
|
|
|
|
|
2018-11-07 15:29:37 +01:00
|
|
|
should.exist(res.body.authors[0].url);
|
|
|
|
should.exist(url.parse(res.body.authors[0].url).protocol);
|
|
|
|
should.exist(url.parse(res.body.authors[0].url).host);
|
|
|
|
|
|
|
|
// Public api returns all authors, but no status! Locked/Inactive authors can still have written articles.
|
2019-01-03 20:30:35 +01:00
|
|
|
models.Author.findPage(Object.assign({status: 'all'}, testUtils.context.internal))
|
2018-11-07 15:29:37 +01:00
|
|
|
.then((response) => {
|
2019-07-05 13:40:43 +02:00
|
|
|
_.map(response.data, model => model.toJSON()).length.should.eql(3);
|
2018-11-07 15:29:37 +01:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2019-02-04 15:49:59 +01:00
|
|
|
it('Can request authors including post count', function (done) {
|
|
|
|
request.get(localUtils.API.getApiQuery(`authors/?key=${validKey}&include=count.posts&order=count.posts ASC`))
|
2018-11-07 15:29:37 +01:00
|
|
|
.set('Origin', testUtils.API.getURL())
|
|
|
|
.expect('Content-Type', /json/)
|
|
|
|
.expect('Cache-Control', testUtils.cacheRules.private)
|
|
|
|
.expect(200)
|
|
|
|
.end(function (err, res) {
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
2020-04-29 16:44:27 +01:00
|
|
|
const jsonResponse = res.body;
|
2018-11-07 15:29:37 +01:00
|
|
|
|
|
|
|
should.exist(jsonResponse.authors);
|
2019-02-04 15:49:59 +01:00
|
|
|
jsonResponse.authors.should.have.length(3);
|
2018-11-07 15:29:37 +01:00
|
|
|
|
|
|
|
// We don't expose the email address.
|
2018-12-17 16:14:36 +01:00
|
|
|
localUtils.API.checkResponse(jsonResponse.authors[0], 'author', ['count', 'url'], null, null);
|
2018-11-07 15:29:37 +01:00
|
|
|
|
2019-02-04 15:49:59 +01:00
|
|
|
// Each user should have the correct count and be more than 0
|
2019-08-19 12:41:09 +01:00
|
|
|
_.find(jsonResponse.authors, {slug: 'joe-bloggs'}).count.posts.should.eql(4);
|
|
|
|
_.find(jsonResponse.authors, {slug: 'slimer-mcectoplasm'}).count.posts.should.eql(1);
|
|
|
|
_.find(jsonResponse.authors, {slug: 'ghost'}).count.posts.should.eql(7);
|
2018-11-07 15:29:37 +01:00
|
|
|
|
2019-02-04 15:49:59 +01:00
|
|
|
const ids = jsonResponse.authors
|
|
|
|
.filter(author => (author.slug !== 'ghost'))
|
2019-07-05 13:40:43 +02:00
|
|
|
.map(user => user.id);
|
2018-11-07 15:29:37 +01:00
|
|
|
|
2019-02-04 15:49:59 +01:00
|
|
|
ids.should.eql([
|
|
|
|
testUtils.DataGenerator.Content.users[3].id,
|
|
|
|
testUtils.DataGenerator.Content.users[0].id
|
|
|
|
]);
|
2018-11-07 15:29:37 +01:00
|
|
|
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2019-02-04 15:49:59 +01:00
|
|
|
it('Can request single author', function (done) {
|
|
|
|
request.get(localUtils.API.getApiQuery(`authors/slug/ghost/?key=${validKey}`))
|
2018-11-07 15:29:37 +01:00
|
|
|
.set('Origin', testUtils.API.getURL())
|
|
|
|
.expect('Content-Type', /json/)
|
|
|
|
.expect('Cache-Control', testUtils.cacheRules.private)
|
|
|
|
.expect(200)
|
|
|
|
.end(function (err, res) {
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
2019-02-04 15:49:59 +01:00
|
|
|
should.not.exist(res.headers['x-cache-invalidate']);
|
2020-04-29 16:44:27 +01:00
|
|
|
const jsonResponse = res.body;
|
2018-11-07 15:29:37 +01:00
|
|
|
|
|
|
|
should.exist(jsonResponse.authors);
|
2019-02-04 15:49:59 +01:00
|
|
|
jsonResponse.authors.should.have.length(1);
|
2018-11-07 15:29:37 +01:00
|
|
|
|
|
|
|
// We don't expose the email address.
|
2019-02-04 15:49:59 +01:00
|
|
|
localUtils.API.checkResponse(jsonResponse.authors[0], 'author', ['url'], null, null);
|
2018-11-07 15:29:37 +01:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2019-02-04 15:49:59 +01:00
|
|
|
it('Can request author by id including post count', function (done) {
|
|
|
|
request.get(localUtils.API.getApiQuery(`authors/1/?key=${validKey}&include=count.posts`))
|
2018-11-07 15:29:37 +01:00
|
|
|
.set('Origin', testUtils.API.getURL())
|
|
|
|
.expect('Content-Type', /json/)
|
|
|
|
.expect('Cache-Control', testUtils.cacheRules.private)
|
|
|
|
.expect(200)
|
|
|
|
.end(function (err, res) {
|
|
|
|
if (err) {
|
|
|
|
return done(err);
|
|
|
|
}
|
|
|
|
|
|
|
|
should.not.exist(res.headers['x-cache-invalidate']);
|
2020-04-29 16:44:27 +01:00
|
|
|
const jsonResponse = res.body;
|
2019-02-04 15:49:59 +01:00
|
|
|
|
2018-11-07 15:29:37 +01:00
|
|
|
should.exist(jsonResponse.authors);
|
2019-02-04 15:49:59 +01:00
|
|
|
jsonResponse.authors.should.have.length(1);
|
2018-11-07 15:29:37 +01:00
|
|
|
|
|
|
|
// We don't expose the email address.
|
2018-12-17 16:14:36 +01:00
|
|
|
localUtils.API.checkResponse(jsonResponse.authors[0], 'author', ['count', 'url'], null, null);
|
2018-11-07 15:29:37 +01:00
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|