Fixing workflow execution state calculation
* Fixed workflow execution state calculation when it didn't take to account conditional transitions (Error was considered handled even if transition doesn't trigger a task) Closes-Bug: #1510936 Change-Id: Ia694b6dba9ab2ce9bff2da1fe05f5988864619d9
This commit is contained in:
parent
188d497959
commit
6662bec314
@ -93,6 +93,45 @@ class DirectWorkflowEngineTest(base.EngineTestCase):
|
||||
|
||||
self.assertTrue(wf_ex.state, states.ERROR)
|
||||
|
||||
def test_direct_workflow_condition_transition_not_triggering(self):
|
||||
wf_text = """---
|
||||
version: '2.0'
|
||||
|
||||
wf:
|
||||
input:
|
||||
- var: null
|
||||
|
||||
tasks:
|
||||
task1:
|
||||
action: std.fail
|
||||
on-success:
|
||||
- task2
|
||||
on-error:
|
||||
- task3: <% $.var != null %>
|
||||
|
||||
task2:
|
||||
action: std.noop
|
||||
|
||||
task3:
|
||||
action: std.noop
|
||||
"""
|
||||
|
||||
wf_service.create_workflows(wf_text)
|
||||
wf_ex = self.engine.start_workflow('wf', {})
|
||||
|
||||
self._await(lambda: self.is_execution_error(wf_ex.id))
|
||||
|
||||
wf_ex = db_api.get_workflow_execution(wf_ex.id)
|
||||
tasks = wf_ex.task_executions
|
||||
|
||||
task1 = self._assert_single_item(tasks, name='task1')
|
||||
|
||||
self.assertEqual(1, len(tasks))
|
||||
|
||||
self._await(lambda: self.is_task_error(task1.id))
|
||||
|
||||
self.assertTrue(wf_ex.state, states.ERROR)
|
||||
|
||||
def test_direct_workflow_change_state_after_success(self):
|
||||
wf_text = """
|
||||
version: '2.0'
|
||||
|
@ -150,7 +150,13 @@ class DirectWorkflowController(base.WorkflowController):
|
||||
|
||||
def all_errors_handled(self):
|
||||
for t_ex in wf_utils.find_error_task_executions(self.wf_ex):
|
||||
if not self.wf_spec.get_on_error_clause(t_ex.name):
|
||||
|
||||
tasks_on_error = self._find_next_task_names_for_clause(
|
||||
self.wf_spec.get_on_error_clause(t_ex.name),
|
||||
data_flow.evaluate_task_outbound_context(t_ex)
|
||||
)
|
||||
|
||||
if not tasks_on_error:
|
||||
return False
|
||||
|
||||
return True
|
||||
|
Loading…
x
Reference in New Issue
Block a user