2019-06-10 17:00:28 +00:00
|
|
|
from ....config import config
|
2019-07-06 19:58:01 +00:00
|
|
|
from ....backend_api.services import tasks
|
2019-06-10 17:00:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
class TaskStopReason(object):
|
|
|
|
stopped = "stopped"
|
|
|
|
reset = "reset"
|
|
|
|
status_changed = "status_changed"
|
|
|
|
|
|
|
|
|
|
|
|
class TaskStopSignal(object):
|
|
|
|
enabled = bool(config.get('development.support_stopping', False))
|
|
|
|
|
|
|
|
_number_of_consecutive_reset_tests = 4
|
|
|
|
|
2019-07-06 19:58:01 +00:00
|
|
|
# _unexpected_statuses = (
|
|
|
|
# tasks.TaskStatusEnum.closed,
|
|
|
|
# tasks.TaskStatusEnum.stopped,
|
|
|
|
# tasks.TaskStatusEnum.failed,
|
|
|
|
# tasks.TaskStatusEnum.published,
|
|
|
|
# tasks.TaskStatusEnum.completed,
|
|
|
|
# )
|
2019-06-10 17:00:28 +00:00
|
|
|
|
|
|
|
def __init__(self, task):
|
2019-07-06 19:58:01 +00:00
|
|
|
from ....backend_interface import Task
|
2019-06-10 17:00:28 +00:00
|
|
|
assert isinstance(task, Task)
|
|
|
|
self.task = task
|
|
|
|
self._task_reset_state_counter = 0
|
|
|
|
|
|
|
|
def test(self):
|
2019-07-08 20:27:53 +00:00
|
|
|
# noinspection PyBroadException
|
|
|
|
try:
|
2019-08-19 18:17:53 +00:00
|
|
|
status = str(self.task.status)
|
2019-07-08 20:27:53 +00:00
|
|
|
message = self.task.data.status_message
|
|
|
|
|
2019-08-19 18:17:53 +00:00
|
|
|
if status == str(tasks.TaskStatusEnum.in_progress) and "stopping" in message:
|
2019-07-08 20:27:53 +00:00
|
|
|
return TaskStopReason.stopped
|
|
|
|
|
|
|
|
_expected_statuses = (
|
2019-08-19 18:17:53 +00:00
|
|
|
str(tasks.TaskStatusEnum.created),
|
|
|
|
str(tasks.TaskStatusEnum.queued),
|
|
|
|
str(tasks.TaskStatusEnum.in_progress),
|
2019-07-08 20:27:53 +00:00
|
|
|
)
|
2019-07-06 19:58:01 +00:00
|
|
|
|
2019-07-08 20:27:53 +00:00
|
|
|
if status not in _expected_statuses and "worker" not in message:
|
|
|
|
return TaskStopReason.status_changed
|
2019-06-10 17:00:28 +00:00
|
|
|
|
2019-08-19 18:17:53 +00:00
|
|
|
if status == str(tasks.TaskStatusEnum.created):
|
2019-07-08 20:27:53 +00:00
|
|
|
self._task_reset_state_counter += 1
|
2019-06-10 17:00:28 +00:00
|
|
|
|
2019-07-08 20:27:53 +00:00
|
|
|
if self._task_reset_state_counter >= self._number_of_consecutive_reset_tests:
|
|
|
|
return TaskStopReason.reset
|
2019-06-10 17:00:28 +00:00
|
|
|
|
2019-09-23 15:40:13 +00:00
|
|
|
self.task.log.warning(
|
2019-07-08 20:27:53 +00:00
|
|
|
"Task {} was reset! if state is consistent we shall terminate.".format(self.task.id),
|
|
|
|
)
|
|
|
|
else:
|
|
|
|
self._task_reset_state_counter = 0
|
|
|
|
except Exception:
|
|
|
|
return None
|