Ghost/ghost/admin/tests/acceptance/content-test.js
Kevin Ansfield ea8b4277b0 add dropdown filters for post type, author, and tag (#554)
refs TryGhost/Ghost#7860
- removes post type filter links
- adds dropdown filters for post type, author, and tag
- replaces custom refresh on query params change with Ember's standard `refreshModel` config
2017-03-02 12:35:09 -06:00

169 lines
7.9 KiB
JavaScript

import {describe, it, beforeEach, afterEach} from 'mocha';
import {expect} from 'chai';
import startApp from '../helpers/start-app';
import destroyApp from '../helpers/destroy-app';
import {
invalidateSession,
authenticateSession
} from 'ghost-admin/tests/helpers/ember-simple-auth';
import testSelector from 'ember-test-selectors';
describe('Acceptance: Content', function() {
let application;
beforeEach(function() {
application = startApp();
});
afterEach(function() {
destroyApp(application);
});
it('redirects to signin when not authenticated', function () {
invalidateSession(application);
visit('/');
andThen(function () {
expect(currentURL()).to.equal('/signin');
});
});
describe('as admin', function () {
let admin, editor,
publishedPost, scheduledPost, draftPost, publishedPage, authorPost;
beforeEach(function () {
let adminRole = server.create('role', {name: 'Administrator'});
admin = server.create('user', {roles: [adminRole]});
let editorRole = server.create('role', {name: 'Editor'});
editor = server.create('user', {roles: [editorRole]});
publishedPost = server.create('post', {authorId: admin.id, status: 'published', title: 'Published Post'});
scheduledPost = server.create('post', {authorId: admin.id, status: 'scheduled', title: 'Scheduled Post'});
draftPost = server.create('post', {authorId: admin.id, status: 'draft', title: 'Draft Post'});
publishedPage = server.create('post', {authorId: admin.id, status: 'published', page: true, title: 'Published Page'});
authorPost = server.create('post', {authorId: editor.id, status: 'published', title: 'Editor Published Post'});
return authenticateSession(application);
});
it('displays and filters posts', function () {
visit('/');
andThen(() => {
// Not checking request here as it won't be the last request made
// Displays all posts + pages
expect(find(testSelector('post-id')).length, 'all posts count').to.equal(5);
});
selectChoose(testSelector('type-select'), 'Draft posts');
andThen(() => {
// API request is correct
let [lastRequest] = server.pretender.handledRequests.slice(-1);
expect(lastRequest.queryParams.status, '"drafts" request status param').to.equal('draft');
expect(lastRequest.queryParams.staticPages, '"drafts" request staticPages param').to.equal('false');
// Displays draft post
expect(find(testSelector('post-id')).length, 'drafts count').to.equal(1);
expect(find(testSelector('post-id', draftPost.id)), 'draft post').to.exist;
});
selectChoose(testSelector('type-select'), 'Published posts');
andThen(() => {
// API request is correct
let [lastRequest] = server.pretender.handledRequests.slice(-1);
expect(lastRequest.queryParams.status, '"published" request status param').to.equal('published');
expect(lastRequest.queryParams.staticPages, '"published" request staticPages param').to.equal('false');
// Displays three published posts + pages
expect(find(testSelector('post-id')).length, 'published count').to.equal(2);
expect(find(testSelector('post-id', publishedPost.id)), 'admin published post').to.exist;
expect(find(testSelector('post-id', authorPost.id)), 'author published post').to.exist;
});
selectChoose(testSelector('type-select'), 'Scheduled posts');
andThen(() => {
// API request is correct
let [lastRequest] = server.pretender.handledRequests.slice(-1);
expect(lastRequest.queryParams.status, '"scheduled" request status param').to.equal('scheduled');
expect(lastRequest.queryParams.staticPages, '"scheduled" request staticPages param').to.equal('false');
// Displays scheduled post
expect(find(testSelector('post-id')).length, 'scheduled count').to.equal(1);
expect(find(testSelector('post-id', scheduledPost.id)), 'scheduled post').to.exist;
});
selectChoose(testSelector('type-select'), 'Pages');
andThen(() => {
// API request is correct
let [lastRequest] = server.pretender.handledRequests.slice(-1);
expect(lastRequest.queryParams.status, '"pages" request status param').to.equal('all');
expect(lastRequest.queryParams.staticPages, '"pages" request staticPages param').to.equal('true');
// Displays page
expect(find(testSelector('post-id')).length, 'pages count').to.equal(1);
expect(find(testSelector('post-id', publishedPage.id)), 'page post').to.exist;
});
selectChoose(testSelector('type-select'), 'All posts');
andThen(() => {
// API request is correct
let [lastRequest] = server.pretender.handledRequests.slice(-1);
expect(lastRequest.queryParams.status, '"all" request status param').to.equal('all');
expect(lastRequest.queryParams.staticPages, '"all" request staticPages param').to.equal('all');
});
selectChoose(testSelector('author-select'), editor.name);
andThen(() => {
// API request is correct
let [lastRequest] = server.pretender.handledRequests.slice(-1);
expect(lastRequest.queryParams.status, '"all" request status param').to.equal('all');
expect(lastRequest.queryParams.staticPages, '"all" request staticPages param').to.equal('all');
expect(lastRequest.queryParams.filter, '"editor" request filter param')
.to.equal(`author:${editor.slug}`);
// Displays editor post
// TODO: implement "filter" param support and fix mirage post->author association
// expect(find(testSelector('post-id')).length, 'editor post count').to.equal(1);
// expect(find(testSelector('post-id', authorPost.id)), 'author post').to.exist;
});
// TODO: test tags dropdown
});
});
describe('as author', function () {
let author, authorPost;
beforeEach(function () {
let authorRole = server.create('role', {name: 'Author'});
author = server.create('user', {roles: [authorRole]});
let adminRole = server.create('role', {name: 'Administrator'});
let admin = server.create('user', {roles: [adminRole]});
// create posts
authorPost = server.create('post', {authorId: author.id, status: 'published', title: 'Author Post'});
server.create('post', {authorId: admin.id, status: 'scheduled', title: 'Admin Post'});
return authenticateSession(application);
});
it('only fetches the author\'s posts', function () {
visit('/');
// trigger a filter request so we can grab the posts API request easily
selectChoose(testSelector('type-select'), 'Published posts');
andThen(() => {
// API request includes author filter
let [lastRequest] = server.pretender.handledRequests.slice(-1);
expect(lastRequest.queryParams.filter).to.equal(`author:${author.slug}`);
// only author's post is shown
expect(find(testSelector('post-id')).length, 'post count').to.equal(1);
expect(find(testSelector('post-id', authorPost.id)), 'author post').to.exist;
});
});
});
});