0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-06 22:40:14 -05:00

post-scheduling: HTTP 503 retry logic for default adapter

This commit is contained in:
kirrg001 2016-06-14 16:08:49 +02:00
parent fe5e0eed48
commit a3cd43909b
2 changed files with 58 additions and 3 deletions

View file

@ -13,6 +13,7 @@ function SchedulingDefault(options) {
this.runTimeoutInMs = 1000 * 60 * 5;
this.offsetInMinutes = 10;
this.beforePingInMs = -50;
this.retryTimeoutInMs = 1000 * 5;
this.allJobs = {};
this.deletedJobs = {};
@ -158,14 +159,16 @@ SchedulingDefault.prototype._execute = function (jobs) {
};
/**
* if we detect to publish a post in the past (case blog is down)
* we add a force flag
* - if we detect to publish a post in the past (case blog is down), we add a force flag
*/
SchedulingDefault.prototype._pingUrl = function (object) {
var url = object.url,
time = object.time,
httpMethod = object.extra.httpMethod,
req = request[httpMethod.toLowerCase()](url);
tries = object.tries || 0,
maxTries = 30,
req = request[httpMethod.toLowerCase()](url),
self = this, timeout;
if (moment(time).isBefore(moment())) {
if (httpMethod === 'GET') {
@ -184,6 +187,16 @@ SchedulingDefault.prototype._pingUrl = function (object) {
return;
}
// CASE: blog is in maintenance mode, retry
if (response && response.status === 503 && tries < maxTries) {
timeout = setTimeout(function pingAgain() {
clearTimeout(timeout);
object.tries = tries + 1;
self._pingUrl(object);
}, self.retryTimeoutInMs);
}
errors.logError(err);
}
});

View file

@ -282,5 +282,47 @@ describe('Scheduling Default Adapter', function () {
setTimeout(retry, 100);
})();
});
it('pingUrl, but blog returns 503', function (done) {
var app = express(),
server = http.createServer(app),
returned500Count = 0,
returned200 = false,
reqBody;
scope.adapter.retryTimeoutInMs = 200;
app.use(bodyParser.json());
app.put('/ping', function (req, res) {
reqBody = req.body;
if (returned500Count === 5) {
returned200 = true;
return res.sendStatus(200);
}
returned500Count = returned500Count + 1;
res.sendStatus(503);
});
server.listen(1111);
scope.adapter._pingUrl({
url: 'http://localhost:1111/ping',
time: moment().valueOf(),
extra: {
httpMethod: 'PUT'
}
});
(function retry() {
if (returned200) {
should.exist(reqBody.force);
return server.close(done);
}
setTimeout(retry, 100);
})();
});
});
});