Files
2019-05-07 09:47:19 +02:00

41 lines
2.0 KiB
Python

from sqlalchemy import create_engine
from sqlalchemy.sql import text
import datetime
class TaskStatus:
"""Helper class to help manage Task's status in the SCDF DB. """
def __init__(self, task_id, jdbc_url):
self.task_id = task_id
self.engine = create_engine(jdbc_url)
self.connection = self.engine.connect()
def running(self):
"""Set the TASK_EXECUTION's START_TIME """
now = datetime.datetime.now()
start_task_statement = text(
"UPDATE TASK_EXECUTION SET START_TIME=:start_time, EXIT_CODE=null, LAST_UPDATED=:last_updated "
"WHERE TASK_EXECUTION_ID=:task_id")
self.connection.execute(start_task_statement, start_time=now, last_updated=now, task_id=self.task_id)
def completed(self):
"""Set the TASK_EXECUTION's END_TIME, EXIST_CODE=0 and EXIST_MESSAGE/ERROR_MESSAGE must be null """
now = datetime.datetime.now()
complete_task_statement = text(
"UPDATE TASK_EXECUTION SET END_TIME=:end_time, EXIT_CODE=0, EXIT_MESSAGE=null, ERROR_MESSAGE=null, "
"LAST_UPDATED=:last_updated WHERE TASK_EXECUTION_ID=:task_id")
self.connection.execute(complete_task_statement, end_time=now, last_updated=now, task_id=self.task_id)
def failed(self, exit_code, exit_message, error_message=''):
"""Set the TASK_EXECUTION's END_TIME, EXIST_CODE is the error code and EXIST_MESSAGE/ERROR_MESSAGE describe
the error """
now = datetime.datetime.now()
complete_task_statement = text(
"UPDATE TASK_EXECUTION SET END_TIME=:end_time, EXIT_CODE=:exit_code, EXIT_MESSAGE=:exit_message, "
" ERROR_MESSAGE=:error_message, LAST_UPDATED=:last_updated "
"WHERE TASK_EXECUTION_ID=:task_id")
self.connection.execute(complete_task_statement, end_time=now, exit_code=exit_code,
exit_message=exit_message, error_message=error_message, last_updated=now,
task_id=self.task_id)