Fix REST API dangling transactions

Make all DB API public function session aware

Change-Id: I2dcba176fa016076372c4dde22cc70986daddc2b
Closes-Bug: #1640469
This commit is contained in:
Xavier Hardy 2016-11-10 17:18:36 +01:00 committed by Renat Akhmerov
parent f1071f5908
commit c70779041d
35 changed files with 1587 additions and 1084 deletions

View File

@ -169,7 +169,7 @@ def _paginate_query(model, limit=None, marker=None, sort_keys=None,
return query return query
def _delete_all(model, session=None, **kwargs): def _delete_all(model, **kwargs):
# NOTE(kong): Because we use 'in_' operator in _secure_query(), delete() # NOTE(kong): Because we use 'in_' operator in _secure_query(), delete()
# method will raise error with default parameter. Please refer to # method will raise error with default parameter. Please refer to
# http://docs.sqlalchemy.org/en/rel_1_0/orm/query.html#sqlalchemy.orm.query.Query.delete # http://docs.sqlalchemy.org/en/rel_1_0/orm/query.html#sqlalchemy.orm.query.Query.delete
@ -323,7 +323,8 @@ def insert_or_ignore(model_cls, values, session=None):
# Workbook definitions. # Workbook definitions.
def get_workbook(name): @b.session_aware()
def get_workbook(name, session=None):
wb = _get_db_object_by_name(models.Workbook, name) wb = _get_db_object_by_name(models.Workbook, name)
if not wb: if not wb:
@ -334,11 +335,13 @@ def get_workbook(name):
return wb return wb
def load_workbook(name): @b.session_aware()
def load_workbook(name, session=None):
return _get_db_object_by_name(models.Workbook, name) return _get_db_object_by_name(models.Workbook, name)
def get_workbooks(**kwargs): @b.session_aware()
def get_workbooks(session=None, **kwargs):
return _get_collection_sorted_by_name(models.Workbook, **kwargs) return _get_collection_sorted_by_name(models.Workbook, **kwargs)
@ -383,13 +386,14 @@ def delete_workbook(name, session=None):
@b.session_aware() @b.session_aware()
def delete_workbooks(**kwargs): def delete_workbooks(session=None, **kwargs):
return _delete_all(models.Workbook, **kwargs) return _delete_all(models.Workbook, **kwargs)
# Workflow definitions. # Workflow definitions.
def get_workflow_definition(identifier): @b.session_aware()
def get_workflow_definition(identifier, session=None):
"""Gets workflow definition by name or uuid. """Gets workflow definition by name or uuid.
:param identifier: Identifier could be in the format of plain string or :param identifier: Identifier could be in the format of plain string or
@ -409,7 +413,8 @@ def get_workflow_definition(identifier):
return wf_def return wf_def
def get_workflow_definition_by_id(id): @b.session_aware()
def get_workflow_definition_by_id(id, session=None):
wf_def = _get_db_object_by_id(models.WorkflowDefinition, id) wf_def = _get_db_object_by_id(models.WorkflowDefinition, id)
if not wf_def: if not wf_def:
@ -420,11 +425,14 @@ def get_workflow_definition_by_id(id):
return wf_def return wf_def
def load_workflow_definition(name): @b.session_aware()
def load_workflow_definition(name, session=None):
return _get_db_object_by_name(models.WorkflowDefinition, name) return _get_db_object_by_name(models.WorkflowDefinition, name)
def get_workflow_definitions(sort_keys=['created_at'], fields=None, **kwargs): @b.session_aware()
def get_workflow_definitions(sort_keys=['created_at'], fields=None,
session=None, **kwargs):
if fields and 'input' in fields: if fields and 'input' in fields:
fields.remove('input') fields.remove('input')
fields.append('spec') fields.append('spec')
@ -544,13 +552,14 @@ def delete_workflow_definition(identifier, session=None):
@b.session_aware() @b.session_aware()
def delete_workflow_definitions(**kwargs): def delete_workflow_definitions(session=None, **kwargs):
return _delete_all(models.WorkflowDefinition, **kwargs) return _delete_all(models.WorkflowDefinition, **kwargs)
# Action definitions. # Action definitions.
def get_action_definition_by_id(id): @b.session_aware()
def get_action_definition_by_id(id, session=None):
action_def = _get_db_object_by_id(models.ActionDefinition, id) action_def = _get_db_object_by_id(models.ActionDefinition, id)
if not action_def: if not action_def:
@ -561,7 +570,8 @@ def get_action_definition_by_id(id):
return action_def return action_def
def get_action_definition(identifier): @b.session_aware()
def get_action_definition(identifier, session=None):
a_def = _get_db_object_by_name_or_id( a_def = _get_db_object_by_name_or_id(
models.ActionDefinition, models.ActionDefinition,
identifier identifier
@ -575,11 +585,13 @@ def get_action_definition(identifier):
return a_def return a_def
def load_action_definition(name): @b.session_aware()
def load_action_definition(name, session=None):
return _get_db_object_by_name(models.ActionDefinition, name) return _get_db_object_by_name(models.ActionDefinition, name)
def get_action_definitions(**kwargs): @b.session_aware()
def get_action_definitions(session=None, **kwargs):
return _get_collection_sorted_by_name( return _get_collection_sorted_by_name(
model=models.ActionDefinition, model=models.ActionDefinition,
**kwargs **kwargs
@ -627,13 +639,14 @@ def delete_action_definition(identifier, session=None):
@b.session_aware() @b.session_aware()
def delete_action_definitions(**kwargs): def delete_action_definitions(session=None, **kwargs):
return _delete_all(models.ActionDefinition, **kwargs) return _delete_all(models.ActionDefinition, **kwargs)
# Action executions. # Action executions.
def get_action_execution(id): @b.session_aware()
def get_action_execution(id, session=None):
a_ex = _get_db_object_by_id(models.ActionExecution, id) a_ex = _get_db_object_by_id(models.ActionExecution, id)
if not a_ex: if not a_ex:
@ -644,15 +657,18 @@ def get_action_execution(id):
return a_ex return a_ex
def load_action_execution(id): @b.session_aware()
def load_action_execution(id, session=None):
return _get_db_object_by_id(models.ActionExecution, id) return _get_db_object_by_id(models.ActionExecution, id)
def ensure_action_execution_exists(id): @b.session_aware()
def ensure_action_execution_exists(id, session=None):
get_action_execution(id) get_action_execution(id)
def get_action_executions(**kwargs): @b.session_aware()
def get_action_executions(session=None, **kwargs):
return _get_action_executions(**kwargs) return _get_action_executions(**kwargs)
@ -697,7 +713,7 @@ def delete_action_execution(id, session=None):
@b.session_aware() @b.session_aware()
def delete_action_executions(**kwargs): def delete_action_executions(session=None, **kwargs):
return _delete_all(models.ActionExecution, **kwargs) return _delete_all(models.ActionExecution, **kwargs)
@ -707,7 +723,8 @@ def _get_action_executions(**kwargs):
# Workflow executions. # Workflow executions.
def get_workflow_execution(id): @b.session_aware()
def get_workflow_execution(id, session=None):
wf_ex = _get_db_object_by_id(models.WorkflowExecution, id) wf_ex = _get_db_object_by_id(models.WorkflowExecution, id)
if not wf_ex: if not wf_ex:
@ -718,15 +735,18 @@ def get_workflow_execution(id):
return wf_ex return wf_ex
def load_workflow_execution(id): @b.session_aware()
def load_workflow_execution(id, session=None):
return _get_db_object_by_id(models.WorkflowExecution, id) return _get_db_object_by_id(models.WorkflowExecution, id)
def ensure_workflow_execution_exists(id): @b.session_aware()
def ensure_workflow_execution_exists(id, session=None):
get_workflow_execution(id) get_workflow_execution(id)
def get_workflow_executions(**kwargs): @b.session_aware()
def get_workflow_executions(session=None, **kwargs):
return _get_collection_sorted_by_time( return _get_collection_sorted_by_time(
models.WorkflowExecution, models.WorkflowExecution,
**kwargs **kwargs
@ -774,13 +794,14 @@ def delete_workflow_execution(id, session=None):
@b.session_aware() @b.session_aware()
def delete_workflow_executions(**kwargs): def delete_workflow_executions(session=None, **kwargs):
return _delete_all(models.WorkflowExecution, **kwargs) return _delete_all(models.WorkflowExecution, **kwargs)
# Tasks executions. # Tasks executions.
def get_task_execution(id): @b.session_aware()
def get_task_execution(id, session=None):
task_ex = _get_db_object_by_id(models.TaskExecution, id) task_ex = _get_db_object_by_id(models.TaskExecution, id)
if not task_ex: if not task_ex:
@ -791,11 +812,13 @@ def get_task_execution(id):
return task_ex return task_ex
def load_task_execution(id): @b.session_aware()
def load_task_execution(id, session=None):
return _get_db_object_by_id(models.TaskExecution, id) return _get_db_object_by_id(models.TaskExecution, id)
def get_task_executions(**kwargs): @b.session_aware()
def get_task_executions(session=None, **kwargs):
return _get_task_executions(**kwargs) return _get_task_executions(**kwargs)
@ -815,7 +838,8 @@ def _get_completed_task_executions_query(kwargs):
return query return query
def get_completed_task_executions(**kwargs): @b.session_aware()
def get_completed_task_executions(session=None, **kwargs):
query = _get_completed_task_executions_query(kwargs) query = _get_completed_task_executions_query(kwargs)
return query.all() return query.all()
@ -838,13 +862,15 @@ def _get_incomplete_task_executions_query(kwargs):
return query return query
def get_incomplete_task_executions(**kwargs): @b.session_aware()
def get_incomplete_task_executions(session=None, **kwargs):
query = _get_incomplete_task_executions_query(kwargs) query = _get_incomplete_task_executions_query(kwargs)
return query.all() return query.all()
def get_incomplete_task_executions_count(**kwargs): @b.session_aware()
def get_incomplete_task_executions_count(session=None, **kwargs):
query = _get_incomplete_task_executions_query(kwargs) query = _get_incomplete_task_executions_query(kwargs)
return query.count() return query.count()
@ -891,7 +917,7 @@ def delete_task_execution(id, session=None):
@b.session_aware() @b.session_aware()
def delete_task_executions(**kwargs): def delete_task_executions(session=None, **kwargs):
return _delete_all(models.TaskExecution, **kwargs) return _delete_all(models.TaskExecution, **kwargs)
@ -973,7 +999,8 @@ def get_delayed_call(id, session=None):
return delayed_call return delayed_call
def get_delayed_calls(**kwargs): @b.session_aware()
def get_delayed_calls(session=None, **kwargs):
return _get_collection( return _get_collection(
model=models.DelayedCall, model=models.DelayedCall,
**kwargs **kwargs
@ -981,7 +1008,7 @@ def get_delayed_calls(**kwargs):
@b.session_aware() @b.session_aware()
def delete_delayed_calls(**kwargs): def delete_delayed_calls(session=None, **kwargs):
return _delete_all(models.DelayedCall, **kwargs) return _delete_all(models.DelayedCall, **kwargs)
@ -1006,7 +1033,8 @@ def get_expired_executions(time, session=None):
# Cron triggers. # Cron triggers.
def get_cron_trigger(name): @b.session_aware()
def get_cron_trigger(name, session=None):
cron_trigger = _get_db_object_by_name(models.CronTrigger, name) cron_trigger = _get_db_object_by_name(models.CronTrigger, name)
if not cron_trigger: if not cron_trigger:
@ -1017,11 +1045,13 @@ def get_cron_trigger(name):
return cron_trigger return cron_trigger
def load_cron_trigger(name): @b.session_aware()
def load_cron_trigger(name, session=None):
return _get_db_object_by_name(models.CronTrigger, name) return _get_db_object_by_name(models.CronTrigger, name)
def get_cron_triggers(insecure=False, **kwargs): @b.session_aware()
def get_cron_triggers(insecure=False, session=None, **kwargs):
return _get_collection_sorted_by_name( return _get_collection_sorted_by_name(
models.CronTrigger, models.CronTrigger,
insecure=insecure, insecure=insecure,
@ -1120,13 +1150,14 @@ def delete_cron_trigger(name, session=None):
@b.session_aware() @b.session_aware()
def delete_cron_triggers(**kwargs): def delete_cron_triggers(session=None, **kwargs):
return _delete_all(models.CronTrigger, **kwargs) return _delete_all(models.CronTrigger, **kwargs)
# Environments. # Environments.
def get_environment(name): @b.session_aware()
def get_environment(name, session=None):
env = _get_db_object_by_name(models.Environment, name) env = _get_db_object_by_name(models.Environment, name)
if not env: if not env:
@ -1137,11 +1168,13 @@ def get_environment(name):
return env return env
def load_environment(name): @b.session_aware()
def load_environment(name, session=None):
return _get_db_object_by_name(models.Environment, name) return _get_db_object_by_name(models.Environment, name)
def get_environments(**kwargs): @b.session_aware()
def get_environments(session=None, **kwargs):
return _get_collection_sorted_by_name(models.Environment, **kwargs) return _get_collection_sorted_by_name(models.Environment, **kwargs)
@ -1188,7 +1221,7 @@ def delete_environment(name, session=None):
@b.session_aware() @b.session_aware()
def delete_environments(**kwargs): def delete_environments(session=None, **kwargs):
return _delete_all(models.Environment, **kwargs) return _delete_all(models.Environment, **kwargs)
@ -1245,7 +1278,8 @@ def create_resource_member(values, session=None):
return res_member return res_member
def get_resource_member(resource_id, res_type, member_id): @b.session_aware()
def get_resource_member(resource_id, res_type, member_id, session=None):
query = _secure_query(models.ResourceMember).filter_by( query = _secure_query(models.ResourceMember).filter_by(
resource_type=res_type resource_type=res_type
) )
@ -1267,7 +1301,8 @@ def get_resource_member(resource_id, res_type, member_id):
return res_member return res_member
def get_resource_members(resource_id, res_type): @b.session_aware()
def get_resource_members(resource_id, res_type, session=None):
query = _secure_query(models.ResourceMember).filter_by( query = _secure_query(models.ResourceMember).filter_by(
resource_type=res_type resource_type=res_type
) )
@ -1334,7 +1369,7 @@ def delete_resource_member(resource_id, res_type, member_id, session=None):
@b.session_aware() @b.session_aware()
def delete_resource_members(**kwargs): def delete_resource_members(session=None, **kwargs):
return _delete_all(models.ResourceMember, **kwargs) return _delete_all(models.ResourceMember, **kwargs)
@ -1352,7 +1387,8 @@ def _get_accepted_resources(res_type):
# Event triggers. # Event triggers.
def get_event_trigger(id, insecure=False): @b.session_aware()
def get_event_trigger(id, insecure=False, session=None):
event_trigger = _get_event_trigger(id, insecure) event_trigger = _get_event_trigger(id, insecure)
if not event_trigger: if not event_trigger:
@ -1363,7 +1399,8 @@ def get_event_trigger(id, insecure=False):
return event_trigger return event_trigger
def get_event_triggers(insecure=False, **kwargs): @b.session_aware()
def get_event_triggers(insecure=False, session=None, **kwargs):
return _get_collection_sorted_by_time( return _get_collection_sorted_by_time(
model=models.EventTrigger, model=models.EventTrigger,
insecure=insecure, insecure=insecure,
@ -1411,7 +1448,7 @@ def delete_event_trigger(id, session=None):
@b.session_aware() @b.session_aware()
def delete_event_triggers(**kwargs): def delete_event_triggers(session=None, **kwargs):
return _delete_all(models.EventTrigger, **kwargs) return _delete_all(models.EventTrigger, **kwargs)
@ -1422,7 +1459,8 @@ def _get_event_trigger(id, insecure=False):
return _get_db_object_by_id(models.EventTrigger, id) return _get_db_object_by_id(models.EventTrigger, id)
def ensure_event_trigger_exists(id): @b.session_aware()
def ensure_event_trigger_exists(id, session=None):
get_event_trigger(id) get_event_trigger(id)
@ -1447,7 +1485,8 @@ def create_named_lock(name, session=None):
return lock_id return lock_id
def get_named_locks(**kwargs): @b.session_aware()
def get_named_locks(session=None, **kwargs):
return _get_collection(models.NamedLock, **kwargs) return _get_collection(models.NamedLock, **kwargs)

View File

@ -412,10 +412,13 @@ def _get_environment(params):
def _send_result_to_parent_workflow(wf_ex_id): def _send_result_to_parent_workflow(wf_ex_id):
wf_ex = db_api.get_workflow_execution(wf_ex_id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex_id)
wf_output = wf_ex.output
if wf_ex.state == states.SUCCESS: if wf_ex.state == states.SUCCESS:
result = wf_utils.Result(data=wf_ex.output) result = wf_utils.Result(data=wf_output)
elif wf_ex.state == states.ERROR: elif wf_ex.state == states.ERROR:
err_msg = ( err_msg = (
wf_ex.state_info or wf_ex.state_info or

View File

@ -1175,15 +1175,16 @@ ACTION_EXECS = [
class ActionExecutionTest(SQLAlchemyTest): class ActionExecutionTest(SQLAlchemyTest):
def test_create_and_get_and_load_action_execution(self): def test_create_and_get_and_load_action_execution(self):
created = db_api.create_action_execution(ACTION_EXECS[0]) with db_api.transaction():
created = db_api.create_action_execution(ACTION_EXECS[0])
fetched = db_api.get_action_execution(created.id) fetched = db_api.get_action_execution(created.id)
self.assertEqual(created, fetched) self.assertEqual(created, fetched)
fetched = db_api.load_action_execution(created.id) fetched = db_api.load_action_execution(created.id)
self.assertEqual(created, fetched) self.assertEqual(created, fetched)
self.assertIsNone(db_api.load_action_execution("not-existing-id")) self.assertIsNone(db_api.load_action_execution("not-existing-id"))
@ -1236,22 +1237,24 @@ class ActionExecutionTest(SQLAlchemyTest):
self.assertEqual(updated, fetched) self.assertEqual(updated, fetched)
def test_get_action_executions(self): def test_get_action_executions(self):
created0 = db_api.create_action_execution(WF_EXECS[0]) with db_api.transaction():
db_api.create_action_execution(ACTION_EXECS[1]) created0 = db_api.create_action_execution(WF_EXECS[0])
db_api.create_action_execution(ACTION_EXECS[1])
fetched = db_api.get_action_executions( fetched = db_api.get_action_executions(
state=WF_EXECS[0]['state'] state=WF_EXECS[0]['state']
) )
self.assertEqual(1, len(fetched)) self.assertEqual(1, len(fetched))
self.assertEqual(created0, fetched[0]) self.assertEqual(created0, fetched[0])
def test_delete_action_execution(self): def test_delete_action_execution(self):
created = db_api.create_action_execution(ACTION_EXECS[0]) with db_api.transaction():
created = db_api.create_action_execution(ACTION_EXECS[0])
fetched = db_api.get_action_execution(created.id) fetched = db_api.get_action_execution(created.id)
self.assertEqual(created, fetched) self.assertEqual(created, fetched)
db_api.delete_action_execution(created.id) db_api.delete_action_execution(created.id)
@ -1331,17 +1334,20 @@ WF_EXECS = [
class WorkflowExecutionTest(SQLAlchemyTest): class WorkflowExecutionTest(SQLAlchemyTest):
def test_create_and_get_and_load_workflow_execution(self): def test_create_and_get_and_load_workflow_execution(self):
created = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created = db_api.create_workflow_execution(WF_EXECS[0])
fetched = db_api.get_workflow_execution(created.id) fetched = db_api.get_workflow_execution(created.id)
self.assertEqual(created, fetched) self.assertEqual(created, fetched)
fetched = db_api.load_workflow_execution(created.id) fetched = db_api.load_workflow_execution(created.id)
self.assertEqual(created, fetched) self.assertEqual(created, fetched)
self.assertIsNone(db_api.load_workflow_execution("not-existing-id")) self.assertIsNone(
db_api.load_workflow_execution("not-existing-id")
)
def test_update_workflow_execution(self): def test_update_workflow_execution(self):
with db_api.transaction(): with db_api.transaction():
@ -1395,157 +1401,168 @@ class WorkflowExecutionTest(SQLAlchemyTest):
self.assertEqual(updated, fetched) self.assertEqual(updated, fetched)
def test_get_workflow_executions(self): def test_get_workflow_executions(self):
created0 = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
db_api.create_workflow_execution(WF_EXECS[1]) created0 = db_api.create_workflow_execution(WF_EXECS[0])
db_api.create_workflow_execution(WF_EXECS[1])
fetched = db_api.get_workflow_executions( fetched = db_api.get_workflow_executions(
state=WF_EXECS[0]['state'] state=WF_EXECS[0]['state']
) )
self.assertEqual(1, len(fetched)) self.assertEqual(1, len(fetched))
self.assertEqual(created0, fetched[0]) self.assertEqual(created0, fetched[0])
def test_filter_workflow_execution_by_equal_value(self): def test_filter_workflow_execution_by_equal_value(self):
db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created = db_api.create_workflow_execution(WF_EXECS[1]) db_api.create_workflow_execution(WF_EXECS[0])
created = db_api.create_workflow_execution(WF_EXECS[1])
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'id', 'id',
created.id, created.id,
'eq' 'eq'
) )
fetched = db_api.get_workflow_executions(**_filter) fetched = db_api.get_workflow_executions(**_filter)
self.assertEqual(1, len(fetched)) self.assertEqual(1, len(fetched))
self.assertEqual(created, fetched[0]) self.assertEqual(created, fetched[0])
def test_filter_workflow_execution_by_not_equal_value(self): def test_filter_workflow_execution_by_not_equal_value(self):
created0 = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created1 = db_api.create_workflow_execution(WF_EXECS[1]) created0 = db_api.create_workflow_execution(WF_EXECS[0])
created1 = db_api.create_workflow_execution(WF_EXECS[1])
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'id', 'id',
created0.id, created0.id,
'neq' 'neq'
) )
fetched = db_api.get_workflow_executions(**_filter) fetched = db_api.get_workflow_executions(**_filter)
self.assertEqual(1, len(fetched)) self.assertEqual(1, len(fetched))
self.assertEqual(created1, fetched[0]) self.assertEqual(created1, fetched[0])
def test_filter_workflow_execution_by_greater_than_value(self): def test_filter_workflow_execution_by_greater_than_value(self):
created0 = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created1 = db_api.create_workflow_execution(WF_EXECS[1]) created0 = db_api.create_workflow_execution(WF_EXECS[0])
created1 = db_api.create_workflow_execution(WF_EXECS[1])
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'created_at', 'created_at',
created0['created_at'], created0['created_at'],
'gt' 'gt'
) )
fetched = db_api.get_workflow_executions(**_filter) fetched = db_api.get_workflow_executions(**_filter)
self.assertEqual(1, len(fetched)) self.assertEqual(1, len(fetched))
self.assertEqual(created1, fetched[0]) self.assertEqual(created1, fetched[0])
def test_filter_workflow_execution_by_greater_than_equal_value(self): def test_filter_workflow_execution_by_greater_than_equal_value(self):
created0 = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created1 = db_api.create_workflow_execution(WF_EXECS[1]) created0 = db_api.create_workflow_execution(WF_EXECS[0])
created1 = db_api.create_workflow_execution(WF_EXECS[1])
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'created_at', 'created_at',
created0['created_at'], created0['created_at'],
'gte' 'gte'
) )
fetched = db_api.get_workflow_executions(**_filter) fetched = db_api.get_workflow_executions(**_filter)
self.assertEqual(2, len(fetched)) self.assertEqual(2, len(fetched))
self.assertEqual(created0, fetched[0]) self.assertEqual(created0, fetched[0])
self.assertEqual(created1, fetched[1]) self.assertEqual(created1, fetched[1])
def test_filter_workflow_execution_by_less_than_value(self): def test_filter_workflow_execution_by_less_than_value(self):
created0 = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created1 = db_api.create_workflow_execution(WF_EXECS[1]) created0 = db_api.create_workflow_execution(WF_EXECS[0])
created1 = db_api.create_workflow_execution(WF_EXECS[1])
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'created_at', 'created_at',
created1['created_at'], created1['created_at'],
'lt' 'lt'
) )
fetched = db_api.get_workflow_executions(**_filter) fetched = db_api.get_workflow_executions(**_filter)
self.assertEqual(1, len(fetched)) self.assertEqual(1, len(fetched))
self.assertEqual(created0, fetched[0]) self.assertEqual(created0, fetched[0])
def test_filter_workflow_execution_by_less_than_equal_value(self): def test_filter_workflow_execution_by_less_than_equal_value(self):
created0 = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created1 = db_api.create_workflow_execution(WF_EXECS[1]) created0 = db_api.create_workflow_execution(WF_EXECS[0])
created1 = db_api.create_workflow_execution(WF_EXECS[1])
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'created_at', 'created_at',
created1['created_at'], created1['created_at'],
'lte' 'lte'
) )
fetched = db_api.get_workflow_executions(**_filter) fetched = db_api.get_workflow_executions(**_filter)
self.assertEqual(2, len(fetched)) self.assertEqual(2, len(fetched))
self.assertEqual(created0, fetched[0]) self.assertEqual(created0, fetched[0])
self.assertEqual(created1, fetched[1]) self.assertEqual(created1, fetched[1])
def test_filter_workflow_execution_by_values_in_list(self): def test_filter_workflow_execution_by_values_in_list(self):
created0 = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
db_api.create_workflow_execution(WF_EXECS[1]) created0 = db_api.create_workflow_execution(WF_EXECS[0])
db_api.create_workflow_execution(WF_EXECS[1])
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'created_at', 'created_at',
[created0['created_at']], [created0['created_at']],
'in' 'in'
) )
fetched = db_api.get_workflow_executions(**_filter) fetched = db_api.get_workflow_executions(**_filter)
self.assertEqual(1, len(fetched)) self.assertEqual(1, len(fetched))
self.assertEqual(created0, fetched[0]) self.assertEqual(created0, fetched[0])
def test_filter_workflow_execution_by_values_notin_list(self): def test_filter_workflow_execution_by_values_notin_list(self):
created0 = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created1 = db_api.create_workflow_execution(WF_EXECS[1]) created0 = db_api.create_workflow_execution(WF_EXECS[0])
created1 = db_api.create_workflow_execution(WF_EXECS[1])
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'created_at', 'created_at',
[created0['created_at']], [created0['created_at']],
'nin' 'nin'
) )
fetched = db_api.get_workflow_executions(**_filter) fetched = db_api.get_workflow_executions(**_filter)
self.assertEqual(1, len(fetched)) self.assertEqual(1, len(fetched))
self.assertEqual(created1, fetched[0]) self.assertEqual(created1, fetched[0])
def test_filter_workflow_execution_by_multiple_columns(self): def test_filter_workflow_execution_by_multiple_columns(self):
created0 = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created1 = db_api.create_workflow_execution(WF_EXECS[1]) created0 = db_api.create_workflow_execution(WF_EXECS[0])
created1 = db_api.create_workflow_execution(WF_EXECS[1])
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'created_at', 'created_at',
[created0['created_at'], created1['created_at']], [created0['created_at'], created1['created_at']],
'in' 'in'
) )
_filter = filter_utils.create_or_update_filter( _filter = filter_utils.create_or_update_filter(
'id', 'id',
created1.id, created1.id,
'eq', 'eq',
_filter _filter
) )
fetched = db_api.get_workflow_executions(**_filter) fetched = db_api.get_workflow_executions(**_filter)
self.assertEqual(1, len(fetched)) self.assertEqual(1, len(fetched))
self.assertEqual(created1, fetched[0]) self.assertEqual(created1, fetched[0])
def test_delete_workflow_execution(self): def test_delete_workflow_execution(self):
created = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
created = db_api.create_workflow_execution(WF_EXECS[0])
fetched = db_api.get_workflow_execution(created.id) fetched = db_api.get_workflow_execution(created.id)
self.assertEqual(created, fetched) self.assertEqual(created, fetched)
db_api.delete_workflow_execution(created.id) db_api.delete_workflow_execution(created.id)
@ -1652,24 +1669,25 @@ TASK_EXECS = [
class TaskExecutionTest(SQLAlchemyTest): class TaskExecutionTest(SQLAlchemyTest):
def test_create_and_get_and_load_task_execution(self): def test_create_and_get_and_load_task_execution(self):
wf_ex = db_api.create_workflow_execution(WF_EXECS[0]) with db_api.transaction():
wf_ex = db_api.create_workflow_execution(WF_EXECS[0])
values = copy.deepcopy(TASK_EXECS[0]) values = copy.deepcopy(TASK_EXECS[0])
values.update({'workflow_execution_id': wf_ex.id}) values.update({'workflow_execution_id': wf_ex.id})
created = db_api.create_task_execution(values) created = db_api.create_task_execution(values)
fetched = db_api.get_task_execution(created.id) fetched = db_api.get_task_execution(created.id)
self.assertEqual(created, fetched) self.assertEqual(created, fetched)
self.assertNotIsInstance(fetched.workflow_execution, list) self.assertNotIsInstance(fetched.workflow_execution, list)
fetched = db_api.load_task_execution(created.id) fetched = db_api.load_task_execution(created.id)
self.assertEqual(created, fetched) self.assertEqual(created, fetched)
self.assertIsNone(db_api.load_task_execution("not-existing-id")) self.assertIsNone(db_api.load_task_execution("not-existing-id"))
def test_action_executions(self): def test_action_executions(self):
# Store one task with two invocations. # Store one task with two invocations.
@ -2440,13 +2458,15 @@ class TXTest(SQLAlchemyTest):
self.assertFalse(self.is_db_session_open()) self.assertFalse(self.is_db_session_open())
fetched = db_api.get_workflow_execution(created.id) with db_api.transaction():
fetched = db_api.get_workflow_execution(created.id)
self.assertEqual(created, fetched) self.assertEqual(created, fetched)
fetched_wb = db_api.get_workbook(created_wb.name) fetched_wb = db_api.get_workbook(created_wb.name)
self.assertEqual(created_wb, fetched_wb)
self.assertEqual(created_wb, fetched_wb)
self.assertFalse(self.is_db_session_open()) self.assertFalse(self.is_db_session_open())

View File

@ -171,21 +171,21 @@ class EngineTestCase(base.DbTestCase):
a.output) a.output)
) )
print("\nPrinting standalone action executions...") print("\nPrinting standalone action executions...")
child_execs = db_api.get_action_executions(task_execution_id=None) child_execs = db_api.get_action_executions(task_execution_id=None)
for a in child_execs: for a in child_execs:
print( print(
"\t\t%s [id=%s, state=%s, state_info=%s, accepted=%s," "\t\t%s [id=%s, state=%s, state_info=%s, accepted=%s,"
" output=%s]" % " output=%s]" %
(a.name, (a.name,
a.id, a.id,
a.state, a.state,
a.state_info, a.state_info,
a.accepted, a.accepted,
a.output) a.output)
) )
# Various methods for action execution objects. # Various methods for action execution objects.

View File

@ -64,11 +64,16 @@ class ActionContextTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
task_ex = self._assert_single_item(wf_ex.task_executions, name='task1')
action_ex = self._assert_single_item(task_ex.executions) task_ex = self._assert_single_item(
wf_ex.task_executions,
name='task1'
)
action_ex = self._assert_single_item(task_ex.executions)
headers = { headers = {
'Mistral-Workflow-Name': wf_ex.workflow_name, 'Mistral-Workflow-Name': wf_ex.workflow_name,

View File

@ -109,10 +109,11 @@ class ActionDefaultTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self._assert_single_item(wf_ex.task_executions, name='task1') self._assert_single_item(wf_ex.task_executions, name='task1')
requests.request.assert_called_with( requests.request.assert_called_with(
'GET', 'https://api.library.org/books', 'GET', 'https://api.library.org/books',
@ -134,10 +135,11 @@ class ActionDefaultTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self._assert_single_item(wf_ex.task_executions, name='task1') self._assert_single_item(wf_ex.task_executions, name='task1')
requests.request.assert_called_with( requests.request.assert_called_with(
'GET', 'https://api.library.org/books', 'GET', 'https://api.library.org/books',
@ -171,17 +173,18 @@ class ActionDefaultTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self._assert_single_item(wf_ex.task_executions, name='task1') self._assert_single_item(wf_ex.task_executions, name='task1')
calls = [mock.call('GET', url, params=None, data=None, calls = [mock.call('GET', url, params=None, data=None,
headers=None, cookies=None, headers=None, cookies=None,
allow_redirects=None, proxies=None, allow_redirects=None, proxies=None,
auth=EXPECTED_ENV_AUTH, verify=None, auth=EXPECTED_ENV_AUTH, verify=None,
timeout=ENV['__actions']['std.http']['timeout']) timeout=ENV['__actions']['std.http']['timeout'])
for url in wf_input['links']] for url in wf_input['links']]
requests.request.assert_has_calls(calls, any_order=True) requests.request.assert_has_calls(calls, any_order=True)
@ -209,10 +212,11 @@ class ActionDefaultTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self._assert_single_item(wf_ex.task_executions, name='task1') self._assert_single_item(wf_ex.task_executions, name='task1')
calls = [mock.call('GET', url, params=None, data=None, calls = [mock.call('GET', url, params=None, data=None,
headers=None, cookies=None, headers=None, cookies=None,

View File

@ -98,17 +98,16 @@ class AdhocActionsTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.maxDiff = None self.assertDictEqual(
{
self.assertDictEqual( 'workflow_result': 'a+b and a+b',
{ 'concat_task_result': 'a+b and a+b'
'workflow_result': 'a+b and a+b', },
'concat_task_result': 'a+b and a+b' wf_ex.output
}, )
wf_ex.output
)
def test_run_adhoc_action_without_input_value(self): def test_run_adhoc_action_without_input_value(self):
wf_ex = self.engine.start_workflow( wf_ex = self.engine.start_workflow(
@ -118,17 +117,15 @@ class AdhocActionsTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) expected_output = {
'workflow_result': 'a+b and a+b',
'concat_task_result': 'a+b and a+b'
}
self.maxDiff = None with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertDictEqual( self.assertDictEqual(expected_output, wf_ex.output)
{
'workflow_result': 'a+b and a+b',
'concat_task_result': 'a+b and a+b'
},
wf_ex.output
)
def test_run_adhoc_action_without_sufficient_input_value(self): def test_run_adhoc_action_without_sufficient_input_value(self):
wf_ex = self.engine.start_workflow( wf_ex = self.engine.start_workflow(

View File

@ -62,11 +62,14 @@ class SimpleEngineCommandsTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -76,11 +79,14 @@ class SimpleEngineCommandsTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -90,11 +96,14 @@ class SimpleEngineCommandsTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -139,11 +148,14 @@ class SimpleEngineWorkflowLevelCommandsTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -153,11 +165,14 @@ class SimpleEngineWorkflowLevelCommandsTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -167,11 +182,14 @@ class SimpleEngineWorkflowLevelCommandsTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -249,11 +267,14 @@ class OrderEngineCommandsTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -263,18 +284,18 @@ class OrderEngineCommandsTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(2, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(2, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
task2_db = self._assert_single_item( task2_db = self._assert_single_item(task_execs, name='task2')
wf_ex.task_executions,
name='task2'
)
self.await_task_success(task2_db.id) self.await_task_success(task2_db.id)
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
@ -284,11 +305,14 @@ class OrderEngineCommandsTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -298,18 +322,18 @@ class OrderEngineCommandsTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(2, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(2, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
task2_db = self._assert_single_item( task2_db = self._assert_single_item(task_execs, name='task2')
wf_ex.task_executions,
name='task2'
)
self.await_task_error(task2_db.id) self.await_task_error(task2_db.id)
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
@ -351,11 +375,14 @@ class SimpleEngineCmdsWithMsgTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -367,11 +394,14 @@ class SimpleEngineCmdsWithMsgTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -383,11 +413,14 @@ class SimpleEngineCmdsWithMsgTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -433,11 +466,14 @@ class SimpleEngineWorkflowLevelCmdsWithMsgTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -449,11 +485,14 @@ class SimpleEngineWorkflowLevelCmdsWithMsgTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -465,11 +504,14 @@ class SimpleEngineWorkflowLevelCmdsWithMsgTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self._assert_single_item( self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )

View File

@ -67,13 +67,14 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
task2 = self._assert_single_item(tasks, name='task2') task2 = self._assert_single_item(tasks, name='task2')
task3 = self._assert_single_item(tasks, name='task3') task3 = self._assert_single_item(tasks, name='task3')
@ -136,13 +137,14 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
task2 = self._assert_single_item(tasks, name='task2') task2 = self._assert_single_item(tasks, name='task2')
task3 = self._assert_single_item(tasks, name='task3') task3 = self._assert_single_item(tasks, name='task3')
@ -171,9 +173,18 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.assertDictEqual(exp_published_arr[1], task2.published) self.assertDictEqual(exp_published_arr[1], task2.published)
self.assertDictEqual(exp_published_arr[2], task3.published) self.assertDictEqual(exp_published_arr[2], task3.published)
self.assertIn(exp_published_arr[0]['progress'], notify_published_arr) self.assertIn(
self.assertIn(exp_published_arr[1]['progress'], notify_published_arr) exp_published_arr[0]['progress'],
self.assertIn(exp_published_arr[2]['progress'], notify_published_arr) notify_published_arr
)
self.assertIn(
exp_published_arr[1]['progress'],
notify_published_arr
)
self.assertIn(
exp_published_arr[2]['progress'],
notify_published_arr
)
def test_parallel_tasks(self): def test_parallel_tasks(self):
parallel_tasks_wf = """--- parallel_tasks_wf = """---
@ -201,13 +212,15 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
wf_output = wf_ex.output
tasks = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
tasks = wf_ex.task_executions
self.assertEqual(2, len(tasks)) self.assertEqual(2, len(tasks))
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
@ -219,8 +232,8 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.assertDictEqual({'var1': 1}, task1.published) self.assertDictEqual({'var1': 1}, task1.published)
self.assertDictEqual({'var2': 2}, task2.published) self.assertDictEqual({'var2': 2}, task2.published)
self.assertEqual(1, wf_ex.output['var1']) self.assertEqual(1, wf_output['var1'])
self.assertEqual(2, wf_ex.output['var2']) self.assertEqual(2, wf_output['var2'])
def test_parallel_tasks_complex(self): def test_parallel_tasks_complex(self):
parallel_tasks_complex_wf = """--- parallel_tasks_complex_wf = """---
@ -277,13 +290,15 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
wf_output = wf_ex.output
tasks = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
tasks = wf_ex.task_executions
self.assertEqual(6, len(tasks)) self.assertEqual(6, len(tasks))
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
@ -306,12 +321,12 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.assertDictEqual({'var2': 2}, task2.published) self.assertDictEqual({'var2': 2}, task2.published)
self.assertDictEqual({'var21': 21}, task21.published) self.assertDictEqual({'var21': 21}, task21.published)
self.assertEqual(1, wf_ex.output['var1']) self.assertEqual(1, wf_output['var1'])
self.assertEqual(12, wf_ex.output['var12']) self.assertEqual(12, wf_output['var12'])
self.assertNotIn('var13', wf_ex.output) self.assertNotIn('var13', wf_output)
self.assertEqual(14, wf_ex.output['var14']) self.assertEqual(14, wf_output['var14'])
self.assertEqual(2, wf_ex.output['var2']) self.assertEqual(2, wf_output['var2'])
self.assertEqual(21, wf_ex.output['var21']) self.assertEqual(21, wf_output['var21'])
def test_sequential_tasks_publishing_same_var(self): def test_sequential_tasks_publishing_same_var(self):
var_overwrite_wf = """--- var_overwrite_wf = """---
@ -358,13 +373,14 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
task2 = self._assert_single_item(tasks, name='task2') task2 = self._assert_single_item(tasks, name='task2')
task3 = self._assert_single_item(tasks, name='task3') task3 = self._assert_single_item(tasks, name='task3')
@ -416,12 +432,13 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
task2 = self._assert_single_item(tasks, name='task2') task2 = self._assert_single_item(tasks, name='task2')
task3 = self._assert_single_item(tasks, name='task3') task3 = self._assert_single_item(tasks, name='task3')
@ -469,10 +486,12 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
tasks = wf_ex.task_executions
task4 = self._assert_single_item(tasks, name='task4') task4 = self._assert_single_item(tasks, name='task4')
self.assertDictEqual( self.assertDictEqual(
@ -502,14 +521,15 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
result = data_flow.get_task_execution_result(task1) result = data_flow.get_task_execution_result(task1)
# Published vars are saved. # Published vars are saved.
self.assertDictEqual( self.assertDictEqual(
@ -541,12 +561,16 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task1 = self._assert_single_item(wf_ex.task_executions, name='task1') task1 = self._assert_single_item(
wf_ex.task_executions,
name='task1'
)
result = data_flow.get_task_execution_result(task1) result = data_flow.get_task_execution_result(task1)
self.assertListEqual([], result) self.assertListEqual([], result)
@ -575,20 +599,28 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
wf_output = wf_ex.output
tasks = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
self.assertEqual(states.ERROR, task1.state) self.assertEqual(states.ERROR, task1.state)
self.assertEqual('hello_from_error', task1.published['hi']) self.assertEqual('hello_from_error', task1.published['hi'])
self.assertIn('Fail action expected exception', task1.published['err']) self.assertIn(
self.assertEqual('hello_from_error', wf_ex.output['out']) 'Fail action expected exception',
self.assertIn('Fail action expected exception', wf_ex.output['result']) task1.published['err']
)
self.assertEqual('hello_from_error', wf_output['out'])
self.assertIn(
'Fail action expected exception',
wf_output['result']
)
def test_output_on_error_wb_yaql_failed(self): def test_output_on_error_wb_yaql_failed(self):
wb_def = """--- wb_def = """---
@ -627,17 +659,19 @@ class DataFlowEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIn('Failed to evaluate expression in output-on-error!', self.assertIn('Failed to evaluate expression in output-on-error!',
wf_ex.state_info) wf_ex.state_info)
self.assertIn('$.message', wf_ex.state_info) self.assertIn('$.message', wf_ex.state_info)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
self.assertIn('task(task1).result.message', task1.state_info) self.assertIn('task(task1).result.message', task1.state_info)

View File

@ -118,12 +118,15 @@ class DefaultEngineTest(base.DbTestCase):
self.assertEqual('my execution', wf_ex.description) self.assertEqual('my execution', wf_ex.description)
self.assertIn('__execution', wf_ex.context) self.assertIn('__execution', wf_ex.context)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
task_ex = wf_ex.task_executions[0] self.assertEqual(1, len(task_execs))
task_ex = task_execs[0]
self.assertEqual('wb.wf', task_ex.workflow_name) self.assertEqual('wb.wf', task_ex.workflow_name)
self.assertEqual('task1', task_ex.name) self.assertEqual('task1', task_ex.name)
@ -158,11 +161,14 @@ class DefaultEngineTest(base.DbTestCase):
self.assertIn('__execution', wf_ex.context) self.assertIn('__execution', wf_ex.context)
# Note: We need to reread execution to access related tasks. # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
task_ex = wf_ex.task_executions[0] self.assertEqual(1, len(task_execs))
task_ex = task_execs[0]
self.assertEqual('wb.wf', task_ex.workflow_name) self.assertEqual('wb.wf', task_ex.workflow_name)
self.assertEqual('task1', task_ex.name) self.assertEqual('task1', task_ex.name)
@ -299,12 +305,15 @@ class DefaultEngineTest(base.DbTestCase):
self.assertIsNotNone(wf_ex) self.assertIsNotNone(wf_ex)
self.assertEqual(states.RUNNING, wf_ex.state) self.assertEqual(states.RUNNING, wf_ex.state)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
task1_ex = wf_ex.task_executions[0] self.assertEqual(1, len(task_execs))
task1_ex = task_execs[0]
self.assertEqual('task1', task1_ex.name) self.assertEqual('task1', task1_ex.name)
self.assertEqual(states.RUNNING, task1_ex.state) self.assertEqual(states.RUNNING, task1_ex.state)
@ -340,17 +349,17 @@ class DefaultEngineTest(base.DbTestCase):
self.assertDictEqual({'output': 'Hey'}, task1_action_ex.input) self.assertDictEqual({'output': 'Hey'}, task1_action_ex.input)
self.assertDictEqual({'result': 'Hey'}, task1_action_ex.output) self.assertDictEqual({'result': 'Hey'}, task1_action_ex.output)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertIsNotNone(wf_ex) self.assertIsNotNone(wf_ex)
self.assertEqual(states.RUNNING, wf_ex.state) self.assertEqual(states.RUNNING, wf_ex.state)
self.assertEqual(2, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
task2_ex = self._assert_single_item( self.assertEqual(2, len(task_execs))
wf_ex.task_executions,
name='task2' task2_ex = self._assert_single_item(task_execs, name='task2')
)
self.assertEqual(states.RUNNING, task2_ex.state) self.assertEqual(states.RUNNING, task2_ex.state)
@ -371,9 +380,12 @@ class DefaultEngineTest(base.DbTestCase):
wf_utils.Result(data='Hi') wf_utils.Result(data='Hi')
) )
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertIsNotNone(wf_ex) self.assertIsNotNone(wf_ex)
task_execs = wf_ex.task_executions
# Workflow completion check is done separate with scheduler # Workflow completion check is done separate with scheduler
# but scheduler doesn't start in this test (in fact, it's just # but scheduler doesn't start in this test (in fact, it's just
@ -390,10 +402,10 @@ class DefaultEngineTest(base.DbTestCase):
self.assertDictEqual({'output': 'Hi'}, task2_action_ex.input) self.assertDictEqual({'output': 'Hi'}, task2_action_ex.input)
self.assertDictEqual({'result': 'Hi'}, task2_action_ex.output) self.assertDictEqual({'result': 'Hi'}, task2_action_ex.output)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
self._assert_single_item(wf_ex.task_executions, name='task1') self._assert_single_item(task_execs, name='task1')
self._assert_single_item(wf_ex.task_executions, name='task2') self._assert_single_item(task_execs, name='task2')
def test_stop_workflow_fail(self): def test_stop_workflow_fail(self):
# Start workflow. # Start workflow.

View File

@ -74,7 +74,10 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
wf_ex = self._run_workflow(wf_text) wf_ex = self._run_workflow(wf_text)
tasks = wf_ex.task_executions with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
task3 = self._assert_single_item(tasks, name='task3') task3 = self._assert_single_item(tasks, name='task3')
@ -116,8 +119,10 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
tasks = wf_ex.task_executions wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
@ -271,7 +276,10 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIn('Can not evaluate YAQL expression', wf_ex.state_info) self.assertIn('Can not evaluate YAQL expression', wf_ex.state_info)
task_execs = wf_ex.task_executions with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(2, len(task_execs)) self.assertEqual(2, len(task_execs))
@ -324,13 +332,15 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
# and async action execution are RUNNING. # and async action execution are RUNNING.
wf_ex = self._run_workflow(wf_text, states.RUNNING) wf_ex = self._run_workflow(wf_text, states.RUNNING)
self.assertEqual(states.RUNNING, wf_ex.state) with db_api.transaction():
self.assertEqual(1, len(wf_ex.task_executions)) wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_1_ex = self._assert_single_item( task_execs = wf_ex.task_executions
wf_ex.task_executions,
name='task1' self.assertEqual(states.RUNNING, wf_ex.state)
) self.assertEqual(1, len(task_execs))
task_1_ex = self._assert_single_item(task_execs, name='task1')
self.assertEqual(states.RUNNING, task_1_ex.state) self.assertEqual(states.RUNNING, task_1_ex.state)
@ -347,13 +357,14 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
wf_utils.Result(data='foobar') wf_utils.Result(data='foobar')
) )
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIn('Can not evaluate YAQL expression', wf_ex.state_info) self.assertIn('Can not evaluate YAQL expression', wf_ex.state_info)
task_execs = wf_ex.task_executions
self.assertEqual(2, len(task_execs)) self.assertEqual(2, len(task_execs))
# 'task1' must be in SUCCESS. # 'task1' must be in SUCCESS.
@ -478,11 +489,16 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIn('Can not evaluate YAQL expression', wf_ex.state_info) self.assertIn('Can not evaluate YAQL expression', wf_ex.state_info)
with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
# Assert that there is only one task execution and it's SUCCESS. # Assert that there is only one task execution and it's SUCCESS.
self.assertEqual(1, len(wf_ex.task_executions)) self.assertEqual(1, len(task_execs))
task_1_ex = self._assert_single_item( task_1_ex = self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1' name='task1'
) )
@ -518,12 +534,15 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
wf_ex = self._run_workflow(wf_text, states.RUNNING) wf_ex = self._run_workflow(wf_text, states.RUNNING)
self.assertEqual(states.RUNNING, wf_ex.state) self.assertEqual(states.RUNNING, wf_ex.state)
self.assertEqual(1, len(wf_ex.task_executions))
task_1_ex = self._assert_single_item( with db_api.transaction():
wf_ex.task_executions, wf_ex = db_api.get_workflow_execution(wf_ex.id)
name='task1'
) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
task_1_ex = self._assert_single_item(task_execs, name='task1')
self.assertEqual(states.RUNNING, task_1_ex.state) self.assertEqual(states.RUNNING, task_1_ex.state)
@ -541,16 +560,16 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
) )
# Assert that task1 is SUCCESS and workflow is ERROR. # Assert that task1 is SUCCESS and workflow is ERROR.
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIn('Can not evaluate YAQL expression', wf_ex.state_info) self.assertIn('Can not evaluate YAQL expression', wf_ex.state_info)
self.assertEqual(1, len(wf_ex.task_executions)) self.assertEqual(1, len(task_execs))
task_1_ex = self._assert_single_item( task_1_ex = self._assert_single_item(task_execs, name='task1')
wf_ex.task_executions,
name='task1'
)
self.assertEqual(states.ERROR, task_1_ex.state) self.assertEqual(states.ERROR, task_1_ex.state)

View File

@ -228,14 +228,17 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
self.assertEqual(states.ERROR, task_2_ex.state) self.assertEqual(states.ERROR, task_2_ex.state)
@ -252,15 +255,18 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
# Wait for the workflow to succeed. # Wait for the workflow to succeed.
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
task_3_ex = self._assert_single_item(wf_ex.task_executions, name='t3') task_3_ex = self._assert_single_item(task_execs, name='t3')
# Check action executions of task 1. # Check action executions of task 1.
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
@ -460,13 +466,14 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
task_execs = wf_ex.task_executions
self.assertEqual(2, len(task_execs)) self.assertEqual(2, len(task_execs))
task_1_ex = self._assert_single_item( task_1_ex = self._assert_single_item(
@ -513,13 +520,14 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs)) self.assertEqual(1, len(task_execs))
task_1_ex = self._assert_single_item(task_execs, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
@ -543,13 +551,14 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id, delay=10) self.await_workflow_success(wf_ex.id, delay=10)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
task_execs = wf_ex.task_executions
self.assertEqual(2, len(task_execs)) self.assertEqual(2, len(task_execs))
task_1_ex = self._assert_single_item(task_execs, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
@ -685,13 +694,16 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
self.assertEqual(1, len(wf_ex.task_executions)) self.assertEqual(1, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
self.assertEqual(states.ERROR, task_1_ex.state) self.assertEqual(states.ERROR, task_1_ex.state)
self.assertIsNotNone(task_1_ex.state_info) self.assertIsNotNone(task_1_ex.state_info)
@ -703,9 +715,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.assertEqual(3, len(task_1_action_exs)) self.assertEqual(3, len(task_1_action_exs))
# Update env in workflow execution with the following. # Update env in workflow execution with the following.
updated_env = { updated_env = {'var1': 'foobar'}
'var1': 'foobar'
}
# Resume workflow and re-run failed task. # Resume workflow and re-run failed task.
self.engine.rerun_workflow( self.engine.rerun_workflow(
@ -721,14 +731,17 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id, delay=10) self.await_workflow_success(wf_ex.id, delay=10)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
# Check action executions of task 1. # Check action executions of task 1.
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
@ -785,15 +798,18 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
task_3_ex = self._assert_single_item(wf_ex.task_executions, name='t3') task_3_ex = self._assert_single_item(task_execs, name='t3')
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
self.assertEqual(states.SUCCESS, task_2_ex.state) self.assertEqual(states.SUCCESS, task_2_ex.state)
@ -811,15 +827,18 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
# Wait for the workflow to succeed. # Wait for the workflow to succeed.
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
task_3_ex = self._assert_single_item(wf_ex.task_executions, name='t3') task_3_ex = self._assert_single_item(task_execs, name='t3')
# Check action executions of task 1. # Check action executions of task 1.
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
@ -846,7 +865,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.assertIsNone(task_3_ex.state_info) self.assertIsNone(task_3_ex.state_info)
task_3_action_exs = db_api.get_action_executions( task_3_action_exs = db_api.get_action_executions(
task_execution_id=wf_ex.task_executions[2].id task_execution_id=task_execs[2].id
) )
self.assertEqual(2, len(task_3_action_exs)) self.assertEqual(2, len(task_3_action_exs))
@ -1022,13 +1041,16 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
self.assertEqual(1, len(wf_ex.task_executions)) self.assertEqual(1, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
self.await_task_error(task_1_ex.id) self.await_task_error(task_1_ex.id)
@ -1111,14 +1133,17 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id, delay=10) self.await_workflow_success(wf_ex.id, delay=10)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
# Check action executions of task 1. # Check action executions of task 1.
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
@ -1131,8 +1156,10 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
# The single action execution that succeeded should not re-run. # The single action execution that succeeded should not re-run.
self.assertEqual(12, len(task_1_action_exs)) self.assertEqual(12, len(task_1_action_exs))
self.assertListEqual(['Task 1.0', 'Task 1.1', 'Task 1.2'], self.assertListEqual(
task_1_ex.published.get('v1')) ['Task 1.0', 'Task 1.1', 'Task 1.2'],
task_1_ex.published.get('v1')
)
# Check action executions of task 2. # Check action executions of task 2.
self.assertEqual(states.SUCCESS, task_2_ex.state) self.assertEqual(states.SUCCESS, task_2_ex.state)
@ -1163,14 +1190,17 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
self.assertEqual(states.ERROR, task_2_ex.state) self.assertEqual(states.ERROR, task_2_ex.state)
@ -1178,6 +1208,7 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
# Resume workflow and re-run failed task. # Resume workflow and re-run failed task.
self.engine.rerun_workflow(task_2_ex.id) self.engine.rerun_workflow(task_2_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(states.RUNNING, wf_ex.state) self.assertEqual(states.RUNNING, wf_ex.state)
@ -1186,15 +1217,18 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
# Wait for the workflow to succeed. # Wait for the workflow to succeed.
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
task_3_ex = self._assert_single_item(wf_ex.task_executions, name='t3') task_3_ex = self._assert_single_item(task_execs, name='t3')
# Check action executions of task 1. # Check action executions of task 1.
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
@ -1221,7 +1255,8 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.assertEqual(states.SUCCESS, task_3_ex.state) self.assertEqual(states.SUCCESS, task_3_ex.state)
task_3_action_exs = db_api.get_action_executions( task_3_action_exs = db_api.get_action_executions(
task_execution_id=task_3_ex.id) task_execution_id=task_3_ex.id
)
self.assertEqual(1, len(task_3_action_exs)) self.assertEqual(1, len(task_3_action_exs))
self.assertEqual(states.SUCCESS, task_3_action_exs[0].state) self.assertEqual(states.SUCCESS, task_3_action_exs[0].state)
@ -1246,32 +1281,37 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
self.assertEqual(states.ERROR, task_2_ex.state) self.assertEqual(states.ERROR, task_2_ex.state)
self.assertIsNotNone(task_2_ex.state_info) self.assertIsNotNone(task_2_ex.state_info)
# Get subworkflow and related task with db_api.transaction():
sub_wf_exs = db_api.get_workflow_executions( # Get subworkflow and related task
task_execution_id=task_2_ex.id sub_wf_exs = db_api.get_workflow_executions(
) task_execution_id=task_2_ex.id
)
sub_wf_ex = sub_wf_exs[0] sub_wf_ex = sub_wf_exs[0]
sub_wf_task_execs = sub_wf_ex.task_executions
self.assertEqual(states.ERROR, sub_wf_ex.state) self.assertEqual(states.ERROR, sub_wf_ex.state)
self.assertIsNotNone(sub_wf_ex.state_info) self.assertIsNotNone(sub_wf_ex.state_info)
self.assertEqual(1, len(sub_wf_ex.task_executions)) self.assertEqual(1, len(sub_wf_task_execs))
sub_wf_task_ex = self._assert_single_item( sub_wf_task_ex = self._assert_single_item(
sub_wf_ex.task_executions, sub_wf_task_execs,
name='wf2_t1' name='wf2_t1'
) )
@ -1294,14 +1334,17 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
# Wait for the subworkflow to succeed. # Wait for the subworkflow to succeed.
self.await_workflow_success(sub_wf_ex.id) self.await_workflow_success(sub_wf_ex.id)
sub_wf_ex = db_api.get_workflow_execution(sub_wf_ex.id) with db_api.transaction():
sub_wf_ex = db_api.get_workflow_execution(sub_wf_ex.id)
sub_wf_task_execs = sub_wf_ex.task_executions
self.assertEqual(states.SUCCESS, sub_wf_ex.state) self.assertEqual(states.SUCCESS, sub_wf_ex.state)
self.assertIsNone(sub_wf_ex.state_info) self.assertIsNone(sub_wf_ex.state_info)
self.assertEqual(1, len(sub_wf_ex.task_executions)) self.assertEqual(1, len(sub_wf_task_execs))
sub_wf_task_ex = self._assert_single_item( sub_wf_task_ex = self._assert_single_item(
sub_wf_ex.task_executions, sub_wf_task_execs,
name='wf2_t1' name='wf2_t1'
) )
@ -1310,7 +1353,8 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
self.assertIsNone(sub_wf_task_ex.state_info) self.assertIsNone(sub_wf_task_ex.state_info)
sub_wf_task_ex_action_exs = db_api.get_action_executions( sub_wf_task_ex_action_exs = db_api.get_action_executions(
task_execution_id=sub_wf_task_ex.id) task_execution_id=sub_wf_task_ex.id
)
self.assertEqual(2, len(sub_wf_task_ex_action_exs)) self.assertEqual(2, len(sub_wf_task_ex_action_exs))
self.assertEqual(states.ERROR, sub_wf_task_ex_action_exs[0].state) self.assertEqual(states.ERROR, sub_wf_task_ex_action_exs[0].state)
@ -1319,21 +1363,25 @@ class DirectWorkflowRerunTest(base.EngineTestCase):
# Wait for the main workflow to succeed. # Wait for the main workflow to succeed.
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
task_3_ex = self._assert_single_item(wf_ex.task_executions, name='t3') task_3_ex = self._assert_single_item(task_execs, name='t3')
# Check action executions of task 1. # Check action executions of task 1.
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
task_1_action_exs = db_api.get_action_executions( task_1_action_exs = db_api.get_action_executions(
task_execution_id=task_1_ex.id) task_execution_id=task_1_ex.id
)
self.assertEqual(1, len(task_1_action_exs)) self.assertEqual(1, len(task_1_action_exs))
self.assertEqual(states.SUCCESS, task_1_action_exs[0].state) self.assertEqual(states.SUCCESS, task_1_action_exs[0].state)

View File

@ -102,11 +102,7 @@ class EnvironmentTest(base.EngineTestCase):
@mock.patch.object(rpc.ExecutorClient, 'run_action', MOCK_RUN_AT_TARGET) @mock.patch.object(rpc.ExecutorClient, 'run_action', MOCK_RUN_AT_TARGET)
def _test_subworkflow(self, env): def _test_subworkflow(self, env):
wf2_ex = self.engine.start_workflow( wf2_ex = self.engine.start_workflow('my_wb.wf2', {}, env=env)
'my_wb.wf2',
{},
env=env
)
# Execution of 'wf2'. # Execution of 'wf2'.
self.assertIsNotNone(wf2_ex) self.assertIsNotNone(wf2_ex)
@ -142,41 +138,46 @@ class EnvironmentTest(base.EngineTestCase):
# Wait till workflow 'wf1' is completed. # Wait till workflow 'wf1' is completed.
self.await_workflow_success(wf1_ex.id) self.await_workflow_success(wf1_ex.id)
wf1_ex = db_api.get_workflow_execution(wf1_ex.id) with db_api.transaction():
wf1_ex = db_api.get_workflow_execution(wf1_ex.id)
expected_wf1_output = {'final_result': "'Bonnie & Clyde'"} self.assertDictEqual(
{'final_result': "'Bonnie & Clyde'"},
self.assertDictEqual(wf1_ex.output, expected_wf1_output) wf1_ex.output
)
# Wait till workflow 'wf2' is completed. # Wait till workflow 'wf2' is completed.
self.await_workflow_success(wf2_ex.id) self.await_workflow_success(wf2_ex.id)
wf2_ex = db_api.get_workflow_execution(wf2_ex.id) with db_api.transaction():
wf2_ex = db_api.get_workflow_execution(wf2_ex.id)
expected_wf2_output = {'slogan': "'Bonnie & Clyde' is a cool movie!\n"} self.assertDictEqual(
{'slogan': "'Bonnie & Clyde' is a cool movie!\n"},
self.assertDictEqual(wf2_ex.output, expected_wf2_output) wf2_ex.output
# Check if target is resolved.
wf1_task_execs = db_api.get_task_executions(
workflow_execution_id=wf1_ex.id
)
self._assert_single_item(wf1_task_execs, name='task1')
self._assert_single_item(wf1_task_execs, name='task2')
for t_ex in wf1_task_execs:
a_ex = t_ex.action_executions[0]
rpc.ExecutorClient.run_action.assert_any_call(
a_ex.id,
'mistral.actions.std_actions.EchoAction',
{},
a_ex.input,
TARGET,
safe_rerun=False
) )
with db_api.transaction():
# Check if target is resolved.
wf1_task_execs = db_api.get_task_executions(
workflow_execution_id=wf1_ex.id
)
self._assert_single_item(wf1_task_execs, name='task1')
self._assert_single_item(wf1_task_execs, name='task2')
for t_ex in wf1_task_execs:
a_ex = t_ex.action_executions[0]
rpc.ExecutorClient.run_action.assert_any_call(
a_ex.id,
'mistral.actions.std_actions.EchoAction',
{},
a_ex.input,
TARGET,
safe_rerun=False
)
def test_subworkflow_env_task_input(self): def test_subworkflow_env_task_input(self):
env = { env = {
'var1': TARGET, 'var1': TARGET,

View File

@ -82,9 +82,10 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs)) self.assertEqual(1, len(task_execs))
@ -109,9 +110,10 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs)) self.assertEqual(1, len(task_execs))
@ -138,22 +140,23 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
# Now we need to make sure that task is in ERROR state but action # Now we need to make sure that task is in ERROR state but action
# is in SUCCESS because error occurred in 'publish' clause which # is in SUCCESS because error occurred in 'publish' clause which
# must not affect action state. # must not affect action state.
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs)) self.assertEqual(1, len(task_execs))
task_ex = self._assert_single_item( task_ex = self._assert_single_item(
task_execs, task_execs,
name='task1', name='task1',
state=states.ERROR state=states.ERROR
) )
action_execs = task_ex.executions action_execs = task_ex.executions
self.assertEqual(1, len(action_execs)) self.assertEqual(1, len(action_execs))
@ -195,24 +198,26 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
# Now we need to make sure that task is in ERROR state but action # Now we need to make sure that task is in ERROR state but action
# is in SUCCESS because error occurred in 'publish' clause which # is in SUCCESS because error occurred in 'publish' clause which
# must not affect action state. # must not affect action state.
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
# NOTE: task3 must not run because on-error handler triggers only # NOTE: task3 must not run because on-error handler triggers
# on error outcome of an action (or workflow) associated with a task. # only on error outcome of an action (or workflow) associated
self.assertEqual(1, len(task_execs)) # with a task.
self.assertEqual(1, len(task_execs))
task_ex = self._assert_single_item( task_ex = self._assert_single_item(
task_execs, task_execs,
name='task1', name='task1',
state=states.ERROR state=states.ERROR
) )
action_execs = task_ex.executions action_execs = task_ex.executions
self.assertEqual(1, len(action_execs)) self.assertEqual(1, len(action_execs))
@ -244,22 +249,23 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
# Now we need to make sure that task and action are in SUCCESS # Now we need to make sure that task and action are in SUCCESS
# state because mistake at workflow level (output evaluation) # state because mistake at workflow level (output evaluation)
# must not affect them. # must not affect them.
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs)) self.assertEqual(1, len(task_execs))
task_ex = self._assert_single_item( task_ex = self._assert_single_item(
task_execs, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
action_execs = task_ex.executions action_execs = task_ex.executions
self.assertEqual(1, len(action_execs)) self.assertEqual(1, len(action_execs))
@ -295,19 +301,20 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs)) self.assertEqual(1, len(task_execs))
task_ex = self._assert_single_item( task_ex = self._assert_single_item(
task_execs, task_execs,
name='task1', name='task1',
state=states.ERROR state=states.ERROR
) )
action_execs = task_ex.executions action_execs = task_ex.executions
self.assertEqual(0, len(action_execs)) self.assertEqual(0, len(action_execs))
@ -342,19 +349,20 @@ class ErrorHandlingEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs)) self.assertEqual(1, len(task_execs))
task_ex = self._assert_single_item( task_ex = self._assert_single_item(
task_execs, task_execs,
name='task1', name='task1',
state=states.ERROR state=states.ERROR
) )
action_execs = task_ex.executions action_execs = task_ex.executions
self.assertEqual(1, len(action_execs)) self.assertEqual(1, len(action_execs))

View File

@ -93,23 +93,24 @@ class ErrorResultTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(2, len(tasks)) self.assertEqual(2, len(tasks))
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
task2 = self._assert_single_item(tasks, name='task2') task2 = self._assert_single_item(tasks, name='task2')
self.assertEqual(states.ERROR, task1.state) self.assertEqual(states.ERROR, task1.state)
self.assertEqual(states.SUCCESS, task2.state) self.assertEqual(states.SUCCESS, task2.state)
# "publish" clause is ignored in case of ERROR so task execution field # "publish" clause is ignored in case of ERROR so task execution
# must be empty. # field must be empty.
self.assertDictEqual({}, task1.published) self.assertDictEqual({}, task1.published)
self.assertEqual(2, data_flow.get_task_execution_result(task1)) self.assertEqual(2, data_flow.get_task_execution_result(task1))
def test_error_result2(self): def test_error_result2(self):
wf_service.create_workflows(WF) wf_service.create_workflows(WF)
@ -125,23 +126,24 @@ class ErrorResultTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(2, len(tasks)) self.assertEqual(2, len(tasks))
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
task3 = self._assert_single_item(tasks, name='task3') task3 = self._assert_single_item(tasks, name='task3')
self.assertEqual(states.ERROR, task1.state) self.assertEqual(states.ERROR, task1.state)
self.assertEqual(states.SUCCESS, task3.state) self.assertEqual(states.SUCCESS, task3.state)
# "publish" clause is ignored in case of ERROR so task execution field # "publish" clause is ignored in case of ERROR so task execution
# must be empty. # field must be empty.
self.assertDictEqual({}, task1.published) self.assertDictEqual({}, task1.published)
self.assertEqual(3, data_flow.get_task_execution_result(task1)) self.assertEqual(3, data_flow.get_task_execution_result(task1))
def test_success_result(self): def test_success_result(self):
wf_service.create_workflows(WF) wf_service.create_workflows(WF)
@ -157,18 +159,22 @@ class ErrorResultTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(1, len(tasks)) self.assertEqual(1, len(tasks))
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
self.assertEqual(states.SUCCESS, task1.state) self.assertEqual(states.SUCCESS, task1.state)
# "publish" clause is ignored in case of ERROR so task execution field # "publish" clause is ignored in case of ERROR so task execution
# must be empty. # field must be empty.
self.assertDictEqual({'p_var': 'success'}, task1.published) self.assertDictEqual({'p_var': 'success'}, task1.published)
self.assertEqual('success', data_flow.get_task_execution_result(task1)) self.assertEqual(
'success',
data_flow.get_task_execution_result(task1)
)

View File

@ -191,17 +191,19 @@ class ExecutionFieldsSizeLimitTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertIn( self.assertIn(
'Failed to handle action completion [error=Size of', 'Failed to handle action completion [error=Size of',
wf_ex.state_info wf_ex.state_info
) )
self.assertIn('wf=wf, task=task1', wf_ex.state_info) self.assertIn('wf=wf, task=task1', wf_ex.state_info)
task_ex = self._assert_single_item(wf_ex.task_executions, name='task1') task_ex = self._assert_single_item(task_execs, name='task1')
self.assertIn( self.assertIn(
"Size of 'published' is 1KB which exceeds the limit of 0KB", "Size of 'published' is 1KB which exceeds the limit of 0KB",

View File

@ -95,9 +95,11 @@ class JavaScriptEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual(states.SUCCESS, task_ex.state) self.assertEqual(states.SUCCESS, task_ex.state)
self.assertDictEqual({}, task_ex.runtime_context) self.assertDictEqual({}, task_ex.runtime_context)

View File

@ -202,14 +202,18 @@ class JoinEngineTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wf', {}) wf_ex = self.engine.start_workflow('wf', {})
self._await( def _num_of_tasks():
lambda: return len(
len(db_api.get_workflow_execution(wf_ex.id).task_executions) == 4 db_api.get_task_executions(workflow_execution_id=wf_ex.id)
) )
# Note: We need to reread execution to access related tasks. self._await(lambda: _num_of_tasks() == 4)
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions with db_api.transaction():
# Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
task2 = self._assert_single_item(tasks, name='task2') task2 = self._assert_single_item(tasks, name='task2')
@ -857,7 +861,10 @@ class JoinEngineTest(base.EngineTestCase):
mtd_name = 'mistral.engine.task_handler._refresh_task_state' mtd_name = 'mistral.engine.task_handler._refresh_task_state'
self._assert_single_item(calls, target_method_name=mtd_name) cnt = sum([1 for c in calls if c.target_method_name == mtd_name])
# There can be 2 calls with different value of 'processing' flag.
self.assertTrue(cnt == 1 or cnt == 2)
# Stop the workflow. # Stop the workflow.
self.engine.stop_workflow(wf_ex.id, state=states.CANCELLED) self.engine.stop_workflow(wf_ex.id, state=states.CANCELLED)
@ -912,7 +919,10 @@ class JoinEngineTest(base.EngineTestCase):
mtd_name = 'mistral.engine.task_handler._refresh_task_state' mtd_name = 'mistral.engine.task_handler._refresh_task_state'
self._assert_single_item(calls, target_method_name=mtd_name) cnt = sum([1 for c in calls if c.target_method_name == mtd_name])
# There can be 2 calls with different value of 'processing' flag.
self.assertTrue(cnt == 1 or cnt == 2)
# Stop the workflow. # Stop the workflow.
db_api.delete_workflow_execution(wf_ex.id) db_api.delete_workflow_execution(wf_ex.id)

View File

@ -82,10 +82,12 @@ class NoopTaskEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions wf_output = wf_ex.output
tasks = wf_ex.task_executions
self.assertEqual(4, len(tasks)) self.assertEqual(4, len(tasks))
@ -99,7 +101,7 @@ class NoopTaskEngineTest(base.EngineTestCase):
self.assertEqual(states.SUCCESS, task3.state) self.assertEqual(states.SUCCESS, task3.state)
self.assertEqual(states.SUCCESS, task4.state) self.assertEqual(states.SUCCESS, task4.state)
self.assertDictEqual({'result': 4}, wf_ex.output) self.assertDictEqual({'result': 4}, wf_output)
def test_noop_task2(self): def test_noop_task2(self):
wf_service.create_workflows(WF) wf_service.create_workflows(WF)
@ -109,10 +111,12 @@ class NoopTaskEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions wf_output = wf_ex.output
tasks = wf_ex.task_executions
self.assertEqual(4, len(tasks)) self.assertEqual(4, len(tasks))
@ -126,4 +130,4 @@ class NoopTaskEngineTest(base.EngineTestCase):
self.assertEqual(states.SUCCESS, task3.state) self.assertEqual(states.SUCCESS, task3.state)
self.assertEqual(states.SUCCESS, task5.state) self.assertEqual(states.SUCCESS, task5.state)
self.assertDictEqual({'result': 5}, wf_ex.output) self.assertDictEqual({'result': 5}, wf_output)

View File

@ -424,9 +424,11 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual(states.RUNNING_DELAYED, task_ex.state) self.assertEqual(states.RUNNING_DELAYED, task_ex.state)
self.assertDictEqual( self.assertDictEqual(
@ -440,15 +442,17 @@ class PoliciesTest(base.EngineTestCase):
wb_service.create_workbook_v2(WAIT_BEFORE_FROM_VAR) wb_service.create_workbook_v2(WAIT_BEFORE_FROM_VAR)
# Start workflow. # Start workflow.
exec_db = self.engine.start_workflow('wb.wf1', {'wait_before': 1}) wf_ex = self.engine.start_workflow('wb.wf1', {'wait_before': 1})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
exec_db = db_api.get_workflow_execution(exec_db.id) # Note: We need to reread execution to access related tasks.
task_db = exec_db.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(states.RUNNING_DELAYED, task_db.state) task_ex = wf_ex.task_executions[0]
self.await_workflow_success(exec_db.id) self.assertEqual(states.RUNNING_DELAYED, task_ex.state)
self.await_workflow_success(wf_ex.id)
def test_wait_before_policy_two_tasks(self): def test_wait_before_policy_two_tasks(self):
wf_text = """--- wf_text = """---
@ -472,6 +476,7 @@ class PoliciesTest(base.EngineTestCase):
with db_api.transaction(): with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
self.assertEqual(2, len(task_execs)) self.assertEqual(2, len(task_execs))
@ -484,9 +489,11 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual(states.RUNNING, task_ex.state) self.assertEqual(states.RUNNING, task_ex.state)
self.assertDictEqual({}, task_ex.runtime_context) self.assertDictEqual({}, task_ex.runtime_context)
@ -500,9 +507,11 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {'wait_after': 2}) wf_ex = self.engine.start_workflow('wb.wf1', {'wait_after': 2})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual(states.RUNNING, task_ex.state) self.assertEqual(states.RUNNING, task_ex.state)
self.assertDictEqual({}, task_ex.runtime_context) self.assertDictEqual({}, task_ex.runtime_context)
@ -518,9 +527,11 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual(states.RUNNING, task_ex.state) self.assertEqual(states.RUNNING, task_ex.state)
self.assertDictEqual({}, task_ex.runtime_context) self.assertDictEqual({}, task_ex.runtime_context)
@ -530,8 +541,10 @@ class PoliciesTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual( self.assertEqual(
2, 2,
@ -544,9 +557,11 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {'count': 3, 'delay': 1}) wf_ex = self.engine.start_workflow('wb.wf1', {'count': 3, 'delay': 1})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual(states.RUNNING, task_ex.state) self.assertEqual(states.RUNNING, task_ex.state)
self.assertDictEqual({}, task_ex.runtime_context) self.assertDictEqual({}, task_ex.runtime_context)
@ -572,21 +587,26 @@ class PoliciesTest(base.EngineTestCase):
count: 3 count: 3
delay: 1 delay: 1
""" """
wb_service.create_workbook_v2(retry_wb) wb_service.create_workbook_v2(retry_wb)
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.await_task_success(task_ex.id) self.await_task_success(task_ex.id)
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual( self.assertEqual(
{}, {},
@ -616,16 +636,20 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.await_task_error(task_ex.id) self.await_task_error(task_ex.id)
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual( self.assertEqual(
{}, {},
@ -655,16 +679,20 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.await_task_error(task_ex.id) self.await_task_error(task_ex.id)
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual( self.assertEqual(
2, 2,
@ -695,16 +723,20 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.await_task_success(task_ex.id) self.await_task_success(task_ex.id)
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual( self.assertEqual(
2, 2,
@ -732,16 +764,19 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.await_task_success(task_ex.id) self.await_task_success(task_ex.id)
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual( self.assertEqual(
{}, {},
@ -768,16 +803,19 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.await_task_error(task_ex.id) self.await_task_error(task_ex.id)
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual( self.assertEqual(
2, 2,
@ -811,15 +849,18 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.main', {}) wf_ex = self.engine.start_workflow('wb.main', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.await_task_error(task_ex.id) self.await_task_error(task_ex.id)
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual( self.assertEqual(
2, 2,
@ -854,23 +895,27 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.await_task_success(task_ex.id) self.await_task_success(task_ex.id)
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
wf_output = wf_ex.output
task_ex = wf_ex.task_executions[0]
self.assertDictEqual( self.assertDictEqual(
{'retry_no': 1}, {'retry_no': 1},
task_ex.runtime_context['retry_task_policy'] task_ex.runtime_context['retry_task_policy']
) )
self.assertDictEqual({'result': 'mocked result'}, wf_ex.output) self.assertDictEqual({'result': 'mocked result'}, wf_output)
@mock.patch.object( @mock.patch.object(
std_actions.EchoAction, std_actions.EchoAction,
@ -899,24 +944,26 @@ class PoliciesTest(base.EngineTestCase):
count: 3 count: 3
delay: 1 delay: 1
""" """
wf_service.create_workflows(retry_wf) wf_service.create_workflows(retry_wf)
wf_ex = self.engine.start_workflow('wf1', {}) wf_ex = self.engine.start_workflow('wf1', {})
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
retry_task = self._assert_single_item( wf_output = wf_ex.output
wf_ex.task_executions, task_execs = wf_ex.task_executions
name='task2'
) retry_task = self._assert_single_item(task_execs, name='task2')
self.assertDictEqual( self.assertDictEqual(
{'retry_no': 1}, {'retry_no': 1},
retry_task.runtime_context['retry_task_policy'] retry_task.runtime_context['retry_task_policy']
) )
self.assertDictEqual({'result': 'value'}, wf_ex.output) self.assertDictEqual({'result': 'value'}, wf_output)
def test_timeout_policy(self): def test_timeout_policy(self):
wb_service.create_workbook_v2(TIMEOUT_WB) wb_service.create_workbook_v2(TIMEOUT_WB)
@ -924,17 +971,22 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual(states.RUNNING, task_ex.state) self.assertEqual(states.RUNNING, task_ex.state)
self.await_task_error(task_ex.id) self.await_task_error(task_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self._assert_single_item(wf_ex.task_executions, name='task1') task_execs = wf_ex.task_executions
self._assert_single_item(task_execs, name='task1')
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
@ -944,9 +996,11 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual(states.RUNNING, task_ex.state) self.assertEqual(states.RUNNING, task_ex.state)
@ -955,11 +1009,13 @@ class PoliciesTest(base.EngineTestCase):
# Wait until timeout exceeds. # Wait until timeout exceeds.
self._sleep(1) self._sleep(1)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
tasks_db = wf_ex.task_executions wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
# Make sure that engine did not create extra tasks. # Make sure that engine did not create extra tasks.
self.assertEqual(1, len(tasks_db)) self.assertEqual(1, len(task_execs))
def test_timeout_policy_from_var(self): def test_timeout_policy_from_var(self):
wb_service.create_workbook_v2(TIMEOUT_FROM_VAR) wb_service.create_workbook_v2(TIMEOUT_FROM_VAR)
@ -967,9 +1023,11 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {'timeout': 1}) wf_ex = self.engine.start_workflow('wb.wf1', {'timeout': 1})
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = wf_ex.task_executions[0]
self.assertEqual(states.RUNNING, task_ex.state) self.assertEqual(states.RUNNING, task_ex.state)
@ -984,11 +1042,12 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = self._assert_single_item( wf_ex = db_api.get_workflow_execution(wf_ex.id)
wf_ex.task_executions,
name='task1' task_execs = wf_ex.task_executions
)
task_ex = self._assert_single_item(task_execs, name='task1')
self.assertEqual(states.IDLE, task_ex.state) self.assertEqual(states.IDLE, task_ex.state)
@ -998,20 +1057,22 @@ class PoliciesTest(base.EngineTestCase):
self.engine.resume_workflow(wf_ex.id) self.engine.resume_workflow(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
self._assert_single_item(wf_ex.task_executions, name='task1') wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self._assert_single_item(task_execs, name='task1')
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = self._assert_single_item( wf_ex = db_api.get_workflow_execution(wf_ex.id)
wf_ex.task_executions,
name='task1' task_execs = wf_ex.task_executions
)
next_task_ex = self._assert_single_item( task_ex = self._assert_single_item(task_execs, name='task1')
wf_ex.task_executions, next_task_ex = self._assert_single_item(task_execs, name='task2')
name='task2'
)
self.assertEqual(states.SUCCESS, task_ex.state) self.assertEqual(states.SUCCESS, task_ex.state)
self.assertEqual(states.SUCCESS, next_task_ex.state) self.assertEqual(states.SUCCESS, next_task_ex.state)
@ -1022,11 +1083,12 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {}) wf_ex = self.engine.start_workflow('wb.wf1', {})
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = self._assert_single_item( wf_ex = db_api.get_workflow_execution(wf_ex.id)
wf_ex.task_executions,
name='task1' task_execs = wf_ex.task_executions
)
task_ex = self._assert_single_item(task_execs, name='task1')
self.assertEqual(states.IDLE, task_ex.state) self.assertEqual(states.IDLE, task_ex.state)
@ -1042,24 +1104,27 @@ class PoliciesTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
task_ex = db_api.get_task_execution(task_ex.id) task_ex = db_api.get_task_execution(task_ex.id)
self.assertEqual(states.IDLE, task_ex.state) self.assertEqual(states.IDLE, task_ex.state)
self.engine.resume_workflow(wf_ex.id) self.engine.resume_workflow(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
self._assert_single_item(wf_ex.task_executions, name='task1') wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self._assert_single_item(task_execs, name='task1')
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = self._assert_single_item( wf_ex = db_api.get_workflow_execution(wf_ex.id)
wf_ex.task_executions,
name='task1' task_execs = wf_ex.task_executions
)
next_task_ex = self._assert_single_item( task_ex = self._assert_single_item(task_execs, name='task1')
wf_ex.task_executions, next_task_ex = self._assert_single_item(task_execs, name='task2')
name='task2'
)
self.assertEqual(states.SUCCESS, task_ex.state) self.assertEqual(states.SUCCESS, task_ex.state)
self.assertEqual(states.SUCCESS, next_task_ex.state) self.assertEqual(states.SUCCESS, next_task_ex.state)
@ -1072,14 +1137,14 @@ class PoliciesTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = self._assert_single_item( wf_ex = db_api.get_workflow_execution(wf_ex.id)
wf_ex.task_executions,
name='task1' task_execs = wf_ex.task_executions
)
task_ex = self._assert_single_item(task_execs, name='task1')
self.assertEqual(states.SUCCESS, task_ex.state) self.assertEqual(states.SUCCESS, task_ex.state)
self.assertEqual(4, task_ex.runtime_context['concurrency']) self.assertEqual(4, task_ex.runtime_context['concurrency'])
def test_concurrency_is_in_runtime_context_from_var(self): def test_concurrency_is_in_runtime_context_from_var(self):
@ -1088,12 +1153,12 @@ class PoliciesTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb.wf1', {'concurrency': 4}) wf_ex = self.engine.start_workflow('wb.wf1', {'concurrency': 4})
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = self._assert_single_item( task_execs = wf_ex.task_executions
wf_ex.task_executions,
name='task1' task_ex = self._assert_single_item(task_execs, name='task1')
)
self.assertEqual(4, task_ex.runtime_context['concurrency']) self.assertEqual(4, task_ex.runtime_context['concurrency'])
@ -1143,7 +1208,8 @@ class PoliciesTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(wf_ex.task_executions))

View File

@ -143,27 +143,36 @@ class EngineActionRaceConditionTest(base.EngineTestCase):
wf_ex = self.engine.start_workflow('wf', None) wf_ex = self.engine.start_workflow('wf', None)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.RUNNING, wf_ex.state) self.assertEqual(states.RUNNING, wf_ex.state)
self.assertEqual(states.RUNNING, wf_ex.task_executions[0].state) self.assertEqual(states.RUNNING, task_execs[0].state)
self.wait_for_action() self.wait_for_action()
# Here's the point when the action is blocked but already running. with db_api.transaction():
# Do the same check again, it should always pass. # Here's the point when the action is blocked but already running.
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Do the same check again, it should always pass.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.RUNNING, wf_ex.state) self.assertEqual(states.RUNNING, wf_ex.state)
self.assertEqual(states.RUNNING, wf_ex.task_executions[0].state) self.assertEqual(states.RUNNING, task_execs[0].state)
self.unblock_action() self.unblock_action()
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertDictEqual({'result': 'test'}, wf_ex.output) wf_output = wf_ex.output
self.assertDictEqual({'result': 'test'}, wf_output)
# TODO(rakhmerov): Should periodically fail now because of poor # TODO(rakhmerov): Should periodically fail now because of poor
# transaction isolation support in SQLite. Requires more research # transaction isolation support in SQLite. Requires more research

View File

@ -84,13 +84,16 @@ class ReverseWorkflowEngineTest(base.EngineTestCase):
# Wait till workflow 'wf1' is completed. # Wait till workflow 'wf1' is completed.
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(1, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
self.assertEqual(1, len(db_api.get_task_executions())) self.assertEqual(1, len(db_api.get_task_executions()))
task_ex = self._assert_single_item( task_ex = self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -114,13 +117,16 @@ class ReverseWorkflowEngineTest(base.EngineTestCase):
# Wait till workflow 'wf1' is completed. # Wait till workflow 'wf1' is completed.
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(2, len(wf_ex.task_executions)) task_execs = wf_ex.task_executions
self.assertEqual(2, len(task_execs))
self.assertEqual(2, len(db_api.get_task_executions())) self.assertEqual(2, len(db_api.get_task_executions()))
task1_ex = self._assert_single_item( task1_ex = self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -128,7 +134,7 @@ class ReverseWorkflowEngineTest(base.EngineTestCase):
self.assertDictEqual({'result1': 'a'}, task1_ex.published) self.assertDictEqual({'result1': 'a'}, task1_ex.published)
task2_ex = self._assert_single_item( task2_ex = self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task2', name='task2',
state=states.SUCCESS state=states.SUCCESS
) )

View File

@ -89,15 +89,20 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
# Run workflow and fail task. # Run workflow and fail task.
wf_ex = self.engine.start_workflow('wb1.wf1', {}, task_name='t3') wf_ex = self.engine.start_workflow('wb1.wf1', {}, task_name='t3')
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id)
with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
self.assertEqual(states.ERROR, task_2_ex.state) self.assertEqual(states.ERROR, task_2_ex.state)
@ -105,6 +110,7 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
# Resume workflow and re-run failed task. # Resume workflow and re-run failed task.
self.engine.rerun_workflow(task_2_ex.id) self.engine.rerun_workflow(task_2_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(states.RUNNING, wf_ex.state) self.assertEqual(states.RUNNING, wf_ex.state)
@ -112,21 +118,26 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
# Wait for the workflow to succeed. # Wait for the workflow to succeed.
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id)
with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
task_3_ex = self._assert_single_item(wf_ex.task_executions, name='t3') task_3_ex = self._assert_single_item(task_execs, name='t3')
# Check action executions of task 1. # Check action executions of task 1.
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
task_1_action_exs = db_api.get_action_executions( task_1_action_exs = db_api.get_action_executions(
task_execution_id=task_1_ex.id) task_execution_id=task_1_ex.id
)
self.assertEqual(1, len(task_1_action_exs)) self.assertEqual(1, len(task_1_action_exs))
self.assertEqual(states.SUCCESS, task_1_action_exs[0].state) self.assertEqual(states.SUCCESS, task_1_action_exs[0].state)
@ -136,7 +147,8 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
self.assertIsNone(task_2_ex.state_info) self.assertIsNone(task_2_ex.state_info)
task_2_action_exs = db_api.get_action_executions( task_2_action_exs = db_api.get_action_executions(
task_execution_id=task_2_ex.id) task_execution_id=task_2_ex.id
)
self.assertEqual(2, len(task_2_action_exs)) self.assertEqual(2, len(task_2_action_exs))
self.assertEqual(states.ERROR, task_2_action_exs[0].state) self.assertEqual(states.ERROR, task_2_action_exs[0].state)
@ -146,7 +158,8 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
self.assertEqual(states.SUCCESS, task_3_ex.state) self.assertEqual(states.SUCCESS, task_3_ex.state)
task_3_action_exs = db_api.get_action_executions( task_3_action_exs = db_api.get_action_executions(
task_execution_id=task_3_ex.id) task_execution_id=task_3_ex.id
)
self.assertEqual(1, len(task_3_action_exs)) self.assertEqual(1, len(task_3_action_exs))
self.assertEqual(states.SUCCESS, task_3_action_exs[0].state) self.assertEqual(states.SUCCESS, task_3_action_exs[0].state)
@ -181,16 +194,20 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
) )
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id)
with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
self.assertDictEqual(env, wf_ex.params['env']) self.assertDictEqual(env, wf_ex.params['env'])
self.assertDictEqual(env, wf_ex.context['__env']) self.assertDictEqual(env, wf_ex.context['__env'])
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
self.assertEqual(states.ERROR, task_2_ex.state) self.assertEqual(states.ERROR, task_2_ex.state)
@ -204,6 +221,7 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
# Resume workflow and re-run failed task. # Resume workflow and re-run failed task.
self.engine.rerun_workflow(task_2_ex.id, env=updated_env) self.engine.rerun_workflow(task_2_ex.id, env=updated_env)
wf_ex = db_api.get_workflow_execution(wf_ex.id) wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(states.RUNNING, wf_ex.state) self.assertEqual(states.RUNNING, wf_ex.state)
@ -213,21 +231,26 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
# Wait for the workflow to succeed. # Wait for the workflow to succeed.
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id)
with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
task_3_ex = self._assert_single_item(wf_ex.task_executions, name='t3') task_3_ex = self._assert_single_item(task_execs, name='t3')
# Check action executions of task 1. # Check action executions of task 1.
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
task_1_action_exs = db_api.get_action_executions( task_1_action_exs = db_api.get_action_executions(
task_execution_id=task_1_ex.id) task_execution_id=task_1_ex.id
)
self.assertEqual(1, len(task_1_action_exs)) self.assertEqual(1, len(task_1_action_exs))
self.assertEqual(states.SUCCESS, task_1_action_exs[0].state) self.assertEqual(states.SUCCESS, task_1_action_exs[0].state)
@ -242,7 +265,8 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
self.assertIsNone(task_2_ex.state_info) self.assertIsNone(task_2_ex.state_info)
task_2_action_exs = db_api.get_action_executions( task_2_action_exs = db_api.get_action_executions(
task_execution_id=task_2_ex.id) task_execution_id=task_2_ex.id
)
self.assertEqual(2, len(task_2_action_exs)) self.assertEqual(2, len(task_2_action_exs))
self.assertEqual(states.ERROR, task_2_action_exs[0].state) self.assertEqual(states.ERROR, task_2_action_exs[0].state)
@ -262,7 +286,8 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
self.assertEqual(states.SUCCESS, task_3_ex.state) self.assertEqual(states.SUCCESS, task_3_ex.state)
task_3_action_exs = db_api.get_action_executions( task_3_action_exs = db_api.get_action_executions(
task_execution_id=task_3_ex.id) task_execution_id=task_3_ex.id
)
self.assertEqual(1, len(task_3_action_exs)) self.assertEqual(1, len(task_3_action_exs))
self.assertEqual(states.SUCCESS, task_3_action_exs[0].state) self.assertEqual(states.SUCCESS, task_3_action_exs[0].state)
@ -287,15 +312,20 @@ class ReverseWorkflowRerunTest(base.EngineTestCase):
# Run workflow and fail task. # Run workflow and fail task.
wf_ex = self.engine.start_workflow('wb1.wf1', {}, task_name='t3') wf_ex = self.engine.start_workflow('wb1.wf1', {}, task_name='t3')
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id)
with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertIsNotNone(wf_ex.state_info) self.assertIsNotNone(wf_ex.state_info)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
task_2_ex = self._assert_single_item(wf_ex.task_executions, name='t2') task_2_ex = self._assert_single_item(task_execs, name='t2')
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
self.assertEqual(states.ERROR, task_2_ex.state) self.assertEqual(states.ERROR, task_2_ex.state)

View File

@ -121,10 +121,11 @@ class RunActionEngineTest(base.EngineTestCase):
self.await_action_success(action_ex.id) self.await_action_success(action_ex.id)
action_ex = db_api.get_action_execution(action_ex.id) with db_api.transaction():
action_ex = db_api.get_action_execution(action_ex.id)
self.assertEqual(states.SUCCESS, action_ex.state) self.assertEqual(states.SUCCESS, action_ex.state)
self.assertEqual({'result': 'Hello!'}, action_ex.output) self.assertEqual({'result': 'Hello!'}, action_ex.output)
def test_run_action_run_sync(self): def test_run_action_run_sync(self):
# Start action. # Start action.
@ -149,15 +150,21 @@ class RunActionEngineTest(base.EngineTestCase):
self.assertEqual('Hello!', action_ex.output['result']) self.assertEqual('Hello!', action_ex.output['result'])
self.assertEqual(states.SUCCESS, action_ex.state) self.assertEqual(states.SUCCESS, action_ex.state)
db_action_ex = db_api.get_action_execution(action_ex.id) with db_api.transaction():
self.assertEqual(states.SUCCESS, db_action_ex.state) action_ex = db_api.get_action_execution(action_ex.id)
self.assertEqual({'result': 'Hello!'}, db_action_ex.output)
self.assertEqual(states.SUCCESS, action_ex.state)
self.assertEqual({'result': 'Hello!'}, action_ex.output)
def test_run_action_run_sync_error(self): def test_run_action_run_sync_error(self):
# Start action. # Start action.
self.assertRaises( self.assertRaises(
exc.InputException, exc.InputException,
self.engine.start_action, 'std.async_noop', {}, run_sync=True) self.engine.start_action,
'std.async_noop',
{},
run_sync=True
)
def test_run_action_async(self): def test_run_action_async(self):
action_ex = self.engine.start_action('std.async_noop', {}) action_ex = self.engine.start_action('std.async_noop', {})
@ -176,10 +183,11 @@ class RunActionEngineTest(base.EngineTestCase):
self.await_action_error(action_ex.id) self.await_action_error(action_ex.id)
action_ex = db_api.get_action_execution(action_ex.id) with db_api.transaction():
action_ex = db_api.get_action_execution(action_ex.id)
self.assertEqual(states.ERROR, action_ex.state) self.assertEqual(states.ERROR, action_ex.state)
self.assertIn('Invoke failed.', action_ex.output.get('result', '')) self.assertIn('Invoke failed.', action_ex.output.get('result', ''))
@mock.patch.object( @mock.patch.object(
std_actions.AsyncNoOpAction, 'run', std_actions.AsyncNoOpAction, 'run',
@ -189,10 +197,11 @@ class RunActionEngineTest(base.EngineTestCase):
self.await_action_error(action_ex.id) self.await_action_error(action_ex.id)
action_ex = db_api.get_action_execution(action_ex.id) with db_api.transaction():
action_ex = db_api.get_action_execution(action_ex.id)
self.assertEqual(states.ERROR, action_ex.state) self.assertEqual(states.ERROR, action_ex.state)
self.assertIn('Invoke erred.', action_ex.output.get('result', '')) self.assertIn('Invoke erred.', action_ex.output.get('result', ''))
def test_run_action_adhoc(self): def test_run_action_adhoc(self):
# Start action and see the result. # Start action and see the result.

View File

@ -76,10 +76,11 @@ class TestSafeRerun(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(len(tasks), 2) self.assertEqual(len(tasks), 2)
@ -121,10 +122,11 @@ class TestSafeRerun(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(len(tasks), 2) self.assertEqual(len(tasks), 2)
@ -155,18 +157,19 @@ class TestSafeRerun(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(len(tasks), 1) self.assertEqual(len(tasks), 1)
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
self.assertEqual(task1.state, states.SUCCESS) self.assertEqual(task1.state, states.SUCCESS)
result = data_flow.get_task_execution_result(task1) result = data_flow.get_task_execution_result(task1)
self.assertIn(1, result) self.assertIn(1, result)
self.assertIn(2, result) self.assertIn(2, result)

View File

@ -135,16 +135,20 @@ class ExecutionStateInfoTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
self.assertEqual(states.ERROR, task_1_ex.state) self.assertEqual(states.ERROR, task_1_ex.state)
task_1_action_exs = db_api.get_action_executions( task_1_action_exs = db_api.get_action_executions(
task_execution_id=task_1_ex.id) task_execution_id=task_1_ex.id
)
self.assertEqual(3, len(task_1_action_exs)) self.assertEqual(3, len(task_1_action_exs))
self.assertIn(task_1_action_exs[0].id, wf_ex.state_info) self.assertIn(task_1_action_exs[0].id, wf_ex.state_info)

View File

@ -145,21 +145,27 @@ class SubworkflowsTest(base.EngineTestCase):
# Wait till workflow 'wf1' is completed. # Wait till workflow 'wf1' is completed.
self.await_workflow_success(wf1_ex.id) self.await_workflow_success(wf1_ex.id)
wf1_ex = db_api.get_workflow_execution(wf1_ex.id) with db_api.transaction():
wf1_ex = db_api.get_workflow_execution(wf1_ex.id)
wf1_output = wf1_ex.output
self.assertDictEqual( self.assertDictEqual(
{'final_result': "'Bonnie & Clyde'"}, {'final_result': "'Bonnie & Clyde'"},
wf1_ex.output wf1_output
) )
# Wait till workflow 'wf2' is completed. # Wait till workflow 'wf2' is completed.
self.await_workflow_success(wf2_ex.id, timeout=4) self.await_workflow_success(wf2_ex.id, timeout=4)
wf2_ex = db_api.get_workflow_execution(wf2_ex.id) with db_api.transaction():
wf2_ex = db_api.get_workflow_execution(wf2_ex.id)
wf2_output = wf2_ex.output
self.assertDictEqual( self.assertDictEqual(
{'slogan': "'Bonnie & Clyde' is a cool movie!"}, {'slogan': "'Bonnie & Clyde' is a cool movie!"},
wf2_ex.output wf2_output
) )
# Check project_id in tasks. # Check project_id in tasks.

View File

@ -60,10 +60,11 @@ class TaskDefaultsDirectWorkflowEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
task3 = self._assert_single_item(tasks, name='task3') task3 = self._assert_single_item(tasks, name='task3')
@ -109,10 +110,11 @@ class TaskDefaultsReverseWorkflowEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(1, len(tasks)) self.assertEqual(1, len(tasks))
@ -152,16 +154,17 @@ class TaskDefaultsReverseWorkflowEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(1, len(tasks)) self.assertEqual(1, len(tasks))
self._assert_single_item(tasks, name='task1', state=states.ERROR) self._assert_single_item(tasks, name='task1', state=states.ERROR)
task_ex = db_api.get_task_execution(tasks[0].id) task_ex = db_api.get_task_execution(tasks[0].id)
self.assertIn("Task timed out", task_ex.state_info) self.assertIn("Task timed out", task_ex.state_info)
def test_task_defaults_wait_policies(self): def test_task_defaults_wait_policies(self):
@ -195,13 +198,13 @@ class TaskDefaultsReverseWorkflowEngineTest(base.EngineTestCase):
2 2
) )
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(1, len(tasks)) self.assertEqual(1, len(tasks))
self._assert_single_item(tasks, name='task1', state=states.SUCCESS) self._assert_single_item(tasks, name='task1', state=states.SUCCESS)
def test_task_defaults_requires(self): def test_task_defaults_requires(self):
@ -234,10 +237,11 @@ class TaskDefaultsReverseWorkflowEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions tasks = wf_ex.task_executions
self.assertEqual(3, len(tasks)) self.assertEqual(3, len(tasks))

View File

@ -71,12 +71,15 @@ class TaskPublishTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.ERROR, wf_ex.state) self.assertEqual(states.ERROR, wf_ex.state)
self.assertEqual(1, len(wf_ex.task_executions)) self.assertEqual(1, len(task_execs))
task_1_ex = self._assert_single_item(wf_ex.task_executions, name='t1') task_1_ex = self._assert_single_item(task_execs, name='t1')
# Task 1 should have failed. # Task 1 should have failed.
self.assertEqual(states.ERROR, task_1_ex.state) self.assertEqual(states.ERROR, task_1_ex.state)
@ -84,7 +87,8 @@ class TaskPublishTest(base.EngineTestCase):
# Action execution of task 1 should have succeeded. # Action execution of task 1 should have succeeded.
task_1_action_exs = db_api.get_action_executions( task_1_action_exs = db_api.get_action_executions(
task_execution_id=task_1_ex.id) task_execution_id=task_1_ex.id
)
self.assertEqual(1, len(task_1_action_exs)) self.assertEqual(1, len(task_1_action_exs))
self.assertEqual(states.SUCCESS, task_1_action_exs[0].state) self.assertEqual(states.SUCCESS, task_1_action_exs[0].state)

View File

@ -188,10 +188,11 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
task1_ex = self._assert_single_item(task_execs, name='task1') task1_ex = self._assert_single_item(task_execs, name='task1')
@ -243,10 +244,11 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(wf_ex.task_executions))
def test_with_items_yaql_fail(self): def test_with_items_yaql_fail(self):
wf_text = """--- wf_text = """---
@ -268,14 +270,13 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
# Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1')
with db_api.transaction(): with db_api.transaction():
task1 = db_api.get_task_execution(task1.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1')
result = data_flow.get_task_execution_result(task1) result = data_flow.get_task_execution_result(task1)
@ -317,10 +318,11 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(wf_ex.task_executions))
def test_with_items_static_var(self): def test_with_items_static_var(self):
wb_service.create_workbook_v2(WB_WITH_STATIC_VAR) wb_service.create_workbook_v2(WB_WITH_STATIC_VAR)
@ -333,14 +335,12 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1')
with db_api.transaction(): with db_api.transaction():
task1 = db_api.get_task_execution(task1.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1')
result = data_flow.get_task_execution_result(task1) result = data_flow.get_task_execution_result(task1)
@ -363,18 +363,16 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
task1_ex = self._assert_single_item(task_execs, name='task1')
# Since we know that we can receive results in random order,
# check is not depend on order of items.
with db_api.transaction(): with db_api.transaction():
task1_ex = db_api.get_task_execution(task1_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
task1_ex = self._assert_single_item(task_execs, name='task1')
# Since we know that we can receive results in random order,
# check is not depend on order of items.
result = data_flow.get_task_execution_result(task1_ex) result = data_flow.get_task_execution_result(task1_ex)
self.assertIsInstance(result, list) self.assertIsInstance(result, list)
@ -392,10 +390,12 @@ class WithItemsEngineTest(base.EngineTestCase):
# Start workflow. # Start workflow.
wf_ex = self.engine.start_workflow('wb1.wf1_with_items', WF_INPUT_URLS) wf_ex = self.engine.start_workflow('wb1.wf1_with_items', WF_INPUT_URLS)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
task_ex = wf_ex.task_executions[0] wf_ex = db_api.get_workflow_execution(wf_ex.id)
act_exs = task_ex.executions task_ex = wf_ex.task_executions[0]
act_exs = task_ex.executions
self.engine.on_action_complete(act_exs[0].id, wf_utils.Result("Ivan")) self.engine.on_action_complete(act_exs[0].id, wf_utils.Result("Ivan"))
self.engine.on_action_complete(act_exs[1].id, wf_utils.Result("John")) self.engine.on_action_complete(act_exs[1].id, wf_utils.Result("John"))
@ -406,11 +406,10 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) task_ex = db_api.get_task_execution(task_ex.id)
task_ex = db_api.get_task_execution(task_ex.id) result = data_flow.get_task_execution_result(task_ex)
result = data_flow.get_task_execution_result(task_ex)
self.assertIsInstance(result, list) self.assertIsInstance(result, list)
@ -452,10 +451,11 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
task1_ex = self._assert_single_item(task_execs, name='task1') task1_ex = self._assert_single_item(task_execs, name='task1')
task2_ex = self._assert_single_item(task_execs, name='task2') task2_ex = self._assert_single_item(task_execs, name='task2')
@ -487,17 +487,15 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task1_ex = self._assert_single_item(
wf_ex.task_executions,
name='task1',
state=states.SUCCESS
)
with db_api.transaction(): with db_api.transaction():
task1_ex = db_api.get_task_execution(task1_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task1_ex = self._assert_single_item(
wf_ex.task_executions,
name='task1',
state=states.SUCCESS
)
result = data_flow.get_task_execution_result(task1_ex) result = data_flow.get_task_execution_result(task1_ex)
@ -558,11 +556,14 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
task1_ex = self._assert_single_item( task1_ex = self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1', name='task1',
state=states.SUCCESS state=states.SUCCESS
) )
@ -580,21 +581,19 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
task1_ex = self._assert_single_item(
task_execs,
name='task1',
state=states.SUCCESS
)
with db_api.transaction(): with db_api.transaction():
task1_ex = db_api.get_task_execution(task1_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(1, len(task_execs))
task1_ex = self._assert_single_item(
task_execs,
name='task1',
state=states.SUCCESS
)
result = data_flow.get_task_execution_result(task1_ex) result = data_flow.get_task_execution_result(task1_ex)
@ -1038,21 +1037,24 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
self.assertEqual(2, len(task_execs)) self.assertEqual(2, len(task_execs))
task1_ex = self._assert_single_item(task_execs, name='task1') task1_ex = self._assert_single_item(task_execs, name='task1')
task1_executions = task1_ex.executions
self.assertEqual( self.assertEqual(
2, 2,
task1_ex.runtime_context['retry_task_policy']['retry_no'] task1_ex.runtime_context['retry_task_policy']['retry_no']
) )
self.assertEqual(9, len(task1_ex.executions)) self.assertEqual(9, len(task1_executions))
self._assert_multiple_items(task1_ex.executions, 3, accepted=True) self._assert_multiple_items(task1_executions, 3, accepted=True)
@testtools.skip('Restore concurrency support.') @testtools.skip('Restore concurrency support.')
def test_with_items_retry_policy_concurrency(self): def test_with_items_retry_policy_concurrency(self):
@ -1115,14 +1117,14 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1')
with db_api.transaction(): with db_api.transaction():
task1 = db_api.get_task_execution(task1.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task1 = self._assert_single_item(
wf_ex.task_executions,
name='task1'
)
result = data_flow.get_task_execution_result(task1) result = data_flow.get_task_execution_result(task1)
@ -1165,10 +1167,11 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
task1_ex = self._assert_single_item( task1_ex = self._assert_single_item(
task_execs, task_execs,
@ -1299,10 +1302,11 @@ class WithItemsEngineTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions task_execs = wf_ex.task_executions
task1_ex = self._assert_single_item(task_execs, name='get_pages') task1_ex = self._assert_single_item(task_execs, name='get_pages')
task2_ex = self._assert_single_item(task_execs, name='well_done') task2_ex = self._assert_single_item(task_execs, name='well_done')

View File

@ -50,25 +50,25 @@ class WorkflowCancelTest(base.EngineTestCase):
self.await_workflow_cancelled(wf_ex.id) self.await_workflow_cancelled(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_1_ex = self._assert_single_item( task_execs = wf_ex.task_executions
wf_ex.task_executions,
name='task1' task_1_ex = self._assert_single_item(task_execs, name='task1')
)
self.await_task_success(task_1_ex.id) self.await_task_success(task_1_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_1_ex = self._assert_single_item( task_execs = wf_ex.task_executions
wf_ex.task_executions,
name='task1' task_1_ex = self._assert_single_item(task_execs, name='task1')
)
self.assertEqual(states.CANCELLED, wf_ex.state) self.assertEqual(states.CANCELLED, wf_ex.state)
self.assertEqual("Cancelled by user.", wf_ex.state_info) self.assertEqual("Cancelled by user.", wf_ex.state_info)
self.assertEqual(1, len(wf_ex.task_executions)) self.assertEqual(1, len(task_execs))
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
def test_cancel_paused_workflow(self): def test_cancel_paused_workflow(self):
@ -104,25 +104,28 @@ class WorkflowCancelTest(base.EngineTestCase):
self.await_workflow_cancelled(wf_ex.id) self.await_workflow_cancelled(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_1_ex = self._assert_single_item( task_execs = wf_ex.task_executions
wf_ex.task_executions,
name='task1' task_1_ex = self._assert_single_item(task_execs, name='task1')
)
self.await_task_success(task_1_ex.id) self.await_task_success(task_1_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
task_1_ex = self._assert_single_item( task_1_ex = self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task1' name='task1'
) )
self.assertEqual(states.CANCELLED, wf_ex.state) self.assertEqual(states.CANCELLED, wf_ex.state)
self.assertEqual("Cancelled by user.", wf_ex.state_info) self.assertEqual("Cancelled by user.", wf_ex.state_info)
self.assertEqual(1, len(wf_ex.task_executions)) self.assertEqual(1, len(task_execs))
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
def test_cancel_completed_workflow(self): def test_cancel_completed_workflow(self):
@ -148,16 +151,16 @@ class WorkflowCancelTest(base.EngineTestCase):
"Cancelled by user." "Cancelled by user."
) )
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_1_ex = self._assert_single_item( task_execs = wf_ex.task_executions
wf_ex.task_executions,
name='task1' task_1_ex = self._assert_single_item(task_execs, name='task1')
)
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertIsNone(wf_ex.state_info) self.assertIsNone(wf_ex.state_info)
self.assertEqual(1, len(wf_ex.task_executions)) self.assertEqual(1, len(task_execs))
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
def test_cancel_parent_workflow(self): def test_cancel_parent_workflow(self):
@ -198,15 +201,21 @@ class WorkflowCancelTest(base.EngineTestCase):
self.await_workflow_cancelled(wf_ex.id) self.await_workflow_cancelled(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_execs = wf_ex.task_executions
task_ex = self._assert_single_item(task_execs, name='taskx')
self.await_task_cancelled(task_ex.id) self.await_task_cancelled(task_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_execs = wf_ex.task_executions
task_ex = self._assert_single_item(task_execs, name='taskx')
subwf_execs = db_api.get_workflow_executions( subwf_execs = db_api.get_workflow_executions(
task_execution_id=task_ex.id task_execution_id=task_ex.id
@ -250,11 +259,15 @@ class WorkflowCancelTest(base.EngineTestCase):
self.engine.start_workflow('wb.wf', {}) self.engine.start_workflow('wb.wf', {})
wf_execs = db_api.get_workflow_executions() with db_api.transaction():
wf_execs = db_api.get_workflow_executions()
wf_ex = self._assert_single_item(wf_execs, name='wb.wf') wf_ex = self._assert_single_item(wf_execs, name='wb.wf')
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_ex = self._assert_single_item(
subwf_ex = self._assert_single_item(wf_execs, name='wb.subwf') wf_ex.task_executions,
name='taskx'
)
subwf_ex = self._assert_single_item(wf_execs, name='wb.subwf')
self.engine.stop_workflow( self.engine.stop_workflow(
subwf_ex.id, subwf_ex.id,
@ -266,11 +279,15 @@ class WorkflowCancelTest(base.EngineTestCase):
self.await_task_cancelled(task_ex.id) self.await_task_cancelled(task_ex.id)
self.await_workflow_cancelled(wf_ex.id) self.await_workflow_cancelled(wf_ex.id)
wf_execs = db_api.get_workflow_executions() with db_api.transaction():
wf_execs = db_api.get_workflow_executions()
wf_ex = self._assert_single_item(wf_execs, name='wb.wf') wf_ex = self._assert_single_item(wf_execs, name='wb.wf')
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_ex = self._assert_single_item(
subwf_ex = self._assert_single_item(wf_execs, name='wb.subwf') wf_ex.task_executions,
name='taskx'
)
subwf_ex = self._assert_single_item(wf_execs, name='wb.subwf')
self.assertEqual(states.CANCELLED, subwf_ex.state) self.assertEqual(states.CANCELLED, subwf_ex.state)
self.assertEqual("Cancelled by user.", subwf_ex.state_info) self.assertEqual("Cancelled by user.", subwf_ex.state_info)
@ -315,18 +332,29 @@ class WorkflowCancelTest(base.EngineTestCase):
"Cancelled by user." "Cancelled by user."
) )
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_execs = wf_ex.task_executions
task_ex = self._assert_single_item(task_execs, name='taskx')
self.await_workflow_cancelled(wf_ex.id) self.await_workflow_cancelled(wf_ex.id)
self.await_task_cancelled(task_ex.id) self.await_task_cancelled(task_ex.id)
wf_execs = db_api.get_workflow_executions() with db_api.transaction():
wf_execs = db_api.get_workflow_executions()
wf_ex = self._assert_single_item(wf_execs, name='wb.wf') wf_ex = self._assert_single_item(wf_execs, name='wb.wf')
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_ex = self._assert_single_item(
subwf_exs = self._assert_multiple_items(wf_execs, 2, name='wb.subwf') wf_ex.task_executions,
name='taskx'
)
subwf_exs = self._assert_multiple_items(
wf_execs,
2,
name='wb.subwf'
)
self.assertEqual(states.CANCELLED, subwf_exs[0].state) self.assertEqual(states.CANCELLED, subwf_exs[0].state)
self.assertEqual("Cancelled by user.", subwf_exs[0].state_info) self.assertEqual("Cancelled by user.", subwf_exs[0].state_info)
@ -368,11 +396,19 @@ class WorkflowCancelTest(base.EngineTestCase):
self.engine.start_workflow('wb.wf', {}) self.engine.start_workflow('wb.wf', {})
wf_execs = db_api.get_workflow_executions() with db_api.transaction():
wf_execs = db_api.get_workflow_executions()
wf_ex = self._assert_single_item(wf_execs, name='wb.wf') wf_ex = self._assert_single_item(wf_execs, name='wb.wf')
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_ex = self._assert_single_item(
subwf_exs = self._assert_multiple_items(wf_execs, 2, name='wb.subwf') wf_ex.task_executions,
name='taskx'
)
subwf_exs = self._assert_multiple_items(
wf_execs,
2,
name='wb.subwf'
)
self.engine.stop_workflow( self.engine.stop_workflow(
subwf_exs[0].id, subwf_exs[0].id,
@ -385,11 +421,19 @@ class WorkflowCancelTest(base.EngineTestCase):
self.await_task_cancelled(task_ex.id) self.await_task_cancelled(task_ex.id)
self.await_workflow_cancelled(wf_ex.id) self.await_workflow_cancelled(wf_ex.id)
wf_execs = db_api.get_workflow_executions() with db_api.transaction():
wf_execs = db_api.get_workflow_executions()
wf_ex = self._assert_single_item(wf_execs, name='wb.wf') wf_ex = self._assert_single_item(wf_execs, name='wb.wf')
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_ex = self._assert_single_item(
subwf_exs = self._assert_multiple_items(wf_execs, 2, name='wb.subwf') wf_ex.task_executions,
name='taskx'
)
subwf_exs = self._assert_multiple_items(
wf_execs,
2,
name='wb.subwf'
)
self.assertEqual(states.CANCELLED, subwf_exs[0].state) self.assertEqual(states.CANCELLED, subwf_exs[0].state)
self.assertEqual("Cancelled by user.", subwf_exs[0].state_info) self.assertEqual("Cancelled by user.", subwf_exs[0].state_info)
@ -431,11 +475,19 @@ class WorkflowCancelTest(base.EngineTestCase):
self.engine.start_workflow('wb.wf', {}) self.engine.start_workflow('wb.wf', {})
wf_execs = db_api.get_workflow_executions() with db_api.transaction():
wf_execs = db_api.get_workflow_executions()
wf_ex = self._assert_single_item(wf_execs, name='wb.wf') wf_ex = self._assert_single_item(wf_execs, name='wb.wf')
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_ex = self._assert_single_item(
subwf_exs = self._assert_multiple_items(wf_execs, 2, name='wb.subwf') wf_ex.task_executions,
name='taskx'
)
subwf_exs = self._assert_multiple_items(
wf_execs,
2,
name='wb.subwf'
)
self.engine.stop_workflow( self.engine.stop_workflow(
subwf_exs[0].id, subwf_exs[0].id,
@ -454,11 +506,19 @@ class WorkflowCancelTest(base.EngineTestCase):
self.await_task_error(task_ex.id) self.await_task_error(task_ex.id)
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_execs = db_api.get_workflow_executions() with db_api.transaction():
wf_execs = db_api.get_workflow_executions()
wf_ex = self._assert_single_item(wf_execs, name='wb.wf') wf_ex = self._assert_single_item(wf_execs, name='wb.wf')
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_ex = self._assert_single_item(
subwf_exs = self._assert_multiple_items(wf_execs, 2, name='wb.subwf') wf_ex.task_executions,
name='taskx'
)
subwf_exs = self._assert_multiple_items(
wf_execs,
2,
name='wb.subwf'
)
self.assertEqual(states.CANCELLED, subwf_exs[0].state) self.assertEqual(states.CANCELLED, subwf_exs[0].state)
self.assertEqual("Cancelled by user.", subwf_exs[0].state_info) self.assertEqual("Cancelled by user.", subwf_exs[0].state_info)
@ -500,11 +560,19 @@ class WorkflowCancelTest(base.EngineTestCase):
self.engine.start_workflow('wb.wf', {}) self.engine.start_workflow('wb.wf', {})
wf_execs = db_api.get_workflow_executions() with db_api.transaction():
wf_execs = db_api.get_workflow_executions()
wf_ex = self._assert_single_item(wf_execs, name='wb.wf') wf_ex = self._assert_single_item(wf_execs, name='wb.wf')
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_ex = self._assert_single_item(
subwf_exs = self._assert_multiple_items(wf_execs, 2, name='wb.subwf') wf_ex.task_executions,
name='taskx'
)
subwf_exs = self._assert_multiple_items(
wf_execs,
2,
name='wb.subwf'
)
self.engine.stop_workflow( self.engine.stop_workflow(
subwf_exs[1].id, subwf_exs[1].id,
@ -523,11 +591,19 @@ class WorkflowCancelTest(base.EngineTestCase):
self.await_task_error(task_ex.id) self.await_task_error(task_ex.id)
self.await_workflow_error(wf_ex.id) self.await_workflow_error(wf_ex.id)
wf_execs = db_api.get_workflow_executions() with db_api.transaction():
wf_execs = db_api.get_workflow_executions()
wf_ex = self._assert_single_item(wf_execs, name='wb.wf') wf_ex = self._assert_single_item(wf_execs, name='wb.wf')
task_ex = self._assert_single_item(wf_ex.task_executions, name='taskx') task_ex = self._assert_single_item(
subwf_exs = self._assert_multiple_items(wf_execs, 2, name='wb.subwf') wf_ex.task_executions,
name='taskx'
)
subwf_exs = self._assert_multiple_items(
wf_execs,
2,
name='wb.subwf'
)
self.assertEqual(states.CANCELLED, subwf_exs[0].state) self.assertEqual(states.CANCELLED, subwf_exs[0].state)
self.assertEqual("Cancelled by user.", subwf_exs[0].state_info) self.assertEqual("Cancelled by user.", subwf_exs[0].state_info)

View File

@ -199,23 +199,30 @@ class WorkflowResumeTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.PAUSED, wf_ex.state) self.assertEqual(states.PAUSED, wf_ex.state)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
self.engine.resume_workflow(wf_ex.id) self.engine.resume_workflow(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(wf_ex.task_executions))
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
def test_resume_reverse(self): def test_resume_reverse(self):
wb_service.create_workbook_v2(RESUME_WORKBOOK_REVERSE) wb_service.create_workbook_v2(RESUME_WORKBOOK_REVERSE)
@ -227,14 +234,16 @@ class WorkflowResumeTest(base.EngineTestCase):
task_name='task2' task_name='task2'
) )
# Note: We need to reread execution to access related tasks.
self.engine.pause_workflow(wf_ex.id) self.engine.pause_workflow(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
# Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.PAUSED, wf_ex.state) self.assertEqual(states.PAUSED, wf_ex.state)
self.assertEqual(1, len(wf_ex.task_executions)) self.assertEqual(1, len(task_execs))
self.engine.resume_workflow(wf_ex.id) self.engine.resume_workflow(wf_ex.id)
@ -243,10 +252,14 @@ class WorkflowResumeTest(base.EngineTestCase):
self.assertEqual(states.RUNNING, wf_ex.state) self.assertEqual(states.RUNNING, wf_ex.state)
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id)
with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
def test_resume_two_branches(self): def test_resume_two_branches(self):
wb_service.create_workbook_v2(WORKBOOK_TWO_BRANCHES) wb_service.create_workbook_v2(WORKBOOK_TWO_BRANCHES)
@ -256,21 +269,27 @@ class WorkflowResumeTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.PAUSED, wf_ex.state) self.assertEqual(states.PAUSED, wf_ex.state)
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
wf_ex = self.engine.resume_workflow(wf_ex.id) wf_ex = self.engine.resume_workflow(wf_ex.id)
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
# We can see 3 tasks in execution. # We can see 3 tasks in execution.
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
def test_resume_two_start_tasks(self): def test_resume_two_start_tasks(self):
wb_service.create_workbook_v2(WORKBOOK_TWO_START_TASKS) wb_service.create_workbook_v2(WORKBOOK_TWO_START_TASKS)
@ -280,12 +299,13 @@ class WorkflowResumeTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.PAUSED, wf_ex.state) self.assertEqual(states.PAUSED, wf_ex.state)
task_execs = wf_ex.task_executions
# The exact number of tasks depends on which of two tasks # The exact number of tasks depends on which of two tasks
# 'task1' and 'task2' completed earlier. # 'task1' and 'task2' completed earlier.
self.assertGreaterEqual(len(task_execs), 2) self.assertGreaterEqual(len(task_execs), 2)
@ -300,10 +320,13 @@ class WorkflowResumeTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
def test_resume_different_task_states(self): def test_resume_different_task_states(self):
wb_service.create_workbook_v2(WORKBOOK_DIFFERENT_TASK_STATES) wb_service.create_workbook_v2(WORKBOOK_DIFFERENT_TASK_STATES)
@ -313,12 +336,13 @@ class WorkflowResumeTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.PAUSED, wf_ex.state) self.assertEqual(states.PAUSED, wf_ex.state)
task_execs = wf_ex.task_executions
self.assertEqual(3, len(task_execs)) self.assertEqual(3, len(task_execs))
task2_ex = self._assert_single_item(task_execs, name='task2') task2_ex = self._assert_single_item(task_execs, name='task2')
@ -345,10 +369,13 @@ class WorkflowResumeTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state, wf_ex.state_info) self.assertEqual(states.SUCCESS, wf_ex.state, wf_ex.state_info)
self.assertEqual(4, len(wf_ex.task_executions)) self.assertEqual(4, len(task_execs))
def test_resume_fails(self): def test_resume_fails(self):
# Start and pause workflow. # Start and pause workflow.
@ -390,20 +417,16 @@ class WorkflowResumeTest(base.EngineTestCase):
self.await_workflow_paused(wf_ex.id) self.await_workflow_paused(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_1_ex = self._assert_single_item( task_execs = wf_ex.task_executions
wf_ex.task_executions,
name='task1'
)
task_2_ex = self._assert_single_item( task_1_ex = self._assert_single_item(task_execs, name='task1')
wf_ex.task_executions, task_2_ex = self._assert_single_item(task_execs, name='task2')
name='task2'
)
self.assertEqual(states.PAUSED, wf_ex.state) self.assertEqual(states.PAUSED, wf_ex.state)
self.assertEqual(2, len(wf_ex.task_executions)) self.assertEqual(2, len(task_execs))
self.assertDictEqual(env, wf_ex.params['env']) self.assertDictEqual(env, wf_ex.params['env'])
self.assertDictEqual(env, wf_ex.context['__env']) self.assertDictEqual(env, wf_ex.context['__env'])
self.assertEqual(states.SUCCESS, task_1_ex.state) self.assertEqual(states.SUCCESS, task_1_ex.state)
@ -420,17 +443,17 @@ class WorkflowResumeTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
wf_ex = db_api.get_workflow_execution(wf_ex.id) with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id)
task_execs = wf_ex.task_executions
self.assertDictEqual(updated_env, wf_ex.params['env']) self.assertDictEqual(updated_env, wf_ex.params['env'])
self.assertDictEqual(updated_env, wf_ex.context['__env']) self.assertDictEqual(updated_env, wf_ex.context['__env'])
self.assertEqual(3, len(wf_ex.task_executions)) self.assertEqual(3, len(task_execs))
# Check result of task2. # Check result of task2.
task_2_ex = self._assert_single_item( task_2_ex = self._assert_single_item(task_execs, name='task2')
wf_ex.task_executions,
name='task2'
)
self.assertEqual(states.SUCCESS, task_2_ex.state) self.assertEqual(states.SUCCESS, task_2_ex.state)
@ -445,7 +468,7 @@ class WorkflowResumeTest(base.EngineTestCase):
# Check result of task3. # Check result of task3.
task_3_ex = self._assert_single_item( task_3_ex = self._assert_single_item(
wf_ex.task_executions, task_execs,
name='task3' name='task3'
) )

View File

@ -55,10 +55,12 @@ class WorkflowVariablesTest(base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Note: We need to reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Note: We need to reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions wf_output = wf_ex.output
tasks = wf_ex.task_executions
task1 = self._assert_single_item(tasks, name='task1') task1 = self._assert_single_item(tasks, name='task1')
@ -69,5 +71,5 @@ class WorkflowVariablesTest(base.EngineTestCase):
'literal_var': 'Literal value', 'literal_var': 'Literal value',
'yaql_var': 'Hello Renat' 'yaql_var': 'Hello Renat'
}, },
wf_ex.output wf_output
) )

View File

@ -66,13 +66,14 @@ class YAQLFunctionsEngineTest(engine_test_base.EngineTestCase):
self.await_workflow_success(wf_ex.id) self.await_workflow_success(wf_ex.id)
# Reread execution to access related tasks. with db_api.transaction():
wf_ex = db_api.get_workflow_execution(wf_ex.id) # Reread execution to access related tasks.
wf_ex = db_api.get_workflow_execution(wf_ex.id)
tasks = wf_ex.task_executions
self.assertEqual(states.SUCCESS, wf_ex.state) self.assertEqual(states.SUCCESS, wf_ex.state)
tasks = wf_ex.task_executions
task1 = self._assert_single_item( task1 = self._assert_single_item(
tasks, tasks,
name='task1', name='task1',

View File

@ -219,13 +219,13 @@ class WorkflowServiceTest(base.DbTestCase):
update_env update_env
) )
self.assertDictEqual(update_env, updated.params['env']) self.assertDictEqual(update_env, updated.params['env'])
self.assertDictEqual(update_env, updated.context['__env']) self.assertDictEqual(update_env, updated.context['__env'])
fetched = db_api.get_workflow_execution(created.id) fetched = db_api.get_workflow_execution(created.id)
self.assertEqual(updated, fetched) self.assertEqual(updated, fetched)
self.assertIsNotNone(fetched.updated_at) self.assertIsNotNone(fetched.updated_at)
def test_update_workflow_execution_env_wrong_state(self): def test_update_workflow_execution_env_wrong_state(self):
wf_exec_template = { wf_exec_template = {