mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-22 10:21:36 +03:00
715d658e11
fixes https://github.com/TryGhost/Product/issues/3911 For now we decided that we don't want to enable one-click-subscribe in case a site has a required checkbox (which isn't shown during the one-click-subscribe flow)
85 lines
2.8 KiB
JavaScript
85 lines
2.8 KiB
JavaScript
const {agentProvider, fixtureManager, matchers} = require('../../utils/e2e-framework');
|
|
const {anyEtag, stringMatching, anyContentLength} = matchers;
|
|
const assert = require('assert/strict');
|
|
const models = require('../../../core/server/models');
|
|
|
|
describe('Site Public Settings', function () {
|
|
let membersAgent;
|
|
|
|
before(async function () {
|
|
membersAgent = await agentProvider.getMembersAPIAgent();
|
|
await fixtureManager.init();
|
|
});
|
|
|
|
afterEach(async function () {
|
|
await await models.Settings.edit({
|
|
key: 'members_signup_access',
|
|
value: 'all'
|
|
}, {context: {internal: true}});
|
|
});
|
|
|
|
it('Can retrieve site pubic config', async function () {
|
|
const {body} = await membersAgent
|
|
.get('/api/site')
|
|
.matchBodySnapshot({
|
|
site: {
|
|
version: stringMatching(/\d+\.\d+/)
|
|
}
|
|
})
|
|
.matchHeaderSnapshot({
|
|
etag: anyEtag,
|
|
'content-length': anyContentLength
|
|
});
|
|
assert.equal(body.site.allow_external_signup, true);
|
|
});
|
|
|
|
it('Sets allow_external_signup to false when members are invite only', async function () {
|
|
await await models.Settings.edit({
|
|
key: 'members_signup_access',
|
|
value: 'invite'
|
|
}, {context: {internal: true}});
|
|
|
|
const {body} = await membersAgent
|
|
.get('/api/site')
|
|
.matchBodySnapshot({
|
|
site: {
|
|
version: stringMatching(/\d+\.\d+/)
|
|
}
|
|
})
|
|
.matchHeaderSnapshot({
|
|
etag: anyEtag,
|
|
'content-length': anyContentLength
|
|
});
|
|
assert.equal(body.site.allow_external_signup, false);
|
|
});
|
|
|
|
it('Sets allow_external_signup to false when portal requires checkbox', async function () {
|
|
const {body: initialBody} = await membersAgent
|
|
.get('/api/site');
|
|
assert.equal(initialBody.site.allow_external_signup, true, 'This test requires the initial state to allow external signups');
|
|
|
|
await await models.Settings.edit({
|
|
key: 'portal_signup_checkbox_required',
|
|
value: true
|
|
}, {context: {internal: true}});
|
|
|
|
await await models.Settings.edit({
|
|
key: 'portal_signup_terms_html',
|
|
value: 'I agree to the terms and conditions'
|
|
}, {context: {internal: true}});
|
|
|
|
const {body} = await membersAgent
|
|
.get('/api/site')
|
|
.matchBodySnapshot({
|
|
site: {
|
|
version: stringMatching(/\d+\.\d+/)
|
|
}
|
|
})
|
|
.matchHeaderSnapshot({
|
|
etag: anyEtag,
|
|
'content-length': anyContentLength
|
|
});
|
|
assert.equal(body.site.allow_external_signup, false);
|
|
});
|
|
});
|