summaryrefslogtreecommitdiff
path: root/tests/temporal/Workflow/CancelSignalledChildWorkflow.php
diff options
context:
space:
mode:
authorValery Piashchynski <[email protected]>2021-01-26 11:52:03 +0300
committerGitHub <[email protected]>2021-01-26 11:52:03 +0300
commite2266b80db47444ba5858c736833a8a81b1361ad (patch)
tree37e06810352752f88032f7d0eadb554fa18b98da /tests/temporal/Workflow/CancelSignalledChildWorkflow.php
parentfae4711e3548bfd2e34f13aabfaab6a5b4e317c6 (diff)
parenta392d962508e1bc9e497c8c4ef021425bc2c67c2 (diff)
Merge pull request #502 from spiral/plugin/temporalv2.0.0-beta12
plugin(temporal): Add temporal plugins set to the RR2
Diffstat (limited to 'tests/temporal/Workflow/CancelSignalledChildWorkflow.php')
-rw-r--r--tests/temporal/Workflow/CancelSignalledChildWorkflow.php57
1 files changed, 57 insertions, 0 deletions
diff --git a/tests/temporal/Workflow/CancelSignalledChildWorkflow.php b/tests/temporal/Workflow/CancelSignalledChildWorkflow.php
new file mode 100644
index 00000000..e2e43efa
--- /dev/null
+++ b/tests/temporal/Workflow/CancelSignalledChildWorkflow.php
@@ -0,0 +1,57 @@
+<?php
+
+namespace Temporal\Tests\Workflow;
+
+use React\Promise\Deferred;
+use Temporal\Workflow;
+use Temporal\Workflow\WorkflowMethod;
+
+#[Workflow\WorkflowInterface]
+class CancelSignalledChildWorkflow
+{
+ private array $status = [];
+
+ #[Workflow\QueryMethod(name: 'getStatus')]
+ public function getStatus(): array
+ {
+ return $this->status;
+ }
+
+ #[WorkflowMethod(name: 'CancelSignalledChildWorkflow')]
+ public function handler()
+ {
+ // typed stub
+ $simple = Workflow::newChildWorkflowStub(SimpleSignalledWorkflow::class);
+
+ $waitSignalled = new Deferred();
+
+ $this->status[] = 'start';
+
+ // start execution
+ $scope = Workflow::newCancellationScope(
+ function () use ($simple, $waitSignalled) {
+ $call = $simple->handler();
+ $this->status[] = 'child started';
+
+ yield $simple->add(8);
+ $this->status[] = 'child signalled';
+ $waitSignalled->resolve();
+
+ return yield $call;
+ }
+ );
+
+ // only cancel scope when signal dispatched
+ yield $waitSignalled;
+ $scope->cancel();
+ $this->status[] = 'scope cancelled';
+
+ try {
+ return yield $scope;
+ } catch (\Throwable $e) {
+ $this->status[] = 'process done';
+
+ return 'cancelled ok';
+ }
+ }
+}