Wenjun Ruan
2 months ago
committed by
GitHub
22 changed files with 1441 additions and 48 deletions
@ -0,0 +1,35 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.extract.master.transportor.workflow; |
||||
|
||||
import lombok.AllArgsConstructor; |
||||
import lombok.Builder; |
||||
import lombok.Data; |
||||
import lombok.NoArgsConstructor; |
||||
|
||||
@Data |
||||
@Builder |
||||
@NoArgsConstructor |
||||
@AllArgsConstructor |
||||
public class WorkflowInstanceRecoverFailureTasksRequest { |
||||
|
||||
private Integer workflowInstanceId; |
||||
|
||||
private Integer userId; |
||||
|
||||
} |
@ -0,0 +1,39 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.extract.master.transportor.workflow; |
||||
|
||||
import lombok.AllArgsConstructor; |
||||
import lombok.Data; |
||||
import lombok.NoArgsConstructor; |
||||
|
||||
@Data |
||||
@AllArgsConstructor |
||||
@NoArgsConstructor |
||||
public class WorkflowInstanceRecoverFailureTasksResponse { |
||||
|
||||
private boolean success; |
||||
private String message; |
||||
|
||||
public static WorkflowInstanceRecoverFailureTasksResponse success() { |
||||
return new WorkflowInstanceRecoverFailureTasksResponse(true, null); |
||||
} |
||||
|
||||
public static WorkflowInstanceRecoverFailureTasksResponse fail(String message) { |
||||
return new WorkflowInstanceRecoverFailureTasksResponse(false, message); |
||||
} |
||||
} |
@ -0,0 +1,35 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.extract.master.transportor.workflow; |
||||
|
||||
import lombok.AllArgsConstructor; |
||||
import lombok.Builder; |
||||
import lombok.Data; |
||||
import lombok.NoArgsConstructor; |
||||
|
||||
@Data |
||||
@Builder |
||||
@NoArgsConstructor |
||||
@AllArgsConstructor |
||||
public class WorkflowInstanceRecoverSuspendTasksRequest { |
||||
|
||||
private Integer workflowInstanceId; |
||||
|
||||
private Integer userId; |
||||
|
||||
} |
@ -0,0 +1,39 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.extract.master.transportor.workflow; |
||||
|
||||
import lombok.AllArgsConstructor; |
||||
import lombok.Data; |
||||
import lombok.NoArgsConstructor; |
||||
|
||||
@Data |
||||
@AllArgsConstructor |
||||
@NoArgsConstructor |
||||
public class WorkflowInstanceRecoverSuspendTasksResponse { |
||||
|
||||
private boolean success; |
||||
private String message; |
||||
|
||||
public static WorkflowInstanceRecoverSuspendTasksResponse success() { |
||||
return new WorkflowInstanceRecoverSuspendTasksResponse(true, null); |
||||
} |
||||
|
||||
public static WorkflowInstanceRecoverSuspendTasksResponse fail(String message) { |
||||
return new WorkflowInstanceRecoverSuspendTasksResponse(false, message); |
||||
} |
||||
} |
@ -0,0 +1,35 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.extract.master.transportor.workflow; |
||||
|
||||
import lombok.AllArgsConstructor; |
||||
import lombok.Builder; |
||||
import lombok.Data; |
||||
import lombok.NoArgsConstructor; |
||||
|
||||
@Data |
||||
@Builder |
||||
@NoArgsConstructor |
||||
@AllArgsConstructor |
||||
public class WorkflowInstanceRepeatRunningRequest { |
||||
|
||||
private Integer workflowInstanceId; |
||||
|
||||
private Integer userId; |
||||
|
||||
} |
@ -0,0 +1,39 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.extract.master.transportor.workflow; |
||||
|
||||
import lombok.AllArgsConstructor; |
||||
import lombok.Data; |
||||
import lombok.NoArgsConstructor; |
||||
|
||||
@Data |
||||
@AllArgsConstructor |
||||
@NoArgsConstructor |
||||
public class WorkflowInstanceRepeatRunningResponse { |
||||
|
||||
private boolean success; |
||||
private String message; |
||||
|
||||
public static WorkflowInstanceRepeatRunningResponse success() { |
||||
return new WorkflowInstanceRepeatRunningResponse(true, null); |
||||
} |
||||
|
||||
public static WorkflowInstanceRepeatRunningResponse fail(String message) { |
||||
return new WorkflowInstanceRepeatRunningResponse(false, message); |
||||
} |
||||
} |
@ -0,0 +1,76 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.server.master.engine.workflow.trigger; |
||||
|
||||
import org.apache.dolphinscheduler.dao.entity.Command; |
||||
import org.apache.dolphinscheduler.dao.entity.WorkflowInstance; |
||||
import org.apache.dolphinscheduler.dao.repository.CommandDao; |
||||
import org.apache.dolphinscheduler.dao.repository.UserDao; |
||||
import org.apache.dolphinscheduler.dao.repository.WorkflowDefinitionLogDao; |
||||
import org.apache.dolphinscheduler.dao.repository.WorkflowInstanceDao; |
||||
|
||||
import lombok.extern.slf4j.Slf4j; |
||||
|
||||
import org.springframework.beans.factory.annotation.Autowired; |
||||
import org.springframework.transaction.annotation.Transactional; |
||||
|
||||
@Slf4j |
||||
public abstract class AbstractWorkflowInstanceTrigger<TriggerRequest, TriggerResponse> |
||||
implements |
||||
IWorkflowTrigger<TriggerRequest, TriggerResponse> { |
||||
|
||||
@Autowired |
||||
private WorkflowDefinitionLogDao workflowDefinitionDao; |
||||
|
||||
@Autowired |
||||
private WorkflowInstanceDao workflowInstanceDao; |
||||
|
||||
@Autowired |
||||
private UserDao userDao; |
||||
|
||||
@Autowired |
||||
private CommandDao commandDao; |
||||
|
||||
@Override |
||||
@Transactional |
||||
public TriggerResponse triggerWorkflow(final TriggerRequest triggerRequest) { |
||||
final WorkflowInstance workflowInstance = constructWorkflowInstance(triggerRequest); |
||||
workflowInstanceDao.updateById(workflowInstance); |
||||
|
||||
final Command command = constructTriggerCommand(triggerRequest, workflowInstance); |
||||
commandDao.insert(command); |
||||
|
||||
return onTriggerSuccess(workflowInstance); |
||||
} |
||||
|
||||
protected abstract WorkflowInstance constructWorkflowInstance(final TriggerRequest triggerRequest); |
||||
|
||||
protected abstract Command constructTriggerCommand(final TriggerRequest triggerRequest, |
||||
final WorkflowInstance workflowInstance); |
||||
|
||||
protected abstract TriggerResponse onTriggerSuccess(final WorkflowInstance workflowInstance); |
||||
|
||||
protected WorkflowInstance getWorkflowInstance(final Integer workflowInstanceId) { |
||||
final WorkflowInstance workflowInstance = workflowInstanceDao.queryById(workflowInstanceId); |
||||
if (workflowInstance == null) { |
||||
throw new IllegalStateException("Workflow instance not found: " + workflowInstanceId); |
||||
} |
||||
return workflowInstance; |
||||
} |
||||
|
||||
} |
@ -0,0 +1,58 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.server.master.engine.workflow.trigger; |
||||
|
||||
import org.apache.dolphinscheduler.common.enums.CommandType; |
||||
import org.apache.dolphinscheduler.dao.entity.Command; |
||||
import org.apache.dolphinscheduler.dao.entity.WorkflowInstance; |
||||
import org.apache.dolphinscheduler.extract.master.transportor.workflow.WorkflowInstanceRecoverFailureTasksRequest; |
||||
import org.apache.dolphinscheduler.extract.master.transportor.workflow.WorkflowInstanceRecoverFailureTasksResponse; |
||||
|
||||
import java.util.Date; |
||||
|
||||
import org.springframework.stereotype.Component; |
||||
|
||||
@Component |
||||
public class WorkflowInstanceRecoverFailureTaskTrigger |
||||
extends |
||||
AbstractWorkflowInstanceTrigger<WorkflowInstanceRecoverFailureTasksRequest, WorkflowInstanceRecoverFailureTasksResponse> { |
||||
|
||||
@Override |
||||
protected WorkflowInstance constructWorkflowInstance(final WorkflowInstanceRecoverFailureTasksRequest workflowInstanceRecoverFailureTasksRequest) { |
||||
return getWorkflowInstance(workflowInstanceRecoverFailureTasksRequest.getWorkflowInstanceId()); |
||||
} |
||||
|
||||
@Override |
||||
protected Command constructTriggerCommand(final WorkflowInstanceRecoverFailureTasksRequest workflowInstanceRecoverFailureTasksRequest, |
||||
final WorkflowInstance workflowInstance) { |
||||
return Command.builder() |
||||
.commandType(CommandType.START_FAILURE_TASK_PROCESS) |
||||
.processDefinitionCode(workflowInstance.getProcessDefinitionCode()) |
||||
.processDefinitionVersion(workflowInstance.getProcessDefinitionVersion()) |
||||
.processInstanceId(workflowInstance.getId()) |
||||
.executorId(workflowInstanceRecoverFailureTasksRequest.getUserId()) |
||||
.startTime(new Date()) |
||||
.updateTime(new Date()) |
||||
.build(); |
||||
} |
||||
|
||||
@Override |
||||
protected WorkflowInstanceRecoverFailureTasksResponse onTriggerSuccess(WorkflowInstance workflowInstance) { |
||||
return WorkflowInstanceRecoverFailureTasksResponse.success(); |
||||
} |
||||
} |
@ -0,0 +1,58 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.server.master.engine.workflow.trigger; |
||||
|
||||
import org.apache.dolphinscheduler.common.enums.CommandType; |
||||
import org.apache.dolphinscheduler.dao.entity.Command; |
||||
import org.apache.dolphinscheduler.dao.entity.WorkflowInstance; |
||||
import org.apache.dolphinscheduler.extract.master.transportor.workflow.WorkflowInstanceRecoverSuspendTasksRequest; |
||||
import org.apache.dolphinscheduler.extract.master.transportor.workflow.WorkflowInstanceRecoverSuspendTasksResponse; |
||||
|
||||
import java.util.Date; |
||||
|
||||
import org.springframework.stereotype.Component; |
||||
|
||||
@Component |
||||
public class WorkflowInstanceRecoverSuspendTaskTrigger |
||||
extends |
||||
AbstractWorkflowInstanceTrigger<WorkflowInstanceRecoverSuspendTasksRequest, WorkflowInstanceRecoverSuspendTasksResponse> { |
||||
|
||||
@Override |
||||
protected WorkflowInstance constructWorkflowInstance(final WorkflowInstanceRecoverSuspendTasksRequest workflowInstanceRecoverSuspendTasksRequest) { |
||||
return getWorkflowInstance(workflowInstanceRecoverSuspendTasksRequest.getWorkflowInstanceId()); |
||||
} |
||||
|
||||
@Override |
||||
protected Command constructTriggerCommand(final WorkflowInstanceRecoverSuspendTasksRequest workflowInstanceRecoverSuspendTasksRequest, |
||||
final WorkflowInstance workflowInstance) { |
||||
return Command.builder() |
||||
.commandType(CommandType.RECOVER_SUSPENDED_PROCESS) |
||||
.processDefinitionCode(workflowInstance.getProcessDefinitionCode()) |
||||
.processDefinitionVersion(workflowInstance.getProcessDefinitionVersion()) |
||||
.processInstanceId(workflowInstance.getId()) |
||||
.executorId(workflowInstanceRecoverSuspendTasksRequest.getUserId()) |
||||
.startTime(new Date()) |
||||
.updateTime(new Date()) |
||||
.build(); |
||||
} |
||||
|
||||
@Override |
||||
protected WorkflowInstanceRecoverSuspendTasksResponse onTriggerSuccess(WorkflowInstance workflowInstance) { |
||||
return WorkflowInstanceRecoverSuspendTasksResponse.success(); |
||||
} |
||||
} |
@ -0,0 +1,58 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.server.master.engine.workflow.trigger; |
||||
|
||||
import org.apache.dolphinscheduler.common.enums.CommandType; |
||||
import org.apache.dolphinscheduler.dao.entity.Command; |
||||
import org.apache.dolphinscheduler.dao.entity.WorkflowInstance; |
||||
import org.apache.dolphinscheduler.extract.master.transportor.workflow.WorkflowInstanceRepeatRunningRequest; |
||||
import org.apache.dolphinscheduler.extract.master.transportor.workflow.WorkflowInstanceRepeatRunningResponse; |
||||
|
||||
import java.util.Date; |
||||
|
||||
import org.springframework.stereotype.Component; |
||||
|
||||
@Component |
||||
public class WorkflowInstanceRepeatTrigger |
||||
extends |
||||
AbstractWorkflowInstanceTrigger<WorkflowInstanceRepeatRunningRequest, WorkflowInstanceRepeatRunningResponse> { |
||||
|
||||
@Override |
||||
protected WorkflowInstance constructWorkflowInstance(final WorkflowInstanceRepeatRunningRequest repeatRunningRequest) { |
||||
return getWorkflowInstance(repeatRunningRequest.getWorkflowInstanceId()); |
||||
} |
||||
|
||||
@Override |
||||
protected Command constructTriggerCommand(final WorkflowInstanceRepeatRunningRequest repeatRunningRequest, |
||||
final WorkflowInstance workflowInstance) { |
||||
return Command.builder() |
||||
.commandType(CommandType.REPEAT_RUNNING) |
||||
.processInstanceId(workflowInstance.getId()) |
||||
.processDefinitionCode(workflowInstance.getProcessDefinitionCode()) |
||||
.processDefinitionVersion(workflowInstance.getProcessDefinitionVersion()) |
||||
.executorId(repeatRunningRequest.getUserId()) |
||||
.startTime(new Date()) |
||||
.updateTime(new Date()) |
||||
.build(); |
||||
} |
||||
|
||||
@Override |
||||
protected WorkflowInstanceRepeatRunningResponse onTriggerSuccess(final WorkflowInstance workflowInstance) { |
||||
return WorkflowInstanceRepeatRunningResponse.success(); |
||||
} |
||||
} |
@ -0,0 +1,117 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.server.master.it.cases; |
||||
|
||||
import static com.google.common.truth.Truth.assertThat; |
||||
import static org.awaitility.Awaitility.await; |
||||
|
||||
import org.apache.dolphinscheduler.common.enums.Flag; |
||||
import org.apache.dolphinscheduler.common.enums.WorkflowExecutionStatus; |
||||
import org.apache.dolphinscheduler.dao.entity.TaskInstance; |
||||
import org.apache.dolphinscheduler.dao.entity.WorkflowInstance; |
||||
import org.apache.dolphinscheduler.plugin.task.api.enums.TaskExecutionStatus; |
||||
import org.apache.dolphinscheduler.server.master.AbstractMasterIntegrationTest; |
||||
import org.apache.dolphinscheduler.server.master.engine.IWorkflowRepository; |
||||
import org.apache.dolphinscheduler.server.master.it.Repository; |
||||
import org.apache.dolphinscheduler.server.master.it.WorkflowITContext; |
||||
import org.apache.dolphinscheduler.server.master.it.WorkflowITContextFactory; |
||||
import org.apache.dolphinscheduler.server.master.it.WorkflowOperator; |
||||
|
||||
import org.apache.commons.lang3.StringUtils; |
||||
|
||||
import java.time.Duration; |
||||
import java.util.List; |
||||
|
||||
import org.assertj.core.api.Assertions; |
||||
import org.junit.jupiter.api.DisplayName; |
||||
import org.junit.jupiter.api.Test; |
||||
import org.springframework.beans.factory.annotation.Autowired; |
||||
|
||||
/** |
||||
* The integration test for recover from failure tasks. |
||||
*/ |
||||
public class WorkflowInstanceRecoverFailureTaskIT extends AbstractMasterIntegrationTest { |
||||
|
||||
@Autowired |
||||
private WorkflowITContextFactory workflowITContextFactory; |
||||
|
||||
@Autowired |
||||
private WorkflowOperator workflowOperator; |
||||
|
||||
@Autowired |
||||
private IWorkflowRepository workflowRepository; |
||||
|
||||
@Autowired |
||||
private Repository repository; |
||||
|
||||
@Test |
||||
@DisplayName("Test recover from failure tasks") |
||||
public void testRepeatRunningWorkflow_with_taskOnly() { |
||||
final String yaml = "/it/recover_failure_tasks/failure_workflow_with_two_serial_fake_task.yaml"; |
||||
final WorkflowITContext context = workflowITContextFactory.initializeContextFromYaml(yaml); |
||||
|
||||
final Integer workflowInstanceId = context.getWorkflowInstance().getId(); |
||||
workflowOperator.recoverFailureTasks(workflowInstanceId); |
||||
|
||||
await() |
||||
.pollInterval(Duration.ofMillis(100)) |
||||
.atMost(Duration.ofMinutes(1)) |
||||
.untilAsserted(() -> { |
||||
Assertions |
||||
.assertThat(repository.queryWorkflowInstance(workflowInstanceId).getState()) |
||||
.isEqualTo(WorkflowExecutionStatus.RUNNING_EXECUTION); |
||||
}); |
||||
|
||||
await() |
||||
.atMost(Duration.ofMinutes(1)) |
||||
.untilAsserted(() -> { |
||||
final WorkflowInstance workflowInstance = repository.queryWorkflowInstance(workflowInstanceId); |
||||
Assertions |
||||
.assertThat(workflowInstance.getState()) |
||||
.isEqualTo(WorkflowExecutionStatus.SUCCESS); |
||||
Assertions |
||||
.assertThat(workflowInstance.getRunTimes()) |
||||
.isEqualTo(2); |
||||
final List<TaskInstance> taskInstances = repository.queryTaskInstance(workflowInstanceId); |
||||
Assertions |
||||
.assertThat(taskInstances) |
||||
.hasSize(3); |
||||
|
||||
Assertions |
||||
.assertThat(taskInstances.get(0)) |
||||
.matches(t -> "A".equals(t.getName())) |
||||
.matches(t -> t.getState() == TaskExecutionStatus.FAILURE) |
||||
.matches(t -> t.getFlag() == Flag.NO); |
||||
|
||||
Assertions |
||||
.assertThat(taskInstances.get(1)) |
||||
.matches(t -> "A".equals(t.getName())) |
||||
.matches(t -> t.getState() == TaskExecutionStatus.SUCCESS) |
||||
.matches(t -> t.getFlag() == Flag.YES) |
||||
.matches(t -> StringUtils.isNotEmpty(t.getLogPath())); |
||||
|
||||
Assertions |
||||
.assertThat(taskInstances.get(2)) |
||||
.matches(t -> t.getState() == TaskExecutionStatus.SUCCESS) |
||||
.matches(t -> t.getFlag() == Flag.YES) |
||||
.matches(t -> StringUtils.isNotEmpty(t.getLogPath())); |
||||
}); |
||||
assertThat(workflowRepository.getAll()).isEmpty(); |
||||
} |
||||
|
||||
} |
@ -0,0 +1,202 @@
|
||||
/* |
||||
* Licensed to the Apache Software Foundation (ASF) under one or more |
||||
* contributor license agreements. See the NOTICE file distributed with |
||||
* this work for additional information regarding copyright ownership. |
||||
* The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
* (the "License"); you may not use this file except in compliance with |
||||
* the License. You may obtain a copy of the License at |
||||
* |
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
* |
||||
* Unless required by applicable law or agreed to in writing, software |
||||
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
* See the License for the specific language governing permissions and |
||||
* limitations under the License. |
||||
*/ |
||||
|
||||
package org.apache.dolphinscheduler.server.master.it.cases; |
||||
|
||||
import static com.google.common.truth.Truth.assertThat; |
||||
import static org.awaitility.Awaitility.await; |
||||
|
||||
import org.apache.dolphinscheduler.common.enums.Flag; |
||||
import org.apache.dolphinscheduler.common.enums.WorkflowExecutionStatus; |
||||
import org.apache.dolphinscheduler.dao.entity.TaskInstance; |
||||
import org.apache.dolphinscheduler.dao.entity.WorkflowInstance; |
||||
import org.apache.dolphinscheduler.plugin.task.api.enums.TaskExecutionStatus; |
||||
import org.apache.dolphinscheduler.server.master.AbstractMasterIntegrationTest; |
||||
import org.apache.dolphinscheduler.server.master.engine.IWorkflowRepository; |
||||
import org.apache.dolphinscheduler.server.master.it.Repository; |
||||
import org.apache.dolphinscheduler.server.master.it.WorkflowITContext; |
||||
import org.apache.dolphinscheduler.server.master.it.WorkflowITContextFactory; |
||||
import org.apache.dolphinscheduler.server.master.it.WorkflowOperator; |
||||
|
||||
import org.apache.commons.lang3.StringUtils; |
||||
|
||||
import java.time.Duration; |
||||
import java.util.List; |
||||
|
||||
import org.assertj.core.api.Assertions; |
||||
import org.junit.jupiter.api.DisplayName; |
||||
import org.junit.jupiter.api.Test; |
||||
import org.springframework.beans.factory.annotation.Autowired; |
||||
|
||||
/** |
||||
* The integration test for repeat running a workflow instance. |
||||
*/ |
||||
public class WorkflowInstanceRepeatRunningIT extends AbstractMasterIntegrationTest { |
||||
|
||||
@Autowired |
||||
private WorkflowITContextFactory workflowITContextFactory; |
||||
|
||||
@Autowired |
||||
private WorkflowOperator workflowOperator; |
||||
|
||||
@Autowired |
||||
private IWorkflowRepository workflowRepository; |
||||
|
||||
@Autowired |
||||
private Repository repository; |
||||
|
||||
@Test |
||||
@DisplayName("Test repeat running a workflow instance with one success task") |
||||
public void testRepeatRunningWorkflow_with_oneSuccessTask() { |
||||
final String yaml = "/it/repeat_running/success_workflow_with_one_fake_task_success.yaml"; |
||||
final WorkflowITContext context = workflowITContextFactory.initializeContextFromYaml(yaml); |
||||
|
||||
final Integer workflowInstanceId = context.getWorkflowInstance().getId(); |
||||
workflowOperator.repeatRunningWorkflowInstance(workflowInstanceId); |
||||
|
||||
await() |
||||
.pollInterval(Duration.ofMillis(100)) |
||||
.atMost(Duration.ofMinutes(1)) |
||||
.untilAsserted(() -> { |
||||
Assertions |
||||
.assertThat(repository.queryWorkflowInstance(workflowInstanceId).getState()) |
||||
.isEqualTo(WorkflowExecutionStatus.RUNNING_EXECUTION); |
||||
}); |
||||
|
||||
await() |
||||
.atMost(Duration.ofMinutes(1)) |
||||
.untilAsserted(() -> { |
||||
final WorkflowInstance workflowInstance = repository.queryWorkflowInstance(workflowInstanceId); |
||||
Assertions |
||||
.assertThat(workflowInstance) |
||||
.matches(w -> w.getState() == WorkflowExecutionStatus.SUCCESS) |
||||
.matches(w -> w.getRunTimes() == 2); |
||||
|
||||
final List<TaskInstance> taskInstances = repository.queryTaskInstance(workflowInstanceId); |
||||
Assertions |
||||
.assertThat(taskInstances) |
||||
.hasSize(2); |
||||
|
||||
Assertions |
||||
.assertThat(taskInstances.get(0)) |
||||
.matches(t -> t.getState() == TaskExecutionStatus.SUCCESS) |
||||
.matches(t -> t.getFlag() == Flag.NO); |
||||
|
||||
Assertions |
||||
.assertThat(taskInstances.get(1)) |
||||
.matches(t -> t.getState() == TaskExecutionStatus.SUCCESS) |
||||
.matches(t -> t.getFlag() == Flag.YES) |
||||
.matches(t -> StringUtils.isNotEmpty(t.getLogPath())); |
||||
}); |
||||
assertThat(workflowRepository.getAll()).isEmpty(); |
||||
} |
||||
|
||||
@Test |
||||
@DisplayName("Test repeat running a workflow instance with one failed task") |
||||
public void testRepeatRunningWorkflow_with_oneFailedTask() { |
||||
final String yaml = "/it/repeat_running/failed_workflow_with_one_fake_task_failed.yaml"; |
||||
final WorkflowITContext context = workflowITContextFactory.initializeContextFromYaml(yaml); |
||||
|
||||
final Integer workflowInstanceId = context.getWorkflowInstance().getId(); |
||||
workflowOperator.repeatRunningWorkflowInstance(workflowInstanceId); |
||||
|
||||
await() |
||||
.pollInterval(Duration.ofMillis(100)) |
||||
.atMost(Duration.ofMinutes(1)) |
||||
.untilAsserted(() -> { |
||||
Assertions |
||||
.assertThat(repository.queryWorkflowInstance(workflowInstanceId).getState()) |
||||
.isEqualTo(WorkflowExecutionStatus.RUNNING_EXECUTION); |
||||
}); |
||||
|
||||
await() |
||||
.atMost(Duration.ofMinutes(1)) |
||||
.untilAsserted(() -> { |
||||
final WorkflowInstance workflowInstance = repository.queryWorkflowInstance(workflowInstanceId); |
||||
Assertions |
||||
.assertThat(workflowInstance.getState()) |
||||
.isEqualTo(WorkflowExecutionStatus.SUCCESS); |
||||
Assertions |
||||
.assertThat(workflowInstance.getRunTimes()) |
||||
.isEqualTo(2); |
||||
final List<TaskInstance> taskInstances = repository.queryTaskInstance(workflowInstanceId); |
||||
Assertions |
||||
.assertThat(taskInstances) |
||||
.hasSize(2); |
||||
|
||||
Assertions |
||||
.assertThat(taskInstances.get(0)) |
||||
.matches(t -> t.getState() == TaskExecutionStatus.FAILURE) |
||||
.matches(t -> t.getFlag() == Flag.NO); |
||||
|
||||
Assertions |
||||
.assertThat(taskInstances.get(1)) |
||||
.matches(t -> t.getState() == TaskExecutionStatus.SUCCESS) |
||||
.matches(t -> t.getFlag() == Flag.YES) |
||||
.matches(t -> StringUtils.isNotEmpty(t.getLogPath())); |
||||
}); |
||||
assertThat(workflowRepository.getAll()).isEmpty(); |
||||
} |
||||
|
||||
@Test |
||||
@DisplayName("Test repeat running a workflow instance with task only") |
||||
public void testRepeatRunningWorkflow_with_taskOnly() { |
||||
final String yaml = "/it/repeat_running/success_workflow_with_task_only.yaml"; |
||||
final WorkflowITContext context = workflowITContextFactory.initializeContextFromYaml(yaml); |
||||
|
||||
final Integer workflowInstanceId = context.getWorkflowInstance().getId(); |
||||
workflowOperator.repeatRunningWorkflowInstance(workflowInstanceId); |
||||
|
||||
await() |
||||
.pollInterval(Duration.ofMillis(100)) |
||||
.atMost(Duration.ofMinutes(1)) |
||||
.untilAsserted(() -> { |
||||
Assertions |
||||
.assertThat(repository.queryWorkflowInstance(workflowInstanceId).getState()) |
||||
.isEqualTo(WorkflowExecutionStatus.RUNNING_EXECUTION); |
||||
}); |
||||
|
||||
await() |
||||
.atMost(Duration.ofMinutes(1)) |
||||
.untilAsserted(() -> { |
||||
final WorkflowInstance workflowInstance = repository.queryWorkflowInstance(workflowInstanceId); |
||||
Assertions |
||||
.assertThat(workflowInstance.getState()) |
||||
.isEqualTo(WorkflowExecutionStatus.SUCCESS); |
||||
Assertions |
||||
.assertThat(workflowInstance.getRunTimes()) |
||||
.isEqualTo(2); |
||||
final List<TaskInstance> taskInstances = repository.queryTaskInstance(workflowInstanceId); |
||||
Assertions |
||||
.assertThat(taskInstances) |
||||
.hasSize(2); |
||||
|
||||
Assertions |
||||
.assertThat(taskInstances.get(0)) |
||||
.matches(t -> t.getState() == TaskExecutionStatus.SUCCESS) |
||||
.matches(t -> t.getFlag() == Flag.NO); |
||||
|
||||
Assertions |
||||
.assertThat(taskInstances.get(1)) |
||||
.matches(t -> t.getState() == TaskExecutionStatus.SUCCESS) |
||||
.matches(t -> t.getFlag() == Flag.YES) |
||||
.matches(t -> StringUtils.isNotEmpty(t.getLogPath())); |
||||
}); |
||||
assertThat(workflowRepository.getAll()).isEmpty(); |
||||
} |
||||
|
||||
} |
@ -0,0 +1,130 @@
|
||||
# |
||||
# Licensed to the Apache Software Foundation (ASF) under one or more |
||||
# contributor license agreements. See the NOTICE file distributed with |
||||
# this work for additional information regarding copyright ownership. |
||||
# The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
# (the "License"); you may not use this file except in compliance with |
||||
# the License. You may obtain a copy of the License at |
||||
# |
||||
# http://www.apache.org/licenses/LICENSE-2.0 |
||||
# |
||||
# Unless required by applicable law or agreed to in writing, software |
||||
# distributed under the License is distributed on an "AS IS" BASIS, |
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
# See the License for the specific language governing permissions and |
||||
# limitations under the License. |
||||
# |
||||
project: |
||||
name: MasterIntegrationTest |
||||
code: 1 |
||||
description: This is a fake project |
||||
userId: 1 |
||||
userName: admin |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
|
||||
workflowInstance: |
||||
id: 1 |
||||
name: workflow_with_two_serial_fake_task_success-20240816071251690 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
projectCode: 1 |
||||
state: FAILURE |
||||
recovery: NO |
||||
startTime: 2024-08-16 07:12:52 |
||||
endTime: 2024-08-16 07:12:57 |
||||
runTimes: 1 |
||||
host: 127.0.0.1:5678 |
||||
commandType: START_PROCESS |
||||
commandParam: '{"commandType":"START_PROCESS","startNodes":[],"commandParams":[],"timeZone":"UTC"}' |
||||
taskDependType: TASK_POST |
||||
commandStartTime: 2024-08-16 07:12:52 |
||||
isSubProcess: NO |
||||
executorId: 1 |
||||
historyCmd: START_PROCESS |
||||
workerGroup: default |
||||
globalParams: '[]' |
||||
varPool: '[]' |
||||
dryRun: 0 |
||||
|
||||
taskInstances: |
||||
- id: 1 |
||||
name: A |
||||
taskType: LogicFakeTask |
||||
processInstanceId: 1 |
||||
processInstanceName: workflow_with_two_parallel_fake_task_success-20240816071251690 |
||||
projectCode: 1 |
||||
taskCode: 1 |
||||
taskDefinitionVersion: 1 |
||||
state: FAILURE |
||||
firstSubmitTime: 2024-08-16 07:12:52 |
||||
submitTime: 2024-08-16 07:12:57 |
||||
startTime: 2024-08-16 07:12:57 |
||||
endTime: 2024-08-16 07:12:57 |
||||
retryTimes: 0 |
||||
host: 127.0.0.1:1234 |
||||
maxRetryTimes: 0 |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"sleep 5"}' |
||||
flag: YES |
||||
retryInterval: 0 |
||||
delayTime: 0 |
||||
workerGroup: default |
||||
executorId: 1 |
||||
varPool: '[]' |
||||
taskExecuteType: BATCH |
||||
|
||||
workflow: |
||||
name: workflow_with_two_serial_fake_task_success |
||||
code: 1 |
||||
version: 1 |
||||
projectCode: 1 |
||||
description: This is a fake workflow with two serial tasks |
||||
releaseState: ONLINE |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
userId: 1 |
||||
executionType: PARALLEL |
||||
|
||||
tasks: |
||||
- name: A |
||||
code: 1 |
||||
version: 1 |
||||
projectCode: 1 |
||||
userId: 1 |
||||
taskType: LogicFakeTask |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"echo hello"}' |
||||
workerGroup: default |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
taskExecuteType: BATCH |
||||
- name: B |
||||
code: 2 |
||||
version: 1 |
||||
projectCode: 1 |
||||
userId: 1 |
||||
taskType: LogicFakeTask |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"echo hello"}' |
||||
workerGroup: default |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
taskExecuteType: BATCH |
||||
|
||||
taskRelations: |
||||
- projectCode: 1 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
preTaskCode: 0 |
||||
preTaskVersion: 0 |
||||
postTaskCode: 1 |
||||
postTaskVersion: 1 |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2024-08-12 00:00:00 |
||||
- projectCode: 1 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
preTaskCode: 1 |
||||
preTaskVersion: 1 |
||||
postTaskCode: 2 |
||||
postTaskVersion: 1 |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2024-08-12 00:00:00 |
@ -0,0 +1,111 @@
|
||||
# |
||||
# Licensed to the Apache Software Foundation (ASF) under one or more |
||||
# contributor license agreements. See the NOTICE file distributed with |
||||
# this work for additional information regarding copyright ownership. |
||||
# The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
# (the "License"); you may not use this file except in compliance with |
||||
# the License. You may obtain a copy of the License at |
||||
# |
||||
# http://www.apache.org/licenses/LICENSE-2.0 |
||||
# |
||||
# Unless required by applicable law or agreed to in writing, software |
||||
# distributed under the License is distributed on an "AS IS" BASIS, |
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
# See the License for the specific language governing permissions and |
||||
# limitations under the License. |
||||
# |
||||
|
||||
project: |
||||
name: MasterIntegrationTest |
||||
code: 1 |
||||
description: This is a fake project |
||||
userId: 1 |
||||
userName: admin |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
|
||||
workflow: |
||||
name: workflow_with_one_fake_task_success |
||||
code: 1 |
||||
version: 1 |
||||
projectCode: 1 |
||||
description: This is a fake workflow with single task |
||||
releaseState: ONLINE |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
userId: 1 |
||||
executionType: PARALLEL |
||||
|
||||
workflowInstance: |
||||
id: 1 |
||||
name: workflow_with_one_fake_task_success-20240816071251690 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
projectCode: 1 |
||||
state: FAILURE |
||||
recovery: NO |
||||
startTime: 2024-08-16 07:12:52 |
||||
endTime: 2024-08-16 07:12:57 |
||||
runTimes: 1 |
||||
host: 127.0.0.1:5678 |
||||
commandType: START_PROCESS |
||||
commandParam: '{"commandType":"START_PROCESS","startNodes":[],"commandParams":[],"timeZone":"UTC"}' |
||||
taskDependType: TASK_POST |
||||
commandStartTime: 2024-08-16 07:12:52 |
||||
isSubProcess: NO |
||||
executorId: 1 |
||||
historyCmd: START_PROCESS |
||||
workerGroup: default |
||||
globalParams: '[]' |
||||
varPool: '[]' |
||||
dryRun: 0 |
||||
|
||||
taskInstances: |
||||
- id: 1 |
||||
name: A |
||||
taskType: LogicFakeTask |
||||
processInstanceId: 1 |
||||
processInstanceName: workflow_with_one_fake_task_success-20240816071251690 |
||||
projectCode: 1 |
||||
taskCode: 1 |
||||
taskDefinitionVersion: 1 |
||||
state: FAILURE |
||||
firstSubmitTime: 2024-08-16 07:12:52 |
||||
submitTime: 2024-08-16 07:12:57 |
||||
startTime: 2024-08-16 07:12:57 |
||||
endTime: 2024-08-16 07:12:57 |
||||
retryTimes: 0 |
||||
host: 127.0.0.1:1234 |
||||
maxRetryTimes: 0 |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"sleep 5"}' |
||||
flag: YES |
||||
retryInterval: 0 |
||||
delayTime: 0 |
||||
workerGroup: default |
||||
executorId: 1 |
||||
varPool: '[]' |
||||
taskExecuteType: BATCH |
||||
|
||||
tasks: |
||||
- name: A |
||||
code: 1 |
||||
version: 1 |
||||
projectCode: 1 |
||||
userId: 1 |
||||
taskType: LogicFakeTask |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"sleep 5"}' |
||||
workerGroup: default |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
taskExecuteType: BATCH |
||||
|
||||
taskRelations: |
||||
- projectCode: 1 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
preTaskCode: 0 |
||||
preTaskVersion: 0 |
||||
postTaskCode: 1 |
||||
postTaskVersion: 1 |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2024-08-12 00:00:00 |
@ -0,0 +1,111 @@
|
||||
# |
||||
# Licensed to the Apache Software Foundation (ASF) under one or more |
||||
# contributor license agreements. See the NOTICE file distributed with |
||||
# this work for additional information regarding copyright ownership. |
||||
# The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
# (the "License"); you may not use this file except in compliance with |
||||
# the License. You may obtain a copy of the License at |
||||
# |
||||
# http://www.apache.org/licenses/LICENSE-2.0 |
||||
# |
||||
# Unless required by applicable law or agreed to in writing, software |
||||
# distributed under the License is distributed on an "AS IS" BASIS, |
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
# See the License for the specific language governing permissions and |
||||
# limitations under the License. |
||||
# |
||||
|
||||
project: |
||||
name: MasterIntegrationTest |
||||
code: 1 |
||||
description: This is a fake project |
||||
userId: 1 |
||||
userName: admin |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
|
||||
workflow: |
||||
name: workflow_with_one_fake_task_success |
||||
code: 1 |
||||
version: 1 |
||||
projectCode: 1 |
||||
description: This is a fake workflow with single task |
||||
releaseState: ONLINE |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
userId: 1 |
||||
executionType: PARALLEL |
||||
|
||||
workflowInstance: |
||||
id: 1 |
||||
name: workflow_with_one_fake_task_success-20240816071251690 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
projectCode: 1 |
||||
state: SUCCESS |
||||
recovery: NO |
||||
startTime: 2024-08-16 07:12:52 |
||||
endTime: 2024-08-16 07:12:57 |
||||
runTimes: 1 |
||||
host: 127.0.0.1:5678 |
||||
commandType: START_PROCESS |
||||
commandParam: '{"commandType":"START_PROCESS","startNodes":[],"commandParams":[],"timeZone":"UTC"}' |
||||
taskDependType: TASK_POST |
||||
commandStartTime: 2024-08-16 07:12:52 |
||||
isSubProcess: NO |
||||
executorId: 1 |
||||
historyCmd: START_PROCESS |
||||
workerGroup: default |
||||
globalParams: '[]' |
||||
varPool: '[]' |
||||
dryRun: 0 |
||||
|
||||
taskInstances: |
||||
- id: 1 |
||||
name: A |
||||
taskType: LogicFakeTask |
||||
processInstanceId: 1 |
||||
processInstanceName: workflow_with_one_fake_task_success-20240816071251690 |
||||
projectCode: 1 |
||||
taskCode: 1 |
||||
taskDefinitionVersion: 1 |
||||
state: SUCCESS |
||||
firstSubmitTime: 2024-08-16 07:12:52 |
||||
submitTime: 2024-08-16 07:12:57 |
||||
startTime: 2024-08-16 07:12:57 |
||||
endTime: 2024-08-16 07:12:57 |
||||
retryTimes: 0 |
||||
host: 127.0.0.1:1234 |
||||
maxRetryTimes: 0 |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"sleep 5"}' |
||||
flag: YES |
||||
retryInterval: 0 |
||||
delayTime: 0 |
||||
workerGroup: default |
||||
executorId: 1 |
||||
varPool: '[]' |
||||
taskExecuteType: BATCH |
||||
|
||||
tasks: |
||||
- name: A |
||||
code: 1 |
||||
version: 1 |
||||
projectCode: 1 |
||||
userId: 1 |
||||
taskType: LogicFakeTask |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"sleep 5"}' |
||||
workerGroup: default |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
taskExecuteType: BATCH |
||||
|
||||
taskRelations: |
||||
- projectCode: 1 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
preTaskCode: 0 |
||||
preTaskVersion: 0 |
||||
postTaskCode: 1 |
||||
postTaskVersion: 1 |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2024-08-12 00:00:00 |
@ -0,0 +1,131 @@
|
||||
# |
||||
# Licensed to the Apache Software Foundation (ASF) under one or more |
||||
# contributor license agreements. See the NOTICE file distributed with |
||||
# this work for additional information regarding copyright ownership. |
||||
# The ASF licenses this file to You under the Apache License, Version 2.0 |
||||
# (the "License"); you may not use this file except in compliance with |
||||
# the License. You may obtain a copy of the License at |
||||
# |
||||
# http://www.apache.org/licenses/LICENSE-2.0 |
||||
# |
||||
# Unless required by applicable law or agreed to in writing, software |
||||
# distributed under the License is distributed on an "AS IS" BASIS, |
||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
# See the License for the specific language governing permissions and |
||||
# limitations under the License. |
||||
# |
||||
|
||||
project: |
||||
name: MasterIntegrationTest |
||||
code: 1 |
||||
description: This is a fake project |
||||
userId: 1 |
||||
userName: admin |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
|
||||
workflowInstance: |
||||
id: 1 |
||||
name: workflow_with_two_parallel_fake_task_success-20240816071251690 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
projectCode: 1 |
||||
state: SUCCESS |
||||
recovery: NO |
||||
startTime: 2024-08-16 07:12:52 |
||||
endTime: 2024-08-16 07:12:57 |
||||
runTimes: 1 |
||||
host: 127.0.0.1:5678 |
||||
commandType: START_PROCESS |
||||
commandParam: '{"commandType":"START_PROCESS","startNodes":[1],"commandParams":[],"timeZone":"UTC"}' |
||||
taskDependType: TASK_ONLY |
||||
commandStartTime: 2024-08-16 07:12:52 |
||||
isSubProcess: NO |
||||
executorId: 1 |
||||
historyCmd: START_PROCESS |
||||
workerGroup: default |
||||
globalParams: '[]' |
||||
varPool: '[]' |
||||
dryRun: 0 |
||||
|
||||
taskInstances: |
||||
- id: 1 |
||||
name: A |
||||
taskType: LogicFakeTask |
||||
processInstanceId: 1 |
||||
processInstanceName: workflow_with_two_parallel_fake_task_success-20240816071251690 |
||||
projectCode: 1 |
||||
taskCode: 1 |
||||
taskDefinitionVersion: 1 |
||||
state: SUCCESS |
||||
firstSubmitTime: 2024-08-16 07:12:52 |
||||
submitTime: 2024-08-16 07:12:57 |
||||
startTime: 2024-08-16 07:12:57 |
||||
endTime: 2024-08-16 07:12:57 |
||||
retryTimes: 0 |
||||
host: 127.0.0.1:1234 |
||||
maxRetryTimes: 0 |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"sleep 5"}' |
||||
flag: YES |
||||
retryInterval: 0 |
||||
delayTime: 0 |
||||
workerGroup: default |
||||
executorId: 1 |
||||
varPool: '[]' |
||||
taskExecuteType: BATCH |
||||
|
||||
workflow: |
||||
name: workflow_with_two_parallel_fake_task_success |
||||
code: 1 |
||||
version: 1 |
||||
projectCode: 1 |
||||
description: This is a fake workflow with two parallel success tasks |
||||
releaseState: ONLINE |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
userId: 1 |
||||
executionType: PARALLEL |
||||
|
||||
tasks: |
||||
- name: A |
||||
code: 1 |
||||
version: 1 |
||||
projectCode: 1 |
||||
userId: 1 |
||||
taskType: LogicFakeTask |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"sleep 5"}' |
||||
workerGroup: default |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
taskExecuteType: BATCH |
||||
- name: B |
||||
code: 2 |
||||
version: 1 |
||||
projectCode: 1 |
||||
userId: 1 |
||||
taskType: LogicFakeTask |
||||
taskParams: '{"localParams":null,"varPool":[],"shellScript":"sleep 5"}' |
||||
workerGroup: default |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2021-08-12 00:00:00 |
||||
taskExecuteType: BATCH |
||||
|
||||
taskRelations: |
||||
- projectCode: 1 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
preTaskCode: 0 |
||||
preTaskVersion: 0 |
||||
postTaskCode: 1 |
||||
postTaskVersion: 1 |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2024-08-12 00:00:00 |
||||
- projectCode: 1 |
||||
processDefinitionCode: 1 |
||||
processDefinitionVersion: 1 |
||||
preTaskCode: 0 |
||||
preTaskVersion: 0 |
||||
postTaskCode: 2 |
||||
postTaskVersion: 1 |
||||
createTime: 2024-08-12 00:00:00 |
||||
updateTime: 2024-08-12 00:00:00 |
Loading…
Reference in new issue