mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
Merge pull request #6083 from ErisDS/filter-missing
Add filter param for tags & users
This commit is contained in:
commit
6b31f362a2
4 changed files with 99 additions and 7 deletions
|
@ -79,7 +79,7 @@ Tag = ghostBookshelf.Model.extend({
|
||||||
// whitelists for the `options` hash argument on methods, by method name.
|
// whitelists for the `options` hash argument on methods, by method name.
|
||||||
// these are the only options that can be passed to Bookshelf / Knex.
|
// these are the only options that can be passed to Bookshelf / Knex.
|
||||||
validOptions = {
|
validOptions = {
|
||||||
findPage: ['page', 'limit', 'columns', 'order']
|
findPage: ['page', 'limit', 'columns', 'filter', 'order']
|
||||||
};
|
};
|
||||||
|
|
||||||
if (validOptions[methodName]) {
|
if (validOptions[methodName]) {
|
||||||
|
|
|
@ -228,7 +228,7 @@ User = ghostBookshelf.Model.extend({
|
||||||
findOne: ['withRelated', 'status'],
|
findOne: ['withRelated', 'status'],
|
||||||
setup: ['id'],
|
setup: ['id'],
|
||||||
edit: ['withRelated', 'id'],
|
edit: ['withRelated', 'id'],
|
||||||
findPage: ['page', 'limit', 'columns', 'order', 'status']
|
findPage: ['page', 'limit', 'columns', 'filter', 'order', 'status']
|
||||||
};
|
};
|
||||||
|
|
||||||
if (validOptions[methodName]) {
|
if (validOptions[methodName]) {
|
||||||
|
|
|
@ -178,7 +178,7 @@ describe('Filter Param Spec', function () {
|
||||||
|
|
||||||
describe('5. Users - filter="posts.tags:photo" order="posts.count DESC" limit="3"', function () {
|
describe('5. Users - filter="posts.tags:photo" order="posts.count DESC" limit="3"', function () {
|
||||||
it('Will fetch the 3 most prolific users who write posts with the tag `photo` ordered by most posts.', function (done) {
|
it('Will fetch the 3 most prolific users who write posts with the tag `photo` ordered by most posts.', function (done) {
|
||||||
UserAPI.browse({filter: 'posts.tags:photo', order: 'posts.count DESC', limit: 3}).then(function (result) {
|
UserAPI.browse({filter: 'posts.tags:special', order: 'posts.count DESC', limit: 3}).then(function (result) {
|
||||||
var ids;
|
var ids;
|
||||||
// 1. Result should have the correct base structure
|
// 1. Result should have the correct base structure
|
||||||
should.exist(result);
|
should.exist(result);
|
||||||
|
@ -230,6 +230,79 @@ describe('Filter Param Spec', function () {
|
||||||
}).catch(done);
|
}).catch(done);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('7. Users filter: "website:-null", order: "website"', function () {
|
||||||
|
it('Will fetch users that have a website and order them by website', function (done) {
|
||||||
|
UserAPI.browse({filter: 'website:-null', order: 'website ASC'}).then(function (result) {
|
||||||
|
var ids;
|
||||||
|
// 1. Result should have the correct base structure
|
||||||
|
should.exist(result);
|
||||||
|
result.should.have.property('users');
|
||||||
|
result.should.have.property('meta');
|
||||||
|
|
||||||
|
// 2. The data part of the response should be correct
|
||||||
|
// We should have 2 matching items
|
||||||
|
result.users.should.be.an.Array.with.lengthOf(2);
|
||||||
|
|
||||||
|
ids = _.pluck(result.users, 'id');
|
||||||
|
ids.should.eql([2, 1]);
|
||||||
|
|
||||||
|
should.exist(result.users[0].website);
|
||||||
|
should.exist(result.users[1].website);
|
||||||
|
|
||||||
|
// 3. The meta object should contain the right details
|
||||||
|
result.meta.should.have.property('pagination');
|
||||||
|
result.meta.pagination.should.be.an.Object.with.properties(['page', 'limit', 'pages', 'total', 'next', 'prev']);
|
||||||
|
result.meta.pagination.page.should.eql(1);
|
||||||
|
result.meta.pagination.limit.should.eql(15);
|
||||||
|
result.meta.pagination.pages.should.eql(1);
|
||||||
|
result.meta.pagination.total.should.eql(2);
|
||||||
|
should.equal(result.meta.pagination.next, null);
|
||||||
|
should.equal(result.meta.pagination.prev, null);
|
||||||
|
|
||||||
|
done();
|
||||||
|
}).catch(done);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('8. Tags filter: "image:-null+description:-null"', function () {
|
||||||
|
it('Will fetch tags which have an image and a description', function (done) {
|
||||||
|
TagAPI.browse({filter: 'image:-null+description:-null', order: 'name ASC'}).then(function (result) {
|
||||||
|
var ids;
|
||||||
|
// 1. Result should have the correct base structure
|
||||||
|
should.exist(result);
|
||||||
|
result.should.have.property('tags');
|
||||||
|
result.should.have.property('meta');
|
||||||
|
|
||||||
|
// 2. The data part of the response should be correct
|
||||||
|
// We should have 3 matching items
|
||||||
|
result.tags.should.be.an.Array.with.lengthOf(3);
|
||||||
|
|
||||||
|
ids = _.pluck(result.tags, 'id');
|
||||||
|
ids.should.eql([4, 3, 2]);
|
||||||
|
|
||||||
|
should.exist(result.tags[0].image);
|
||||||
|
should.exist(result.tags[1].image);
|
||||||
|
should.exist(result.tags[2].image);
|
||||||
|
|
||||||
|
should.exist(result.tags[0].description);
|
||||||
|
should.exist(result.tags[1].description);
|
||||||
|
should.exist(result.tags[2].description);
|
||||||
|
|
||||||
|
// 3. The meta object should contain the right details
|
||||||
|
result.meta.should.have.property('pagination');
|
||||||
|
result.meta.pagination.should.be.an.Object.with.properties(['page', 'limit', 'pages', 'total', 'next', 'prev']);
|
||||||
|
result.meta.pagination.page.should.eql(1);
|
||||||
|
result.meta.pagination.limit.should.eql(15);
|
||||||
|
result.meta.pagination.pages.should.eql(1);
|
||||||
|
result.meta.pagination.total.should.eql(3);
|
||||||
|
should.equal(result.meta.pagination.next, null);
|
||||||
|
should.equal(result.meta.pagination.prev, null);
|
||||||
|
|
||||||
|
done();
|
||||||
|
}).catch(done);
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe.skip('Count capabilities', function () {
|
describe.skip('Count capabilities', function () {
|
||||||
|
|
|
@ -14,22 +14,33 @@ data.tags = [
|
||||||
{
|
{
|
||||||
name: 'photo',
|
name: 'photo',
|
||||||
slug: 'photo',
|
slug: 'photo',
|
||||||
|
image: 'some/image/path.jpg',
|
||||||
|
description: 'Photo posts',
|
||||||
created_by: 2
|
created_by: 2
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'Video',
|
name: 'Video',
|
||||||
slug: 'video',
|
slug: 'video',
|
||||||
|
image: 'some/image/path.jpg',
|
||||||
|
description: 'Video posts',
|
||||||
created_by: 1
|
created_by: 1
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'Audio',
|
name: 'Audio',
|
||||||
slug: 'audio',
|
slug: 'audio',
|
||||||
|
image: 'some/image/path.jpg',
|
||||||
|
description: 'Audio posts',
|
||||||
created_by: 1
|
created_by: 1
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'No Posts',
|
name: 'No Posts',
|
||||||
slug: 'no-posts',
|
slug: 'no-posts',
|
||||||
created_by: 2
|
created_by: 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Special',
|
||||||
|
slug: 'special',
|
||||||
|
created_by: 2
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -39,12 +50,20 @@ data.users = [
|
||||||
name: 'Leslie Jones',
|
name: 'Leslie Jones',
|
||||||
slug: 'leslie',
|
slug: 'leslie',
|
||||||
email: 'ljones@nothere.com',
|
email: 'ljones@nothere.com',
|
||||||
password: '$2a$10$.pZeeBE0gHXd0PTnbT/ph.GEKgd0Wd3q2pWna3ynTGBkPKnGIKZL6'
|
password: '$2a$10$.pZeeBE0gHXd0PTnbT/ph.GEKgd0Wd3q2pWna3ynTGBkPKnGIKZL6',
|
||||||
|
website: 'http://twitter.com/ljonestestuser'
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'Pat Smith',
|
name: 'Pat Smith',
|
||||||
slug: 'pat-smith',
|
slug: 'pat-smith',
|
||||||
email: 'pat-smith@nothere.com',
|
email: 'pat-smith@nothere.com',
|
||||||
|
password: '$2a$10$.pZeeBE0gHXd0PTnbT/ph.GEKgd0Wd3q2pWna3ynTGBkPKnGIKZL6',
|
||||||
|
website: 'http://github.com/patsmithtestuser'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: 'Cameron Howe',
|
||||||
|
slug: 'camhowe',
|
||||||
|
email: 'camhowe@c-e-is-real.com',
|
||||||
password: '$2a$10$.pZeeBE0gHXd0PTnbT/ph.GEKgd0Wd3q2pWna3ynTGBkPKnGIKZL6'
|
password: '$2a$10$.pZeeBE0gHXd0PTnbT/ph.GEKgd0Wd3q2pWna3ynTGBkPKnGIKZL6'
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
@ -64,7 +83,7 @@ data.posts = [
|
||||||
markdown: 'Hello World!',
|
markdown: 'Hello World!',
|
||||||
featured: false,
|
featured: false,
|
||||||
author_id: 2,
|
author_id: 2,
|
||||||
tags: [2, 3, 4]
|
tags: [2, 3, 4, 6]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Third Post',
|
title: 'Third Post',
|
||||||
|
@ -88,7 +107,7 @@ data.posts = [
|
||||||
markdown: 'Hello World!',
|
markdown: 'Hello World!',
|
||||||
featured: true,
|
featured: true,
|
||||||
author_id: 2,
|
author_id: 2,
|
||||||
tags: []
|
tags: [6]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Sixth Post',
|
title: 'Sixth Post',
|
||||||
|
@ -97,7 +116,7 @@ data.posts = [
|
||||||
featured: false,
|
featured: false,
|
||||||
author_id: 2,
|
author_id: 2,
|
||||||
image: 'some/image/path.jpg',
|
image: 'some/image/path.jpg',
|
||||||
tags: [1, 4]
|
tags: [1, 4, 6]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Seventh Post',
|
title: 'Seventh Post',
|
||||||
|
|
Loading…
Add table
Reference in a new issue