Ghost/test/frontend-acceptance/members_spec.js
Rishabh Garg 8ad11fe082
Enabled Portal (#12317)
no refs

[Portal](https://github.com/TryGhost/Portal) is a new drop-in script to make the bulk of Ghost membership features work on any theme out of the box, which was under a developer flag so far. This release removes the flag for Portal and makes it included as default for any members-enabled Ghost site. The Portal script is backward compatible with old public members script and existing Members-enabled themes should notice no change.

- Removes Portal config flag as Portal is now enabled by default
- Removes old members script as Portal is backward compatible with it
- Changes `{{content}}` helper to show default CTA in case of restricted content access
- `accent_color` setting is no more behind the dev experiment flag and included by default
- Adds migration to switch off Portal button setting for all existing sites which don't have Portal enabled in beta
2020-11-03 14:36:21 +05:30

175 lines
6.3 KiB
JavaScript

const should = require('should');
const sinon = require('sinon');
const supertest = require('supertest');
const testUtils = require('../utils');
const configUtils = require('../utils/configUtils');
const settingsCache = require('../../core/server/services/settings/cache');
const ghost = testUtils.startGhost;
// @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"
describe('Basic Members Routes', function () {
let request;
before(function () {
return ghost()
.then(function () {
request = supertest.agent(configUtils.config.get('url'));
});
});
describe('Members enabled', function () {
before(function () {
const originalSettingsCacheGetFn = settingsCache.get;
sinon.stub(settingsCache, 'get').callsFake(function (key, options) {
if (key === 'labs') {
return {members: true};
}
return originalSettingsCacheGetFn(key, options);
});
});
after(function () {
sinon.restore();
});
describe('Routes', function () {
it('should error serving webhook endpoint without any parameters', function () {
return request.post('/members/webhooks/stripe')
.expect(400);
});
it('should error when invalid member token is passed into session', function () {
return request.get('/members/api/session')
.expect(400);
});
it('should return no content when removing member sessions', function () {
return request.del('/members/api/session')
.expect(204);
});
it('should error for invalid member token on member data endpoint', function () {
return request.get('/members/api/member')
.expect(400);
});
it('should serve member site endpoint', function () {
return request.get('/members/api/site')
.expect(200);
});
it('should error for invalid data on member magic link endpoint', function () {
return request.post('/members/api/send-magic-link')
.expect(400);
});
it('should error for invalid data on members create checkout session endpoint', function () {
return request.post('/members/api/create-stripe-checkout-session')
.expect(400);
});
it('should error for invalid data on members create update session endpoint', function () {
return request.post('/members/api/create-stripe-update-session')
.expect(400);
});
it('should error for invalid data on members subscription endpoint', function () {
return request.put('/members/api/subscriptions/123')
.expect(400);
});
it('should serve theme 404 on members endpoint', function () {
return request.get('/members/')
.expect(404)
.expect('Content-Type', 'text/html; charset=utf-8');
});
it('should redirect invalid token on members endpoint', function () {
return request.get('/members/?token=abc&action=signup')
.expect(302)
.expect('Location', '/?action=signup&success=false');
});
});
});
describe('Members disabled', function () {
before(function () {
const originalSettingsCacheGetFn = settingsCache.get;
sinon.stub(settingsCache, 'get').callsFake(function (key, options) {
if (key === 'labs') {
return {members: false};
}
return originalSettingsCacheGetFn(key, options);
});
});
after(function () {
sinon.restore();
});
describe('Routes', function () {
it('should not serve webhook endpoint', function () {
return request.post('/members/webhooks/stripe')
.expect(404);
});
it('should not serve session endpoint', function () {
return request.get('/members/api/session')
.expect(404);
});
it('should not serve session removal endpoint', function () {
return request.del('/members/api/session')
.expect(404);
});
it('should not serve member data endpoint', function () {
return request.get('/members/api/member')
.expect(404);
});
it('should not serve member site endpoint', function () {
return request.get('/members/api/site')
.expect(404);
});
it('should not serve member magic link endpoint', function () {
return request.post('/members/api/send-magic-link')
.expect(404);
});
it('should not serve members create checkout session endpoint', function () {
return request.post('/members/api/create-stripe-checkout-session')
.expect(404);
});
it('should not serve members create update session endpoint', function () {
return request.post('/members/api/create-stripe-update-session')
.expect(404);
});
it('should not serve members subscription endpoint', function () {
return request.put('/members/api/subscriptions/123')
.expect(404);
});
it('should serve 404 on members endpoint', function () {
return request.get('/members/')
.expect(404);
});
it('should not redirect members endpoint with token', function () {
return request.get('/members/?token=abc&action=signup')
.expect(404);
});
});
});
});