Will-Lo commented on code in PR #4002:
URL: https://github.com/apache/gobblin/pull/4002#discussion_r1681865265


##########
gobblin-service/src/main/java/org/apache/gobblin/service/modules/orchestration/task/LaunchDagTask.java:
##########
@@ -36,4 +42,25 @@ public LaunchDagTask(DagActionStore.DagAction dagAction, 
LeaseAttemptStatus.Leas
   public <T> T host(DagTaskVisitor<T> visitor) {
     return visitor.meet(this);
   }
+
+  @Override
+  public final boolean conclude() {
+    try {
+      // Delete adhoc flowSpecs from catalog if the dag was concluded properly

Review Comment:
   You probably want to rename this comment to be "remove adhoc flowspecs after 
the adhoc job is launched", to be more accurate to what we want out of the 
behavior



##########
gobblin-service/src/test/java/org/apache/gobblin/service/modules/orchestration/DagProcessingEngineTest.java:
##########
@@ -54,7 +54,7 @@ public class DagProcessingEngineTest {
   private DagManagementTaskStreamImpl dagManagementTaskStream;
   private DagTaskStream dagTaskStream;
   private DagProcFactory dagProcFactory;
-  private static MostlyMySqlDagManagementStateStore dagManagementStateStore;
+  private static MostlyMySqlDagManagementStateStore 
testDagManagementStateStore;

Review Comment:
   Does this field need to be static? If so please add a comment as to why



##########
gobblin-service/src/main/java/org/apache/gobblin/service/modules/orchestration/task/LaunchDagTask.java:
##########
@@ -36,4 +43,25 @@ public LaunchDagTask(DagActionStore.DagAction dagAction, 
LeaseAttemptStatus.Leas
   public <T> T host(DagTaskVisitor<T> visitor) {
     return visitor.meet(this);
   }
+
+  @Override
+  public final boolean conclude() {
+    try {
+      // Delete adhoc flowSpecs from catalog if the dag was concluded properly
+      if (super.conclude()) {
+        DagManager.DagId dagId = 
DagManagerUtils.generateDagId(this.dagAction.getFlowGroup(),
+            this.dagAction.getFlowName(), this.dagAction.getFlowExecutionId());
+        FlowSpec flowSpec =
+            
this.dagManagementStateStore.getFlowSpec(FlowSpec.Utils.createFlowSpecUri(dagId.getFlowId()));
+        flowSpec.addProperty(ConfigurationKeys.FLOW_EXECUTION_ID_KEY, 
dagId.getFlowExecutionId());
+        if (!flowSpec.isScheduled()) {
+          dagManagementStateStore.removeFlowSpec(flowSpec);

Review Comment:
   My take is that I prefer avoiding overloading functions unless absolutely 
needed



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: [email protected]

For queries about this service, please contact Infrastructure at:
[email protected]

Reply via email to