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

Moved custom routes test to e2e frontend suite

https://github.com/TryGhost/Toolbox/issues/140

- This test was bloating the regression/site suite and was using hacks (calling the Admin API) to create a custom redirects state
- It suits way better in e2e frontend test suite with less hacky approach to start the Ghsot instance  - using custom routes file path to initialize the instance
This commit is contained in:
Naz 2021-11-30 10:39:23 +04:00 committed by naz
parent 961c29dc72
commit 6e395291fe
2 changed files with 82 additions and 122 deletions

View file

@ -0,0 +1,81 @@
const should = require('should');
const sinon = require('sinon');
const supertest = require('supertest');
const path = require('path');
const moment = require('moment');
const testUtils = require('../utils');
const configUtils = require('../utils/configUtils');
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('Custom Frontend routing', function () {
let request;
afterEach(function () {
sinon.restore();
});
before(async function () {
const routesFilePath = path.join(configUtils.config.get('paths:appRoot'), 'test/utils/fixtures/settings/newroutes.yaml');
await testUtils.startGhost({
forceStart: true,
routesFilePath
});
request = supertest.agent(configUtils.config.get('url'));
});
after(function () {
return testUtils.stopGhost();
});
it('serve welcome post with old permalink structure', function () {
return request.get('/welcome/')
.expect(404)
.expect(assertCorrectFrontendHeaders);
});
it('serve welcome post with new permalink structure', function () {
const year = moment().year();
return request.get(`/blog/${year}/welcome/`)
.expect(200)
.expect(assertCorrectFrontendHeaders);
});
it('serve welcome post with new permalink structure and old date', function () {
return request.get('/blog/2016/welcome/')
.expect(301)
.expect(assertCorrectFrontendHeaders);
});
it('serve rss', function () {
return request.get('/blog/rss/')
.expect(200)
.expect(assertCorrectFrontendHeaders)
.then(function (res) {
const content = res.text;
const todayMoment = moment();
const year = todayMoment.format('YYYY');
const postLink = `/blog/${year}/welcome/`;
content.indexOf(postLink).should.be.above(0);
});
});
it('serve collection index', function () {
return request.get('/blog/')
.expect(200)
.expect(assertCorrectFrontendHeaders);
});
it('serve tag', function () {
return request.get('/category/getting-started/')
.expect(200)
.expect(assertCorrectFrontendHeaders);
});
});

View file

@ -6,13 +6,10 @@ const should = require('should');
const supertest = require('supertest');
const sinon = require('sinon');
const moment = require('moment');
const path = require('path');
const testUtils = require('../../utils');
const configUtils = require('../../utils/configUtils');
const urlServiceUtils = require('../../utils/url-service-utils');
const cheerio = require('cheerio');
const config = require('../../../core/shared/config');
const api = require('../../../core/server/api');
const settingsCache = require('../../../core/shared/settings-cache');
let request;
@ -464,7 +461,7 @@ describe('Dynamic Routing', function () {
// Add enough posts to trigger pages
before(function (done) {
testUtils.clearData().then(function () {
// we initialise data, but not a user. No user should be required for navigating the frontend
// we initialize data, but not a user. No user should be required for navigating the frontend
return testUtils.initData();
}).then(function () {
return testUtils.fixtures.insertPostsAndTags();
@ -546,122 +543,4 @@ describe('Dynamic Routing', function () {
});
});
});
describe('Reload routes.yaml', function () {
before(async function () {
await testUtils.clearData();
// we initialize data, but not a user. No user should be required for navigating the frontend
await testUtils.initData();
await testUtils.fixtures.overrideOwnerUser('ghost-owner');
await testUtils.initFixtures('settings');
});
after(testUtils.teardownDb);
after(function () {
return testUtils.stopGhost();
});
it('confirm current routing pattern', function (done) {
request.get('/welcome/')
.expect(200)
.end(function (err, res) {
if (err) {
return done(err);
}
done();
});
});
it('simulate upload of routes.yaml', function () {
return api.settings.upload.query({
context: testUtils.context.internal.context,
file: {
path: path.join(config.get('paths:appRoot'), 'test', 'utils', 'fixtures', 'settings', 'newroutes.yaml')
}
}).then(() => {
return urlServiceUtils.isFinished();
});
});
it('serve welcome post with old permalink structure', function (done) {
request.get('/welcome/')
.expect(404)
.end(function (err) {
if (err) {
return done(err);
}
done();
});
});
it('serve welcome post with new permalink structure', function (done) {
const year = moment().year();
request.get(`/blog/${year}/welcome/`)
.expect(200)
.end(function (err) {
if (err) {
return done(err);
}
done();
});
});
it('serve welcome post with new permalink structure and old date', function (done) {
request.get('/blog/2016/welcome/')
.expect(301)
.end(function (err) {
if (err) {
return done(err);
}
done();
});
});
it('serve serve rss', function (done) {
request.get('/blog/rss/')
.expect(200)
.end(function (err, res) {
if (err) {
return done(err);
}
const content = res.text;
const todayMoment = moment();
const year = todayMoment.format('YYYY');
const postLink = `/blog/${year}/welcome/`;
content.indexOf(postLink).should.be.above(0);
done();
});
});
it('serve collection index', function (done) {
request.get('/blog/')
.expect(200)
.end(function (err, res) {
if (err) {
return done(err);
}
done();
});
});
it('serve tag', function (done) {
request.get('/category/getting-started/')
.expect(200)
.end(function (err, res) {
if (err) {
return done(err);
}
done();
});
});
});
});