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

Removed GhostMailer parameter from UpdateCheckService

refs https://github.com/TryGhost/Team/issues/728

- This is continuation of the previous commit. TLDR: Passing only the necessary parameter data makes it easier to reason about what dependencies the UpdateCheckService has to deal with
- Instead of passing in a whole GhostMailer instance passing only an email sending function, which again - makes things way more manageable to reason about
- The end of refactor, next will be a move of the UpdateCheckService into a separate module in tryghost/core
This commit is contained in:
Naz 2021-06-02 15:18:32 +04:00
parent 42efa043d8
commit 666baf8d50
3 changed files with 15 additions and 25 deletions

View file

@ -40,14 +40,15 @@ class UpdateCheckService {
* @param {boolean} [options.config.forceUpdate] * @param {boolean} [options.config.forceUpdate]
* @param {string} options.config.ghostVersion - Ghost instance version * @param {string} options.config.ghostVersion - Ghost instance version
* @param {Function} options.request - a HTTP request proxy function * @param {Function} options.request - a HTTP request proxy function
* @param {Function} options.sendEmail - function handling sending an email
*/ */
constructor({api, config, i18n, logging, request, ghostMailer}) { constructor({api, config, i18n, logging, request, sendEmail}) {
this.api = api; this.api = api;
this.config = config; this.config = config;
this.i18n = i18n; this.i18n = i18n;
this.logging = logging; this.logging = logging;
this.request = request; this.request = request;
this.ghostMailer = ghostMailer; this.sendEmail = sendEmail;
} }
nextCheckTimestamp() { nextCheckTimestamp() {
@ -311,7 +312,7 @@ class UpdateCheckService {
if (toAdd.type === 'alert') { if (toAdd.type === 'alert') {
for (const email of adminEmails) { for (const email of adminEmails) {
try { try {
this.ghostMailer.send({ this.sendEmail({
to: email, to: email,
subject: `Action required: Critical alert from Ghost instance ${siteUrl}`, subject: `Action required: Critical alert from Ghost instance ${siteUrl}`,
html: toAdd.message, html: toAdd.message,

View file

@ -50,7 +50,7 @@ module.exports = () => {
i18n, i18n,
logging, logging,
request, request,
ghostMailer sendEmail: ghostMailer.send
}); });
} }

View file

@ -65,10 +65,7 @@ describe('Update Check', function () {
}, },
i18n: i18nStub, i18n: i18nStub,
logging: loggingStub, logging: loggingStub,
request: requestStub, request: requestStub
ghostMailer: {
send: sinon.stub().resolves()
}
}); });
await updateCheckService.check(); await updateCheckService.check();
@ -129,10 +126,7 @@ describe('Update Check', function () {
}, },
i18n: i18nStub, i18n: i18nStub,
logging: loggingStub, logging: loggingStub,
request: requestStub, request: requestStub
ghostMailer: {
send: sinon.stub().resolves()
}
}); });
await updateCheckService.check(); await updateCheckService.check();
@ -254,10 +248,7 @@ describe('Update Check', function () {
body: { body: {
notifications: [notification] notifications: [notification]
} }
}), })
ghostMailer: {
send: sinon.stub().resolves()
}
}); });
await updateCheckService.check(); await updateCheckService.check();
@ -287,9 +278,7 @@ describe('Update Check', function () {
}; };
const notificationsAPIAddStub = sinon.stub().resolves(); const notificationsAPIAddStub = sinon.stub().resolves();
const mailServiceStub = { const sendEmailStub = sinon.stub().resolves();
send: sinon.stub().resolves()
};
const updateCheckService = new UpdateCheckService({ const updateCheckService = new UpdateCheckService({
api: { api: {
@ -322,16 +311,16 @@ describe('Update Check', function () {
request: sinon.stub().resolves({ request: sinon.stub().resolves({
body: [notification] body: [notification]
}), }),
ghostMailer: mailServiceStub sendEmail: sendEmailStub
}); });
await updateCheckService.check(); await updateCheckService.check();
mailServiceStub.send.called.should.be.true(); sendEmailStub.called.should.be.true();
mailServiceStub.send.args[0][0].to.should.equal('jbloggs@example.com'); sendEmailStub.args[0][0].to.should.equal('jbloggs@example.com');
mailServiceStub.send.args[0][0].subject.should.equal('Action required: Critical alert from Ghost instance http://127.0.0.1:2369'); sendEmailStub.args[0][0].subject.should.equal('Action required: Critical alert from Ghost instance http://127.0.0.1:2369');
mailServiceStub.send.args[0][0].html.should.equal('<p>Critical message. Upgrade your site!</p>'); sendEmailStub.args[0][0].html.should.equal('<p>Critical message. Upgrade your site!</p>');
mailServiceStub.send.args[0][0].forceTextContent.should.equal(true); sendEmailStub.args[0][0].forceTextContent.should.equal(true);
notificationsAPIAddStub.calledOnce.should.equal(true); notificationsAPIAddStub.calledOnce.should.equal(true);
notificationsAPIAddStub.args[0][0].notifications.length.should.equal(1); notificationsAPIAddStub.args[0][0].notifications.length.should.equal(1);