-
Notifications
You must be signed in to change notification settings - Fork 209
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Workflows alignment with Spring Boot (Dependency Injection for Workfl…
…ows and Activities) (#1170) * evaluating annotations Signed-off-by: salaboy <[email protected]> * adding workflows autoconfig Signed-off-by: salaboy <[email protected]> * initial @EnableDaprWorkflows implementation Signed-off-by: salaboy <[email protected]> * validating managed beans for workflows and activities Signed-off-by: salaboy <[email protected]> * [docs] remove 'beta' for Java SDK workflow docs (#1169) * fix link Signed-off-by: Hannah Hunter <[email protected]> * fix one more link Signed-off-by: Hannah Hunter <[email protected]> * remove beta from Java SDK workflow Signed-off-by: Hannah Hunter <[email protected]> --------- Signed-off-by: Hannah Hunter <[email protected]> Signed-off-by: salaboy <[email protected]> * Fix create release to run with right JDK (#1171) Signed-off-by: Artur Souza <[email protected]> Signed-off-by: salaboy <[email protected]> * Remove test from create release script. (#1172) Signed-off-by: Artur Souza <[email protected]> Signed-off-by: salaboy <[email protected]> * Fix typo crashing release script. (#1173) Signed-off-by: Artur Souza <[email protected]> Signed-off-by: salaboy <[email protected]> * Update master version to 1.14.0-SNAPSHOT (#1174) Signed-off-by: Dapr Bot <[email protected]> Signed-off-by: salaboy <[email protected]> * Generate updated javadocs for 1.13.1 (#1179) Signed-off-by: Dapr Bot <[email protected]> Co-authored-by: Dapr Bot <[email protected]> Signed-off-by: salaboy <[email protected]> * upgrading snap Signed-off-by: salaboy <[email protected]> * fix checkstyle Signed-off-by: salaboy <[email protected]> * Fix conflict and build trigger on right branch for SNAPSHOT. (#1180) Signed-off-by: Artur Souza <[email protected]> Signed-off-by: salaboy <[email protected]> * private internals Signed-off-by: salaboy <[email protected]> --------- Signed-off-by: salaboy <[email protected]> Signed-off-by: Hannah Hunter <[email protected]> Signed-off-by: Artur Souza <[email protected]> Signed-off-by: Dapr Bot <[email protected]> Co-authored-by: Hannah Hunter <[email protected]> Co-authored-by: Artur Souza <[email protected]> Co-authored-by: Dapr Bot <[email protected]> Co-authored-by: Dapr Bot <[email protected]>
- Loading branch information
1 parent
3a54a5e
commit 69f2407
Showing
11 changed files
with
249 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
44 changes: 44 additions & 0 deletions
44
...rc/test/java/io/dapr/spring/boot/autoconfigure/client/DaprWorkflowsRegistrationTests.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,44 @@ | ||
package io.dapr.spring.boot.autoconfigure.client; | ||
|
||
import io.dapr.spring.boot.autoconfigure.client.workflows.TestActivity; | ||
import io.dapr.spring.boot.autoconfigure.client.workflows.TestWorkflow; | ||
import io.dapr.workflows.client.DaprWorkflowClient; | ||
import io.dapr.workflows.runtime.WorkflowRuntimeBuilder; | ||
import org.junit.jupiter.api.Test; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.boot.test.context.SpringBootTest; | ||
|
||
import static org.junit.jupiter.api.Assertions.assertNotNull; | ||
|
||
@SpringBootTest(classes = {WorkflowTestApplication.class, DaprClientAutoConfiguration.class, TestActivity.class, TestWorkflow.class}) | ||
public class DaprWorkflowsRegistrationTests { | ||
|
||
@Autowired | ||
private DaprWorkflowClient daprWorkflowClient; | ||
|
||
@Autowired | ||
private WorkflowRuntimeBuilder workflowRuntimeBuilder; | ||
|
||
@Autowired | ||
private TestActivity testActivity; | ||
|
||
@Autowired | ||
private TestWorkflow testWorkflow; | ||
|
||
@Test | ||
public void testWorkflowInjection(){ | ||
|
||
//I cannot test here if the client works, as it needs the runtime | ||
assertNotNull(daprWorkflowClient); | ||
|
||
//@TODO: there is no way to assert the runtime and its registered workflows and activities | ||
assertNotNull(workflowRuntimeBuilder); | ||
|
||
//Check that both Activities and Workflows are managed beans | ||
assertNotNull(testActivity); | ||
assertNotNull(testWorkflow); | ||
assertNotNull(testActivity.getRestTemplate()); | ||
assertNotNull(testWorkflow.getRestTemplate()); | ||
|
||
} | ||
} |
24 changes: 24 additions & 0 deletions
24
...igure/src/test/java/io/dapr/spring/boot/autoconfigure/client/WorkflowTestApplication.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
package io.dapr.spring.boot.autoconfigure.client; | ||
|
||
import io.dapr.spring.workflows.config.EnableDaprWorkflows; | ||
import org.springframework.boot.SpringApplication; | ||
import org.springframework.boot.autoconfigure.SpringBootApplication; | ||
import org.springframework.context.annotation.Bean; | ||
import org.springframework.context.annotation.Configuration; | ||
import org.springframework.web.client.RestTemplate; | ||
|
||
@SpringBootApplication | ||
@EnableDaprWorkflows | ||
public class WorkflowTestApplication { | ||
public static void main(String[] args) { | ||
SpringApplication.run(WorkflowTestApplication.class, args); | ||
} | ||
|
||
@Configuration | ||
static class Config { | ||
@Bean | ||
RestTemplate restTemplate(){ | ||
return new RestTemplate(); | ||
} | ||
} | ||
} |
21 changes: 21 additions & 0 deletions
21
...figure/src/test/java/io/dapr/spring/boot/autoconfigure/client/workflows/TestActivity.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
package io.dapr.spring.boot.autoconfigure.client.workflows; | ||
|
||
import io.dapr.workflows.runtime.WorkflowActivity; | ||
import io.dapr.workflows.runtime.WorkflowActivityContext; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.web.client.RestTemplate; | ||
|
||
public class TestActivity implements WorkflowActivity { | ||
|
||
@Autowired | ||
private RestTemplate restTemplate; | ||
|
||
@Override | ||
public Object run(WorkflowActivityContext ctx) { | ||
return "OK"; | ||
} | ||
|
||
public RestTemplate getRestTemplate() { | ||
return restTemplate; | ||
} | ||
} |
23 changes: 23 additions & 0 deletions
23
...figure/src/test/java/io/dapr/spring/boot/autoconfigure/client/workflows/TestWorkflow.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
package io.dapr.spring.boot.autoconfigure.client.workflows; | ||
|
||
import io.dapr.workflows.Workflow; | ||
import io.dapr.workflows.WorkflowStub; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.web.client.RestTemplate; | ||
|
||
public class TestWorkflow extends Workflow { | ||
|
||
@Autowired | ||
private RestTemplate restTemplate; | ||
|
||
@Override | ||
public WorkflowStub create() { | ||
return ctx -> { | ||
ctx.callActivity(TestActivity.class.getName(), null).await(); | ||
}; | ||
} | ||
|
||
public RestTemplate getRestTemplate() { | ||
return restTemplate; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
<?xml version="1.0" encoding="UTF-8"?> | ||
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://maven.apache.org/POM/4.0.0" | ||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"> | ||
<modelVersion>4.0.0</modelVersion> | ||
|
||
<parent> | ||
<groupId>io.dapr.spring</groupId> | ||
<artifactId>dapr-spring-parent</artifactId> | ||
<version>0.14.0-SNAPSHOT</version> | ||
</parent> | ||
|
||
<artifactId>dapr-spring-workflows</artifactId> | ||
<name>dapr-spring-workflows</name> | ||
<description>Dapr Spring Workflows</description> | ||
<packaging>jar</packaging> | ||
|
||
<dependencies> | ||
<dependency> | ||
<groupId>io.dapr</groupId> | ||
<artifactId>dapr-sdk-workflows</artifactId> | ||
<version>${project.version}</version> | ||
</dependency> | ||
</dependencies> | ||
</project> |
55 changes: 55 additions & 0 deletions
55
...g-workflows/src/main/java/io/dapr/spring/workflows/config/DaprWorkflowsConfiguration.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
package io.dapr.spring.workflows.config; | ||
|
||
import io.dapr.workflows.Workflow; | ||
import io.dapr.workflows.runtime.WorkflowActivity; | ||
import io.dapr.workflows.runtime.WorkflowRuntime; | ||
import io.dapr.workflows.runtime.WorkflowRuntimeBuilder; | ||
import org.slf4j.Logger; | ||
import org.slf4j.LoggerFactory; | ||
import org.springframework.beans.BeansException; | ||
import org.springframework.beans.factory.annotation.Autowired; | ||
import org.springframework.context.ApplicationContext; | ||
import org.springframework.context.ApplicationContextAware; | ||
import org.springframework.context.annotation.Configuration; | ||
|
||
import java.util.Map; | ||
|
||
@Configuration | ||
public class DaprWorkflowsConfiguration implements ApplicationContextAware { | ||
private static final Logger LOGGER = LoggerFactory.getLogger(DaprWorkflowsConfiguration.class); | ||
|
||
private WorkflowRuntimeBuilder workflowRuntimeBuilder; | ||
|
||
public DaprWorkflowsConfiguration(WorkflowRuntimeBuilder workflowRuntimeBuilder) { | ||
this.workflowRuntimeBuilder = workflowRuntimeBuilder; | ||
} | ||
|
||
/** | ||
* Register workflows and activities to the workflowRuntimeBuilder. | ||
* @param applicationContext Spring Application Context | ||
*/ | ||
private void registerWorkflowsAndActivities(ApplicationContext applicationContext) { | ||
LOGGER.info("Registering Dapr Workflows and Activities"); | ||
Map<String, Workflow> workflowBeans = applicationContext.getBeansOfType(Workflow.class); | ||
for (Workflow w : workflowBeans.values()) { | ||
LOGGER.info("Dapr Workflow: '{}' registered", w.getClass().getName()); | ||
workflowRuntimeBuilder.registerWorkflow(w.getClass()); | ||
} | ||
|
||
Map<String, WorkflowActivity> workflowActivitiesBeans = applicationContext.getBeansOfType(WorkflowActivity.class); | ||
for (WorkflowActivity a : workflowActivitiesBeans.values()) { | ||
LOGGER.info("Dapr Workflow Activity: '{}' registered", a.getClass().getName()); | ||
workflowRuntimeBuilder.registerActivity(a.getClass()); | ||
} | ||
|
||
try (WorkflowRuntime runtime = workflowRuntimeBuilder.build()) { | ||
LOGGER.info("Starting workflow runtime ... "); | ||
runtime.start(false); | ||
} | ||
} | ||
|
||
@Override | ||
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { | ||
registerWorkflowsAndActivities(applicationContext); | ||
} | ||
} |
16 changes: 16 additions & 0 deletions
16
...r-spring-workflows/src/main/java/io/dapr/spring/workflows/config/EnableDaprWorkflows.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
package io.dapr.spring.workflows.config; | ||
|
||
|
||
import org.springframework.context.annotation.Import; | ||
|
||
import java.lang.annotation.Retention; | ||
import java.lang.annotation.Target; | ||
|
||
import static java.lang.annotation.ElementType.TYPE; | ||
import static java.lang.annotation.RetentionPolicy.RUNTIME; | ||
|
||
@Retention(RUNTIME) | ||
@Target(TYPE) | ||
@Import(DaprWorkflowsConfiguration.class) | ||
public @interface EnableDaprWorkflows { | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters