mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
Used consistent patterns in acceptance tests
- use testUtils.startGhost() directly - use async+await for tests - simplify tests down using expect(fn) to make them more readable - don't require config directly - removed TODO which is no longer valid - All this is essentially ground work before introducing a better framework for running acceptance tests
This commit is contained in:
parent
52eb6c3f4b
commit
d0c54afd4e
3 changed files with 328 additions and 411 deletions
|
@ -3,8 +3,6 @@ const supertest = require('supertest');
|
|||
const testUtils = require('../utils');
|
||||
const configUtils = require('../utils/configUtils');
|
||||
const urlUtils = require('../utils/urlUtils');
|
||||
const config = require('../../core/shared/config');
|
||||
const ghost = testUtils.startGhost;
|
||||
|
||||
let request;
|
||||
|
||||
|
@ -18,33 +16,14 @@ let request;
|
|||
*/
|
||||
|
||||
describe('Advanced URL Configurations', function () {
|
||||
function doEnd(done) {
|
||||
return function (err, res) {
|
||||
if (err) {
|
||||
return done(err);
|
||||
}
|
||||
|
||||
should.not.exist(res.headers['x-cache-invalidate']);
|
||||
should.not.exist(res.headers['X-CSRF-Token']);
|
||||
should.not.exist(res.headers['set-cookie']);
|
||||
should.exist(res.headers.date);
|
||||
|
||||
done();
|
||||
};
|
||||
}
|
||||
|
||||
describe('Subdirectory config', function () {
|
||||
let ghostServer;
|
||||
|
||||
before(function () {
|
||||
before(async function () {
|
||||
configUtils.set('url', 'http://localhost/blog/');
|
||||
urlUtils.stubUrlUtilsFromConfig();
|
||||
|
||||
return ghost({forceStart: true, subdir: true})
|
||||
.then(function (_ghostServer) {
|
||||
ghostServer = _ghostServer;
|
||||
request = supertest.agent(config.get('server:host') + ':' + config.get('server:port'));
|
||||
});
|
||||
await testUtils.startGhost({forceStart: true});
|
||||
|
||||
request = supertest.agent(configUtils.config.get('server:host') + ':' + configUtils.config.get('server:port'));
|
||||
});
|
||||
|
||||
after(function () {
|
||||
|
@ -52,75 +31,62 @@ describe('Advanced URL Configurations', function () {
|
|||
urlUtils.restore();
|
||||
});
|
||||
|
||||
it('http://localhost should 404', function (done) {
|
||||
request.get('/')
|
||||
.expect(404)
|
||||
.end(doEnd(done));
|
||||
it('http://localhost should 404', async function () {
|
||||
await request.get('/')
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('/blog should 301 to /blog/', function (done) {
|
||||
request.get('/blog')
|
||||
it('/blog should 301 to /blog/', async function () {
|
||||
await request.get('/blog')
|
||||
.expect(301)
|
||||
.expect('Location', '/blog/')
|
||||
.end(doEnd(done));
|
||||
.expect('Location', '/blog/');
|
||||
});
|
||||
|
||||
it('/blog/ should 200', function (done) {
|
||||
request.get('/blog/')
|
||||
.expect(200)
|
||||
.end(doEnd(done));
|
||||
it('/blog/ should 200', async function () {
|
||||
await request.get('/blog/')
|
||||
.expect(200);
|
||||
});
|
||||
|
||||
it('/blog/welcome/ should 200', function (done) {
|
||||
request.get('/blog/welcome/')
|
||||
.expect(200)
|
||||
.end(doEnd(done));
|
||||
it('/blog/welcome/ should 200', async function () {
|
||||
await request.get('/blog/welcome/')
|
||||
.expect(200);
|
||||
});
|
||||
|
||||
it('/welcome/ should 404', function (done) {
|
||||
request.get('/welcome/')
|
||||
.expect(404)
|
||||
.end(doEnd(done));
|
||||
it('/welcome/ should 404', async function () {
|
||||
await request.get('/welcome/')
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('/blog/tag/getting-started/ should 200', function (done) {
|
||||
request.get('/blog/tag/getting-started/')
|
||||
.expect(200)
|
||||
.end(doEnd(done));
|
||||
it('/blog/tag/getting-started/ should 200', async function () {
|
||||
await request.get('/blog/tag/getting-started/')
|
||||
.expect(200);
|
||||
});
|
||||
|
||||
it('/tag/getting-started/ should 404', function (done) {
|
||||
request.get('/tag/getting-started/')
|
||||
.expect(404)
|
||||
.end(doEnd(done));
|
||||
it('/tag/getting-started/ should 404', async function () {
|
||||
await request.get('/tag/getting-started/')
|
||||
.expect(404);
|
||||
});
|
||||
|
||||
it('/blog/welcome/amp/ should 200', function (done) {
|
||||
request.get('/blog/welcome/amp/')
|
||||
.expect(200)
|
||||
.end(doEnd(done));
|
||||
it('/blog/welcome/amp/ should 200', async function () {
|
||||
await request.get('/blog/welcome/amp/')
|
||||
.expect(200);
|
||||
});
|
||||
|
||||
it('/welcome/amp/ should 404', function (done) {
|
||||
request.get('/welcome/amp/')
|
||||
.expect(404)
|
||||
.end(doEnd(done));
|
||||
it('/welcome/amp/ should 404', async function () {
|
||||
await request.get('/welcome/amp/')
|
||||
.expect(404);
|
||||
});
|
||||
});
|
||||
|
||||
// we'll use X-Forwarded-Proto: https to simulate an 'https://' request behind a proxy
|
||||
describe('HTTPS', function () {
|
||||
let ghostServer;
|
||||
|
||||
before(function () {
|
||||
before(async function () {
|
||||
configUtils.set('url', 'http://localhost:2370/');
|
||||
urlUtils.stubUrlUtilsFromConfig();
|
||||
|
||||
return ghost({forceStart: true})
|
||||
.then(function (_ghostServer) {
|
||||
ghostServer = _ghostServer;
|
||||
request = supertest.agent(config.get('server:host') + ':' + config.get('server:port'));
|
||||
});
|
||||
await testUtils.startGhost({forceStart: true});
|
||||
|
||||
request = supertest.agent(configUtils.config.get('server:host') + ':' + configUtils.config.get('server:port'));
|
||||
});
|
||||
|
||||
after(function () {
|
||||
|
@ -128,21 +94,19 @@ describe('Advanced URL Configurations', function () {
|
|||
urlUtils.restore();
|
||||
});
|
||||
|
||||
it('should set links to url over non-HTTPS', function (done) {
|
||||
request.get('/')
|
||||
it('should set links to url over non-HTTPS', async function () {
|
||||
await request.get('/')
|
||||
.expect(200)
|
||||
.expect(/<link rel="canonical" href="http:\/\/localhost:2370\/" \/\>/)
|
||||
.expect(/<a href="http:\/\/localhost:2370">Ghost<\/a\>/)
|
||||
.end(doEnd(done));
|
||||
.expect(/<a href="http:\/\/localhost:2370">Ghost<\/a\>/);
|
||||
});
|
||||
|
||||
it('should set links over HTTPS besides canonical', function (done) {
|
||||
request.get('/')
|
||||
it('should set links over HTTPS besides canonical', async function () {
|
||||
await request.get('/')
|
||||
.set('X-Forwarded-Proto', 'https')
|
||||
.expect(200)
|
||||
.expect(/<link rel="canonical" href="http:\/\/localhost:2370\/" \/\>/)
|
||||
.expect(/<a href="https:\/\/localhost:2370">Ghost<\/a\>/)
|
||||
.end(doEnd(done));
|
||||
.expect(/<a href="https:\/\/localhost:2370">Ghost<\/a\>/);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
|
@ -13,19 +13,18 @@ const cheerio = require('cheerio');
|
|||
const _ = require('lodash');
|
||||
const testUtils = require('../utils');
|
||||
const configUtils = require('../utils/configUtils');
|
||||
const config = require('../../core/shared/config');
|
||||
const settingsCache = require('../../core/server/services/settings/cache');
|
||||
const origCache = _.cloneDeep(settingsCache);
|
||||
|
||||
describe('Default Frontend routing', function () {
|
||||
let request;
|
||||
|
||||
function doEnd(res) {
|
||||
function assertCorrectFrontendHeaders(res) {
|
||||
should.not.exist(res.headers['x-cache-invalidate']);
|
||||
should.not.exist(res.headers['X-CSRF-Token']);
|
||||
should.not.exist(res.headers['set-cookie']);
|
||||
should.exist(res.headers.date);
|
||||
}
|
||||
}
|
||||
|
||||
describe('Default Frontend routing', function () {
|
||||
let request;
|
||||
|
||||
afterEach(function () {
|
||||
sinon.restore();
|
||||
|
@ -33,36 +32,35 @@ describe('Default Frontend routing', function () {
|
|||
|
||||
before(async function () {
|
||||
await testUtils.startGhost();
|
||||
request = supertest.agent(config.get('url'));
|
||||
request = supertest.agent(configUtils.config.get('url'));
|
||||
});
|
||||
|
||||
describe('Error', function () {
|
||||
it('should 404 for unknown post', async function () {
|
||||
const res = await request.get('/spectacular/')
|
||||
await request.get('/spectacular/')
|
||||
.expect('Cache-Control', testUtils.cacheRules.private)
|
||||
.expect(404)
|
||||
.expect(/Page not found/);
|
||||
|
||||
doEnd(res);
|
||||
.expect(/Page not found/)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
it('should 404 for unknown file', async function () {
|
||||
const res = await request.get('/content/images/some/file/that/doesnt-exist.jpg')
|
||||
await request.get('/content/images/some/file/that/doesnt-exist.jpg')
|
||||
.expect('Cache-Control', testUtils.cacheRules.private)
|
||||
.expect(404)
|
||||
.expect(/404 Image not found/);
|
||||
|
||||
doEnd(res);
|
||||
.expect(/404 Image not found/)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
});
|
||||
|
||||
describe('Main Routes', function () {
|
||||
it('/ should respond with valid HTML', async function () {
|
||||
const res = await request.get('/')
|
||||
await request.get('/')
|
||||
.expect('Content-Type', /html/)
|
||||
.expect('Cache-Control', testUtils.cacheRules.public)
|
||||
.expect(200);
|
||||
|
||||
.expect(200)
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
const $ = cheerio.load(res.text);
|
||||
|
||||
// NOTE: "Ghost" is the title from the settings.
|
||||
|
@ -73,16 +71,16 @@ describe('Default Frontend routing', function () {
|
|||
$('article.tag-getting-started').length.should.equal(7);
|
||||
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('/author/ghost/ should respond with valid HTML', async function () {
|
||||
const res = await request.get('/author/ghost/')
|
||||
await request.get('/author/ghost/')
|
||||
.expect('Content-Type', /html/)
|
||||
.expect('Cache-Control', testUtils.cacheRules.public)
|
||||
.expect(200);
|
||||
|
||||
.expect(200)
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
const $ = cheerio.load(res.text);
|
||||
|
||||
// NOTE: "Ghost" is the title from the settings.
|
||||
|
@ -93,16 +91,16 @@ describe('Default Frontend routing', function () {
|
|||
$('article.tag-getting-started').length.should.equal(7);
|
||||
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('/tag/getting-started/ should respond with valid HTML', async function () {
|
||||
const res = await request.get('/tag/getting-started/')
|
||||
await request.get('/tag/getting-started/')
|
||||
.expect('Content-Type', /html/)
|
||||
.expect('Cache-Control', testUtils.cacheRules.public)
|
||||
.expect(200);
|
||||
|
||||
.expect(200)
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
const $ = cheerio.load(res.text);
|
||||
|
||||
// NOTE: "Ghost" is the title from the settings.
|
||||
|
@ -113,18 +111,17 @@ describe('Default Frontend routing', function () {
|
|||
$('article.tag-getting-started').length.should.equal(7);
|
||||
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('Single post', function () {
|
||||
it('/welcome/ should respond with valid HTML', async function () {
|
||||
const res = await request.get('/welcome/')
|
||||
await request.get('/welcome/')
|
||||
.expect('Content-Type', /html/)
|
||||
.expect('Cache-Control', testUtils.cacheRules.public)
|
||||
.expect(200);
|
||||
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
const $ = cheerio.load(res.text);
|
||||
|
||||
// NOTE: This is the title from the settings.
|
||||
|
@ -136,40 +133,36 @@ describe('Default Frontend routing', function () {
|
|||
$('article.tag-getting-started').length.should.equal(2);
|
||||
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('should not work with date permalinks', async function () {
|
||||
// get today's date
|
||||
const date = moment().format('YYYY/MM/DD');
|
||||
|
||||
const res = await request.get('/' + date + '/welcome/')
|
||||
await request.get('/' + date + '/welcome/')
|
||||
.expect('Cache-Control', testUtils.cacheRules.private)
|
||||
.expect(404)
|
||||
.expect(/Page not found/);
|
||||
|
||||
doEnd(res);
|
||||
.expect(/Page not found/)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
});
|
||||
|
||||
describe('Post edit', function () {
|
||||
it('should redirect to editor', async function () {
|
||||
const res = await request.get('/welcome/edit/')
|
||||
await request.get('/welcome/edit/')
|
||||
.expect('Location', /ghost\/#\/editor\/\w+/)
|
||||
.expect('Cache-Control', testUtils.cacheRules.public)
|
||||
.expect(302);
|
||||
|
||||
doEnd(res);
|
||||
.expect(302)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
it('should 404 for non-edit parameter', async function () {
|
||||
const res = await request.get('/welcome/notedit/')
|
||||
await request.get('/welcome/notedit/')
|
||||
.expect('Cache-Control', testUtils.cacheRules.private)
|
||||
.expect(404)
|
||||
.expect(/Page not found/);
|
||||
|
||||
doEnd(res);
|
||||
.expect(/Page not found/)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
describe('Admin Redirects Disabled', function () {
|
||||
|
@ -177,33 +170,33 @@ describe('Default Frontend routing', function () {
|
|||
configUtils.set('admin:redirects', false);
|
||||
|
||||
await testUtils.startGhost({forceStart: true});
|
||||
request = supertest.agent(config.get('url'));
|
||||
request = supertest.agent(configUtils.config.get('url'));
|
||||
});
|
||||
|
||||
after(async function () {
|
||||
configUtils.restore();
|
||||
|
||||
await testUtils.startGhost({forceStart: true});
|
||||
request = supertest.agent(config.get('url'));
|
||||
request = supertest.agent(configUtils.config.get('url'));
|
||||
});
|
||||
|
||||
it('/edit/ should NOT redirect to the editor', async function () {
|
||||
const res = await request.get('/welcome/edit/')
|
||||
await request.get('/welcome/edit/')
|
||||
.expect('Cache-Control', testUtils.cacheRules.private)
|
||||
.expect(404);
|
||||
|
||||
doEnd(res);
|
||||
.expect(404)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('AMP post', function () {
|
||||
it('should respond with html for valid url', async function () {
|
||||
const res = await request.get('/welcome/amp/')
|
||||
await request.get('/welcome/amp/')
|
||||
.expect('Content-Type', /html/)
|
||||
.expect('Cache-Control', testUtils.cacheRules.public)
|
||||
.expect(200);
|
||||
|
||||
.expect(200)
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
const $ = cheerio.load(res.text);
|
||||
|
||||
$('.post-title').text().should.equal('Start here for a quick overview of everything you need to know');
|
||||
|
@ -218,20 +211,18 @@ describe('Default Frontend routing', function () {
|
|||
res.text.should.containEql(':root {--ghost-accent-color: #FF1A75;}');
|
||||
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('should not work with date permalinks', async function () {
|
||||
// get today's date
|
||||
const date = moment().format('YYYY/MM/DD');
|
||||
|
||||
const res = await request.get('/' + date + '/welcome/amp/')
|
||||
await request.get('/' + date + '/welcome/amp/')
|
||||
.expect('Cache-Control', testUtils.cacheRules.private)
|
||||
.expect(404)
|
||||
.expect(/Page not found/);
|
||||
|
||||
doEnd(res);
|
||||
.expect(/Page not found/)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
describe('AMP Disabled', function () {
|
||||
|
@ -243,75 +234,74 @@ describe('Default Frontend routing', function () {
|
|||
return origCache.get(key, options);
|
||||
});
|
||||
|
||||
const res = await request.get('/welcome/amp/?q=a')
|
||||
await request.get('/welcome/amp/?q=a')
|
||||
.expect('Location', '/welcome/?q=a')
|
||||
.expect(301);
|
||||
|
||||
doEnd(res);
|
||||
.expect(301)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('RSS', function () {
|
||||
it('/rss/ should serve an RSS feed', async function () {
|
||||
const res = await request.get('/rss/')
|
||||
await request.get('/rss/')
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.public)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/<!\[CDATA\[Start here for a quick overview of everything you need to know\]\]>/);
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('/author/ghost/rss/ should serve an RSS feed', async function () {
|
||||
const res = await request.get('/author/ghost/rss/')
|
||||
await request.get('/author/ghost/rss/')
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.public)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/<!\[CDATA\[Start here for a quick overview of everything you need to know\]\]>/);
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('/tag/getting-started/rss/ should serve an RSS feed', async function () {
|
||||
const res = await request.get('/tag/getting-started/rss/')
|
||||
await request.get('/tag/getting-started/rss/')
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.public)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/<!\[CDATA\[Start here for a quick overview of everything you need to know\]\]>/);
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('Static assets', function () {
|
||||
it('should retrieve theme assets', async function () {
|
||||
const res = await request.get('/assets/css/screen.css')
|
||||
await request.get('/assets/css/screen.css')
|
||||
.expect('Cache-Control', testUtils.cacheRules.year)
|
||||
.expect(200);
|
||||
|
||||
doEnd(res);
|
||||
.expect(200)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
it('should retrieve default robots.txt', async function () {
|
||||
const res = await request.get('/robots.txt')
|
||||
await request.get('/robots.txt')
|
||||
.expect('Cache-Control', testUtils.cacheRules.hour)
|
||||
.expect('ETag', /[0-9a-f]{32}/i)
|
||||
.expect(200);
|
||||
|
||||
doEnd(res);
|
||||
.expect(200)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
it('should retrieve default favicon.ico', async function () {
|
||||
const res = await request.get('/favicon.ico')
|
||||
await request.get('/favicon.ico')
|
||||
.expect('Cache-Control', testUtils.cacheRules.day)
|
||||
.expect('ETag', /[0-9a-f]{32}/i)
|
||||
.expect(200);
|
||||
|
||||
doEnd(res);
|
||||
.expect(200)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -323,69 +313,75 @@ describe('Default Frontend routing', function () {
|
|||
});
|
||||
|
||||
it('should serve sitemap.xml', async function () {
|
||||
const res = await request.get('/sitemap.xml')
|
||||
await request.get('/sitemap.xml')
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.hour)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/sitemapindex/);
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('should serve sitemap-posts.xml', async function () {
|
||||
const res = await request.get('/sitemap-posts.xml')
|
||||
await request.get('/sitemap-posts.xml')
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.hour)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/urlset/);
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('should serve sitemap-pages.xml', async function () {
|
||||
const res = await request.get('/sitemap-pages.xml')
|
||||
await request.get('/sitemap-pages.xml')
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.hour)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/urlset/);
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('should serve sitemap-tags.xml', async function () {
|
||||
const res = await request.get('/sitemap-tags.xml')
|
||||
await request.get('/sitemap-tags.xml')
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.hour)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/urlset/);
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('should serve sitemap-users.xml', async function () {
|
||||
const res = await request.get('/sitemap-users.xml')
|
||||
await request.get('/sitemap-users.xml')
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.hour)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/urlset/);
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('should serve sitemap.xsl', async function () {
|
||||
const res = await request.get('/sitemap.xsl')
|
||||
await request.get('/sitemap.xsl')
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.day)
|
||||
.expect('Content-Type', 'text/xsl');
|
||||
|
||||
.expect('Content-Type', 'text/xsl')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/urlset/);
|
||||
res.text.should.not.containEql('__GHOST_URL__');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -400,83 +396,80 @@ describe('Default Frontend routing', function () {
|
|||
});
|
||||
|
||||
it('/ should redirect to /private/', async function () {
|
||||
const res = await request.get('/')
|
||||
await request.get('/')
|
||||
.expect('Location', '/private/?r=%2F')
|
||||
.expect(302);
|
||||
|
||||
doEnd(res);
|
||||
.expect(302)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
it('/welcome/ should redirect to /private/', async function () {
|
||||
const res = await request.get('/welcome/')
|
||||
await request.get('/welcome/')
|
||||
.expect('Location', '/private/?r=%2Fwelcome%2F')
|
||||
.expect(302);
|
||||
|
||||
doEnd(res);
|
||||
.expect(302)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
it('/private/?r=%2Fwelcome%2F should not redirect', async function () {
|
||||
const res = await request.get('/private/?r=%2Fwelcome%2F')
|
||||
.expect(200);
|
||||
|
||||
doEnd(res);
|
||||
await request.get('/private/?r=%2Fwelcome%2F')
|
||||
.expect(200)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
it('should redirect, NOT 404 for private route with extra path', async function () {
|
||||
const res = await request.get('/private/welcome/')
|
||||
await request.get('/private/welcome/')
|
||||
.expect('Location', '/private/?r=%2Fprivate%2Fwelcome%2F')
|
||||
.expect(302);
|
||||
|
||||
doEnd(res);
|
||||
.expect(302)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
it('should still serve private RSS feed', async function () {
|
||||
const res = await request.get(`/${settingsCache.get('public_hash')}/rss/`)
|
||||
await request.get(`/${settingsCache.get('public_hash')}/rss/`)
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.private)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/<!\[CDATA\[Start here for a quick overview of everything you need to know\]\]>/);
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('should still serve private tag RSS feed', async function () {
|
||||
const res = await request.get(`/tag/getting-started/${settingsCache.get('public_hash')}/rss/`)
|
||||
await request.get(`/tag/getting-started/${settingsCache.get('public_hash')}/rss/`)
|
||||
.expect(200)
|
||||
.expect('Cache-Control', testUtils.cacheRules.private)
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8');
|
||||
|
||||
.expect('Content-Type', 'text/xml; charset=utf-8')
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match(/<!\[CDATA\[Start here for a quick overview of everything you need to know\]\]>/);
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
|
||||
it('should redirect, NOT 404 for private tag RSS feed with extra path', async function () {
|
||||
const res = await request.get(`/tag/getting-started/${settingsCache.get('public_hash')}/rss/hack/`)
|
||||
await request.get(`/tag/getting-started/${settingsCache.get('public_hash')}/rss/hack/`)
|
||||
.expect('Location', `/private/?r=%2Ftag%2Fgetting-started%2F${settingsCache.get('public_hash')}%2Frss%2Fhack%2F`)
|
||||
.expect(302);
|
||||
|
||||
doEnd(res);
|
||||
.expect(302)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
// NOTE: this case is covered by extra error handling, and cannot be unit tested
|
||||
it('should redirect, NOT 404 for unknown private RSS feed', async function () {
|
||||
// NOTE: the redirect will be to /hack/rss because we strip the hash from the URL before trying to serve RSS
|
||||
// This isn't ideal, but it's better to expose this internal logic than it is a 404 page
|
||||
const res = await request.get(`/hack/${settingsCache.get('public_hash')}/rss/`)
|
||||
await request.get(`/hack/${settingsCache.get('public_hash')}/rss/`)
|
||||
.expect('Location', '/private/?r=%2Fhack%2Frss%2F')
|
||||
.expect(302);
|
||||
|
||||
doEnd(res);
|
||||
.expect(302)
|
||||
.expect(assertCorrectFrontendHeaders);
|
||||
});
|
||||
|
||||
// NOTE: this test extends the unit test, checking that there is no other robots.txt middleware overriding private blogging
|
||||
it('should serve private robots.txt', async function () {
|
||||
const res = await request.get('/robots.txt')
|
||||
await request.get('/robots.txt')
|
||||
.expect('Cache-Control', 'public, max-age=3600000')
|
||||
.expect(200);
|
||||
|
||||
.expect(200)
|
||||
.expect(assertCorrectFrontendHeaders)
|
||||
.expect((res) => {
|
||||
res.text.should.match('User-agent: *\nDisallow: /');
|
||||
doEnd(res);
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
|
@ -6,9 +6,14 @@ const testUtils = require('../utils');
|
|||
const configUtils = require('../utils/configUtils');
|
||||
const settingsCache = require('../../core/server/services/settings/cache');
|
||||
|
||||
// @TODO: if only this suite is run some of the tests will fail due to
|
||||
// wrong template loading issues which would need to be investigated
|
||||
// As a workaround run it with some of other tests e.g. "frontend_spec"
|
||||
function assertContentIsPresent(res) {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
}
|
||||
|
||||
function assertContentIsAbsent(res) {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
}
|
||||
|
||||
describe('Front-end members behaviour', function () {
|
||||
let request;
|
||||
|
||||
|
@ -25,7 +30,7 @@ describe('Front-end members behaviour', function () {
|
|||
// perform a sign-in request to set members cookies on superagent
|
||||
await request.get(signinPath)
|
||||
.expect(302)
|
||||
.then((res) => {
|
||||
.expect((res) => {
|
||||
const redirectUrl = new URL(res.headers.location, testUtils.API.getURL());
|
||||
should.exist(redirectUrl.searchParams.get('success'));
|
||||
redirectUrl.searchParams.get('success').should.eql('true');
|
||||
|
@ -125,18 +130,19 @@ describe('Front-end members behaviour', function () {
|
|||
|
||||
describe('Price data', function () {
|
||||
it('Can be used as a number, and with the price helper', async function () {
|
||||
const res = await request.get('/');
|
||||
|
||||
// Check out test/utils/fixtures/themes/price-data-test-theme/index.hbs
|
||||
// To see where this is coming from.
|
||||
//
|
||||
const legacyUse = /You can use the price data as a number and currency: £12/;
|
||||
const withPriceHelper = /You can pass price data to the price helper: £12/;
|
||||
|
||||
await request.get('/')
|
||||
.expect((res) => {
|
||||
should.exist(res.text.match(legacyUse));
|
||||
should.exist(res.text.match(withPriceHelper));
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
describe('Content gating', function () {
|
||||
let publicPost;
|
||||
|
@ -196,49 +202,39 @@ describe('Front-end members behaviour', function () {
|
|||
});
|
||||
|
||||
describe('as non-member', function () {
|
||||
it('can read public post content', function () {
|
||||
return request
|
||||
it('can read public post content', async function () {
|
||||
await request
|
||||
.get('/free-to-see/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
|
||||
it('cannot read members post content', function () {
|
||||
return request
|
||||
it('cannot read members post content', async function () {
|
||||
await request
|
||||
.get('/thou-shalt-not-be-seen/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
|
||||
it('cannot read paid post content', function () {
|
||||
return request
|
||||
it('cannot read paid post content', async function () {
|
||||
await request
|
||||
.get('/thou-shalt-be-paid-for/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
|
||||
it('cannot read label-only post content', function () {
|
||||
return request
|
||||
it('cannot read label-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-be-labelled-vip/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
|
||||
it('cannot read product-only post content', function () {
|
||||
return request
|
||||
it('cannot read product-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-have-default-product/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -247,49 +243,39 @@ describe('Front-end members behaviour', function () {
|
|||
await loginAsMember('member1@test.com');
|
||||
});
|
||||
|
||||
it('can read public post content', function () {
|
||||
return request
|
||||
it('can read public post content', async function () {
|
||||
await request
|
||||
.get('/free-to-see/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
|
||||
it('can read members post content', function () {
|
||||
return request
|
||||
it('can read members post content', async function () {
|
||||
await request
|
||||
.get('/thou-shalt-not-be-seen/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
|
||||
it('cannot read paid post content', function () {
|
||||
return request
|
||||
it('cannot read paid post content', async function () {
|
||||
await request
|
||||
.get('/thou-shalt-be-paid-for/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
|
||||
it('cannot read label-only post content', function () {
|
||||
return request
|
||||
it('cannot read label-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-be-labelled-vip/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
|
||||
it('cannot read product-only post content', function () {
|
||||
return request
|
||||
it('cannot read product-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-have-default-product/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -298,13 +284,11 @@ describe('Front-end members behaviour', function () {
|
|||
await loginAsMember('vip@test.com');
|
||||
});
|
||||
|
||||
it('can read label-only post content', function () {
|
||||
return request
|
||||
it('can read label-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-be-labelled-vip/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -329,49 +313,39 @@ describe('Front-end members behaviour', function () {
|
|||
});
|
||||
});
|
||||
|
||||
it('can read public post content', function () {
|
||||
return request
|
||||
it('can read public post content', async function () {
|
||||
await request
|
||||
.get('/free-to-see/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
|
||||
it('can read members post content', function () {
|
||||
return request
|
||||
it('can read members post content', async function () {
|
||||
await request
|
||||
.get('/thou-shalt-not-be-seen/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
|
||||
it('can read paid post content', function () {
|
||||
return request
|
||||
it('can read paid post content', async function () {
|
||||
await request
|
||||
.get('/thou-shalt-be-paid-for/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
|
||||
it('cannot read label-only post content', function () {
|
||||
return request
|
||||
it('cannot read label-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-be-labelled-vip/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
|
||||
it('cannot read product-only post content', function () {
|
||||
return request
|
||||
it('cannot read product-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-have-default-product/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -380,13 +354,11 @@ describe('Front-end members behaviour', function () {
|
|||
await loginAsMember('vip-paid@test.com');
|
||||
});
|
||||
|
||||
it('can read label-only post content', function () {
|
||||
return request
|
||||
it('can read label-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-be-labelled-vip/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -395,49 +367,39 @@ describe('Front-end members behaviour', function () {
|
|||
await loginAsMember('comped@test.com');
|
||||
});
|
||||
|
||||
it('can read public post content', function () {
|
||||
return request
|
||||
it('can read public post content', async function () {
|
||||
await request
|
||||
.get('/free-to-see/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
|
||||
it('can read members post content', function () {
|
||||
return request
|
||||
it('can read members post content', async function () {
|
||||
await request
|
||||
.get('/thou-shalt-not-be-seen/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
|
||||
it('can read paid post content', function () {
|
||||
return request
|
||||
it('can read paid post content', async function () {
|
||||
await request
|
||||
.get('/thou-shalt-be-paid-for/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
|
||||
it('cannot read label-only post content', function () {
|
||||
return request
|
||||
it('cannot read label-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-be-labelled-vip/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
|
||||
it('cannot read product-only post content', function () {
|
||||
return request
|
||||
it('cannot read product-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-have-default-product/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.not.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsAbsent);
|
||||
});
|
||||
});
|
||||
|
||||
|
@ -446,13 +408,11 @@ describe('Front-end members behaviour', function () {
|
|||
await loginAsMember('with-product@test.com');
|
||||
});
|
||||
|
||||
it('can read product-only post content', function () {
|
||||
return request
|
||||
it('can read product-only post content', async function () {
|
||||
await request
|
||||
.get('/thou-must-have-default-product/')
|
||||
.expect(200)
|
||||
.then((res) => {
|
||||
res.text.should.containEql('<h2 id="markdown">markdown</h2>');
|
||||
});
|
||||
.expect(assertContentIsPresent);
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
Loading…
Add table
Reference in a new issue