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:
parent
42efa043d8
commit
666baf8d50
3 changed files with 15 additions and 25 deletions
|
@ -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,
|
||||||
|
|
|
@ -50,7 +50,7 @@ module.exports = () => {
|
||||||
i18n,
|
i18n,
|
||||||
logging,
|
logging,
|
||||||
request,
|
request,
|
||||||
ghostMailer
|
sendEmail: ghostMailer.send
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Add table
Reference in a new issue