Ensure that getMeta() returns an array in the scheduled task model [MAILPOET-2385]

This commit is contained in:
wxa
2019-09-30 07:59:00 +03:00
committed by Jack Kitterhing
parent ce645306a5
commit f598137f3b
2 changed files with 2 additions and 13 deletions

View File

@@ -36,7 +36,6 @@ abstract class SingleInstanceSimpleWorker extends SimpleWorker {
// If the task is running for too long consider it stuck and reschedule
if (!empty($task->updated_at) && $updated_at->diffInMinutes($current_time, false) > self::TASK_RUN_TIMEOUT) {
$this->ensureMetaIsArray($task);
$task->meta = array_merge($task->getMeta(), ['in_progress' => null]);
$this->reschedule($task, self::TIMED_OUT_TASK_RESCHEDULE_TIMEOUT);
return true;
@@ -49,23 +48,12 @@ abstract class SingleInstanceSimpleWorker extends SimpleWorker {
}
function startProgress(ScheduledTask $task) {
$this->ensureMetaIsArray($task);
$task->meta = array_merge($task->getMeta(), ['in_progress' => true]);
$task->save();
}
function stopProgress(ScheduledTask $task) {
$this->ensureMetaIsArray($task);
$task->meta = array_merge($task->getMeta(), ['in_progress' => null]);
$task->save();
}
private function ensureMetaIsArray(ScheduledTask $task) {
$meta = $task->getMeta();
if (empty($meta)) {
$task->meta = [];
} elseif (!is_array($meta)) {
$task->meta = (array)$meta;
}
}
}