summaryrefslogtreecommitdiff
path: root/tests/temporal/Workflow/WorkflowWithSignalledSteps.php
diff options
context:
space:
mode:
authorValery Piashchynski <[email protected]>2021-01-25 22:47:02 +0300
committerValery Piashchynski <[email protected]>2021-01-25 22:47:02 +0300
commit43071e43a0743ff8c7913bba7819952962124355 (patch)
treee3b61113d3c0d28f972c71592af8b2f708994167 /tests/temporal/Workflow/WorkflowWithSignalledSteps.php
parent5fd1168c687040ca7d72f4727ee1aec753d3f258 (diff)
Initial commit of the Temporal plugins set
Diffstat (limited to 'tests/temporal/Workflow/WorkflowWithSignalledSteps.php')
-rw-r--r--tests/temporal/Workflow/WorkflowWithSignalledSteps.php51
1 files changed, 51 insertions, 0 deletions
diff --git a/tests/temporal/Workflow/WorkflowWithSignalledSteps.php b/tests/temporal/Workflow/WorkflowWithSignalledSteps.php
new file mode 100644
index 00000000..5f1af766
--- /dev/null
+++ b/tests/temporal/Workflow/WorkflowWithSignalledSteps.php
@@ -0,0 +1,51 @@
+<?php
+
+
+namespace Temporal\Tests\Workflow;
+
+use React\Promise\Deferred;
+use React\Promise\PromiseInterface;
+use Temporal\Activity\ActivityOptions;
+use Temporal\Workflow;
+use Temporal\Workflow\WorkflowMethod;
+use Temporal\Tests\Activity\SimpleActivity;
+
+#[Workflow\WorkflowInterface]
+class WorkflowWithSignalledSteps
+{
+ #[WorkflowMethod(name: 'WorkflowWithSignalledSteps')]
+ public function handler()
+ {
+ $simple = Workflow::newActivityStub(
+ SimpleActivity::class,
+ ActivityOptions::new()->withStartToCloseTimeout(5)
+ );
+
+ $value = 0;
+ Workflow::registerQuery('value', function () use (&$value) {
+ return $value;
+ });
+
+ yield $this->promiseSignal('begin');
+ $value++;
+
+ yield $this->promiseSignal('next1');
+ $value++;
+
+ yield $this->promiseSignal('next2');
+ $value++;
+
+ return $value;
+ }
+
+ // is this correct?
+ private function promiseSignal(string $name): PromiseInterface
+ {
+ $signal = new Deferred();
+ Workflow::registerSignal($name, function ($value) use ($signal) {
+ $signal->resolve($value);
+ });
+
+ return $signal->promise();
+ }
+}