0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

deps: ghost-gql@0.0.3

- adds test for nested null/not null query issue
- make use of new findStatement tool
This commit is contained in:
Hannah Wolfe 2015-11-10 15:27:28 +00:00
parent b64a0cc1f4
commit a3bd00d978
3 changed files with 14 additions and 20 deletions

View file

@ -3,12 +3,12 @@
* Parts of the model code which can be split out and unit tested * Parts of the model code which can be split out and unit tested
*/ */
var _ = require('lodash'), var _ = require('lodash'),
gql = require('ghost-gql'),
processGQLResult, processGQLResult,
tagUpdate; tagUpdate;
processGQLResult = function processGQLResult(itemCollection, options) { processGQLResult = function processGQLResult(itemCollection, options) {
var joinTables = options.filter.joins, var joinTables = options.filter.joins;
tagsHasIn = false;
if (joinTables && joinTables.indexOf('tags') > -1) { if (joinTables && joinTables.indexOf('tags') > -1) {
// We need to use leftOuterJoin to insure we still include posts which don't have tags in the result // We need to use leftOuterJoin to insure we still include posts which don't have tags in the result
@ -21,13 +21,7 @@ processGQLResult = function processGQLResult(itemCollection, options) {
// TODO move the order handling to the query building that is currently inside pagination // TODO move the order handling to the query building that is currently inside pagination
// TODO make the order handling in pagination handle orderByRaw // TODO make the order handling in pagination handle orderByRaw
// TODO extend this handling to all joins // TODO extend this handling to all joins
_.each(options.filter.statements, function (statement) { if (gql.json.findStatement(options.filter.statements, {prop: /^tags/, op: 'IN'})) {
if (statement.op === 'IN' && statement.prop.match(/tags/)) {
tagsHasIn = true;
}
});
if (tagsHasIn) {
// TODO make this count the number of MATCHING tags, not just the number of tags // TODO make this count the number of MATCHING tags, not just the number of tags
itemCollection.query('orderByRaw', 'count(tags.id) DESC'); itemCollection.query('orderByRaw', 'count(tags.id) DESC');
} }

View file

@ -126,10 +126,10 @@ describe('Filter Param Spec', function () {
}); });
}); });
describe('4. Posts - filter="author:[leslie,pat]+(featured:true,tag:audio)"', function () { describe('4. Posts - filter="author:[leslie,pat]+(tag:audio,image:-null)"', function () {
// Note that `pat` doesn't exist (it's `pat-smith`) // Note that `pat` doesn't exist (it's `pat-smith`)
it('Will fetch posts by the author `leslie` or `pat` which are either featured or have tag `audio`.', function (done) { it('Will fetch posts by the author `leslie` or `pat` which are either have tag `audio` or an image.', function (done) {
PostAPI.browse({filter: 'author:[leslie,pat]+(featured:true,tag:audio)', include: 'author,tags'}).then(function (result) { PostAPI.browse({filter: 'author:[leslie,pat]+(tag:audio,image:-null)', include: 'author,tags'}).then(function (result) {
var ids, authors; var ids, authors;
// 1. Result should have the correct base structure // 1. Result should have the correct base structure
should.exist(result); should.exist(result);
@ -138,7 +138,7 @@ describe('Filter Param Spec', function () {
// 2. The data part of the response should be correct // 2. The data part of the response should be correct
// We should have 2 matching items // We should have 2 matching items
result.posts.should.be.an.Array.with.lengthOf(4); result.posts.should.be.an.Array.with.lengthOf(6);
// Each post must either have the author 'leslie' or 'pat' // Each post must either have the author 'leslie' or 'pat'
authors = _.map(result.posts, function (post) { authors = _.map(result.posts, function (post) {
@ -148,10 +148,10 @@ describe('Filter Param Spec', function () {
// Each post must either be featured or have the tag 'audio' // Each post must either be featured or have the tag 'audio'
_.each(result.posts, function (post) { _.each(result.posts, function (post) {
var tags; var tags = _.pluck(post.tags, 'slug');
// This construct ensures we get an assertion or a failure // This construct ensures we get an assertion or a failure
if (post.featured === 'true') { if (!_.isEmpty(post.image)) {
post.featured.should.be.true; post.image.should.not.be.empty;
} else { } else {
tags = _.pluck(post.tags, 'slug'); tags = _.pluck(post.tags, 'slug');
tags.should.containEql('audio'); tags.should.containEql('audio');
@ -159,7 +159,7 @@ describe('Filter Param Spec', function () {
}); });
ids = _.pluck(result.posts, 'id'); ids = _.pluck(result.posts, 'id');
ids.should.eql([14, 12, 9, 8]); ids.should.eql([14, 12, 11, 9, 8, 7]);
// 3. The meta object should contain the right details // 3. The meta object should contain the right details
result.meta.should.have.property('pagination'); result.meta.should.have.property('pagination');
@ -167,7 +167,7 @@ describe('Filter Param Spec', function () {
result.meta.pagination.page.should.eql(1); result.meta.pagination.page.should.eql(1);
result.meta.pagination.limit.should.eql(15); result.meta.pagination.limit.should.eql(15);
result.meta.pagination.pages.should.eql(1); result.meta.pagination.pages.should.eql(1);
result.meta.pagination.total.should.eql(4); result.meta.pagination.total.should.eql(6);
should.equal(result.meta.pagination.next, null); should.equal(result.meta.pagination.next, null);
should.equal(result.meta.pagination.prev, null); should.equal(result.meta.pagination.prev, null);

View file

@ -41,7 +41,7 @@
"express-hbs": "0.8.4", "express-hbs": "0.8.4",
"extract-zip": "1.1.1", "extract-zip": "1.1.1",
"fs-extra": "0.24.0", "fs-extra": "0.24.0",
"ghost-gql": "0.0.2", "ghost-gql": "0.0.3",
"glob": "5.0.15", "glob": "5.0.15",
"html-to-text": "1.3.2", "html-to-text": "1.3.2",
"intl": "1.0.0", "intl": "1.0.0",