Wenjun Ruan
3 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