@nocobase/plugin-workflow 0.11.1-alpha.5 → 0.12.0-alpha.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (537) hide show
  1. package/client.d.ts +2 -3
  2. package/client.js +1 -1
  3. package/dist/client/index.js +7802 -0
  4. package/{lib → dist}/client/nodes/aggregate.d.ts +1 -5
  5. package/{lib → dist}/client/nodes/create.d.ts +1 -2
  6. package/{lib → dist}/client/nodes/destroy.d.ts +1 -1
  7. package/{lib → dist}/client/nodes/query.d.ts +1 -2
  8. package/{lib → dist}/client/nodes/request.d.ts +1 -2
  9. package/{lib → dist}/client/nodes/update.d.ts +1 -1
  10. package/{lib → dist}/client/schemas/collection.d.ts +1 -2
  11. package/{lib → dist}/client/triggers/collection.d.ts +6 -7
  12. package/{lib → dist}/index.d.ts +1 -0
  13. package/dist/index.js +18 -0
  14. package/dist/locale/en-US.js +133 -0
  15. package/{lib → dist}/locale/es-ES.js +51 -54
  16. package/dist/locale/fr-FR.js +133 -0
  17. package/dist/locale/ja-JP.js +91 -0
  18. package/dist/locale/pt-BR.js +133 -0
  19. package/dist/locale/ru-RU.js +91 -0
  20. package/dist/locale/tr-TR.js +91 -0
  21. package/dist/locale/zh-CN.js +216 -0
  22. package/dist/node_modules/cron-parser/.eslintrc.json +15 -0
  23. package/dist/node_modules/cron-parser/.travis.yml +7 -0
  24. package/dist/node_modules/cron-parser/LICENSE +21 -0
  25. package/dist/node_modules/cron-parser/component.json +11 -0
  26. package/dist/node_modules/cron-parser/index.d.ts +1 -0
  27. package/dist/node_modules/cron-parser/lib/date.js +252 -0
  28. package/dist/node_modules/cron-parser/lib/expression.js +983 -0
  29. package/dist/node_modules/cron-parser/lib/field_compactor.js +70 -0
  30. package/dist/node_modules/cron-parser/lib/field_stringify.js +38 -0
  31. package/dist/node_modules/cron-parser/lib/parser.js +1 -0
  32. package/dist/node_modules/cron-parser/node_modules/luxon/build/amd/luxon.js +8489 -0
  33. package/dist/node_modules/cron-parser/node_modules/luxon/build/cjs-browser/luxon.js +8487 -0
  34. package/dist/node_modules/cron-parser/node_modules/luxon/build/global/luxon.js +8490 -0
  35. package/dist/node_modules/cron-parser/node_modules/luxon/build/global/luxon.min.js +1 -0
  36. package/dist/node_modules/cron-parser/node_modules/luxon/build/node/luxon.js +7522 -0
  37. package/dist/node_modules/cron-parser/node_modules/luxon/package.json +96 -0
  38. package/dist/node_modules/cron-parser/node_modules/luxon/src/datetime.js +2169 -0
  39. package/dist/node_modules/cron-parser/node_modules/luxon/src/duration.js +880 -0
  40. package/dist/node_modules/cron-parser/node_modules/luxon/src/errors.js +61 -0
  41. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/conversions.js +157 -0
  42. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/diff.js +80 -0
  43. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/digits.js +76 -0
  44. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/english.js +233 -0
  45. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/formats.js +191 -0
  46. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/formatter.js +386 -0
  47. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/invalid.js +14 -0
  48. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/locale.js +482 -0
  49. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/regexParser.js +335 -0
  50. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/tokenParser.js +424 -0
  51. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/util.js +292 -0
  52. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/zoneUtil.js +36 -0
  53. package/dist/node_modules/cron-parser/node_modules/luxon/src/info.js +193 -0
  54. package/dist/node_modules/cron-parser/node_modules/luxon/src/interval.js +602 -0
  55. package/dist/node_modules/cron-parser/node_modules/luxon/src/luxon.js +26 -0
  56. package/dist/node_modules/cron-parser/node_modules/luxon/src/luxonFilled.js +13 -0
  57. package/dist/node_modules/cron-parser/node_modules/luxon/src/settings.js +137 -0
  58. package/dist/node_modules/cron-parser/node_modules/luxon/src/zone.js +88 -0
  59. package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/IANAZone.js +191 -0
  60. package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/fixedOffsetZone.js +94 -0
  61. package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/invalidZone.js +53 -0
  62. package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/localZone.js +63 -0
  63. package/dist/node_modules/cron-parser/package.json +1 -0
  64. package/dist/node_modules/cron-parser/test/31_of_month.js +17 -0
  65. package/dist/node_modules/cron-parser/test/bug.js +29 -0
  66. package/dist/node_modules/cron-parser/test/crondate.js +16 -0
  67. package/dist/node_modules/cron-parser/test/crontab.example +7 -0
  68. package/dist/node_modules/cron-parser/test/empty_around_comma.js +22 -0
  69. package/dist/node_modules/cron-parser/test/expression.js +1489 -0
  70. package/dist/node_modules/cron-parser/test/field_compactor.js +250 -0
  71. package/dist/node_modules/cron-parser/test/field_stringify.js +84 -0
  72. package/dist/node_modules/cron-parser/test/fields.js +32 -0
  73. package/dist/node_modules/cron-parser/test/increment_on_first_iteration.js +22 -0
  74. package/dist/node_modules/cron-parser/test/index-ts3.test-d.ts +133 -0
  75. package/dist/node_modules/cron-parser/test/index.test-d.ts +138 -0
  76. package/dist/node_modules/cron-parser/test/leap_year.js +17 -0
  77. package/dist/node_modules/cron-parser/test/parser.js +46 -0
  78. package/dist/node_modules/cron-parser/test/parser_crondate_formats.js +145 -0
  79. package/dist/node_modules/cron-parser/test/parser_day_of_month.js +169 -0
  80. package/dist/node_modules/cron-parser/test/prev_date.js +32 -0
  81. package/dist/node_modules/cron-parser/test/stringify.js +402 -0
  82. package/dist/node_modules/cron-parser/test/timezone.js +422 -0
  83. package/dist/node_modules/cron-parser/types/common.d.ts +131 -0
  84. package/dist/node_modules/cron-parser/types/index.d.ts +45 -0
  85. package/dist/node_modules/cron-parser/types/ts3/index.d.ts +28 -0
  86. package/dist/node_modules/lru-cache/index-cjs.d.ts +7 -0
  87. package/dist/node_modules/lru-cache/index-cjs.js +1 -0
  88. package/dist/node_modules/lru-cache/index.d.ts +807 -0
  89. package/dist/node_modules/lru-cache/index.js +1334 -0
  90. package/dist/node_modules/lru-cache/index.min.js +2 -0
  91. package/dist/node_modules/lru-cache/package.json +1 -0
  92. package/dist/server/Plugin.js +297 -0
  93. package/{src/server/Processor.ts → dist/server/Processor.js} +80 -147
  94. package/dist/server/actions/index.js +49 -0
  95. package/{src/server/actions/nodes.ts → dist/server/actions/nodes.js} +55 -81
  96. package/{src/server/actions/workflows.ts → dist/server/actions/workflows.js} +60 -72
  97. package/dist/server/collections/executions.js +37 -0
  98. package/dist/server/collections/flow_nodes.js +56 -0
  99. package/dist/server/collections/jobs.js +33 -0
  100. package/dist/server/collections/workflows.js +90 -0
  101. package/{lib → dist}/server/constants.js +5 -8
  102. package/dist/server/fields/expression-field.js +11 -0
  103. package/dist/server/fields/index.js +11 -0
  104. package/dist/server/functions/index.js +13 -0
  105. package/dist/server/index.js +41 -0
  106. package/dist/server/instructions/aggregate.js +37 -0
  107. package/dist/server/instructions/calculation.js +34 -0
  108. package/dist/server/instructions/condition.js +123 -0
  109. package/{src/server/instructions/create.ts → dist/server/instructions/create.js} +17 -17
  110. package/dist/server/instructions/delay.js +87 -0
  111. package/dist/server/instructions/destroy.js +24 -0
  112. package/dist/server/instructions/index.js +40 -0
  113. package/{src/server/instructions/loop.ts → dist/server/instructions/loop.js} +21 -43
  114. package/{src/server/instructions/manual/actions.ts → dist/server/instructions/manual/actions.js} +18 -44
  115. package/dist/server/instructions/manual/collecions/jobs.js +21 -0
  116. package/dist/server/instructions/manual/collecions/users.js +19 -0
  117. package/dist/server/instructions/manual/collecions/users_jobs.js +52 -0
  118. package/{src/server/instructions/manual/forms/create.ts → dist/server/instructions/manual/forms/create.js} +8 -8
  119. package/dist/server/instructions/manual/forms/index.js +16 -0
  120. package/{src/server/instructions/manual/forms/update.ts → dist/server/instructions/manual/forms/update.js} +8 -8
  121. package/dist/server/instructions/manual/index.js +160 -0
  122. package/dist/server/instructions/parallel.js +105 -0
  123. package/dist/server/instructions/query.js +36 -0
  124. package/dist/server/instructions/request.js +69 -0
  125. package/dist/server/instructions/sql.js +26 -0
  126. package/dist/server/instructions/update.js +24 -0
  127. package/{src/server/migrations/20221129153547-calculation-variables.ts → dist/server/migrations/20221129153547-calculation-variables.js} +20 -19
  128. package/dist/server/migrations/20230221032941-change-request-body-type.js +71 -0
  129. package/dist/server/migrations/20230221071831-calculation-expression.js +94 -0
  130. package/dist/server/migrations/20230221121203-condition-calculation.js +41 -0
  131. package/dist/server/migrations/20230221162902-jsonb-to-json.js +52 -0
  132. package/dist/server/migrations/20230411034722-manual-multi-form.js +252 -0
  133. package/dist/server/migrations/20230612021134-manual-collection-block.js +126 -0
  134. package/dist/server/migrations/20230710115902-manual-action-values.js +74 -0
  135. package/{src/server/triggers/collection.ts → dist/server/triggers/collection.js} +34 -64
  136. package/dist/server/triggers/index.js +27 -0
  137. package/{src/server/triggers/schedule.ts → dist/server/triggers/schedule.js} +108 -220
  138. package/dist/server/types/Execution.js +8 -0
  139. package/dist/server/types/FlowNode.js +8 -0
  140. package/dist/server/types/Job.js +8 -0
  141. package/dist/server/types/Workflow.js +8 -0
  142. package/dist/server/types/index.js +2 -0
  143. package/{lib → dist}/server/utils.js +6 -8
  144. package/package.json +26 -37
  145. package/server.d.ts +2 -3
  146. package/server.js +1 -1
  147. package/lib/client/AddButton.js +0 -161
  148. package/lib/client/Branch.js +0 -50
  149. package/lib/client/CanvasContent.js +0 -51
  150. package/lib/client/ExecutionCanvas.js +0 -218
  151. package/lib/client/ExecutionLink.js +0 -48
  152. package/lib/client/ExecutionPage.js +0 -68
  153. package/lib/client/ExecutionResourceProvider.js +0 -48
  154. package/lib/client/FlowContext.js +0 -21
  155. package/lib/client/WorkflowCanvas.js +0 -300
  156. package/lib/client/WorkflowLink.js +0 -48
  157. package/lib/client/WorkflowPage.js +0 -70
  158. package/lib/client/WorkflowProvider.js +0 -100
  159. package/lib/client/components/CollectionBlockInitializer.js +0 -103
  160. package/lib/client/components/CollectionFieldset.js +0 -198
  161. package/lib/client/components/Duration.js +0 -72
  162. package/lib/client/components/DynamicExpression.js +0 -117
  163. package/lib/client/components/FieldsSelect.js +0 -72
  164. package/lib/client/components/FilterDynamicComponent.js +0 -34
  165. package/lib/client/components/NodeDescription.js +0 -73
  166. package/lib/client/components/NullRender.js +0 -9
  167. package/lib/client/components/OpenDrawer.js +0 -68
  168. package/lib/client/components/RadioWithTooltip.js +0 -65
  169. package/lib/client/components/ValueBlock.js +0 -103
  170. package/lib/client/components/renderEngineReference.js +0 -49
  171. package/lib/client/constants.js +0 -126
  172. package/lib/client/index.js +0 -121
  173. package/lib/client/interfaces/expression.js +0 -38
  174. package/lib/client/locale/index.js +0 -42
  175. package/lib/client/nodes/aggregate.js +0 -353
  176. package/lib/client/nodes/calculation.js +0 -292
  177. package/lib/client/nodes/condition.js +0 -531
  178. package/lib/client/nodes/create.js +0 -110
  179. package/lib/client/nodes/delay.js +0 -47
  180. package/lib/client/nodes/destroy.js +0 -49
  181. package/lib/client/nodes/index.js +0 -550
  182. package/lib/client/nodes/loop.js +0 -171
  183. package/lib/client/nodes/manual/AssigneesSelect.js +0 -56
  184. package/lib/client/nodes/manual/DetailsBlockProvider.js +0 -106
  185. package/lib/client/nodes/manual/FormBlockInitializer.js +0 -107
  186. package/lib/client/nodes/manual/FormBlockProvider.js +0 -113
  187. package/lib/client/nodes/manual/ModeConfig.js +0 -126
  188. package/lib/client/nodes/manual/SchemaConfig.js +0 -468
  189. package/lib/client/nodes/manual/WorkflowTodo.js +0 -642
  190. package/lib/client/nodes/manual/WorkflowTodoBlockInitializer.js +0 -60
  191. package/lib/client/nodes/manual/forms/create.js +0 -111
  192. package/lib/client/nodes/manual/forms/custom.js +0 -428
  193. package/lib/client/nodes/manual/forms/update.js +0 -168
  194. package/lib/client/nodes/manual/index.js +0 -168
  195. package/lib/client/nodes/manual/utils.js +0 -31
  196. package/lib/client/nodes/parallel.js +0 -162
  197. package/lib/client/nodes/query.js +0 -112
  198. package/lib/client/nodes/request.js +0 -225
  199. package/lib/client/nodes/sql.js +0 -61
  200. package/lib/client/nodes/update.js +0 -127
  201. package/lib/client/schemas/collection.js +0 -93
  202. package/lib/client/schemas/executions.js +0 -190
  203. package/lib/client/schemas/workflows.js +0 -397
  204. package/lib/client/style.js +0 -350
  205. package/lib/client/triggers/collection.js +0 -188
  206. package/lib/client/triggers/index.js +0 -356
  207. package/lib/client/triggers/schedule/EndsByField.js +0 -71
  208. package/lib/client/triggers/schedule/OnField.js +0 -117
  209. package/lib/client/triggers/schedule/RepeatField.js +0 -155
  210. package/lib/client/triggers/schedule/ScheduleConfig.js +0 -251
  211. package/lib/client/triggers/schedule/constants.js +0 -11
  212. package/lib/client/triggers/schedule/index.js +0 -101
  213. package/lib/client/triggers/schedule/locale/Cron.zh-CN.js +0 -48
  214. package/lib/client/utils.js +0 -59
  215. package/lib/client/variable.js +0 -319
  216. package/lib/index.js +0 -13
  217. package/lib/locale/en-US.js +0 -136
  218. package/lib/locale/fr-FR.js +0 -136
  219. package/lib/locale/ja-JP.js +0 -94
  220. package/lib/locale/pt-BR.js +0 -136
  221. package/lib/locale/ru-RU.js +0 -94
  222. package/lib/locale/tr-TR.js +0 -94
  223. package/lib/locale/zh-CN.js +0 -219
  224. package/lib/server/Plugin.js +0 -382
  225. package/lib/server/Processor.js +0 -394
  226. package/lib/server/actions/index.js +0 -30
  227. package/lib/server/actions/nodes.js +0 -269
  228. package/lib/server/actions/workflows.js +0 -273
  229. package/lib/server/collections/executions.js +0 -33
  230. package/lib/server/collections/flow_nodes.js +0 -53
  231. package/lib/server/collections/jobs.js +0 -30
  232. package/lib/server/collections/workflows.js +0 -76
  233. package/lib/server/fields/expression-field.js +0 -19
  234. package/lib/server/fields/index.js +0 -12
  235. package/lib/server/functions/index.js +0 -26
  236. package/lib/server/index.js +0 -55
  237. package/lib/server/instructions/aggregate.js +0 -57
  238. package/lib/server/instructions/calculation.js +0 -59
  239. package/lib/server/instructions/condition.js +0 -150
  240. package/lib/server/instructions/create.js +0 -60
  241. package/lib/server/instructions/delay.js +0 -118
  242. package/lib/server/instructions/destroy.js +0 -37
  243. package/lib/server/instructions/index.js +0 -44
  244. package/lib/server/instructions/loop.js +0 -107
  245. package/lib/server/instructions/manual/actions.js +0 -99
  246. package/lib/server/instructions/manual/collecions/jobs.js +0 -21
  247. package/lib/server/instructions/manual/collecions/users.js +0 -19
  248. package/lib/server/instructions/manual/collecions/users_jobs.js +0 -46
  249. package/lib/server/instructions/manual/forms/create.js +0 -52
  250. package/lib/server/instructions/manual/forms/index.js +0 -15
  251. package/lib/server/instructions/manual/forms/update.js +0 -53
  252. package/lib/server/instructions/manual/index.js +0 -174
  253. package/lib/server/instructions/parallel.js +0 -128
  254. package/lib/server/instructions/query.js +0 -53
  255. package/lib/server/instructions/request.js +0 -99
  256. package/lib/server/instructions/sql.js +0 -34
  257. package/lib/server/instructions/update.js +0 -38
  258. package/lib/server/migrations/20221129153547-calculation-variables.js +0 -92
  259. package/lib/server/migrations/20230221032941-change-request-body-type.js +0 -90
  260. package/lib/server/migrations/20230221071831-calculation-expression.js +0 -111
  261. package/lib/server/migrations/20230221121203-condition-calculation.js +0 -103
  262. package/lib/server/migrations/20230221162902-jsonb-to-json.js +0 -64
  263. package/lib/server/migrations/20230411034722-manual-multi-form.js +0 -297
  264. package/lib/server/migrations/20230612021134-manual-collection-block.js +0 -155
  265. package/lib/server/migrations/20230710115902-manual-action-values.js +0 -97
  266. package/lib/server/triggers/collection.js +0 -175
  267. package/lib/server/triggers/index.js +0 -46
  268. package/lib/server/triggers/schedule.js +0 -582
  269. package/lib/server/types/Execution.js +0 -15
  270. package/lib/server/types/FlowNode.js +0 -15
  271. package/lib/server/types/Job.js +0 -15
  272. package/lib/server/types/Workflow.js +0 -15
  273. package/lib/server/types/index.js +0 -5
  274. package/src/client/AddButton.tsx +0 -111
  275. package/src/client/Branch.tsx +0 -37
  276. package/src/client/CanvasContent.tsx +0 -25
  277. package/src/client/ExecutionCanvas.tsx +0 -166
  278. package/src/client/ExecutionLink.tsx +0 -16
  279. package/src/client/ExecutionPage.tsx +0 -45
  280. package/src/client/ExecutionResourceProvider.tsx +0 -21
  281. package/src/client/FlowContext.ts +0 -7
  282. package/src/client/WorkflowCanvas.tsx +0 -221
  283. package/src/client/WorkflowLink.tsx +0 -16
  284. package/src/client/WorkflowPage.tsx +0 -52
  285. package/src/client/WorkflowProvider.tsx +0 -84
  286. package/src/client/components/CollectionBlockInitializer.tsx +0 -71
  287. package/src/client/components/CollectionFieldset.tsx +0 -152
  288. package/src/client/components/Duration.tsx +0 -45
  289. package/src/client/components/DynamicExpression.tsx +0 -57
  290. package/src/client/components/FieldsSelect.tsx +0 -32
  291. package/src/client/components/FilterDynamicComponent.tsx +0 -15
  292. package/src/client/components/NodeDescription.tsx +0 -51
  293. package/src/client/components/NullRender.tsx +0 -3
  294. package/src/client/components/OpenDrawer.tsx +0 -24
  295. package/src/client/components/RadioWithTooltip.tsx +0 -38
  296. package/src/client/components/ValueBlock.tsx +0 -67
  297. package/src/client/components/renderEngineReference.tsx +0 -30
  298. package/src/client/constants.tsx +0 -91
  299. package/src/client/index.tsx +0 -51
  300. package/src/client/interfaces/expression.tsx +0 -25
  301. package/src/client/locale/index.ts +0 -18
  302. package/src/client/nodes/aggregate.tsx +0 -327
  303. package/src/client/nodes/calculation.tsx +0 -216
  304. package/src/client/nodes/condition.tsx +0 -463
  305. package/src/client/nodes/create.tsx +0 -85
  306. package/src/client/nodes/delay.tsx +0 -37
  307. package/src/client/nodes/destroy.tsx +0 -34
  308. package/src/client/nodes/index.tsx +0 -500
  309. package/src/client/nodes/loop.tsx +0 -144
  310. package/src/client/nodes/manual/AssigneesSelect.tsx +0 -33
  311. package/src/client/nodes/manual/DetailsBlockProvider.tsx +0 -80
  312. package/src/client/nodes/manual/FormBlockInitializer.tsx +0 -69
  313. package/src/client/nodes/manual/FormBlockProvider.tsx +0 -75
  314. package/src/client/nodes/manual/ModeConfig.tsx +0 -84
  315. package/src/client/nodes/manual/SchemaConfig.tsx +0 -509
  316. package/src/client/nodes/manual/WorkflowTodo.tsx +0 -607
  317. package/src/client/nodes/manual/WorkflowTodoBlockInitializer.tsx +0 -28
  318. package/src/client/nodes/manual/forms/create.tsx +0 -92
  319. package/src/client/nodes/manual/forms/custom.tsx +0 -392
  320. package/src/client/nodes/manual/forms/update.tsx +0 -134
  321. package/src/client/nodes/manual/index.tsx +0 -162
  322. package/src/client/nodes/manual/utils.ts +0 -28
  323. package/src/client/nodes/parallel.tsx +0 -138
  324. package/src/client/nodes/query.tsx +0 -88
  325. package/src/client/nodes/request.tsx +0 -185
  326. package/src/client/nodes/sql.tsx +0 -37
  327. package/src/client/nodes/update.tsx +0 -100
  328. package/src/client/schemas/collection.ts +0 -75
  329. package/src/client/schemas/executions.tsx +0 -169
  330. package/src/client/schemas/workflows.ts +0 -364
  331. package/src/client/style.tsx +0 -350
  332. package/src/client/triggers/collection.tsx +0 -190
  333. package/src/client/triggers/index.tsx +0 -311
  334. package/src/client/triggers/schedule/EndsByField.tsx +0 -40
  335. package/src/client/triggers/schedule/OnField.tsx +0 -64
  336. package/src/client/triggers/schedule/RepeatField.tsx +0 -116
  337. package/src/client/triggers/schedule/ScheduleConfig.tsx +0 -227
  338. package/src/client/triggers/schedule/constants.ts +0 -4
  339. package/src/client/triggers/schedule/index.tsx +0 -78
  340. package/src/client/triggers/schedule/locale/Cron.zh-CN.ts +0 -79
  341. package/src/client/utils.ts +0 -36
  342. package/src/client/variable.tsx +0 -318
  343. package/src/index.ts +0 -1
  344. package/src/locale/en-US.ts +0 -136
  345. package/src/locale/es-ES.ts +0 -129
  346. package/src/locale/fr-FR.ts +0 -137
  347. package/src/locale/ja-JP.ts +0 -90
  348. package/src/locale/pt-BR.ts +0 -136
  349. package/src/locale/ru-RU.ts +0 -90
  350. package/src/locale/tr-TR.ts +0 -90
  351. package/src/locale/zh-CN.ts +0 -248
  352. package/src/server/Plugin.ts +0 -355
  353. package/src/server/__tests__/Plugin.test.ts +0 -398
  354. package/src/server/__tests__/Processor.test.ts +0 -474
  355. package/src/server/__tests__/actions/workflows.test.ts +0 -419
  356. package/src/server/__tests__/collections/categories.ts +0 -27
  357. package/src/server/__tests__/collections/comments.ts +0 -24
  358. package/src/server/__tests__/collections/posts.ts +0 -42
  359. package/src/server/__tests__/collections/replies.ts +0 -9
  360. package/src/server/__tests__/collections/tags.ts +0 -15
  361. package/src/server/__tests__/index.ts +0 -89
  362. package/src/server/__tests__/instructions/aggregate.test.ts +0 -294
  363. package/src/server/__tests__/instructions/calculation.test.ts +0 -265
  364. package/src/server/__tests__/instructions/condition.test.ts +0 -434
  365. package/src/server/__tests__/instructions/create.test.ts +0 -129
  366. package/src/server/__tests__/instructions/delay.test.ts +0 -182
  367. package/src/server/__tests__/instructions/destroy.test.ts +0 -58
  368. package/src/server/__tests__/instructions/loop.test.ts +0 -331
  369. package/src/server/__tests__/instructions/manual.test.ts +0 -1173
  370. package/src/server/__tests__/instructions/parallel.test.ts +0 -445
  371. package/src/server/__tests__/instructions/query.test.ts +0 -359
  372. package/src/server/__tests__/instructions/request.test.ts +0 -247
  373. package/src/server/__tests__/instructions/sql.test.ts +0 -162
  374. package/src/server/__tests__/instructions/update.test.ts +0 -189
  375. package/src/server/__tests__/triggers/collection.test.ts +0 -333
  376. package/src/server/__tests__/triggers/schedule.test.ts +0 -369
  377. package/src/server/actions/index.ts +0 -25
  378. package/src/server/collections/executions.ts +0 -35
  379. package/src/server/collections/flow_nodes.ts +0 -54
  380. package/src/server/collections/jobs.ts +0 -31
  381. package/src/server/collections/workflows.ts +0 -88
  382. package/src/server/constants.ts +0 -26
  383. package/src/server/fields/expression-field.ts +0 -11
  384. package/src/server/fields/index.ts +0 -7
  385. package/src/server/functions/index.ts +0 -16
  386. package/src/server/index.ts +0 -6
  387. package/src/server/instructions/aggregate.ts +0 -42
  388. package/src/server/instructions/calculation.ts +0 -41
  389. package/src/server/instructions/condition.ts +0 -172
  390. package/src/server/instructions/delay.ts +0 -105
  391. package/src/server/instructions/destroy.ts +0 -23
  392. package/src/server/instructions/index.ts +0 -64
  393. package/src/server/instructions/manual/collecions/jobs.ts +0 -17
  394. package/src/server/instructions/manual/collecions/users.ts +0 -15
  395. package/src/server/instructions/manual/collecions/users_jobs.ts +0 -50
  396. package/src/server/instructions/manual/forms/index.ts +0 -12
  397. package/src/server/instructions/manual/index.ts +0 -184
  398. package/src/server/instructions/parallel.ts +0 -121
  399. package/src/server/instructions/query.ts +0 -42
  400. package/src/server/instructions/request.ts +0 -88
  401. package/src/server/instructions/sql.ts +0 -25
  402. package/src/server/instructions/update.ts +0 -24
  403. package/src/server/migrations/20230221032941-change-request-body-type.ts +0 -76
  404. package/src/server/migrations/20230221071831-calculation-expression.ts +0 -102
  405. package/src/server/migrations/20230221121203-condition-calculation.ts +0 -82
  406. package/src/server/migrations/20230221162902-jsonb-to-json.ts +0 -51
  407. package/src/server/migrations/20230411034722-manual-multi-form.ts +0 -282
  408. package/src/server/migrations/20230612021134-manual-collection-block.ts +0 -138
  409. package/src/server/migrations/20230710115902-manual-action-values.ts +0 -78
  410. package/src/server/triggers/index.ts +0 -22
  411. package/src/server/types/Execution.ts +0 -26
  412. package/src/server/types/FlowNode.ts +0 -21
  413. package/src/server/types/Job.ts +0 -18
  414. package/src/server/types/Workflow.ts +0 -36
  415. package/src/server/types/index.ts +0 -4
  416. package/src/server/utils.ts +0 -17
  417. /package/{lib → dist}/client/AddButton.d.ts +0 -0
  418. /package/{lib → dist}/client/Branch.d.ts +0 -0
  419. /package/{lib → dist}/client/CanvasContent.d.ts +0 -0
  420. /package/{lib → dist}/client/ExecutionCanvas.d.ts +0 -0
  421. /package/{lib → dist}/client/ExecutionLink.d.ts +0 -0
  422. /package/{lib → dist}/client/ExecutionPage.d.ts +0 -0
  423. /package/{lib → dist}/client/ExecutionResourceProvider.d.ts +0 -0
  424. /package/{lib → dist}/client/FlowContext.d.ts +0 -0
  425. /package/{lib → dist}/client/WorkflowCanvas.d.ts +0 -0
  426. /package/{lib → dist}/client/WorkflowLink.d.ts +0 -0
  427. /package/{lib → dist}/client/WorkflowPage.d.ts +0 -0
  428. /package/{lib → dist}/client/WorkflowProvider.d.ts +0 -0
  429. /package/{lib → dist}/client/components/CollectionBlockInitializer.d.ts +0 -0
  430. /package/{lib → dist}/client/components/CollectionFieldset.d.ts +0 -0
  431. /package/{lib → dist}/client/components/Duration.d.ts +0 -0
  432. /package/{lib → dist}/client/components/DynamicExpression.d.ts +0 -0
  433. /package/{lib → dist}/client/components/FieldsSelect.d.ts +0 -0
  434. /package/{lib → dist}/client/components/FilterDynamicComponent.d.ts +0 -0
  435. /package/{lib → dist}/client/components/NodeDescription.d.ts +0 -0
  436. /package/{lib → dist}/client/components/NullRender.d.ts +0 -0
  437. /package/{lib → dist}/client/components/OpenDrawer.d.ts +0 -0
  438. /package/{lib → dist}/client/components/RadioWithTooltip.d.ts +0 -0
  439. /package/{lib → dist}/client/components/ValueBlock.d.ts +0 -0
  440. /package/{lib → dist}/client/components/renderEngineReference.d.ts +0 -0
  441. /package/{lib → dist}/client/constants.d.ts +0 -0
  442. /package/{lib → dist}/client/index.d.ts +0 -0
  443. /package/{lib → dist}/client/interfaces/expression.d.ts +0 -0
  444. /package/{lib → dist}/client/locale/index.d.ts +0 -0
  445. /package/{lib → dist}/client/nodes/calculation.d.ts +0 -0
  446. /package/{lib → dist}/client/nodes/condition.d.ts +0 -0
  447. /package/{lib → dist}/client/nodes/delay.d.ts +0 -0
  448. /package/{lib → dist}/client/nodes/index.d.ts +0 -0
  449. /package/{lib → dist}/client/nodes/loop.d.ts +0 -0
  450. /package/{lib → dist}/client/nodes/manual/AssigneesSelect.d.ts +0 -0
  451. /package/{lib → dist}/client/nodes/manual/DetailsBlockProvider.d.ts +0 -0
  452. /package/{lib → dist}/client/nodes/manual/FormBlockInitializer.d.ts +0 -0
  453. /package/{lib → dist}/client/nodes/manual/FormBlockProvider.d.ts +0 -0
  454. /package/{lib → dist}/client/nodes/manual/ModeConfig.d.ts +0 -0
  455. /package/{lib → dist}/client/nodes/manual/SchemaConfig.d.ts +0 -0
  456. /package/{lib → dist}/client/nodes/manual/WorkflowTodo.d.ts +0 -0
  457. /package/{lib → dist}/client/nodes/manual/WorkflowTodoBlockInitializer.d.ts +0 -0
  458. /package/{lib → dist}/client/nodes/manual/forms/create.d.ts +0 -0
  459. /package/{lib → dist}/client/nodes/manual/forms/custom.d.ts +0 -0
  460. /package/{lib → dist}/client/nodes/manual/forms/update.d.ts +0 -0
  461. /package/{lib → dist}/client/nodes/manual/index.d.ts +0 -0
  462. /package/{lib → dist}/client/nodes/manual/utils.d.ts +0 -0
  463. /package/{lib → dist}/client/nodes/parallel.d.ts +0 -0
  464. /package/{lib → dist}/client/nodes/sql.d.ts +0 -0
  465. /package/{lib → dist}/client/schemas/executions.d.ts +0 -0
  466. /package/{lib → dist}/client/schemas/workflows.d.ts +0 -0
  467. /package/{lib → dist}/client/style.d.ts +0 -0
  468. /package/{lib → dist}/client/triggers/index.d.ts +0 -0
  469. /package/{lib → dist}/client/triggers/schedule/EndsByField.d.ts +0 -0
  470. /package/{lib → dist}/client/triggers/schedule/OnField.d.ts +0 -0
  471. /package/{lib → dist}/client/triggers/schedule/RepeatField.d.ts +0 -0
  472. /package/{lib → dist}/client/triggers/schedule/ScheduleConfig.d.ts +0 -0
  473. /package/{lib → dist}/client/triggers/schedule/constants.d.ts +0 -0
  474. /package/{lib → dist}/client/triggers/schedule/index.d.ts +0 -0
  475. /package/{lib → dist}/client/triggers/schedule/locale/Cron.zh-CN.d.ts +0 -0
  476. /package/{lib → dist}/client/utils.d.ts +0 -0
  477. /package/{lib → dist}/client/variable.d.ts +0 -0
  478. /package/{lib → dist}/locale/en-US.d.ts +0 -0
  479. /package/{lib → dist}/locale/es-ES.d.ts +0 -0
  480. /package/{lib → dist}/locale/fr-FR.d.ts +0 -0
  481. /package/{lib → dist}/locale/ja-JP.d.ts +0 -0
  482. /package/{lib → dist}/locale/pt-BR.d.ts +0 -0
  483. /package/{lib → dist}/locale/ru-RU.d.ts +0 -0
  484. /package/{lib → dist}/locale/tr-TR.d.ts +0 -0
  485. /package/{lib → dist}/locale/zh-CN.d.ts +0 -0
  486. /package/{lib → dist}/server/Plugin.d.ts +0 -0
  487. /package/{lib → dist}/server/Processor.d.ts +0 -0
  488. /package/{lib → dist}/server/actions/index.d.ts +0 -0
  489. /package/{lib → dist}/server/actions/nodes.d.ts +0 -0
  490. /package/{lib → dist}/server/actions/workflows.d.ts +0 -0
  491. /package/{lib → dist}/server/collections/executions.d.ts +0 -0
  492. /package/{lib → dist}/server/collections/flow_nodes.d.ts +0 -0
  493. /package/{lib → dist}/server/collections/jobs.d.ts +0 -0
  494. /package/{lib → dist}/server/collections/workflows.d.ts +0 -0
  495. /package/{lib → dist}/server/constants.d.ts +0 -0
  496. /package/{lib → dist}/server/fields/expression-field.d.ts +0 -0
  497. /package/{lib → dist}/server/fields/index.d.ts +0 -0
  498. /package/{lib → dist}/server/functions/index.d.ts +0 -0
  499. /package/{lib → dist}/server/index.d.ts +0 -0
  500. /package/{lib → dist}/server/instructions/aggregate.d.ts +0 -0
  501. /package/{lib → dist}/server/instructions/calculation.d.ts +0 -0
  502. /package/{lib → dist}/server/instructions/condition.d.ts +0 -0
  503. /package/{lib → dist}/server/instructions/create.d.ts +0 -0
  504. /package/{lib → dist}/server/instructions/delay.d.ts +0 -0
  505. /package/{lib → dist}/server/instructions/destroy.d.ts +0 -0
  506. /package/{lib → dist}/server/instructions/index.d.ts +0 -0
  507. /package/{lib → dist}/server/instructions/loop.d.ts +0 -0
  508. /package/{lib → dist}/server/instructions/manual/actions.d.ts +0 -0
  509. /package/{lib → dist}/server/instructions/manual/collecions/jobs.d.ts +0 -0
  510. /package/{lib → dist}/server/instructions/manual/collecions/users.d.ts +0 -0
  511. /package/{lib → dist}/server/instructions/manual/collecions/users_jobs.d.ts +0 -0
  512. /package/{lib → dist}/server/instructions/manual/forms/create.d.ts +0 -0
  513. /package/{lib → dist}/server/instructions/manual/forms/index.d.ts +0 -0
  514. /package/{lib → dist}/server/instructions/manual/forms/update.d.ts +0 -0
  515. /package/{lib → dist}/server/instructions/manual/index.d.ts +0 -0
  516. /package/{lib → dist}/server/instructions/parallel.d.ts +0 -0
  517. /package/{lib → dist}/server/instructions/query.d.ts +0 -0
  518. /package/{lib → dist}/server/instructions/request.d.ts +0 -0
  519. /package/{lib → dist}/server/instructions/sql.d.ts +0 -0
  520. /package/{lib → dist}/server/instructions/update.d.ts +0 -0
  521. /package/{lib → dist}/server/migrations/20221129153547-calculation-variables.d.ts +0 -0
  522. /package/{lib → dist}/server/migrations/20230221032941-change-request-body-type.d.ts +0 -0
  523. /package/{lib → dist}/server/migrations/20230221071831-calculation-expression.d.ts +0 -0
  524. /package/{lib → dist}/server/migrations/20230221121203-condition-calculation.d.ts +0 -0
  525. /package/{lib → dist}/server/migrations/20230221162902-jsonb-to-json.d.ts +0 -0
  526. /package/{lib → dist}/server/migrations/20230411034722-manual-multi-form.d.ts +0 -0
  527. /package/{lib → dist}/server/migrations/20230612021134-manual-collection-block.d.ts +0 -0
  528. /package/{lib → dist}/server/migrations/20230710115902-manual-action-values.d.ts +0 -0
  529. /package/{lib → dist}/server/triggers/collection.d.ts +0 -0
  530. /package/{lib → dist}/server/triggers/index.d.ts +0 -0
  531. /package/{lib → dist}/server/triggers/schedule.d.ts +0 -0
  532. /package/{lib → dist}/server/types/Execution.d.ts +0 -0
  533. /package/{lib → dist}/server/types/FlowNode.d.ts +0 -0
  534. /package/{lib → dist}/server/types/Job.d.ts +0 -0
  535. /package/{lib → dist}/server/types/Workflow.d.ts +0 -0
  536. /package/{lib → dist}/server/types/index.d.ts +0 -0
  537. /package/{lib → dist}/server/utils.d.ts +0 -0
@@ -1,1173 +0,0 @@
1
- import Database from '@nocobase/database';
2
- import UserPlugin from '@nocobase/plugin-users';
3
- import { MockServer } from '@nocobase/test';
4
- import { getApp, sleep } from '..';
5
- import { EXECUTION_STATUS, JOB_STATUS } from '../../constants';
6
-
7
- // NOTE: skipped because time is not stable on github ci, but should work in local
8
- describe('workflow > instructions > manual', () => {
9
- let app: MockServer;
10
- let agent;
11
- let userAgents;
12
- let db: Database;
13
- let PostRepo;
14
- let CommentRepo;
15
- let WorkflowModel;
16
- let workflow;
17
- let UserModel;
18
- let users;
19
- let UserJobModel;
20
-
21
- beforeEach(async () => {
22
- app = await getApp({
23
- plugins: ['users', 'auth'],
24
- });
25
- await app.getPlugin('auth').install();
26
- agent = app.agent();
27
- db = app.db;
28
- WorkflowModel = db.getCollection('workflows').model;
29
- PostRepo = db.getCollection('posts').repository;
30
- CommentRepo = db.getCollection('comments').repository;
31
- UserModel = db.getCollection('users').model;
32
- UserJobModel = db.getModel('users_jobs');
33
-
34
- users = await UserModel.bulkCreate([
35
- { id: 1, nickname: 'a' },
36
- { id: 2, nickname: 'b' },
37
- ]);
38
-
39
- const userPlugin = app.getPlugin('users') as UserPlugin;
40
- userAgents = users.map((user) => app.agent().login(user));
41
-
42
- workflow = await WorkflowModel.create({
43
- enabled: true,
44
- type: 'collection',
45
- config: {
46
- mode: 1,
47
- collection: 'posts',
48
- },
49
- });
50
- });
51
-
52
- afterEach(() => db.close());
53
-
54
- describe('actions configuration', () => {
55
- it('no action configured', async () => {
56
- const n1 = await workflow.createNode({
57
- type: 'manual',
58
- config: {
59
- assignees: [users[0].id],
60
- forms: {
61
- f1: {
62
- },
63
- },
64
- },
65
- });
66
-
67
- const post = await PostRepo.create({ values: { title: 't1' } });
68
-
69
- await sleep(500);
70
-
71
- const [pending] = await workflow.getExecutions();
72
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
73
- const [j1] = await pending.getJobs();
74
- expect(j1.status).toBe(JOB_STATUS.PENDING);
75
-
76
- const usersJobs = await UserJobModel.findAll();
77
- expect(usersJobs.length).toBe(1);
78
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
79
- expect(usersJobs[0].userId).toBe(users[0].id);
80
- expect(usersJobs[0].jobId).toBe(j1.id);
81
-
82
- const res1 = await userAgents[0].resource('users_jobs').submit({
83
- filterByTk: usersJobs[0].id,
84
- values: {
85
- result: { f1: { a: 1 }, _: 'resolve' },
86
- },
87
- });
88
-
89
- expect(res1.status).toBe(400);
90
- });
91
-
92
- it('no actionKey provided', async () => {
93
- const n1 = await workflow.createNode({
94
- type: 'manual',
95
- config: {
96
- assignees: [users[0].id],
97
- forms: {
98
- f1: {
99
- actions: [
100
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
101
- ],
102
- },
103
- },
104
- },
105
- });
106
-
107
- const post = await PostRepo.create({ values: { title: 't1' } });
108
-
109
- await sleep(500);
110
-
111
- const [pending] = await workflow.getExecutions();
112
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
113
- const [j1] = await pending.getJobs();
114
- expect(j1.status).toBe(JOB_STATUS.PENDING);
115
-
116
- const usersJobs = await UserJobModel.findAll();
117
- expect(usersJobs.length).toBe(1);
118
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
119
- expect(usersJobs[0].userId).toBe(users[0].id);
120
- expect(usersJobs[0].jobId).toBe(j1.id);
121
-
122
- const res1 = await userAgents[0].resource('users_jobs').submit({
123
- filterByTk: usersJobs[0].id,
124
- values: {
125
- result: { f1: { a: 1 } },
126
- },
127
- });
128
-
129
- expect(res1.status).toBe(400);
130
- });
131
-
132
- it('values resolved will be overrided by action assigned', async () => {
133
- const n1 = await workflow.createNode({
134
- type: 'manual',
135
- config: {
136
- assignees: [users[0].id],
137
- forms: {
138
- f1: {
139
- actions: [
140
- {
141
- status: JOB_STATUS.RESOLVED,
142
- key: 'resolve',
143
- values: { a: 2 },
144
- },
145
- ],
146
- },
147
- },
148
- },
149
- });
150
-
151
- const post = await PostRepo.create({ values: { title: 't1' } });
152
-
153
- await sleep(500);
154
-
155
- const [pending] = await workflow.getExecutions();
156
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
157
- const [j1] = await pending.getJobs();
158
- expect(j1.status).toBe(JOB_STATUS.PENDING);
159
-
160
- const usersJobs = await UserJobModel.findAll();
161
- expect(usersJobs.length).toBe(1);
162
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
163
- expect(usersJobs[0].userId).toBe(users[0].id);
164
- expect(usersJobs[0].jobId).toBe(j1.id);
165
-
166
- const res1 = await userAgents[0].resource('users_jobs').submit({
167
- filterByTk: usersJobs[0].id,
168
- values: {
169
- result: { f1: { a: 1 }, _: 'resolve' },
170
- },
171
- });
172
-
173
- await sleep(500);
174
-
175
- const [execution] = await workflow.getExecutions();
176
- expect(execution.status).toBe(EXECUTION_STATUS.RESOLVED);
177
- const [job] = await execution.getJobs();
178
- expect(job.status).toBe(JOB_STATUS.RESOLVED);
179
- expect(job.result).toEqual({ f1: { a: 2 }, _: 'resolve' });
180
- });
181
-
182
- it('values rejected will not be overrided by action assigned', async () => {
183
- const n1 = await workflow.createNode({
184
- type: 'manual',
185
- config: {
186
- assignees: [users[0].id],
187
- forms: {
188
- f1: {
189
- actions: [
190
- {
191
- status: JOB_STATUS.REJECTED,
192
- key: 'reject',
193
- values: { a: 2 },
194
- },
195
- ],
196
- },
197
- },
198
- },
199
- });
200
-
201
- const post = await PostRepo.create({ values: { title: 't1' } });
202
-
203
- await sleep(500);
204
-
205
- const [pending] = await workflow.getExecutions();
206
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
207
- const [j1] = await pending.getJobs();
208
- expect(j1.status).toBe(JOB_STATUS.PENDING);
209
-
210
- const usersJobs = await UserJobModel.findAll();
211
- expect(usersJobs.length).toBe(1);
212
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
213
- expect(usersJobs[0].userId).toBe(users[0].id);
214
- expect(usersJobs[0].jobId).toBe(j1.id);
215
-
216
- const res1 = await userAgents[0].resource('users_jobs').submit({
217
- filterByTk: usersJobs[0].id,
218
- values: {
219
- result: { f1: { a: 1 }, _: 'reject' },
220
- },
221
- });
222
-
223
- await sleep(500);
224
-
225
- const [execution] = await workflow.getExecutions();
226
- expect(execution.status).toBe(EXECUTION_STATUS.REJECTED);
227
- const [job] = await execution.getJobs();
228
- expect(job.status).toBe(JOB_STATUS.REJECTED);
229
- expect(job.result).toEqual({ f1: { a: 1 }, _: 'reject' });
230
- });
231
-
232
- it('values saved as pending will not be overrided by action assigned', async () => {
233
- const n1 = await workflow.createNode({
234
- type: 'manual',
235
- config: {
236
- assignees: [users[0].id],
237
- forms: {
238
- f1: {
239
- actions: [
240
- {
241
- status: JOB_STATUS.PENDING,
242
- key: 'save',
243
- values: { a: 2 },
244
- },
245
- ],
246
- },
247
- },
248
- },
249
- });
250
-
251
- const post = await PostRepo.create({ values: { title: 't1' } });
252
-
253
- await sleep(500);
254
-
255
- const [pending] = await workflow.getExecutions();
256
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
257
- const [j1] = await pending.getJobs();
258
- expect(j1.status).toBe(JOB_STATUS.PENDING);
259
-
260
- const usersJobs = await UserJobModel.findAll();
261
- expect(usersJobs.length).toBe(1);
262
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
263
- expect(usersJobs[0].userId).toBe(users[0].id);
264
- expect(usersJobs[0].jobId).toBe(j1.id);
265
-
266
- const res1 = await userAgents[0].resource('users_jobs').submit({
267
- filterByTk: usersJobs[0].id,
268
- values: {
269
- result: { f1: { a: 1 }, _: 'save' },
270
- },
271
- });
272
-
273
- await sleep(500);
274
-
275
- const [execution] = await workflow.getExecutions();
276
- expect(execution.status).toBe(EXECUTION_STATUS.STARTED);
277
- const [job] = await execution.getJobs();
278
- expect(job.status).toBe(JOB_STATUS.PENDING);
279
- expect(job.result).toEqual({ f1: { a: 1 }, _: 'save' });
280
- });
281
-
282
- it('variable within assigned values should work when resolve', async () => {
283
- const n1 = await workflow.createNode({
284
- type: 'manual',
285
- config: {
286
- assignees: [users[0].id],
287
- forms: {
288
- f1: {
289
- actions: [
290
- {
291
- status: JOB_STATUS.RESOLVED,
292
- key: 'resolve',
293
- values: {
294
- a: '{{currentUser.id}}',
295
- b: '{{currentRecord.id}}',
296
- c: '{{currentTime}}',
297
- d: '{{$context.data.title}}',
298
- },
299
- },
300
- ],
301
- },
302
- },
303
- },
304
- });
305
-
306
- const post = await PostRepo.create({ values: { title: 't1' } });
307
-
308
- await sleep(500);
309
-
310
- const [pending] = await workflow.getExecutions();
311
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
312
- const [j1] = await pending.getJobs();
313
- expect(j1.status).toBe(JOB_STATUS.PENDING);
314
-
315
- const usersJobs = await UserJobModel.findAll();
316
- expect(usersJobs.length).toBe(1);
317
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
318
- expect(usersJobs[0].userId).toBe(users[0].id);
319
- expect(usersJobs[0].jobId).toBe(j1.id);
320
-
321
- const now = new Date();
322
- const res1 = await userAgents[0].resource('users_jobs').submit({
323
- filterByTk: usersJobs[0].id,
324
- values: {
325
- result: { f1: { a: 2, id: 3 }, _: 'resolve' },
326
- },
327
- });
328
-
329
- await sleep(500);
330
-
331
- const [execution] = await workflow.getExecutions();
332
- expect(execution.status).toBe(EXECUTION_STATUS.RESOLVED);
333
- const [job] = await execution.getJobs();
334
- expect(job.status).toBe(JOB_STATUS.RESOLVED);
335
- expect(job.result).toMatchObject({ f1: { a: users[0].id, id: 3, b: 3, d: post.title }, _: 'resolve' });
336
- const time = new Date(job.result.f1.c);
337
- expect(time.getTime() - now.getTime()).toBeLessThan(1000);
338
- });
339
- });
340
-
341
- describe('mode: 0 (single record)', () => {
342
- it('the only user assigned could submit', async () => {
343
- const n1 = await workflow.createNode({
344
- type: 'manual',
345
- config: {
346
- assignees: [users[0].id],
347
- forms: {
348
- f1: {
349
- actions: [
350
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
351
- ],
352
- },
353
- },
354
- },
355
- });
356
-
357
- const post = await PostRepo.create({ values: { title: 't1' } });
358
-
359
- await sleep(500);
360
-
361
- const [pending] = await workflow.getExecutions();
362
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
363
- const [j1] = await pending.getJobs();
364
- expect(j1.status).toBe(JOB_STATUS.PENDING);
365
-
366
- const usersJobs = await UserJobModel.findAll();
367
- expect(usersJobs.length).toBe(1);
368
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
369
- expect(usersJobs[0].userId).toBe(users[0].id);
370
- expect(usersJobs[0].jobId).toBe(j1.id);
371
-
372
- const res1 = await agent.resource('users_jobs').submit({
373
- filterByTk: usersJobs[0].id,
374
- values: { result: { f1: {}, _: 'resolve' } },
375
- });
376
- expect(res1.status).toBe(401);
377
-
378
- const res2 = await userAgents[1].resource('users_jobs').submit({
379
- filterByTk: usersJobs[0].id,
380
- values: {
381
- result: { f1: {}, _: 'resolve' },
382
- },
383
- });
384
- expect(res2.status).toBe(403);
385
-
386
- const res3 = await userAgents[0].resource('users_jobs').submit({
387
- filterByTk: usersJobs[0].id,
388
- values: {
389
- result: { f1: { a: 1 }, _: 'resolve' },
390
- },
391
- });
392
- expect(res3.status).toBe(202);
393
-
394
- await sleep(1000);
395
-
396
- const [j2] = await pending.getJobs();
397
- expect(j2.status).toBe(JOB_STATUS.RESOLVED);
398
- expect(j2.result).toEqual({ f1: { a: 1 }, _: 'resolve' });
399
-
400
- const usersJobsAfter = await UserJobModel.findAll();
401
- expect(usersJobsAfter.length).toBe(1);
402
- expect(usersJobsAfter[0].status).toBe(JOB_STATUS.RESOLVED);
403
- expect(usersJobsAfter[0].result).toEqual({ f1: { a: 1 }, _: 'resolve' });
404
-
405
- const res4 = await userAgents[0].resource('users_jobs').submit({
406
- filterByTk: usersJobs[0].id,
407
- values: {
408
- result: { f1: { a: 2 }, _: 'resolve' },
409
- },
410
- });
411
- expect(res4.status).toBe(400);
412
- });
413
-
414
- it('any user assigned could submit', async () => {
415
- const n1 = await workflow.createNode({
416
- type: 'manual',
417
- config: {
418
- assignees: [users[0].id, users[1].id],
419
- forms: {
420
- f1: {
421
- actions: [
422
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
423
- ]
424
- },
425
- },
426
- },
427
- });
428
-
429
- const post = await PostRepo.create({ values: { title: 't1' } });
430
-
431
- await sleep(500);
432
-
433
- const [pending] = await workflow.getExecutions();
434
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
435
- const [j1] = await pending.getJobs();
436
- expect(j1.status).toBe(JOB_STATUS.PENDING);
437
-
438
- const usersJobs = await j1.getUsersJobs();
439
-
440
- const res1 = await userAgents[1].resource('users_jobs').submit({
441
- filterByTk: usersJobs.find((item) => item.userId === users[1].id).id,
442
- values: {
443
- result: { f1: { a: 1 }, _: 'resolve' },
444
- },
445
- });
446
- expect(res1.status).toBe(202);
447
-
448
- await sleep(1000);
449
-
450
- const [j2] = await pending.getJobs();
451
- expect(j2.status).toBe(JOB_STATUS.RESOLVED);
452
- expect(j2.result).toEqual({ f1: { a: 1 }, _: 'resolve' });
453
-
454
- const res2 = await userAgents[0].resource('users_jobs').submit({
455
- filterByTk: usersJobs.find((item) => item.userId === users[0].id).id,
456
- values: {
457
- result: { f1: { a: 1 }, _: 'resolve' },
458
- },
459
- });
460
- expect(res2.status).toBe(400);
461
- });
462
-
463
- it('also could submit to users_jobs api', async () => {
464
- const n1 = await workflow.createNode({
465
- type: 'manual',
466
- config: {
467
- assignees: [users[0].id],
468
- forms: {
469
- f1: {
470
- actions: [
471
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
472
- ],
473
- },
474
- },
475
- },
476
- });
477
-
478
- const post = await PostRepo.create({ values: { title: 't1' } });
479
-
480
- await sleep(500);
481
-
482
- const UserJobModel = db.getModel('users_jobs');
483
- const usersJobs = await UserJobModel.findAll();
484
- expect(usersJobs.length).toBe(1);
485
- expect(usersJobs[0].get('status')).toBe(JOB_STATUS.PENDING);
486
- expect(usersJobs[0].get('userId')).toBe(users[0].id);
487
-
488
- const res = await userAgents[0].resource('users_jobs').submit({
489
- filterByTk: usersJobs[0].get('id'),
490
- values: {
491
- result: { f1: { a: 1 }, _: 'resolve' },
492
- },
493
- });
494
- expect(res.status).toBe(202);
495
-
496
- await sleep(1000);
497
-
498
- const [execution] = await workflow.getExecutions();
499
- expect(execution.status).toBe(EXECUTION_STATUS.RESOLVED);
500
- const [job] = await execution.getJobs();
501
- expect(job.status).toBe(JOB_STATUS.RESOLVED);
502
- expect(job.result).toEqual({ f1: { a: 1 }, _: 'resolve' });
503
- });
504
- });
505
-
506
- describe('mode: 1 (multiple record, all)', () => {
507
- it('all resolved', async () => {
508
- const n1 = await workflow.createNode({
509
- type: 'manual',
510
- config: {
511
- assignees: [users[0].id, users[1].id],
512
- mode: 1,
513
- forms: {
514
- f1: {
515
- actions: [
516
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
517
- ],
518
- },
519
- },
520
- },
521
- });
522
-
523
- const post = await PostRepo.create({ values: { title: 't1' } });
524
-
525
- await sleep(500);
526
-
527
- const UserJobModel = db.getModel('users_jobs');
528
- const pendingJobs = await UserJobModel.findAll({
529
- order: [['userId', 'ASC']],
530
- });
531
- expect(pendingJobs.length).toBe(2);
532
-
533
- const res1 = await userAgents[0].resource('users_jobs').submit({
534
- filterByTk: pendingJobs[0].get('id'),
535
- values: {
536
- result: { f1: { a: 1 }, _: 'resolve' },
537
- },
538
- });
539
- expect(res1.status).toBe(202);
540
-
541
- await sleep(1000);
542
-
543
- const [e1] = await workflow.getExecutions();
544
- expect(e1.status).toBe(EXECUTION_STATUS.STARTED);
545
- const [j1] = await e1.getJobs();
546
- expect(j1.status).toBe(JOB_STATUS.PENDING);
547
- expect(j1.result).toBe(0.5);
548
- const usersJobs1 = await UserJobModel.findAll({
549
- order: [['userId', 'ASC']],
550
- });
551
- expect(usersJobs1.length).toBe(2);
552
-
553
- const res2 = await userAgents[1].resource('users_jobs').submit({
554
- filterByTk: pendingJobs[1].get('id'),
555
- values: {
556
- result: { f1: { a: 2 }, _: 'resolve' },
557
- },
558
- });
559
- expect(res2.status).toBe(202);
560
-
561
- await sleep(1000);
562
-
563
- const [e2] = await workflow.getExecutions();
564
- expect(e2.status).toBe(EXECUTION_STATUS.RESOLVED);
565
- const [j2] = await e2.getJobs();
566
- expect(j2.status).toBe(JOB_STATUS.RESOLVED);
567
- expect(j2.result).toBe(1);
568
- });
569
-
570
- it('first rejected', async () => {
571
- const n1 = await workflow.createNode({
572
- type: 'manual',
573
- config: {
574
- assignees: [users[0].id, users[1].id],
575
- mode: 1,
576
- forms: {
577
- f1: {
578
- actions: [
579
- { status: JOB_STATUS.REJECTED, key: 'reject' },
580
- ],
581
- },
582
- },
583
- },
584
- });
585
-
586
- const post = await PostRepo.create({ values: { title: 't1' } });
587
-
588
- await sleep(500);
589
-
590
- const UserJobModel = db.getModel('users_jobs');
591
- const pendingJobs = await UserJobModel.findAll({
592
- order: [['userId', 'ASC']],
593
- });
594
- expect(pendingJobs.length).toBe(2);
595
-
596
- const res1 = await userAgents[0].resource('users_jobs').submit({
597
- filterByTk: pendingJobs[0].get('id'),
598
- values: {
599
- result: { f1: { a: 0 }, _: 'reject' },
600
- },
601
- });
602
- expect(res1.status).toBe(202);
603
-
604
- await sleep(1000);
605
-
606
- const [e1] = await workflow.getExecutions();
607
- expect(e1.status).toBe(EXECUTION_STATUS.REJECTED);
608
- const [j1] = await e1.getJobs();
609
- expect(j1.status).toBe(JOB_STATUS.REJECTED);
610
- expect(j1.result).toBe(0.5);
611
- const usersJobs1 = await UserJobModel.findAll({
612
- order: [['userId', 'ASC']],
613
- });
614
- expect(usersJobs1.length).toBe(2);
615
-
616
- const res2 = await userAgents[1].resource('users_jobs').submit({
617
- filterByTk: pendingJobs[1].get('id'),
618
- values: {
619
- result: { f1: { a: 0 }, _: 'reject' },
620
- },
621
- });
622
- expect(res2.status).toBe(400);
623
- });
624
-
625
- it('last rejected', async () => {
626
- const n1 = await workflow.createNode({
627
- type: 'manual',
628
- config: {
629
- assignees: [users[0].id, users[1].id],
630
- mode: 1,
631
- forms: {
632
- f1: {
633
- actions: [
634
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
635
- { status: JOB_STATUS.REJECTED, key: 'reject' },
636
- ],
637
- },
638
- },
639
- },
640
- });
641
-
642
- const post = await PostRepo.create({ values: { title: 't1' } });
643
-
644
- await sleep(500);
645
-
646
- const UserJobModel = db.getModel('users_jobs');
647
- const pendingJobs = await UserJobModel.findAll({
648
- order: [['userId', 'ASC']],
649
- });
650
- expect(pendingJobs.length).toBe(2);
651
-
652
- const res1 = await userAgents[0].resource('users_jobs').submit({
653
- filterByTk: pendingJobs[0].get('id'),
654
- values: {
655
- result: { f1: { a: 1 }, _: 'resolve' },
656
- },
657
- });
658
- expect(res1.status).toBe(202);
659
-
660
- await sleep(1000);
661
-
662
- const [e1] = await workflow.getExecutions();
663
- expect(e1.status).toBe(EXECUTION_STATUS.STARTED);
664
- const [j1] = await e1.getJobs();
665
- expect(j1.status).toBe(JOB_STATUS.PENDING);
666
- expect(j1.result).toBe(0.5);
667
- const usersJobs1 = await UserJobModel.findAll({
668
- order: [['userId', 'ASC']],
669
- });
670
- expect(usersJobs1.length).toBe(2);
671
-
672
- const res2 = await userAgents[1].resource('users_jobs').submit({
673
- filterByTk: pendingJobs[1].get('id'),
674
- values: {
675
- result: { f1: { a: 0 }, _: 'reject' },
676
- },
677
- });
678
- expect(res2.status).toBe(202);
679
-
680
- await sleep(1000);
681
-
682
- const [e2] = await workflow.getExecutions();
683
- expect(e2.status).toBe(EXECUTION_STATUS.REJECTED);
684
- const [j2] = await e2.getJobs();
685
- expect(j2.status).toBe(JOB_STATUS.REJECTED);
686
- expect(j2.result).toBe(1);
687
- });
688
- });
689
-
690
- describe('mode: -1 (multiple record, any)', () => {
691
- it('first resolved', async () => {
692
- const n1 = await workflow.createNode({
693
- type: 'manual',
694
- config: {
695
- assignees: [users[0].id, users[1].id],
696
- mode: -1,
697
- forms: {
698
- f1: {
699
- actions: [
700
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
701
- { status: JOB_STATUS.REJECTED, key: 'reject' },
702
- ],
703
- },
704
- },
705
- },
706
- });
707
-
708
- const post = await PostRepo.create({ values: { title: 't1' } });
709
-
710
- await sleep(500);
711
-
712
- const UserJobModel = db.getModel('users_jobs');
713
- const pendingJobs = await UserJobModel.findAll({
714
- order: [['userId', 'ASC']],
715
- });
716
- expect(pendingJobs.length).toBe(2);
717
-
718
- const res1 = await userAgents[0].resource('users_jobs').submit({
719
- filterByTk: pendingJobs[0].get('id'),
720
- values: {
721
- result: { f1: { a: 1 }, _: 'resolve' },
722
- },
723
- });
724
- expect(res1.status).toBe(202);
725
-
726
- await sleep(1000);
727
-
728
- const [e1] = await workflow.getExecutions();
729
- expect(e1.status).toBe(EXECUTION_STATUS.RESOLVED);
730
- const [j1] = await e1.getJobs();
731
- expect(j1.status).toBe(JOB_STATUS.RESOLVED);
732
- expect(j1.result).toBe(0.5);
733
-
734
- const res2 = await userAgents[1].resource('users_jobs').submit({
735
- filterByTk: pendingJobs[1].get('id'),
736
- values: {
737
- result: { f1: { a: 0 }, _: 'reject' },
738
- },
739
- });
740
- expect(res2.status).toBe(400);
741
- });
742
-
743
- it('any resolved', async () => {
744
- const n1 = await workflow.createNode({
745
- type: 'manual',
746
- config: {
747
- assignees: [users[0].id, users[1].id],
748
- mode: -1,
749
- forms: {
750
- f1: {
751
- actions: [
752
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
753
- { status: JOB_STATUS.REJECTED, key: 'reject' },
754
- ],
755
- },
756
- },
757
- },
758
- });
759
-
760
- const post = await PostRepo.create({ values: { title: 't1' } });
761
-
762
- await sleep(500);
763
-
764
- const UserJobModel = db.getModel('users_jobs');
765
- const pendingJobs = await UserJobModel.findAll({
766
- order: [['userId', 'ASC']],
767
- });
768
- expect(pendingJobs.length).toBe(2);
769
-
770
- const res1 = await userAgents[0].resource('users_jobs').submit({
771
- filterByTk: pendingJobs[0].get('id'),
772
- values: {
773
- result: { f1: { a: 0 }, _: 'reject' },
774
- },
775
- });
776
- expect(res1.status).toBe(202);
777
-
778
- await sleep(1000);
779
-
780
- const [e1] = await workflow.getExecutions();
781
- expect(e1.status).toBe(EXECUTION_STATUS.STARTED);
782
- const [j1] = await e1.getJobs();
783
- expect(j1.status).toBe(JOB_STATUS.PENDING);
784
- expect(j1.result).toBe(0.5);
785
-
786
- const res2 = await userAgents[1].resource('users_jobs').submit({
787
- filterByTk: pendingJobs[1].get('id'),
788
- values: {
789
- result: { f1: { a: 1 }, _: 'resolve' },
790
- },
791
- });
792
- expect(res2.status).toBe(202);
793
-
794
- await sleep(1000);
795
-
796
- const [e2] = await workflow.getExecutions();
797
- expect(e2.status).toBe(EXECUTION_STATUS.RESOLVED);
798
- const [j2] = await e2.getJobs();
799
- expect(j2.status).toBe(JOB_STATUS.RESOLVED);
800
- expect(j2.result).toBe(1);
801
- });
802
-
803
- it('all rejected', async () => {
804
- const n1 = await workflow.createNode({
805
- type: 'manual',
806
- config: {
807
- assignees: [users[0].id, users[1].id],
808
- mode: -1,
809
- forms: {
810
- f1: {
811
- actions: [
812
- { status: JOB_STATUS.REJECTED, key: 'reject' },
813
- ],
814
- },
815
- },
816
- },
817
- });
818
-
819
- const post = await PostRepo.create({ values: { title: 't1' } });
820
-
821
- await sleep(500);
822
-
823
- const UserJobModel = db.getModel('users_jobs');
824
- const pendingJobs = await UserJobModel.findAll({
825
- order: [['userId', 'ASC']],
826
- });
827
- expect(pendingJobs.length).toBe(2);
828
-
829
- const res1 = await userAgents[0].resource('users_jobs').submit({
830
- filterByTk: pendingJobs[0].get('id'),
831
- values: {
832
- result: { f1: { a: 0 }, _: 'reject' },
833
- },
834
- });
835
- expect(res1.status).toBe(202);
836
-
837
- await sleep(1000);
838
-
839
- const [e1] = await workflow.getExecutions();
840
- expect(e1.status).toBe(EXECUTION_STATUS.STARTED);
841
- const [j1] = await e1.getJobs();
842
- expect(j1.status).toBe(JOB_STATUS.PENDING);
843
- expect(j1.result).toBe(0.5);
844
-
845
- const res2 = await userAgents[1].resource('users_jobs').submit({
846
- filterByTk: pendingJobs[1].get('id'),
847
- values: {
848
- result: { f1: { a: 0 }, _: 'reject' },
849
- },
850
- });
851
- expect(res2.status).toBe(202);
852
-
853
- await sleep(1000);
854
-
855
- const [e2] = await workflow.getExecutions();
856
- expect(e2.status).toBe(EXECUTION_STATUS.REJECTED);
857
- const [j2] = await e2.getJobs();
858
- expect(j2.status).toBe(JOB_STATUS.REJECTED);
859
- expect(j2.result).toBe(1);
860
- });
861
- });
862
-
863
- describe('mode: (0,1) (multiple record, all to percent)', () => {});
864
-
865
- describe('mode: (-1,0) (multiple record, any to percent)', () => {});
866
-
867
- describe('use result of submitted form in manual node', () => {
868
- it('result should be available and correct', async () => {
869
- const n1 = await workflow.createNode({
870
- type: 'manual',
871
- config: {
872
- assignees: [users[0].id, users[1].id],
873
- forms: {
874
- f1: {
875
- actions: [
876
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
877
- ],
878
- },
879
- },
880
- },
881
- });
882
-
883
- const n2 = await workflow.createNode({
884
- type: 'calculation',
885
- config: {
886
- engine: 'math.js',
887
- expression: `{{$jobsMapByNodeId.${n1.id}.f1.number}} + 1`,
888
- },
889
- upstreamId: n1.id,
890
- });
891
-
892
- await n1.setDownstream(n2);
893
-
894
- const post = await PostRepo.create({ values: { title: 't1' } });
895
-
896
- await sleep(500);
897
-
898
- const UserJobModel = db.getModel('users_jobs');
899
- const pendingJobs = await UserJobModel.findAll({
900
- order: [['userId', 'ASC']],
901
- });
902
- expect(pendingJobs.length).toBe(2);
903
-
904
- const res1 = await userAgents[0].resource('users_jobs').submit({
905
- filterByTk: pendingJobs[0].get('id'),
906
- values: {
907
- result: { f1: { number: 1 }, _: 'resolve' },
908
- },
909
- });
910
- expect(res1.status).toBe(202);
911
-
912
- await sleep(1000);
913
-
914
- const [e2] = await workflow.getExecutions();
915
- expect(e2.status).toBe(EXECUTION_STATUS.RESOLVED);
916
- const [j1, j2] = await e2.getJobs({ order: [['createdAt', 'ASC']] });
917
- expect(j2.status).toBe(JOB_STATUS.RESOLVED);
918
- expect(j2.result).toBe(2);
919
- });
920
-
921
- it('save all forms, only reserve submitted ones', async () => {
922
- const n1 = await workflow.createNode({
923
- type: 'manual',
924
- config: {
925
- assignees: [users[0].id, users[1].id],
926
- forms: {
927
- f1: {
928
- actions: [
929
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
930
- { status: JOB_STATUS.PENDING, key: 'pending' },
931
- ],
932
- },
933
- f2: {
934
- actions: [
935
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
936
- { status: JOB_STATUS.PENDING, key: 'pending' },
937
- ],
938
- },
939
- },
940
- },
941
- });
942
-
943
- const post = await PostRepo.create({ values: { title: 't1' } });
944
-
945
- await sleep(500);
946
-
947
- const UserJobModel = db.getModel('users_jobs');
948
- const pendingJobs = await UserJobModel.findAll({
949
- order: [['userId', 'ASC']],
950
- });
951
- expect(pendingJobs.length).toBe(2);
952
-
953
- const res1 = await userAgents[0].resource('users_jobs').submit({
954
- filterByTk: pendingJobs[0].get('id'),
955
- values: {
956
- result: { f1: { number: 1 }, _: 'pending' },
957
- },
958
- });
959
- expect(res1.status).toBe(202);
960
-
961
- await sleep(500);
962
-
963
- const [e1] = await workflow.getExecutions();
964
- expect(e1.status).toBe(EXECUTION_STATUS.STARTED);
965
- const [j1] = await e1.getJobs({ order: [['createdAt', 'ASC']] });
966
- expect(j1.status).toBe(JOB_STATUS.PENDING);
967
- expect(j1.result).toMatchObject({ f1: { number: 1 } });
968
-
969
- const res2 = await userAgents[0].resource('users_jobs').submit({
970
- filterByTk: pendingJobs[0].get('id'),
971
- values: {
972
- result: { f2: { number: 2 }, _: 'pending' },
973
- },
974
- });
975
- expect(res2.status).toBe(202);
976
-
977
- await sleep(500);
978
-
979
- const [e2] = await workflow.getExecutions();
980
- expect(e2.status).toBe(EXECUTION_STATUS.STARTED);
981
- const [j2] = await e2.getJobs({ order: [['createdAt', 'ASC']] });
982
- expect(j2.status).toBe(JOB_STATUS.PENDING);
983
- expect(j2.result).toMatchObject({
984
- f1: { number: 1 },
985
- f2: { number: 2 },
986
- });
987
-
988
- const res3 = await userAgents[0].resource('users_jobs').submit({
989
- filterByTk: pendingJobs[0].get('id'),
990
- values: {
991
- result: { f2: { number: 3 }, _: 'resolve' },
992
- },
993
- });
994
- expect(res3.status).toBe(202);
995
-
996
- await sleep(500);
997
-
998
- const [e3] = await workflow.getExecutions();
999
- expect(e3.status).toBe(EXECUTION_STATUS.RESOLVED);
1000
- const [j3] = await e3.getJobs({ order: [['createdAt', 'ASC']] });
1001
- expect(j3.status).toBe(JOB_STATUS.RESOLVED);
1002
- expect(j3.result).toMatchObject({ f2: { number: 3 } });
1003
- });
1004
- });
1005
-
1006
- describe('forms', () => {
1007
- describe('create', () => {
1008
- it('create as configured', async () => {
1009
- const n1 = await workflow.createNode({
1010
- type: 'manual',
1011
- config: {
1012
- assignees: [users[0].id],
1013
- forms: {
1014
- f1: {
1015
- type: 'create',
1016
- actions: [
1017
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
1018
- ],
1019
- collection: 'comments',
1020
- },
1021
- },
1022
- },
1023
- });
1024
-
1025
- const post = await PostRepo.create({ values: { title: 't1' } });
1026
-
1027
- await sleep(500);
1028
-
1029
- const UserJobModel = db.getModel('users_jobs');
1030
- const pendingJobs = await UserJobModel.findAll({
1031
- order: [['userId', 'ASC']],
1032
- });
1033
- expect(pendingJobs.length).toBe(1);
1034
-
1035
- const res1 = await userAgents[0].resource('users_jobs').submit({
1036
- filterByTk: pendingJobs[0].get('id'),
1037
- values: {
1038
- result: { f1: { status: 1 }, _: 'resolve' },
1039
- },
1040
- });
1041
- expect(res1.status).toBe(202);
1042
-
1043
- await sleep(1000);
1044
-
1045
- const [e1] = await workflow.getExecutions();
1046
- expect(e1.status).toBe(EXECUTION_STATUS.RESOLVED);
1047
- const [j1] = await e1.getJobs();
1048
- expect(j1.status).toBe(JOB_STATUS.RESOLVED);
1049
- expect(j1.result).toMatchObject({ f1: { status: 1 } });
1050
-
1051
- const comments = await CommentRepo.find();
1052
- expect(comments.length).toBe(1);
1053
- expect(comments[0]).toMatchObject({ status: 1 });
1054
- });
1055
-
1056
- it('save first and then commit', async () => {
1057
- const n1 = await workflow.createNode({
1058
- type: 'manual',
1059
- config: {
1060
- assignees: [users[0].id],
1061
- forms: {
1062
- f1: {
1063
- type: 'create',
1064
- actions: [
1065
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
1066
- { status: JOB_STATUS.PENDING, key: 'pending' },
1067
- ],
1068
- collection: 'comments',
1069
- },
1070
- },
1071
- },
1072
- });
1073
-
1074
- const post = await PostRepo.create({ values: { title: 't1' } });
1075
-
1076
- await sleep(500);
1077
-
1078
- const UserJobModel = db.getModel('users_jobs');
1079
- const pendingJobs = await UserJobModel.findAll({
1080
- order: [['userId', 'ASC']],
1081
- });
1082
- expect(pendingJobs.length).toBe(1);
1083
-
1084
- const res1 = await userAgents[0].resource('users_jobs').submit({
1085
- filterByTk: pendingJobs[0].get('id'),
1086
- values: {
1087
- result: { f1: { status: 1 }, _: 'pending' },
1088
- },
1089
- });
1090
- expect(res1.status).toBe(202);
1091
-
1092
- await sleep(500);
1093
-
1094
- const [e1] = await workflow.getExecutions();
1095
- expect(e1.status).toBe(EXECUTION_STATUS.STARTED);
1096
- const [j1] = await e1.getJobs();
1097
- expect(j1.status).toBe(JOB_STATUS.PENDING);
1098
- expect(j1.result).toMatchObject({ f1: { status: 1 } });
1099
-
1100
- const c1 = await CommentRepo.find();
1101
- expect(c1.length).toBe(0);
1102
-
1103
- const res2 = await userAgents[0].resource('users_jobs').submit({
1104
- filterByTk: pendingJobs[0].get('id'),
1105
- values: {
1106
- result: { f1: { status: 1 }, _: 'resolve' },
1107
- },
1108
- });
1109
-
1110
- await sleep(500);
1111
-
1112
- const [e2] = await workflow.getExecutions();
1113
- expect(e2.status).toBe(EXECUTION_STATUS.RESOLVED);
1114
- const [j2] = await e2.getJobs();
1115
- expect(j2.status).toBe(JOB_STATUS.RESOLVED);
1116
- expect(j2.result).toMatchObject({ f1: { status: 1 } });
1117
-
1118
- const c2 = await CommentRepo.find();
1119
- expect(c2.length).toBe(1);
1120
- });
1121
- });
1122
-
1123
- describe('update', () => {
1124
- it('update as configured', async () => {
1125
- const n1 = await workflow.createNode({
1126
- type: 'manual',
1127
- config: {
1128
- assignees: [users[0].id],
1129
- forms: {
1130
- f1: {
1131
- type: 'update',
1132
- actions: [
1133
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
1134
- ],
1135
- collection: 'posts',
1136
- },
1137
- },
1138
- },
1139
- });
1140
-
1141
- const post = await PostRepo.create({ values: { title: 't1' } });
1142
-
1143
- await sleep(500);
1144
-
1145
- const UserJobModel = db.getModel('users_jobs');
1146
- const pendingJobs = await UserJobModel.findAll({
1147
- order: [['userId', 'ASC']],
1148
- });
1149
- expect(pendingJobs.length).toBe(1);
1150
-
1151
- const res1 = await userAgents[0].resource('users_jobs').submit({
1152
- filterByTk: pendingJobs[0].get('id'),
1153
- values: {
1154
- result: { f1: { title: 't2' }, _: 'resolve' },
1155
- },
1156
- });
1157
- expect(res1.status).toBe(202);
1158
-
1159
- await sleep(1000);
1160
-
1161
- const [e2] = await workflow.getExecutions();
1162
- expect(e2.status).toBe(EXECUTION_STATUS.RESOLVED);
1163
- const [j1] = await e2.getJobs();
1164
- expect(j1.status).toBe(JOB_STATUS.RESOLVED);
1165
- expect(j1.result).toMatchObject({ f1: { title: 't2' } });
1166
-
1167
- const postsAfter = await PostRepo.find();
1168
- expect(postsAfter.length).toBe(1);
1169
- expect(postsAfter[0]).toMatchObject({ title: 't2' });
1170
- });
1171
- });
1172
- });
1173
- });