2013-11-11 21:35:17 +00:00
|
|
|
/*globals describe, beforeEach, afterEach, it*/
|
2014-06-04 22:26:03 +01:00
|
|
|
/*jshint expr:true*/
|
2014-01-01 15:27:39 +00:00
|
|
|
var assert = require('assert'),
|
|
|
|
moment = require('moment'),
|
|
|
|
should = require('should'),
|
|
|
|
sinon = require('sinon'),
|
2014-08-17 06:17:23 +00:00
|
|
|
Promise = require('bluebird'),
|
2014-02-22 21:16:07 -05:00
|
|
|
rewire = require('rewire'),
|
|
|
|
_ = require('lodash'),
|
2014-01-01 15:27:39 +00:00
|
|
|
|
|
|
|
// Stuff we are testing
|
2013-12-09 22:38:25 -05:00
|
|
|
api = require('../../server/api'),
|
2014-07-17 10:33:21 -04:00
|
|
|
config = rewire('../../server/config'),
|
2014-01-05 01:40:53 -05:00
|
|
|
frontend = rewire('../../server/controllers/frontend');
|
2013-11-11 21:35:17 +00:00
|
|
|
|
2014-06-04 22:26:03 +01:00
|
|
|
// To stop jshint complaining
|
|
|
|
should.equal(true, true);
|
|
|
|
|
2013-11-11 21:35:17 +00:00
|
|
|
describe('Frontend Controller', function () {
|
2014-06-04 22:26:03 +01:00
|
|
|
var sandbox,
|
2014-01-02 23:32:31 -05:00
|
|
|
apiSettingsStub,
|
|
|
|
adminEditPagePath = '/ghost/editor/';
|
2013-12-09 22:38:25 -05:00
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
sandbox = sinon.sandbox.create();
|
2014-01-05 01:40:53 -05:00
|
|
|
|
|
|
|
// Reset frontend controller for next test
|
|
|
|
frontend = rewire('../../server/controllers/frontend');
|
2013-12-09 22:38:25 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(function () {
|
|
|
|
sandbox.restore();
|
|
|
|
});
|
|
|
|
|
2014-07-28 23:58:39 -04:00
|
|
|
// Helper function to prevent unit tests
|
|
|
|
// from failing via timeout when they
|
|
|
|
// should just immediately fail
|
|
|
|
function failTest(done, msg) {
|
|
|
|
return function () {
|
|
|
|
done(new Error(msg));
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2014-01-03 00:37:21 +00:00
|
|
|
describe('homepage redirects', function () {
|
|
|
|
var res;
|
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
res = {
|
|
|
|
redirect: sandbox.spy(),
|
|
|
|
render: sandbox.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
sandbox.stub(api.posts, 'browse', function () {
|
2014-09-10 00:06:24 -04:00
|
|
|
return Promise.resolve({posts: {}, meta: {pagination: {pages: 3}}});
|
2014-01-03 00:37:21 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
apiSettingsStub = sandbox.stub(api.settings, 'read');
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('postsPerPage').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'postsPerPage',
|
|
|
|
value: 5
|
2014-04-27 18:28:50 -05:00
|
|
|
}]
|
2014-01-03 00:37:21 +00:00
|
|
|
}));
|
|
|
|
});
|
|
|
|
|
2014-02-10 16:25:31 +00:00
|
|
|
it('Redirects to home if page number is -1', function () {
|
2014-01-03 00:37:21 +00:00
|
|
|
var req = {params: {page: -1}, route: {path: '/page/:page/'}};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to home if page number is 0', function () {
|
|
|
|
var req = {params: {page: 0}, route: {path: '/page/:page/'}};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to home if page number is 1', function () {
|
|
|
|
var req = {params: {page: 1}, route: {path: '/page/:page/'}};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to home if page number is 0 with subdirectory', function () {
|
2014-07-17 10:33:21 -04:00
|
|
|
frontend.__set__('config', {
|
|
|
|
paths: {subdir: '/blog'}
|
2014-01-05 01:40:53 -05:00
|
|
|
});
|
2014-01-03 00:37:21 +00:00
|
|
|
|
|
|
|
var req = {params: {page: 0}, route: {path: '/page/:page/'}};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/blog/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to home if page number is 1 with subdirectory', function () {
|
2014-07-17 10:33:21 -04:00
|
|
|
frontend.__set__('config', {
|
|
|
|
paths: {subdir: '/blog'}
|
2014-01-05 01:40:53 -05:00
|
|
|
});
|
2014-01-03 00:37:21 +00:00
|
|
|
|
|
|
|
var req = {params: {page: 1}, route: {path: '/page/:page/'}};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/blog/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to last page if page number too big', function (done) {
|
|
|
|
var req = {params: {page: 4}, route: {path: '/page/:page/'}};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, done).then(function () {
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/page/3/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
2014-05-05 21:58:58 +01:00
|
|
|
}).catch(done);
|
2014-01-03 00:37:21 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to last page if page number too big with subdirectory', function (done) {
|
2014-07-17 10:33:21 -04:00
|
|
|
frontend.__set__('config', {
|
|
|
|
paths: {subdir: '/blog'}
|
2014-01-05 01:40:53 -05:00
|
|
|
});
|
2014-01-03 00:37:21 +00:00
|
|
|
|
|
|
|
var req = {params: {page: 4}, route: {path: '/page/:page/'}};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, done).then(function () {
|
|
|
|
res.redirect.calledOnce.should.be.true;
|
|
|
|
res.redirect.calledWith('/blog/page/3/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
2014-05-05 21:58:58 +01:00
|
|
|
}).catch(done);
|
2014-07-28 23:58:39 -04:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('homepage', function () {
|
|
|
|
beforeEach(function () {
|
|
|
|
sandbox.stub(api.posts, 'browse', function () {
|
2014-08-17 06:17:23 +00:00
|
|
|
return Promise.resolve({
|
2014-07-28 23:58:39 -04:00
|
|
|
posts: [],
|
|
|
|
meta: {
|
|
|
|
pagination: {
|
|
|
|
page: 1,
|
|
|
|
pages: 3
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
apiSettingsStub = sandbox.stub(api.settings, 'read');
|
|
|
|
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs(sinon.match.has('key', 'activeTheme')).returns(Promise.resolve({
|
2014-07-28 23:58:39 -04:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'activeTheme',
|
|
|
|
value: 'casper'
|
2014-07-28 23:58:39 -04:00
|
|
|
}]
|
|
|
|
}));
|
|
|
|
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('postsPerPage').returns(Promise.resolve({
|
2014-07-28 23:58:39 -04:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'postsPerPage',
|
|
|
|
value: '10'
|
2014-07-28 23:58:39 -04:00
|
|
|
}]
|
|
|
|
}));
|
|
|
|
|
|
|
|
frontend.__set__('config', {
|
2014-09-10 00:06:24 -04:00
|
|
|
paths: {
|
|
|
|
subdir: '',
|
|
|
|
availableThemes: {
|
|
|
|
casper: {
|
|
|
|
assets: null,
|
2014-07-28 23:58:39 -04:00
|
|
|
'default.hbs': '/content/themes/casper/default.hbs',
|
|
|
|
'index.hbs': '/content/themes/casper/index.hbs',
|
|
|
|
'home.hbs': '/content/themes/casper/home.hbs',
|
|
|
|
'page.hbs': '/content/themes/casper/page.hbs',
|
|
|
|
'tag.hbs': '/content/themes/casper/tag.hbs'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
2014-01-03 00:37:21 +00:00
|
|
|
|
2014-07-28 23:58:39 -04:00
|
|
|
it('Renders home.hbs template when it exists in the active theme', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/',
|
|
|
|
params: {},
|
|
|
|
route: {}
|
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-07-28 23:58:39 -04:00
|
|
|
render: function (view) {
|
|
|
|
assert.equal(view, 'home');
|
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, failTest(done));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Renders index.hbs template on 2nd page when home.bs exists', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/page/2/',
|
|
|
|
params: {
|
|
|
|
page: 2
|
|
|
|
},
|
|
|
|
route: {}
|
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-07-28 23:58:39 -04:00
|
|
|
render: function (view) {
|
|
|
|
assert.equal(view, 'index');
|
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, failTest(done));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Renders index.hbs template when home.hbs doesn\'t exist', function (done) {
|
|
|
|
frontend.__set__('config', {
|
2014-09-10 00:06:24 -04:00
|
|
|
paths: {
|
|
|
|
subdir: '',
|
|
|
|
availableThemes: {
|
|
|
|
casper: {
|
|
|
|
assets: null,
|
2014-07-28 23:58:39 -04:00
|
|
|
'default.hbs': '/content/themes/casper/default.hbs',
|
|
|
|
'index.hbs': '/content/themes/casper/index.hbs',
|
|
|
|
'page.hbs': '/content/themes/casper/page.hbs',
|
|
|
|
'tag.hbs': '/content/themes/casper/tag.hbs'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
var req = {
|
|
|
|
path: '/',
|
|
|
|
params: {},
|
|
|
|
route: {}
|
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-07-28 23:58:39 -04:00
|
|
|
render: function (view) {
|
|
|
|
assert.equal(view, 'index');
|
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.homepage(req, res, failTest(done));
|
2014-01-03 00:37:21 +00:00
|
|
|
});
|
2013-11-11 21:35:17 +00:00
|
|
|
});
|
2013-12-09 22:38:25 -05:00
|
|
|
|
2014-09-03 17:42:55 +02:00
|
|
|
describe('tag', function () {
|
2014-03-04 13:06:22 +00:00
|
|
|
var mockPosts = [{
|
2014-09-10 00:06:24 -04:00
|
|
|
status: 'published',
|
|
|
|
id: 1,
|
|
|
|
title: 'Test static page',
|
|
|
|
slug: 'test-static-page',
|
|
|
|
markdown: 'Test static page content',
|
|
|
|
page: 1,
|
|
|
|
published_at: new Date('2013/12/30').getTime(),
|
|
|
|
author: {
|
|
|
|
id: 1,
|
|
|
|
name: 'Test User',
|
|
|
|
email: 'test@ghost.org'
|
2014-07-29 11:23:02 +02:00
|
|
|
}
|
2014-03-04 13:06:22 +00:00
|
|
|
}, {
|
2014-09-10 00:06:24 -04:00
|
|
|
status: 'published',
|
|
|
|
id: 2,
|
|
|
|
title: 'Test normal post',
|
|
|
|
slug: 'test-normal-post',
|
|
|
|
markdown: 'The test normal post content',
|
|
|
|
page: 0,
|
|
|
|
published_at: new Date('2014/1/2').getTime(),
|
|
|
|
author: {
|
|
|
|
id: 1,
|
|
|
|
name: 'Test User',
|
|
|
|
email: 'test@ghost.org'
|
2014-07-29 11:23:02 +02:00
|
|
|
}
|
2014-03-04 13:06:22 +00:00
|
|
|
}],
|
|
|
|
mockTags = [{
|
2014-09-10 00:06:24 -04:00
|
|
|
name: 'video',
|
|
|
|
slug: 'video',
|
|
|
|
id: 1
|
2014-09-03 17:42:55 +02:00
|
|
|
}, {
|
2014-09-10 00:06:24 -04:00
|
|
|
name: 'audio',
|
|
|
|
slug: 'audio',
|
|
|
|
id: 2
|
2014-07-28 23:58:39 -04:00
|
|
|
}];
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
|
2014-03-04 13:06:22 +00:00
|
|
|
beforeEach(function () {
|
2014-06-04 22:26:03 +01:00
|
|
|
sandbox.stub(api.posts, 'browse', function () {
|
2014-08-17 06:17:23 +00:00
|
|
|
return Promise.resolve({
|
2014-04-19 17:03:20 +02:00
|
|
|
posts: mockPosts,
|
|
|
|
meta: {
|
|
|
|
pagination: {
|
|
|
|
page: 1,
|
2014-05-05 21:58:58 +01:00
|
|
|
pages: 1
|
2014-04-19 17:03:20 +02:00
|
|
|
},
|
2014-04-27 19:34:10 +02:00
|
|
|
filters: {
|
|
|
|
tags: [mockTags[0]]
|
|
|
|
}
|
2014-05-05 21:58:58 +01:00
|
|
|
}
|
2014-03-04 13:06:22 +00:00
|
|
|
});
|
|
|
|
});
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
|
2014-03-04 13:06:22 +00:00
|
|
|
apiSettingsStub = sandbox.stub(api.settings, 'read');
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs(sinon.match.has('key', 'activeTheme')).returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'activeTheme',
|
|
|
|
value: 'casper'
|
2014-04-27 18:28:50 -05:00
|
|
|
}]
|
2014-03-04 13:06:22 +00:00
|
|
|
}));
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('postsPerPage').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'postsPerPage',
|
|
|
|
value: '10'
|
2014-04-27 18:28:50 -05:00
|
|
|
}]
|
2014-03-04 13:06:22 +00:00
|
|
|
}));
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
|
2014-07-17 10:33:21 -04:00
|
|
|
frontend.__set__('config', {
|
2014-09-10 00:06:24 -04:00
|
|
|
paths: {
|
|
|
|
subdir: '',
|
|
|
|
availableThemes: {
|
|
|
|
casper: {
|
|
|
|
assets: null,
|
2014-03-04 13:06:22 +00:00
|
|
|
'default.hbs': '/content/themes/casper/default.hbs',
|
|
|
|
'index.hbs': '/content/themes/casper/index.hbs',
|
|
|
|
'page.hbs': '/content/themes/casper/page.hbs',
|
|
|
|
'tag.hbs': '/content/themes/casper/tag.hbs'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-07-17 10:33:21 -04:00
|
|
|
});
|
2014-03-04 13:06:22 +00:00
|
|
|
});
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
|
2014-03-04 13:06:22 +00:00
|
|
|
describe('custom tag template', function () {
|
|
|
|
beforeEach(function () {
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('permalinks').returns(Promise.resolve({
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
settings: [{
|
|
|
|
key: 'permalinks',
|
|
|
|
value: '/tag/:slug/'
|
|
|
|
}]
|
2014-03-04 13:06:22 +00:00
|
|
|
}));
|
|
|
|
});
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
|
2014-03-04 13:06:22 +00:00
|
|
|
it('it will render custom tag template if it exists', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/tag/' + mockTags[0].slug,
|
2014-09-04 16:07:12 +00:00
|
|
|
params: {},
|
|
|
|
route: {
|
|
|
|
path: '/tag/:slug'
|
|
|
|
}
|
2014-03-04 13:06:22 +00:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-03-04 13:06:22 +00:00
|
|
|
render: function (view, context) {
|
|
|
|
assert.equal(view, 'tag');
|
|
|
|
assert.equal(context.tag, mockTags[0]);
|
2014-09-03 17:42:55 +02:00
|
|
|
assert.equal(context.posts[0].author.email, undefined);
|
2014-03-04 13:06:22 +00:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
|
2014-03-04 13:06:22 +00:00
|
|
|
frontend.tag(req, res, failTest(done));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-02-12 22:26:56 -05:00
|
|
|
describe('tag redirects', function () {
|
|
|
|
var res;
|
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
res = {
|
|
|
|
redirect: sandbox.spy(),
|
|
|
|
render: sandbox.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
sandbox.stub(api.posts, 'browse', function () {
|
2014-09-10 00:06:24 -04:00
|
|
|
return Promise.resolve({posts: {}, meta: {pagination: {pages: 3}}});
|
2014-02-12 22:26:56 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
apiSettingsStub = sandbox.stub(api.settings, 'read');
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('postsPerPage').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'postsPerPage',
|
|
|
|
value: 5
|
2014-04-27 18:28:50 -05:00
|
|
|
}]
|
2014-02-12 22:26:56 -05:00
|
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to base tag page if page number is -1', function () {
|
|
|
|
var req = {params: {page: -1, slug: 'pumpkin'}};
|
|
|
|
|
|
|
|
frontend.tag(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/tag/pumpkin/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to base tag page if page number is 0', function () {
|
|
|
|
var req = {params: {page: 0, slug: 'pumpkin'}};
|
|
|
|
|
|
|
|
frontend.tag(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/tag/pumpkin/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to base tag page if page number is 1', function () {
|
|
|
|
var req = {params: {page: 1, slug: 'pumpkin'}};
|
|
|
|
|
|
|
|
frontend.tag(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/tag/pumpkin/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to base tag page if page number is 0 with subdirectory', function () {
|
2014-07-17 10:33:21 -04:00
|
|
|
frontend.__set__('config', {
|
|
|
|
paths: {subdir: '/blog'}
|
2014-02-12 22:26:56 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
var req = {params: {page: 0, slug: 'pumpkin'}};
|
|
|
|
|
|
|
|
frontend.tag(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/blog/tag/pumpkin/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to base tag page if page number is 1 with subdirectory', function () {
|
2014-07-17 10:33:21 -04:00
|
|
|
frontend.__set__('config', {
|
|
|
|
paths: {subdir: '/blog'}
|
2014-02-12 22:26:56 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
var req = {params: {page: 1, slug: 'pumpkin'}};
|
|
|
|
|
|
|
|
frontend.tag(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/blog/tag/pumpkin/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to last page if page number too big', function (done) {
|
|
|
|
var req = {params: {page: 4, slug: 'pumpkin'}};
|
|
|
|
|
|
|
|
frontend.tag(req, res, done).then(function () {
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/tag/pumpkin/page/3/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
2014-05-05 21:58:58 +01:00
|
|
|
}).catch(done);
|
2014-02-12 22:26:56 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to last page if page number too big with subdirectory', function (done) {
|
2014-07-17 10:33:21 -04:00
|
|
|
frontend.__set__('config', {
|
|
|
|
paths: {subdir: '/blog'}
|
2014-02-12 22:26:56 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
var req = {params: {page: 4, slug: 'pumpkin'}};
|
|
|
|
|
|
|
|
frontend.tag(req, res, done).then(function () {
|
|
|
|
res.redirect.calledOnce.should.be.true;
|
|
|
|
res.redirect.calledWith('/blog/tag/pumpkin/page/3/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
2014-05-05 21:58:58 +01:00
|
|
|
}).catch(done);
|
2014-02-12 22:26:56 -05:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-01-01 15:27:39 +00:00
|
|
|
describe('single', function () {
|
2014-02-22 21:16:07 -05:00
|
|
|
var mockPosts = [{
|
2014-09-10 00:06:24 -04:00
|
|
|
posts: [{
|
|
|
|
status: 'published',
|
|
|
|
id: 1,
|
|
|
|
title: 'Test static page',
|
|
|
|
slug: 'test-static-page',
|
|
|
|
markdown: 'Test static page content',
|
|
|
|
page: 1,
|
|
|
|
published_at: new Date('2013/12/30').getTime(),
|
|
|
|
author: {
|
|
|
|
id: 1,
|
|
|
|
name: 'Test User',
|
2014-10-25 18:15:24 -07:00
|
|
|
slug: 'test',
|
2014-09-10 00:06:24 -04:00
|
|
|
email: 'test@ghost.org'
|
2014-07-29 11:23:02 +02:00
|
|
|
}
|
2014-04-16 12:09:03 +02:00
|
|
|
}]
|
2014-02-22 21:16:07 -05:00
|
|
|
}, {
|
2014-09-10 00:06:24 -04:00
|
|
|
posts: [{
|
|
|
|
status: 'published',
|
|
|
|
id: 2,
|
|
|
|
title: 'Test normal post',
|
|
|
|
slug: 'test-normal-post',
|
|
|
|
markdown: 'The test normal post content',
|
|
|
|
page: 0,
|
|
|
|
published_at: new Date('2014/1/2').getTime(),
|
|
|
|
author: {
|
|
|
|
id: 1,
|
|
|
|
name: 'Test User',
|
2014-10-25 18:15:24 -07:00
|
|
|
slug: 'test',
|
2014-09-10 00:06:24 -04:00
|
|
|
email: 'test@ghost.org'
|
2014-07-29 11:23:02 +02:00
|
|
|
}
|
2014-04-16 12:09:03 +02:00
|
|
|
}]
|
2014-02-22 21:16:07 -05:00
|
|
|
}, {
|
2014-09-10 00:06:24 -04:00
|
|
|
posts: [{
|
|
|
|
status: 'published',
|
|
|
|
id: 3,
|
|
|
|
title: 'About',
|
|
|
|
slug: 'about',
|
|
|
|
markdown: 'This is the about page content',
|
|
|
|
page: 1,
|
|
|
|
published_at: new Date('2014/1/30').getTime(),
|
|
|
|
author: {
|
|
|
|
id: 1,
|
|
|
|
name: 'Test User',
|
2014-10-25 18:15:24 -07:00
|
|
|
slug: 'test',
|
2014-09-10 00:06:24 -04:00
|
|
|
email: 'test@ghost.org'
|
2014-07-29 11:23:02 +02:00
|
|
|
}
|
2014-04-16 12:09:03 +02:00
|
|
|
}]
|
2014-07-28 23:58:39 -04:00
|
|
|
}];
|
2013-12-09 22:38:25 -05:00
|
|
|
|
|
|
|
beforeEach(function () {
|
2014-01-01 15:27:39 +00:00
|
|
|
sandbox.stub(api.posts, 'read', function (args) {
|
2014-09-03 17:42:55 +02:00
|
|
|
return Promise.resolve(_.find(mockPosts, function (mock) {
|
2014-04-16 12:09:03 +02:00
|
|
|
return mock.posts[0].slug === args.slug;
|
|
|
|
}));
|
2013-12-09 22:38:25 -05:00
|
|
|
});
|
|
|
|
|
2014-01-01 15:27:39 +00:00
|
|
|
apiSettingsStub = sandbox.stub(api.settings, 'read');
|
2013-12-30 02:03:29 -05:00
|
|
|
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs(sinon.match.has('key', 'activeTheme')).returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'activeTheme',
|
|
|
|
value: 'casper'
|
2014-04-27 18:28:50 -05:00
|
|
|
}]
|
2013-12-30 02:03:29 -05:00
|
|
|
}));
|
2013-12-09 22:38:25 -05:00
|
|
|
|
2014-07-17 10:33:21 -04:00
|
|
|
frontend.__set__('config', {
|
2014-09-10 00:06:24 -04:00
|
|
|
paths: {
|
|
|
|
subdir: '',
|
|
|
|
availableThemes: {
|
|
|
|
casper: {
|
|
|
|
assets: null,
|
2014-02-08 21:16:58 +00:00
|
|
|
'default.hbs': '/content/themes/casper/default.hbs',
|
|
|
|
'index.hbs': '/content/themes/casper/index.hbs',
|
|
|
|
'page.hbs': '/content/themes/casper/page.hbs',
|
2014-02-22 21:16:07 -05:00
|
|
|
'page-about.hbs': '/content/themes/casper/page-about.hbs',
|
2014-02-08 21:16:58 +00:00
|
|
|
'post.hbs': '/content/themes/casper/post.hbs'
|
2013-12-09 22:38:25 -05:00
|
|
|
}
|
|
|
|
}
|
2014-01-05 01:40:53 -05:00
|
|
|
}
|
2014-07-17 10:33:21 -04:00
|
|
|
});
|
2013-12-09 22:38:25 -05:00
|
|
|
});
|
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
describe('static pages', function () {
|
2014-02-22 21:16:07 -05:00
|
|
|
describe('custom page templates', function () {
|
|
|
|
beforeEach(function () {
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('permalinks').returns(Promise.resolve({
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
settings: [{
|
2014-04-27 18:28:50 -05:00
|
|
|
value: '/:slug/'
|
|
|
|
}]
|
2014-02-22 21:16:07 -05:00
|
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('it will render custom page template if it exists', function (done) {
|
|
|
|
var req = {
|
2014-09-04 16:07:12 +00:00
|
|
|
path: '/' + mockPosts[2].posts[0].slug,
|
|
|
|
route: {
|
|
|
|
path: '*'
|
|
|
|
},
|
|
|
|
params: {}
|
2014-02-22 21:16:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-22 21:16:07 -05:00
|
|
|
render: function (view, context) {
|
2014-04-16 12:09:03 +02:00
|
|
|
assert.equal(view, 'page-' + mockPosts[2].posts[0].slug);
|
|
|
|
assert.equal(context.post, mockPosts[2].posts[0]);
|
2014-07-29 11:23:02 +02:00
|
|
|
assert.equal(context.post.author.email, undefined);
|
2014-02-22 21:16:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
describe('permalink set to slug', function () {
|
|
|
|
beforeEach(function () {
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('permalinks').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
|
|
|
value: '/:slug/'
|
|
|
|
}]
|
2014-02-02 00:29:07 -05:00
|
|
|
}));
|
|
|
|
});
|
2013-12-09 22:38:25 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will render static page via /:slug', function (done) {
|
|
|
|
var req = {
|
2014-09-04 16:07:12 +00:00
|
|
|
path: '/' + mockPosts[0].posts[0].slug,
|
|
|
|
route: {
|
|
|
|
path: '*'
|
|
|
|
},
|
|
|
|
params: {}
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: function (view, context) {
|
|
|
|
assert.equal(view, 'page');
|
2014-04-16 12:09:03 +02:00
|
|
|
assert.equal(context.post, mockPosts[0].posts[0]);
|
2014-07-29 11:23:02 +02:00
|
|
|
assert.equal(context.post.author.email, undefined);
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
2013-12-09 22:38:25 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT render static page via /YYY/MM/DD/:slug', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + ['2012/12/30', mockPosts[0].posts[0].slug].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
});
|
|
|
|
|
2014-10-25 18:15:24 -07:00
|
|
|
it('will NOT render static page via /:author/:slug', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + ['test', mockPosts[0].posts[0].slug].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will redirect static page to admin edit page via /:slug/edit', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [mockPosts[0].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
2014-09-03 17:42:55 +02:00
|
|
|
redirect: function (arg) {
|
2014-02-02 00:29:07 -05:00
|
|
|
res.render.called.should.be.false;
|
2014-04-16 12:09:03 +02:00
|
|
|
arg.should.eql(adminEditPagePath + mockPosts[0].posts[0].id + '/');
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT redirect static page to admin edit page via /YYYY/MM/DD/:slug/edit', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + ['2012/12/30', mockPosts[0].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2014-10-25 18:15:24 -07:00
|
|
|
|
|
|
|
it('will NOT redirect static page to admin edit page via /:author/:slug/edit', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + ['test', mockPosts[0].posts[0].slug, 'edit'].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
});
|
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
describe('permalink set to date', function () {
|
|
|
|
beforeEach(function () {
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('permalinks').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
value: '/:year/:month/:day/:slug/'
|
|
|
|
}]
|
2014-02-02 00:29:07 -05:00
|
|
|
}));
|
2013-12-30 02:03:29 -05:00
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will render static page via /:slug', function (done) {
|
|
|
|
var req = {
|
2014-09-04 16:07:12 +00:00
|
|
|
path: '/' + mockPosts[0].posts[0].slug,
|
|
|
|
route: {
|
|
|
|
path: '*'
|
|
|
|
},
|
|
|
|
params: {}
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: function (view, context) {
|
|
|
|
assert.equal(view, 'page');
|
2014-04-16 12:09:03 +02:00
|
|
|
assert.equal(context.post, mockPosts[0].posts[0]);
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT render static page via /YYYY/MM/DD/:slug', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + ['2012/12/30', mockPosts[0].posts[0].slug].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('will redirect static page to admin edit page via /:slug/edit', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [mockPosts[0].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: function (arg) {
|
|
|
|
res.render.called.should.be.false;
|
2014-04-16 12:09:03 +02:00
|
|
|
arg.should.eql(adminEditPagePath + mockPosts[0].posts[0].id + '/');
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT redirect static page to admin edit page via /YYYY/MM/DD/:slug/edit', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + ['2012/12/30', mockPosts[0].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
});
|
|
|
|
});
|
2014-02-02 00:29:07 -05:00
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
describe('post', function () {
|
|
|
|
describe('permalink set to slug', function () {
|
|
|
|
beforeEach(function () {
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('permalinks').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
|
|
|
value: '/:slug'
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
}]
|
2014-02-02 00:29:07 -05:00
|
|
|
}));
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will render post via /:slug', function (done) {
|
|
|
|
var req = {
|
2014-09-04 16:07:12 +00:00
|
|
|
path: '/' + mockPosts[1].posts[0].slug,
|
|
|
|
route: {
|
|
|
|
path: '*'
|
|
|
|
},
|
|
|
|
params: {}
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: function (view, context) {
|
|
|
|
assert.equal(view, 'post');
|
|
|
|
assert(context.post, 'Context object has post attribute');
|
2014-04-16 12:09:03 +02:00
|
|
|
assert.equal(context.post, mockPosts[1].posts[0]);
|
2014-07-29 11:23:02 +02:00
|
|
|
assert.equal(context.post.author.email, undefined);
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT render post via /YYYY/MM/DD/:slug', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + ['2012/12/30', mockPosts[1].posts[0].slug].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-10-25 18:15:24 -07:00
|
|
|
it('will NOT render post via /:author/:slug', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + ['test', mockPosts[1].posts[0].slug].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
// Handle Edit append
|
|
|
|
it('will redirect post to admin edit page via /:slug/edit', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [mockPosts[1].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
2014-09-03 17:42:55 +02:00
|
|
|
redirect: function (arg) {
|
2014-02-02 00:29:07 -05:00
|
|
|
res.render.called.should.be.false;
|
2014-04-16 12:09:03 +02:00
|
|
|
arg.should.eql(adminEditPagePath + mockPosts[1].posts[0].id + '/');
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
2014-01-02 23:32:31 -05:00
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT redirect post to admin edit page via /YYYY/MM/DD/:slug/edit', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + ['2012/12/30', mockPosts[1].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2014-10-25 18:15:24 -07:00
|
|
|
|
|
|
|
it('will NOT redirect post to admin edit page via /:author/:slug/edit', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + ['test', mockPosts[1].posts[0].slug, 'edit'].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
});
|
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
describe('permalink set to date', function () {
|
|
|
|
beforeEach(function () {
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('permalinks').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
|
|
|
value: '/:year/:month/:day/:slug'
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
}]
|
2014-02-02 00:29:07 -05:00
|
|
|
}));
|
|
|
|
});
|
2013-12-09 22:38:25 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will render post via /YYYY/MM/DD/:slug', function (done) {
|
2014-04-16 12:09:03 +02:00
|
|
|
var date = moment(mockPosts[1].posts[0].published_at).format('YYYY/MM/DD'),
|
2014-02-02 00:29:07 -05:00
|
|
|
req = {
|
2014-09-04 16:07:12 +00:00
|
|
|
path: '/' + [date, mockPosts[1].posts[0].slug].join('/'),
|
|
|
|
route: {
|
|
|
|
path: '*'
|
|
|
|
},
|
|
|
|
params: {}
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: function (view, context) {
|
|
|
|
assert.equal(view, 'post');
|
|
|
|
assert(context.post, 'Context object has post attribute');
|
2014-04-16 12:09:03 +02:00
|
|
|
assert.equal(context.post, mockPosts[1].posts[0]);
|
2014-07-29 11:23:02 +02:00
|
|
|
assert.equal(context.post.author.email, undefined);
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT render post via /YYYY/MM/DD/:slug with non-matching date in url', function (done) {
|
2014-02-22 21:16:07 -05:00
|
|
|
var date = moment(mockPosts[1].published_at).subtract('days', 1).format('YYYY/MM/DD'),
|
2014-02-02 00:29:07 -05:00
|
|
|
req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [date, mockPosts[1].posts[0].slug].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
});
|
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT render post via /:slug', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + mockPosts[1].posts[0].slug
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
|
2014-10-25 18:15:24 -07:00
|
|
|
it('will NOT render post via /:author/:slug', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + ['test', mockPosts[1].posts[0].slug].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
// Handle Edit append
|
|
|
|
it('will redirect post to admin edit page via /YYYY/MM/DD/:slug/edit', function (done) {
|
2014-04-16 12:09:03 +02:00
|
|
|
var dateFormat = moment(mockPosts[1].posts[0].published_at).format('YYYY/MM/DD'),
|
2014-02-02 00:29:07 -05:00
|
|
|
req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [dateFormat, mockPosts[1].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: function (arg) {
|
|
|
|
res.render.called.should.be.false;
|
2014-04-16 12:09:03 +02:00
|
|
|
arg.should.eql(adminEditPagePath + mockPosts[1].posts[0].id + '/');
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT redirect post to admin edit page via /:slug/edit', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [mockPosts[1].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
});
|
2014-10-25 18:15:24 -07:00
|
|
|
|
|
|
|
it('will NOT redirect post to admin edit page via /:author/:slug/edit', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + ['test', mockPosts[1].posts[0].slug, 'edit'].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('permalink set to author', function () {
|
|
|
|
beforeEach(function () {
|
|
|
|
apiSettingsStub.withArgs('permalinks').returns(Promise.resolve({
|
|
|
|
settings: [{
|
|
|
|
value: '/:author/:slug'
|
|
|
|
}]
|
|
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('will render post via /:author/:slug', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + ['test', mockPosts[1].posts[0].slug].join('/'),
|
|
|
|
route: {
|
|
|
|
path: '*'
|
|
|
|
},
|
|
|
|
params: {}
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: function (view, context) {
|
|
|
|
assert.equal(view, 'post');
|
|
|
|
assert(context.post, 'Context object has post attribute');
|
|
|
|
assert.equal(context.post, mockPosts[1].posts[0]);
|
|
|
|
assert.equal(context.post.author.email, undefined);
|
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('will NOT render post via /YYYY/MM/DD/:slug', function (done) {
|
|
|
|
var date = moment(mockPosts[1].posts[0].published_at).format('YYYY/MM/DD'),
|
|
|
|
req = {
|
|
|
|
path: '/' + [date, mockPosts[1].posts[0].slug].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('will NOT render post via /:author/:slug when author does not match post author', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + ['test-2', mockPosts[1].posts[0].slug].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('will NOT render post via /:slug', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + mockPosts[1].posts[0].slug
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
// Handle Edit append
|
|
|
|
it('will redirect post to admin edit page via /:author/:slug/edit', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + ['test', mockPosts[1].posts[0].slug, 'edit'].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: function (arg) {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
arg.should.eql(adminEditPagePath + mockPosts[1].posts[0].id + '/');
|
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('will NOT redirect post to admin edit page via /YYYY/MM/DD/:slug/edit', function (done) {
|
|
|
|
var date = moment(mockPosts[1].posts[0].published_at).format('YYYY/MM/DD'),
|
|
|
|
req = {
|
|
|
|
path: '/' + [date, mockPosts[1].posts[0].slug, 'edit'].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
it('will NOT redirect post to admin edit page /:slug/edit', function (done) {
|
|
|
|
var req = {
|
|
|
|
path: '/' + [mockPosts[1].posts[0].slug, 'edit'].join('/')
|
|
|
|
},
|
|
|
|
res = {
|
|
|
|
locals: {},
|
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2013-12-30 02:03:29 -05:00
|
|
|
});
|
2013-12-09 22:38:25 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
describe('permalink set to custom format', function () {
|
|
|
|
beforeEach(function () {
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('permalinks').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
|
|
|
value: '/:year/:slug'
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
}]
|
2014-02-02 00:29:07 -05:00
|
|
|
}));
|
2014-01-01 15:27:39 +00:00
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will render post via /:year/:slug', function (done) {
|
2014-04-16 12:09:03 +02:00
|
|
|
var date = moment(mockPosts[1].posts[0].published_at).format('YYYY'),
|
2014-02-02 00:29:07 -05:00
|
|
|
req = {
|
2014-09-04 16:07:12 +00:00
|
|
|
path: '/' + [date, mockPosts[1].posts[0].slug].join('/'),
|
|
|
|
route: {
|
|
|
|
path: '*'
|
|
|
|
},
|
|
|
|
params: {}
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: function (view, context) {
|
|
|
|
assert.equal(view, 'post');
|
|
|
|
assert(context.post, 'Context object has post attribute');
|
2014-04-16 12:09:03 +02:00
|
|
|
assert.equal(context.post, mockPosts[1].posts[0]);
|
2014-07-29 11:23:02 +02:00
|
|
|
assert.equal(context.post.author.email, undefined);
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT render post via /YYYY/MM/DD/:slug', function (done) {
|
2014-04-16 12:09:03 +02:00
|
|
|
var date = moment(mockPosts[1].posts[0].published_at).format('YYYY/MM/DD'),
|
2014-02-02 00:29:07 -05:00
|
|
|
req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [date, mockPosts[1].posts[0].slug].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT render post via /:year/slug when year does not match post year', function (done) {
|
2014-04-16 12:09:03 +02:00
|
|
|
var date = moment(mockPosts[1].posts[0].published_at).subtract('years', 1).format('YYYY'),
|
2014-02-02 00:29:07 -05:00
|
|
|
req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [date, mockPosts[1].posts[0].slug].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
});
|
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT render post via /:slug', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + mockPosts[1].posts[0].slug
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
// Handle Edit append
|
|
|
|
it('will redirect post to admin edit page via /:year/:slug/edit', function (done) {
|
2014-04-16 12:09:03 +02:00
|
|
|
var date = moment(mockPosts[1].posts[0].published_at).format('YYYY'),
|
2014-02-02 00:29:07 -05:00
|
|
|
req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [date, mockPosts[1].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: function (arg) {
|
|
|
|
res.render.called.should.be.false;
|
2014-04-16 12:09:03 +02:00
|
|
|
arg.should.eql(adminEditPagePath + mockPosts[1].posts[0].id + '/');
|
2014-02-02 00:29:07 -05:00
|
|
|
done();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, failTest(done));
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
|
2014-02-02 00:29:07 -05:00
|
|
|
it('will NOT redirect post to admin edit page /:slug/edit', function (done) {
|
|
|
|
var req = {
|
2014-04-16 12:09:03 +02:00
|
|
|
path: '/' + [mockPosts[1].posts[0].slug, 'edit'].join('/')
|
2014-02-02 00:29:07 -05:00
|
|
|
},
|
|
|
|
res = {
|
2014-09-04 16:07:12 +00:00
|
|
|
locals: {},
|
2014-02-02 00:29:07 -05:00
|
|
|
render: sinon.spy(),
|
|
|
|
redirect: sinon.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
frontend.single(req, res, function () {
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
res.redirect.called.should.be.false;
|
|
|
|
done();
|
|
|
|
});
|
2014-01-02 23:32:31 -05:00
|
|
|
});
|
|
|
|
});
|
2014-01-01 15:27:39 +00:00
|
|
|
});
|
2013-12-09 22:38:25 -05:00
|
|
|
});
|
2014-01-03 00:37:21 +00:00
|
|
|
|
|
|
|
describe('rss redirects', function () {
|
|
|
|
var res,
|
2014-01-05 01:40:53 -05:00
|
|
|
apiUsersStub,
|
2014-07-17 10:33:21 -04:00
|
|
|
overwriteConfig = function (newConfig) {
|
2014-01-05 01:40:53 -05:00
|
|
|
var existingConfig = frontend.__get__('config');
|
2014-08-23 12:19:13 -04:00
|
|
|
config.set(_.extend(existingConfig, newConfig));
|
2014-01-05 01:40:53 -05:00
|
|
|
};
|
2014-01-03 00:37:21 +00:00
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
res = {
|
2014-09-10 00:06:24 -04:00
|
|
|
locals: {version: ''},
|
2014-01-03 00:37:21 +00:00
|
|
|
redirect: sandbox.spy(),
|
|
|
|
render: sandbox.spy()
|
|
|
|
};
|
|
|
|
|
|
|
|
sandbox.stub(api.posts, 'browse', function () {
|
2014-09-10 00:06:24 -04:00
|
|
|
return Promise.resolve({posts: {}, meta: {pagination: {pages: 3}}});
|
2014-01-03 00:37:21 +00:00
|
|
|
});
|
|
|
|
|
2014-08-17 06:17:23 +00:00
|
|
|
apiUsersStub = sandbox.stub(api.users, 'read').returns(Promise.resolve({}));
|
2014-01-03 00:37:21 +00:00
|
|
|
|
|
|
|
apiSettingsStub = sandbox.stub(api.settings, 'read');
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('title').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'title',
|
|
|
|
value: 'Test'
|
2014-04-27 18:28:50 -05:00
|
|
|
}]
|
2014-01-03 00:37:21 +00:00
|
|
|
}));
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('description').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'description',
|
|
|
|
value: 'Some Text'
|
2014-04-27 18:28:50 -05:00
|
|
|
}]
|
2014-01-03 00:37:21 +00:00
|
|
|
}));
|
2014-08-17 06:17:23 +00:00
|
|
|
apiSettingsStub.withArgs('permalinks').returns(Promise.resolve({
|
2014-04-27 18:28:50 -05:00
|
|
|
settings: [{
|
2014-09-10 00:06:24 -04:00
|
|
|
key: 'permalinks',
|
|
|
|
value: '/:slug/'
|
2014-04-27 18:28:50 -05:00
|
|
|
}]
|
2014-01-03 00:37:21 +00:00
|
|
|
}));
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to rss if page number is 0', function () {
|
|
|
|
var req = {params: {page: -1}, route: {path: '/rss/:page/'}};
|
|
|
|
|
|
|
|
frontend.rss(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/rss/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to rss if page number is 0', function () {
|
|
|
|
var req = {params: {page: 0}, route: {path: '/rss/:page/'}};
|
|
|
|
|
|
|
|
frontend.rss(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/rss/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to home if page number is 1', function () {
|
|
|
|
var req = {params: {page: 1}, route: {path: '/rss/:page/'}};
|
|
|
|
|
|
|
|
frontend.rss(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/rss/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to home if page number is 0 with subdirectory', function () {
|
2014-01-05 01:40:53 -05:00
|
|
|
overwriteConfig({paths: {subdir: '/blog'}});
|
2014-01-03 00:37:21 +00:00
|
|
|
|
|
|
|
var req = {params: {page: 0}, route: {path: '/rss/:page/'}};
|
|
|
|
|
|
|
|
frontend.rss(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/blog/rss/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to home if page number is 1 with subdirectory', function () {
|
2014-01-05 01:40:53 -05:00
|
|
|
overwriteConfig({paths: {subdir: '/blog'}});
|
2014-01-03 00:37:21 +00:00
|
|
|
|
|
|
|
var req = {params: {page: 1}, route: {path: '/rss/:page/'}};
|
|
|
|
|
|
|
|
frontend.rss(req, res, null);
|
|
|
|
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/blog/rss/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to last page if page number too big', function (done) {
|
2014-07-17 10:33:21 -04:00
|
|
|
overwriteConfig({paths: {subdir: ''}});
|
|
|
|
|
2014-01-03 00:37:21 +00:00
|
|
|
var req = {params: {page: 4}, route: {path: '/rss/:page/'}};
|
|
|
|
|
|
|
|
frontend.rss(req, res, done).then(function () {
|
|
|
|
res.redirect.called.should.be.true;
|
|
|
|
res.redirect.calledWith('/rss/3/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
2014-05-05 21:58:58 +01:00
|
|
|
}).catch(done);
|
2014-01-03 00:37:21 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('Redirects to last page if page number too big with subdirectory', function (done) {
|
2014-01-05 01:40:53 -05:00
|
|
|
overwriteConfig({paths: {subdir: '/blog'}});
|
2014-01-03 00:37:21 +00:00
|
|
|
|
|
|
|
var req = {params: {page: 4}, route: {path: '/rss/:page/'}};
|
|
|
|
|
|
|
|
frontend.rss(req, res, done).then(function () {
|
|
|
|
res.redirect.calledOnce.should.be.true;
|
|
|
|
res.redirect.calledWith('/blog/rss/3/').should.be.true;
|
|
|
|
res.render.called.should.be.false;
|
|
|
|
done();
|
2014-05-05 21:58:58 +01:00
|
|
|
}).catch(done);
|
2014-01-03 00:37:21 +00:00
|
|
|
});
|
|
|
|
});
|
2014-09-10 00:06:24 -04:00
|
|
|
});
|