|
7 | 7 | import com.codingapi.springboot.flow.em.ApprovalType;
|
8 | 8 | import com.codingapi.springboot.flow.flow.Leave;
|
9 | 9 | import com.codingapi.springboot.flow.matcher.OperatorMatcher;
|
| 10 | +import com.codingapi.springboot.flow.pojo.FlowSubmitResult; |
10 | 11 | import com.codingapi.springboot.flow.record.FlowRecord;
|
11 | 12 | import com.codingapi.springboot.flow.repository.*;
|
12 | 13 | import com.codingapi.springboot.flow.service.FlowService;
|
| 14 | +import com.codingapi.springboot.flow.user.IFlowOperator; |
13 | 15 | import com.codingapi.springboot.flow.user.User;
|
14 | 16 | import org.junit.jupiter.api.Test;
|
15 | 17 | import org.springframework.data.domain.PageRequest;
|
16 | 18 |
|
| 19 | +import java.util.ArrayList; |
17 | 20 | import java.util.List;
|
| 21 | +import java.util.stream.Collectors; |
18 | 22 |
|
19 | 23 | import static org.junit.jupiter.api.Assertions.assertEquals;
|
20 | 24 | import static org.junit.jupiter.api.Assertions.assertTrue;
|
@@ -403,4 +407,141 @@ void signRejectTest(){
|
403 | 407 | assertEquals(12, snapshots.size());
|
404 | 408 |
|
405 | 409 | }
|
| 410 | + |
| 411 | + |
| 412 | + |
| 413 | + /** |
| 414 | + * 多人会签trySubmit测试 |
| 415 | + */ |
| 416 | + @Test |
| 417 | + void signTrySubmitTest(){ |
| 418 | + PageRequest pageRequest = PageRequest.of(0, 1000); |
| 419 | + |
| 420 | + User caocao = new User("曹操"); |
| 421 | + userRepository.save(caocao); |
| 422 | + User lvBu = new User("吕布"); |
| 423 | + userRepository.save(lvBu); |
| 424 | + User zhaoYun = new User("赵云"); |
| 425 | + userRepository.save(zhaoYun); |
| 426 | + |
| 427 | + User user = new User("张飞"); |
| 428 | + userRepository.save(user); |
| 429 | + |
| 430 | + User dept = new User("刘备"); |
| 431 | + userRepository.save(dept); |
| 432 | + |
| 433 | + User boss = new User("诸葛亮"); |
| 434 | + userRepository.save(boss); |
| 435 | + |
| 436 | + List<User> signUsers = new ArrayList<>(); |
| 437 | + signUsers.add(dept); |
| 438 | + signUsers.add(caocao); |
| 439 | + signUsers.add(lvBu); |
| 440 | + signUsers.add(zhaoYun); |
| 441 | + |
| 442 | + FlowWork flowWork = FlowWorkBuilder.builder(user) |
| 443 | + .title("请假流程") |
| 444 | + .nodes() |
| 445 | + .node("开始节点", "start", "default", ApprovalType.UN_SIGN, OperatorMatcher.anyOperatorMatcher()) |
| 446 | + .node("部门领导审批", "dept", "default", ApprovalType.SIGN, OperatorMatcher.specifyOperatorMatcher(signUsers.stream().map(User::getUserId).collect(Collectors.toList()))) |
| 447 | + .node("总经理审批", "manager", "default", ApprovalType.UN_SIGN,OperatorMatcher.specifyOperatorMatcher(boss.getUserId()) ) |
| 448 | + .node("结束节点", "over", "default", ApprovalType.UN_SIGN, OperatorMatcher.anyOperatorMatcher()) |
| 449 | + .relations() |
| 450 | + .relation("部门领导审批", "start", "dept") |
| 451 | + .relation("总经理审批", "dept", "manager") |
| 452 | + .relation("结束节点", "manager", "over") |
| 453 | + .build(); |
| 454 | + |
| 455 | + flowWorkRepository.save(flowWork); |
| 456 | + |
| 457 | + String workCode = flowWork.getCode(); |
| 458 | + |
| 459 | + Leave leave = new Leave("我要出去看看"); |
| 460 | + leaveRepository.save(leave); |
| 461 | + |
| 462 | + // 创建流程 |
| 463 | + flowService.startFlow(workCode, user, leave, "发起流程"); |
| 464 | + |
| 465 | + // 查看我的待办 |
| 466 | + List<FlowRecord> userTodos = flowRecordRepository.findTodoByOperatorId(user.getUserId(), pageRequest).getContent(); |
| 467 | + assertEquals(1, userTodos.size()); |
| 468 | + |
| 469 | + // 提交流程 |
| 470 | + FlowRecord userTodo = userTodos.get(0); |
| 471 | + |
| 472 | + // 验证会签的人员 |
| 473 | + FlowSubmitResult submitResult = flowService.trySubmitFlow(userTodo.getId(), user, leave, Opinion.pass("用户同意")); |
| 474 | + List<? extends IFlowOperator> operators = submitResult.getOperators(); |
| 475 | + assertEquals(signUsers.size(), operators.size()); |
| 476 | + |
| 477 | + flowService.submitFlow(userTodo.getId(), user, leave, Opinion.pass("用户同意").specify(dept.getUserId())); |
| 478 | + |
| 479 | + // 查看部门经理的待办 |
| 480 | + List<FlowRecord> deptTodos = flowRecordRepository.findTodoByOperatorId(dept.getUserId(), pageRequest).getContent(); |
| 481 | + assertEquals(1, deptTodos.size()); |
| 482 | + |
| 483 | + // 提交部门经理的审批 |
| 484 | + FlowRecord deptTodo = deptTodos.get(0); |
| 485 | + |
| 486 | + // 验证会签的人员 |
| 487 | + submitResult = flowService.trySubmitFlow(deptTodo.getId(), dept, leave, Opinion.pass("用户同意")); |
| 488 | + operators = submitResult.getOperators(); |
| 489 | + assertEquals(1, operators.size()); |
| 490 | + assertEquals(boss.getName(), operators.get(0).getName()); |
| 491 | + |
| 492 | + flowService.submitFlow(deptTodo.getId(), dept, leave, Opinion.pass("刘备同意")); |
| 493 | + |
| 494 | + // 查看总经理的待办 |
| 495 | + List<FlowRecord> bossTodos = flowRecordRepository.findTodoByOperatorId(boss.getUserId(), pageRequest).getContent(); |
| 496 | + assertEquals(1, bossTodos.size()); |
| 497 | + |
| 498 | +// // 查看部门经理 吕布 的待办 |
| 499 | +// List<FlowRecord> lvbuTodos = flowRecordRepository.findTodoByOperatorId(lvBu.getUserId(), pageRequest).getContent(); |
| 500 | +// assertEquals(1, lvbuTodos.size()); |
| 501 | +// |
| 502 | +// // 提交部门经理 吕布 的审批 |
| 503 | +// FlowRecord lvbuTodo = lvbuTodos.get(0); |
| 504 | +// flowService.submitFlow(lvbuTodo.getId(), lvBu, leave, Opinion.pass("吕布同意")); |
| 505 | +// |
| 506 | +// |
| 507 | +// // 查看部门经理 赵云 的待办 |
| 508 | +// List<FlowRecord> zhaoYunTodos = flowRecordRepository.findTodoByOperatorId(zhaoYun.getUserId(), pageRequest).getContent(); |
| 509 | +// assertEquals(1, zhaoYunTodos.size()); |
| 510 | +// |
| 511 | +// // 提交部门经理 赵云 的审批 |
| 512 | +// FlowRecord zhaoYunTodo = zhaoYunTodos.get(0); |
| 513 | +// flowService.submitFlow(zhaoYunTodo.getId(), zhaoYun, leave, Opinion.pass("赵云同意")); |
| 514 | +// |
| 515 | +// |
| 516 | +// // 查看部门经理 曹操 的待办 |
| 517 | +// List<FlowRecord> caocaoTodos = flowRecordRepository.findTodoByOperatorId(caocao.getUserId(), pageRequest).getContent(); |
| 518 | +// assertEquals(1, caocaoTodos.size()); |
| 519 | +// |
| 520 | +// // 提交部门经理 曹操 的审批 |
| 521 | +// FlowRecord caocaoTodo = caocaoTodos.get(0); |
| 522 | +// flowService.submitFlow(caocaoTodo.getId(), caocao, leave, Opinion.pass("曹操同意")); |
| 523 | +// |
| 524 | +// bossTodos = flowRecordRepository.findTodoByOperatorId(boss.getUserId(), pageRequest).getContent(); |
| 525 | +// assertEquals(1, bossTodos.size()); |
| 526 | + |
| 527 | + // 提交总经理的审批 |
| 528 | + FlowRecord bossTodo = bossTodos.get(0); |
| 529 | + flowService.submitFlow(bossTodo.getId(), boss, leave, Opinion.pass("同意")); |
| 530 | + |
| 531 | + // 查看所有流程 |
| 532 | + List<FlowRecord> records = flowRecordRepository.findAll(pageRequest).getContent(); |
| 533 | + assertEquals(3, records.size()); |
| 534 | + |
| 535 | + userTodos = flowRecordRepository.findTodoByOperatorId(user.getUserId(), pageRequest).getContent(); |
| 536 | + assertEquals(0, userTodos.size()); |
| 537 | + |
| 538 | + records = flowRecordRepository.findAll(pageRequest).getContent(); |
| 539 | + assertEquals(3, records.size()); |
| 540 | + // 查看所有流程是否都已经结束 |
| 541 | + assertTrue(records.stream().allMatch(FlowRecord::isFinish)); |
| 542 | + |
| 543 | + List<BindDataSnapshot> snapshots = flowBindDataRepository.findAll(); |
| 544 | + assertEquals(4, snapshots.size()); |
| 545 | + |
| 546 | + } |
406 | 547 | }
|
0 commit comments