2023-08-12 07:59:33 +00:00
|
|
|
import re
|
|
|
|
|
|
|
|
import pytest
|
2023-11-30 15:55:51 +00:00
|
|
|
from freezegun import freeze_time
|
2015-10-26 05:31:00 +00:00
|
|
|
|
2016-01-17 23:00:57 +00:00
|
|
|
from moto.swf.exceptions import SWFWorkflowExecutionClosedError
|
2023-11-30 15:55:51 +00:00
|
|
|
from moto.swf.models import DecisionTask, Timeout
|
2015-10-26 05:31:00 +00:00
|
|
|
|
2015-11-05 01:47:05 +00:00
|
|
|
from ..utils import make_workflow_execution, process_first_timeout
|
2015-10-26 05:31:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
def test_decision_task_creation():
|
|
|
|
wfe = make_workflow_execution()
|
|
|
|
dt = DecisionTask(wfe, 123)
|
2023-08-12 07:59:33 +00:00
|
|
|
assert dt.workflow_execution == wfe
|
|
|
|
assert dt.state == "SCHEDULED"
|
|
|
|
assert re.match("[-a-z0-9]+", dt.task_token)
|
|
|
|
assert dt.started_event_id is None
|
2015-10-26 05:31:00 +00:00
|
|
|
|
2016-02-02 19:02:37 +00:00
|
|
|
|
2015-10-26 05:31:00 +00:00
|
|
|
def test_decision_task_full_dict_representation():
|
|
|
|
wfe = make_workflow_execution()
|
|
|
|
wft = wfe.workflow_type
|
|
|
|
dt = DecisionTask(wfe, 123)
|
|
|
|
|
|
|
|
fd = dt.to_full_dict()
|
2023-08-12 07:59:33 +00:00
|
|
|
assert isinstance(fd["events"], list)
|
|
|
|
assert "previousStartedEventId" not in fd
|
|
|
|
assert "startedEventId" not in fd
|
|
|
|
assert "taskToken" in fd
|
|
|
|
assert fd["workflowExecution"] == wfe.to_short_dict()
|
|
|
|
assert fd["workflowType"] == wft.to_short_dict()
|
2015-10-26 05:31:00 +00:00
|
|
|
|
2020-02-25 15:08:03 +00:00
|
|
|
dt.start(1234, 1230)
|
2015-10-26 05:31:00 +00:00
|
|
|
fd = dt.to_full_dict()
|
2023-08-12 07:59:33 +00:00
|
|
|
assert fd["startedEventId"] == 1234
|
|
|
|
assert fd["previousStartedEventId"] == 1230
|
2015-11-04 09:12:17 +00:00
|
|
|
|
2016-02-02 19:02:37 +00:00
|
|
|
|
2015-11-05 01:22:02 +00:00
|
|
|
def test_decision_task_first_timeout():
|
2015-11-04 09:12:17 +00:00
|
|
|
wfe = make_workflow_execution()
|
|
|
|
dt = DecisionTask(wfe, 123)
|
2023-08-12 07:59:33 +00:00
|
|
|
assert dt.first_timeout() is None
|
2015-11-04 09:12:17 +00:00
|
|
|
|
|
|
|
with freeze_time("2015-01-01 12:00:00"):
|
|
|
|
dt.start(1234)
|
2023-08-12 07:59:33 +00:00
|
|
|
assert dt.first_timeout() is None
|
2015-11-04 09:12:17 +00:00
|
|
|
|
|
|
|
# activity task timeout is 300s == 5mins
|
|
|
|
with freeze_time("2015-01-01 12:06:00"):
|
2023-08-12 07:59:33 +00:00
|
|
|
assert isinstance(dt.first_timeout(), Timeout)
|
2015-11-04 09:12:17 +00:00
|
|
|
|
|
|
|
dt.complete()
|
2023-08-12 07:59:33 +00:00
|
|
|
assert dt.first_timeout() is None
|
2015-11-04 21:35:45 +00:00
|
|
|
|
2016-02-02 19:02:37 +00:00
|
|
|
|
2015-11-04 21:35:45 +00:00
|
|
|
def test_decision_task_cannot_timeout_on_closed_workflow_execution():
|
|
|
|
with freeze_time("2015-01-01 12:00:00"):
|
|
|
|
wfe = make_workflow_execution()
|
|
|
|
wfe.start()
|
|
|
|
|
|
|
|
with freeze_time("2015-01-01 13:55:00"):
|
|
|
|
dt = DecisionTask(wfe, 123)
|
|
|
|
dt.start(1234)
|
|
|
|
|
|
|
|
with freeze_time("2015-01-01 14:10:00"):
|
2023-08-12 07:59:33 +00:00
|
|
|
assert isinstance(dt.first_timeout(), Timeout)
|
|
|
|
assert isinstance(wfe.first_timeout(), Timeout)
|
2015-11-05 01:47:05 +00:00
|
|
|
process_first_timeout(wfe)
|
2023-08-12 07:59:33 +00:00
|
|
|
assert dt.first_timeout() is None
|
2015-11-05 00:12:51 +00:00
|
|
|
|
2016-02-02 19:02:37 +00:00
|
|
|
|
2015-11-05 00:12:51 +00:00
|
|
|
def test_decision_task_cannot_change_state_on_closed_workflow_execution():
|
|
|
|
wfe = make_workflow_execution()
|
|
|
|
wfe.start()
|
|
|
|
task = DecisionTask(wfe, 123)
|
|
|
|
|
|
|
|
wfe.complete(123)
|
|
|
|
|
2023-08-12 07:59:33 +00:00
|
|
|
with pytest.raises(SWFWorkflowExecutionClosedError):
|
|
|
|
task.timeout(Timeout(task, 0, "foo"))
|
|
|
|
with pytest.raises(SWFWorkflowExecutionClosedError):
|
|
|
|
task.complete()
|