mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-02-10 23:36:14 -05:00
Tested for updating email and adding existing members
This test is skipped on SQLite3 as there is an issue with transactions
This commit is contained in:
parent
104a0f5181
commit
a332e42476
2 changed files with 147 additions and 0 deletions
|
@ -102,6 +102,111 @@ Object {
|
||||||
}
|
}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
|
exports[`Newsletters API Can add a newsletter - with custom sender_email and subscribe existing members 1: [body] 1`] = `
|
||||||
|
Object {
|
||||||
|
"meta": Object {
|
||||||
|
"opted_in_member_count": 6,
|
||||||
|
"sent_email_verification": Array [
|
||||||
|
"sender_email",
|
||||||
|
],
|
||||||
|
},
|
||||||
|
"newsletters": Array [
|
||||||
|
Object {
|
||||||
|
"body_font_category": "serif",
|
||||||
|
"created_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/,
|
||||||
|
"description": null,
|
||||||
|
"footer_content": null,
|
||||||
|
"header_image": null,
|
||||||
|
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
|
||||||
|
"name": "My test newsletter with custom sender_email and subscribe existing",
|
||||||
|
"sender_email": null,
|
||||||
|
"sender_name": "Test",
|
||||||
|
"sender_reply_to": "newsletter",
|
||||||
|
"show_badge": true,
|
||||||
|
"show_feature_image": true,
|
||||||
|
"show_header_icon": true,
|
||||||
|
"show_header_name": true,
|
||||||
|
"show_header_title": true,
|
||||||
|
"slug": "my-test-newsletter-with-custom-sender_email-and-subscribe-existing",
|
||||||
|
"sort_order": 8,
|
||||||
|
"status": "active",
|
||||||
|
"subscribe_on_signup": true,
|
||||||
|
"title_alignment": "center",
|
||||||
|
"title_font_category": "serif",
|
||||||
|
"updated_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/,
|
||||||
|
"uuid": StringMatching /\\[a-f0-9\\]\\{8\\}-\\[a-f0-9\\]\\{4\\}-\\[a-f0-9\\]\\{4\\}-\\[a-f0-9\\]\\{4\\}-\\[a-f0-9\\]\\{12\\}/,
|
||||||
|
"visibility": "members",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
|
exports[`Newsletters API Can add a newsletter - with custom sender_email and subscribe existing members 2: [headers] 1`] = `
|
||||||
|
Object {
|
||||||
|
"access-control-allow-origin": "http://127.0.0.1:2369",
|
||||||
|
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
|
||||||
|
"content-length": "826",
|
||||||
|
"content-type": "application/json; charset=utf-8",
|
||||||
|
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
|
||||||
|
"location": StringMatching /https\\?:\\\\/\\\\/\\.\\*\\?\\\\/newsletters\\\\/\\[a-f0-9\\]\\{24\\}\\\\//,
|
||||||
|
"vary": "Origin, Accept-Encoding",
|
||||||
|
"x-cache-invalidate": "/*",
|
||||||
|
"x-powered-by": "Express",
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
|
exports[`Newsletters API Can add a newsletter - with custom sender_email and subscribe exsiting members 1: [body] 1`] = `
|
||||||
|
Object {
|
||||||
|
"meta": Object {
|
||||||
|
"opted_in_member_count": 6,
|
||||||
|
"sent_email_verification": Array [
|
||||||
|
"sender_email",
|
||||||
|
],
|
||||||
|
},
|
||||||
|
"newsletters": Array [
|
||||||
|
Object {
|
||||||
|
"body_font_category": "serif",
|
||||||
|
"created_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/,
|
||||||
|
"description": null,
|
||||||
|
"footer_content": null,
|
||||||
|
"header_image": null,
|
||||||
|
"id": StringMatching /\\[a-f0-9\\]\\{24\\}/,
|
||||||
|
"name": "My test newsletter with custom sender_email and subscribe existing",
|
||||||
|
"sender_email": null,
|
||||||
|
"sender_name": "Test",
|
||||||
|
"sender_reply_to": "newsletter",
|
||||||
|
"show_badge": true,
|
||||||
|
"show_feature_image": true,
|
||||||
|
"show_header_icon": true,
|
||||||
|
"show_header_name": true,
|
||||||
|
"show_header_title": true,
|
||||||
|
"slug": "my-test-newsletter-with-custom-sender_email-and-subscribe-existing",
|
||||||
|
"sort_order": 6,
|
||||||
|
"status": "active",
|
||||||
|
"subscribe_on_signup": true,
|
||||||
|
"title_alignment": "center",
|
||||||
|
"title_font_category": "serif",
|
||||||
|
"updated_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/,
|
||||||
|
"visibility": "members",
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
|
exports[`Newsletters API Can add a newsletter - with custom sender_email and subscribe exsiting members 2: [headers] 1`] = `
|
||||||
|
Object {
|
||||||
|
"access-control-allow-origin": "http://127.0.0.1:2369",
|
||||||
|
"cache-control": "no-cache, private, no-store, must-revalidate, max-stale=0, post-check=0, pre-check=0",
|
||||||
|
"content-length": "780",
|
||||||
|
"content-type": "application/json; charset=utf-8",
|
||||||
|
"etag": StringMatching /\\(\\?:W\\\\/\\)\\?"\\(\\?:\\[ !#-\\\\x7E\\\\x80-\\\\xFF\\]\\*\\|\\\\r\\\\n\\[\\\\t \\]\\|\\\\\\\\\\.\\)\\*"/,
|
||||||
|
"location": StringMatching /https\\?:\\\\/\\\\/\\.\\*\\?\\\\/newsletters\\\\/\\[a-f0-9\\]\\{24\\}\\\\//,
|
||||||
|
"vary": "Origin, Accept-Encoding",
|
||||||
|
"x-cache-invalidate": "/*",
|
||||||
|
"x-powered-by": "Express",
|
||||||
|
}
|
||||||
|
`;
|
||||||
|
|
||||||
exports[`Newsletters API Can add a newsletter 1: [body] 1`] = `
|
exports[`Newsletters API Can add a newsletter 1: [body] 1`] = `
|
||||||
Object {
|
Object {
|
||||||
"newsletters": Array [
|
"newsletters": Array [
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
const DatabaseInfo = require('@tryghost/database-info');
|
||||||
const {agentProvider, mockManager, fixtureManager, matchers} = require('../../utils/e2e-framework');
|
const {agentProvider, mockManager, fixtureManager, matchers} = require('../../utils/e2e-framework');
|
||||||
const {anyEtag, anyObjectId, anyUuid, anyISODateTime, anyLocationFor} = matchers;
|
const {anyEtag, anyObjectId, anyUuid, anyISODateTime, anyLocationFor} = matchers;
|
||||||
const configUtils = require('../../utils/configUtils');
|
const configUtils = require('../../utils/configUtils');
|
||||||
|
@ -329,4 +330,45 @@ describe('Newsletters API', function () {
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('Can add a newsletter - with custom sender_email and subscribe existing members', async function () {
|
||||||
|
const db = require('../../../core/server/data/db');
|
||||||
|
if (DatabaseInfo.isSQLite(db.knex)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const newsletter = {
|
||||||
|
name: 'My test newsletter with custom sender_email and subscribe existing',
|
||||||
|
sender_name: 'Test',
|
||||||
|
sender_email: 'test@example.com',
|
||||||
|
sender_reply_to: 'newsletter',
|
||||||
|
status: 'active',
|
||||||
|
subscribe_on_signup: true,
|
||||||
|
title_font_category: 'serif',
|
||||||
|
body_font_category: 'serif',
|
||||||
|
show_header_icon: true,
|
||||||
|
show_header_title: true,
|
||||||
|
show_badge: true,
|
||||||
|
sort_order: 0
|
||||||
|
};
|
||||||
|
|
||||||
|
await agent
|
||||||
|
.post(`newsletters/?opt_in_existing=true`)
|
||||||
|
.body({newsletters: [newsletter]})
|
||||||
|
.expectStatus(201)
|
||||||
|
.matchBodySnapshot({
|
||||||
|
newsletters: [newsletterSnapshot],
|
||||||
|
meta: {
|
||||||
|
sent_email_verification: ['sender_email']
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.matchHeaderSnapshot({
|
||||||
|
etag: anyEtag,
|
||||||
|
location: anyLocationFor('newsletters')
|
||||||
|
});
|
||||||
|
|
||||||
|
mockManager.assert.sentEmail({
|
||||||
|
subject: 'Verify email address',
|
||||||
|
to: 'test@example.com'
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Add table
Reference in a new issue