@nocobase/plugin-workflow-manual 1.0.0-alpha.2 → 1.0.0-alpha.4

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 (88) hide show
  1. package/dist/client/WorkflowTodo.d.ts +8 -0
  2. package/dist/client/WorkflowTodoBlockInitializer.d.ts +8 -0
  3. package/dist/client/index.d.ts +8 -0
  4. package/dist/client/index.js +9 -0
  5. package/dist/client/instruction/AssigneesSelect.d.ts +8 -0
  6. package/dist/client/instruction/FormBlockInitializer.d.ts +8 -0
  7. package/dist/client/instruction/FormBlockProvider.d.ts +8 -0
  8. package/dist/client/instruction/ModeConfig.d.ts +8 -0
  9. package/dist/client/instruction/SchemaConfig.d.ts +8 -0
  10. package/dist/client/instruction/createManualFormBlockUISchema.d.ts +8 -0
  11. package/dist/client/instruction/forms/create.d.ts +8 -0
  12. package/dist/client/instruction/forms/custom.d.ts +8 -0
  13. package/dist/client/instruction/forms/update.d.ts +8 -0
  14. package/dist/client/instruction/index.d.ts +8 -0
  15. package/dist/client/instruction/utils.d.ts +8 -0
  16. package/dist/externalVersion.js +18 -9
  17. package/dist/index.d.ts +8 -0
  18. package/dist/index.js +9 -0
  19. package/dist/locale/index.d.ts +8 -0
  20. package/dist/locale/index.js +9 -0
  21. package/dist/server/ManualInstruction.d.ts +8 -0
  22. package/dist/server/ManualInstruction.js +9 -0
  23. package/dist/server/Plugin.d.ts +8 -0
  24. package/dist/server/Plugin.js +9 -0
  25. package/dist/server/actions.d.ts +8 -0
  26. package/dist/server/actions.js +9 -0
  27. package/dist/server/collections/1-users_jobs.d.ts +8 -0
  28. package/dist/server/collections/1-users_jobs.js +9 -0
  29. package/dist/server/collections/2-jobs.d.ts +8 -0
  30. package/dist/server/collections/2-jobs.js +9 -0
  31. package/dist/server/collections/3-users.d.ts +8 -0
  32. package/dist/server/collections/3-users.js +9 -0
  33. package/dist/server/forms/create.d.ts +8 -0
  34. package/dist/server/forms/create.js +9 -0
  35. package/dist/server/forms/index.d.ts +8 -0
  36. package/dist/server/forms/index.js +9 -0
  37. package/dist/server/forms/update.d.ts +8 -0
  38. package/dist/server/forms/update.js +9 -0
  39. package/dist/server/index.d.ts +8 -0
  40. package/dist/server/index.js +9 -0
  41. package/dist/server/migrations/20240325213145-fix-schema.d.ts +8 -0
  42. package/dist/server/migrations/20240325213145-fix-schema.js +9 -0
  43. package/package.json +2 -2
  44. package/src/client/WorkflowTodo.tsx +0 -647
  45. package/src/client/WorkflowTodoBlockInitializer.tsx +0 -32
  46. package/src/client/__e2e__/assignees.test.ts +0 -0
  47. package/src/client/__e2e__/createRecordForm.test.ts +0 -2287
  48. package/src/client/__e2e__/customFormBlocks.test.ts +0 -1933
  49. package/src/client/__e2e__/datablocks.test.ts +0 -1208
  50. package/src/client/__e2e__/updateRecordForm.test.ts +0 -2338
  51. package/src/client/__e2e__/workflowTodo.test.ts +0 -242
  52. package/src/client/index.ts +0 -51
  53. package/src/client/instruction/AssigneesSelect.tsx +0 -39
  54. package/src/client/instruction/FormBlockInitializer.tsx +0 -79
  55. package/src/client/instruction/FormBlockProvider.tsx +0 -92
  56. package/src/client/instruction/ModeConfig.tsx +0 -85
  57. package/src/client/instruction/SchemaConfig.tsx +0 -659
  58. package/src/client/instruction/createManualFormBlockUISchema.ts +0 -5
  59. package/src/client/instruction/forms/create.tsx +0 -123
  60. package/src/client/instruction/forms/custom.tsx +0 -439
  61. package/src/client/instruction/forms/update.tsx +0 -167
  62. package/src/client/instruction/index.tsx +0 -160
  63. package/src/client/instruction/utils.ts +0 -19
  64. package/src/index.ts +0 -2
  65. package/src/locale/en-US.json +0 -30
  66. package/src/locale/index.ts +0 -14
  67. package/src/locale/ko_KR.json +0 -32
  68. package/src/locale/zh-CN.json +0 -32
  69. package/src/server/ManualInstruction.ts +0 -157
  70. package/src/server/Plugin.ts +0 -43
  71. package/src/server/__tests__/assignees.test.ts +0 -153
  72. package/src/server/__tests__/collections/categories.ts +0 -15
  73. package/src/server/__tests__/collections/comments.ts +0 -24
  74. package/src/server/__tests__/collections/posts.ts +0 -40
  75. package/src/server/__tests__/collections/replies.ts +0 -9
  76. package/src/server/__tests__/collections/tags.ts +0 -15
  77. package/src/server/__tests__/data-source.test.ts +0 -223
  78. package/src/server/__tests__/form.test.ts +0 -637
  79. package/src/server/__tests__/mode.test.ts +0 -561
  80. package/src/server/actions.ts +0 -103
  81. package/src/server/collections/1-users_jobs.ts +0 -52
  82. package/src/server/collections/2-jobs.ts +0 -19
  83. package/src/server/collections/3-users.ts +0 -17
  84. package/src/server/forms/create.ts +0 -30
  85. package/src/server/forms/index.ts +0 -13
  86. package/src/server/forms/update.ts +0 -30
  87. package/src/server/index.ts +0 -1
  88. package/src/server/migrations/20240325213145-fix-schema.ts +0 -82
@@ -1,637 +0,0 @@
1
- import Database from '@nocobase/database';
2
- import { EXECUTION_STATUS, JOB_STATUS } from '@nocobase/plugin-workflow';
3
- import { getApp, sleep } from '@nocobase/plugin-workflow-test';
4
- import { MockServer } from '@nocobase/test';
5
-
6
- // NOTE: skipped because time is not stable on github ci, but should work in local
7
- describe('workflow > instructions > manual', () => {
8
- let app: MockServer;
9
- let agent;
10
- let userAgents;
11
- let db: Database;
12
- let PostRepo;
13
- let CommentRepo;
14
- let WorkflowModel;
15
- let workflow;
16
- let UserModel;
17
- let users;
18
- let UserJobModel;
19
-
20
- beforeEach(async () => {
21
- app = await getApp({
22
- plugins: ['users', 'auth', 'workflow-manual'],
23
- });
24
- // await app.getPlugin('auth').install();
25
- agent = app.agent();
26
- db = app.db;
27
- WorkflowModel = db.getCollection('workflows').model;
28
- PostRepo = db.getCollection('posts').repository;
29
- CommentRepo = db.getCollection('comments').repository;
30
- UserModel = db.getCollection('users').model;
31
- UserJobModel = db.getModel('users_jobs');
32
-
33
- users = await UserModel.bulkCreate([
34
- { id: 2, nickname: 'a' },
35
- { id: 3, nickname: 'b' },
36
- ]);
37
-
38
- userAgents = users.map((user) => app.agent().login(user));
39
-
40
- workflow = await WorkflowModel.create({
41
- enabled: true,
42
- type: 'collection',
43
- config: {
44
- mode: 1,
45
- collection: 'posts',
46
- },
47
- });
48
- });
49
-
50
- afterEach(() => app.destroy());
51
-
52
- describe('actions configuration', () => {
53
- it('no action configured', async () => {
54
- const n1 = await workflow.createNode({
55
- type: 'manual',
56
- config: {
57
- assignees: [users[0].id],
58
- forms: {
59
- f1: {},
60
- },
61
- },
62
- });
63
-
64
- const post = await PostRepo.create({ values: { title: 't1' } });
65
-
66
- await sleep(500);
67
-
68
- const [pending] = await workflow.getExecutions();
69
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
70
- const [j1] = await pending.getJobs();
71
- expect(j1.status).toBe(JOB_STATUS.PENDING);
72
-
73
- const usersJobs = await UserJobModel.findAll();
74
- expect(usersJobs.length).toBe(1);
75
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
76
- expect(usersJobs[0].userId).toBe(users[0].id);
77
- expect(usersJobs[0].jobId).toBe(j1.id);
78
-
79
- const res1 = await userAgents[0].resource('users_jobs').submit({
80
- filterByTk: usersJobs[0].id,
81
- values: {
82
- result: { f1: { a: 1 }, _: 'resolve' },
83
- },
84
- });
85
-
86
- expect(res1.status).toBe(400);
87
- });
88
-
89
- it('no actionKey provided', async () => {
90
- const n1 = await workflow.createNode({
91
- type: 'manual',
92
- config: {
93
- assignees: [users[0].id],
94
- forms: {
95
- f1: {
96
- actions: [{ status: JOB_STATUS.RESOLVED, key: 'resolve' }],
97
- },
98
- },
99
- },
100
- });
101
-
102
- const post = await PostRepo.create({ values: { title: 't1' } });
103
-
104
- await sleep(500);
105
-
106
- const [pending] = await workflow.getExecutions();
107
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
108
- const [j1] = await pending.getJobs();
109
- expect(j1.status).toBe(JOB_STATUS.PENDING);
110
-
111
- const usersJobs = await UserJobModel.findAll();
112
- expect(usersJobs.length).toBe(1);
113
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
114
- expect(usersJobs[0].userId).toBe(users[0].id);
115
- expect(usersJobs[0].jobId).toBe(j1.id);
116
-
117
- const res1 = await userAgents[0].resource('users_jobs').submit({
118
- filterByTk: usersJobs[0].id,
119
- values: {
120
- result: { f1: { a: 1 } },
121
- },
122
- });
123
-
124
- expect(res1.status).toBe(400);
125
- });
126
-
127
- it('values resolved will be overrided by action assigned', async () => {
128
- const n1 = await workflow.createNode({
129
- type: 'manual',
130
- config: {
131
- assignees: [users[0].id],
132
- forms: {
133
- f1: {
134
- actions: [
135
- {
136
- status: JOB_STATUS.RESOLVED,
137
- key: 'resolve',
138
- values: { a: 2 },
139
- },
140
- ],
141
- },
142
- },
143
- },
144
- });
145
-
146
- const post = await PostRepo.create({ values: { title: 't1' } });
147
-
148
- await sleep(500);
149
-
150
- const [pending] = await workflow.getExecutions();
151
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
152
- const [j1] = await pending.getJobs();
153
- expect(j1.status).toBe(JOB_STATUS.PENDING);
154
-
155
- const usersJobs = await UserJobModel.findAll();
156
- expect(usersJobs.length).toBe(1);
157
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
158
- expect(usersJobs[0].userId).toBe(users[0].id);
159
- expect(usersJobs[0].jobId).toBe(j1.id);
160
-
161
- const res1 = await userAgents[0].resource('users_jobs').submit({
162
- filterByTk: usersJobs[0].id,
163
- values: {
164
- result: { f1: { a: 1 }, _: 'resolve' },
165
- },
166
- });
167
-
168
- await sleep(500);
169
-
170
- const [execution] = await workflow.getExecutions();
171
- expect(execution.status).toBe(EXECUTION_STATUS.RESOLVED);
172
- const [job] = await execution.getJobs();
173
- expect(job.status).toBe(JOB_STATUS.RESOLVED);
174
- expect(job.result).toEqual({ f1: { a: 2 }, _: 'resolve' });
175
- });
176
-
177
- it('values rejected will not be overrided by action assigned', async () => {
178
- const n1 = await workflow.createNode({
179
- type: 'manual',
180
- config: {
181
- assignees: [users[0].id],
182
- forms: {
183
- f1: {
184
- actions: [
185
- {
186
- status: JOB_STATUS.REJECTED,
187
- key: 'reject',
188
- values: { a: 2 },
189
- },
190
- ],
191
- },
192
- },
193
- },
194
- });
195
-
196
- const post = await PostRepo.create({ values: { title: 't1' } });
197
-
198
- await sleep(500);
199
-
200
- const [pending] = await workflow.getExecutions();
201
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
202
- const [j1] = await pending.getJobs();
203
- expect(j1.status).toBe(JOB_STATUS.PENDING);
204
-
205
- const usersJobs = await UserJobModel.findAll();
206
- expect(usersJobs.length).toBe(1);
207
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
208
- expect(usersJobs[0].userId).toBe(users[0].id);
209
- expect(usersJobs[0].jobId).toBe(j1.id);
210
-
211
- const res1 = await userAgents[0].resource('users_jobs').submit({
212
- filterByTk: usersJobs[0].id,
213
- values: {
214
- result: { f1: { a: 1 }, _: 'reject' },
215
- },
216
- });
217
-
218
- await sleep(500);
219
-
220
- const [execution] = await workflow.getExecutions();
221
- expect(execution.status).toBe(EXECUTION_STATUS.REJECTED);
222
- const [job] = await execution.getJobs();
223
- expect(job.status).toBe(JOB_STATUS.REJECTED);
224
- expect(job.result).toEqual({ f1: { a: 1 }, _: 'reject' });
225
- });
226
-
227
- it('values saved as pending will not be overrided by action assigned', async () => {
228
- const n1 = await workflow.createNode({
229
- type: 'manual',
230
- config: {
231
- assignees: [users[0].id],
232
- forms: {
233
- f1: {
234
- actions: [
235
- {
236
- status: JOB_STATUS.PENDING,
237
- key: 'save',
238
- values: { a: 2 },
239
- },
240
- ],
241
- },
242
- },
243
- },
244
- });
245
-
246
- const post = await PostRepo.create({ values: { title: 't1' } });
247
-
248
- await sleep(500);
249
-
250
- const [pending] = await workflow.getExecutions();
251
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
252
- const [j1] = await pending.getJobs();
253
- expect(j1.status).toBe(JOB_STATUS.PENDING);
254
-
255
- const usersJobs = await UserJobModel.findAll();
256
- expect(usersJobs.length).toBe(1);
257
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
258
- expect(usersJobs[0].userId).toBe(users[0].id);
259
- expect(usersJobs[0].jobId).toBe(j1.id);
260
-
261
- const res1 = await userAgents[0].resource('users_jobs').submit({
262
- filterByTk: usersJobs[0].id,
263
- values: {
264
- result: { f1: { a: 1 }, _: 'save' },
265
- },
266
- });
267
-
268
- await sleep(500);
269
-
270
- const [execution] = await workflow.getExecutions();
271
- expect(execution.status).toBe(EXECUTION_STATUS.STARTED);
272
- const [job] = await execution.getJobs();
273
- expect(job.status).toBe(JOB_STATUS.PENDING);
274
- expect(job.result).toEqual({ f1: { a: 1 }, _: 'save' });
275
- });
276
-
277
- it('variable within assigned values should work when resolve', async () => {
278
- const n1 = await workflow.createNode({
279
- type: 'manual',
280
- config: {
281
- assignees: [users[0].id],
282
- forms: {
283
- f1: {
284
- actions: [
285
- {
286
- status: JOB_STATUS.RESOLVED,
287
- key: 'resolve',
288
- values: {
289
- a: '{{currentUser.id}}',
290
- b: '{{currentRecord.id}}',
291
- c: '{{currentTime}}',
292
- d: '{{$context.data.title}}',
293
- },
294
- },
295
- ],
296
- },
297
- },
298
- },
299
- });
300
-
301
- const post = await PostRepo.create({ values: { title: 't1' } });
302
-
303
- await sleep(500);
304
-
305
- const [pending] = await workflow.getExecutions();
306
- expect(pending.status).toBe(EXECUTION_STATUS.STARTED);
307
- const [j1] = await pending.getJobs();
308
- expect(j1.status).toBe(JOB_STATUS.PENDING);
309
-
310
- const usersJobs = await UserJobModel.findAll();
311
- expect(usersJobs.length).toBe(1);
312
- expect(usersJobs[0].status).toBe(JOB_STATUS.PENDING);
313
- expect(usersJobs[0].userId).toBe(users[0].id);
314
- expect(usersJobs[0].jobId).toBe(j1.id);
315
-
316
- const now = new Date();
317
- const res1 = await userAgents[0].resource('users_jobs').submit({
318
- filterByTk: usersJobs[0].id,
319
- values: {
320
- result: { f1: { a: 2, id: 3 }, _: 'resolve' },
321
- },
322
- });
323
-
324
- await sleep(500);
325
-
326
- const [execution] = await workflow.getExecutions();
327
- expect(execution.status).toBe(EXECUTION_STATUS.RESOLVED);
328
- const [job] = await execution.getJobs();
329
- expect(job.status).toBe(JOB_STATUS.RESOLVED);
330
- expect(job.result).toMatchObject({ f1: { a: users[0].id, id: 3, b: 3, d: post.title }, _: 'resolve' });
331
- const time = new Date(job.result.f1.c);
332
- expect(time.getTime() - now.getTime()).toBeLessThan(1000);
333
- });
334
- });
335
-
336
- describe('use result of submitted form in manual node', () => {
337
- it('result should be available and correct', async () => {
338
- const n1 = await workflow.createNode({
339
- type: 'manual',
340
- config: {
341
- assignees: [users[0].id, users[1].id],
342
- forms: {
343
- f1: {
344
- actions: [{ status: JOB_STATUS.RESOLVED, key: 'resolve' }],
345
- },
346
- },
347
- },
348
- });
349
-
350
- const n2 = await workflow.createNode({
351
- type: 'calculation',
352
- config: {
353
- engine: 'math.js',
354
- expression: `{{$jobsMapByNodeKey.${n1.key}.f1.number}} + 1`,
355
- },
356
- upstreamId: n1.id,
357
- });
358
-
359
- await n1.setDownstream(n2);
360
-
361
- const post = await PostRepo.create({ values: { title: 't1' } });
362
-
363
- await sleep(500);
364
-
365
- const UserJobModel = db.getModel('users_jobs');
366
- const pendingJobs = await UserJobModel.findAll({
367
- order: [['userId', 'ASC']],
368
- });
369
- expect(pendingJobs.length).toBe(2);
370
-
371
- const res1 = await userAgents[0].resource('users_jobs').submit({
372
- filterByTk: pendingJobs[0].get('id'),
373
- values: {
374
- result: { f1: { number: 1 }, _: 'resolve' },
375
- },
376
- });
377
- expect(res1.status).toBe(202);
378
-
379
- await sleep(1000);
380
-
381
- const [e2] = await workflow.getExecutions();
382
- expect(e2.status).toBe(EXECUTION_STATUS.RESOLVED);
383
- const [j1, j2] = await e2.getJobs({ order: [['createdAt', 'ASC']] });
384
- expect(j2.status).toBe(JOB_STATUS.RESOLVED);
385
- expect(j2.result).toBe(2);
386
- });
387
-
388
- it('save all forms, only reserve submitted ones', async () => {
389
- const n1 = await workflow.createNode({
390
- type: 'manual',
391
- config: {
392
- assignees: [users[0].id, users[1].id],
393
- forms: {
394
- f1: {
395
- actions: [
396
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
397
- { status: JOB_STATUS.PENDING, key: 'pending' },
398
- ],
399
- },
400
- f2: {
401
- actions: [
402
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
403
- { status: JOB_STATUS.PENDING, key: 'pending' },
404
- ],
405
- },
406
- },
407
- },
408
- });
409
-
410
- const post = await PostRepo.create({ values: { title: 't1' } });
411
-
412
- await sleep(500);
413
-
414
- const UserJobModel = db.getModel('users_jobs');
415
- const pendingJobs = await UserJobModel.findAll({
416
- order: [['userId', 'ASC']],
417
- });
418
- expect(pendingJobs.length).toBe(2);
419
-
420
- const res1 = await userAgents[0].resource('users_jobs').submit({
421
- filterByTk: pendingJobs[0].get('id'),
422
- values: {
423
- result: { f1: { number: 1 }, _: 'pending' },
424
- },
425
- });
426
- expect(res1.status).toBe(202);
427
-
428
- await sleep(500);
429
-
430
- const [e1] = await workflow.getExecutions();
431
- expect(e1.status).toBe(EXECUTION_STATUS.STARTED);
432
- const [j1] = await e1.getJobs({ order: [['createdAt', 'ASC']] });
433
- expect(j1.status).toBe(JOB_STATUS.PENDING);
434
- expect(j1.result).toMatchObject({ f1: { number: 1 } });
435
-
436
- const res2 = await userAgents[0].resource('users_jobs').submit({
437
- filterByTk: pendingJobs[0].get('id'),
438
- values: {
439
- result: { f2: { number: 2 }, _: 'pending' },
440
- },
441
- });
442
- expect(res2.status).toBe(202);
443
-
444
- await sleep(500);
445
-
446
- const [e2] = await workflow.getExecutions();
447
- expect(e2.status).toBe(EXECUTION_STATUS.STARTED);
448
- const [j2] = await e2.getJobs({ order: [['createdAt', 'ASC']] });
449
- expect(j2.status).toBe(JOB_STATUS.PENDING);
450
- expect(j2.result).toMatchObject({
451
- f1: { number: 1 },
452
- f2: { number: 2 },
453
- });
454
-
455
- const res3 = await userAgents[0].resource('users_jobs').submit({
456
- filterByTk: pendingJobs[0].get('id'),
457
- values: {
458
- result: { f2: { number: 3 }, _: 'resolve' },
459
- },
460
- });
461
- expect(res3.status).toBe(202);
462
-
463
- await sleep(500);
464
-
465
- const [e3] = await workflow.getExecutions();
466
- expect(e3.status).toBe(EXECUTION_STATUS.RESOLVED);
467
- const [j3] = await e3.getJobs({ order: [['createdAt', 'ASC']] });
468
- expect(j3.status).toBe(JOB_STATUS.RESOLVED);
469
- expect(j3.result).toMatchObject({ f2: { number: 3 } });
470
- });
471
- });
472
-
473
- describe('forms', () => {
474
- describe('create', () => {
475
- it('create as configured', async () => {
476
- const n1 = await workflow.createNode({
477
- type: 'manual',
478
- config: {
479
- assignees: [users[0].id],
480
- forms: {
481
- f1: {
482
- type: 'create',
483
- actions: [{ status: JOB_STATUS.RESOLVED, key: 'resolve' }],
484
- collection: 'comments',
485
- },
486
- },
487
- },
488
- });
489
-
490
- const post = await PostRepo.create({ values: { title: 't1' } });
491
-
492
- await sleep(500);
493
-
494
- const UserJobModel = db.getModel('users_jobs');
495
- const pendingJobs = await UserJobModel.findAll({
496
- order: [['userId', 'ASC']],
497
- });
498
- expect(pendingJobs.length).toBe(1);
499
-
500
- const res1 = await userAgents[0].resource('users_jobs').submit({
501
- filterByTk: pendingJobs[0].get('id'),
502
- values: {
503
- result: { f1: { status: 1 }, _: 'resolve' },
504
- },
505
- });
506
- expect(res1.status).toBe(202);
507
-
508
- await sleep(1000);
509
-
510
- const [e1] = await workflow.getExecutions();
511
- expect(e1.status).toBe(EXECUTION_STATUS.RESOLVED);
512
- const [j1] = await e1.getJobs();
513
- expect(j1.status).toBe(JOB_STATUS.RESOLVED);
514
- expect(j1.result).toMatchObject({ f1: { status: 1 } });
515
-
516
- const comments = await CommentRepo.find();
517
- expect(comments.length).toBe(1);
518
- expect(comments[0]).toMatchObject({ status: 1 });
519
- });
520
-
521
- it('save first and then commit', async () => {
522
- const n1 = await workflow.createNode({
523
- type: 'manual',
524
- config: {
525
- assignees: [users[0].id],
526
- forms: {
527
- f1: {
528
- type: 'create',
529
- actions: [
530
- { status: JOB_STATUS.RESOLVED, key: 'resolve' },
531
- { status: JOB_STATUS.PENDING, key: 'pending' },
532
- ],
533
- collection: 'comments',
534
- },
535
- },
536
- },
537
- });
538
-
539
- const post = await PostRepo.create({ values: { title: 't1' } });
540
-
541
- await sleep(500);
542
-
543
- const UserJobModel = db.getModel('users_jobs');
544
- const pendingJobs = await UserJobModel.findAll({
545
- order: [['userId', 'ASC']],
546
- });
547
- expect(pendingJobs.length).toBe(1);
548
-
549
- const res1 = await userAgents[0].resource('users_jobs').submit({
550
- filterByTk: pendingJobs[0].get('id'),
551
- values: {
552
- result: { f1: { status: 1 }, _: 'pending' },
553
- },
554
- });
555
- expect(res1.status).toBe(202);
556
-
557
- await sleep(500);
558
-
559
- const [e1] = await workflow.getExecutions();
560
- expect(e1.status).toBe(EXECUTION_STATUS.STARTED);
561
- const [j1] = await e1.getJobs();
562
- expect(j1.status).toBe(JOB_STATUS.PENDING);
563
- expect(j1.result).toMatchObject({ f1: { status: 1 } });
564
-
565
- const c1 = await CommentRepo.find();
566
- expect(c1.length).toBe(0);
567
-
568
- const res2 = await userAgents[0].resource('users_jobs').submit({
569
- filterByTk: pendingJobs[0].get('id'),
570
- values: {
571
- result: { f1: { status: 1 }, _: 'resolve' },
572
- },
573
- });
574
-
575
- await sleep(500);
576
-
577
- const [e2] = await workflow.getExecutions();
578
- expect(e2.status).toBe(EXECUTION_STATUS.RESOLVED);
579
- const [j2] = await e2.getJobs();
580
- expect(j2.status).toBe(JOB_STATUS.RESOLVED);
581
- expect(j2.result).toMatchObject({ f1: { status: 1 } });
582
-
583
- const c2 = await CommentRepo.find();
584
- expect(c2.length).toBe(1);
585
- });
586
- });
587
-
588
- describe('update', () => {
589
- it('update as configured', async () => {
590
- const n1 = await workflow.createNode({
591
- type: 'manual',
592
- config: {
593
- assignees: [users[0].id],
594
- forms: {
595
- f1: {
596
- type: 'update',
597
- actions: [{ status: JOB_STATUS.RESOLVED, key: 'resolve' }],
598
- collection: 'posts',
599
- filter: { title: 't1' },
600
- },
601
- },
602
- },
603
- });
604
-
605
- const post = await PostRepo.create({ values: { title: 't1' } });
606
-
607
- await sleep(500);
608
-
609
- const UserJobModel = db.getModel('users_jobs');
610
- const pendingJobs = await UserJobModel.findAll({
611
- order: [['userId', 'ASC']],
612
- });
613
- expect(pendingJobs.length).toBe(1);
614
-
615
- const res1 = await userAgents[0].resource('users_jobs').submit({
616
- filterByTk: pendingJobs[0].get('id'),
617
- values: {
618
- result: { f1: { title: 't2' }, _: 'resolve' },
619
- },
620
- });
621
- expect(res1.status).toBe(202);
622
-
623
- await sleep(1000);
624
-
625
- const [e2] = await workflow.getExecutions();
626
- expect(e2.status).toBe(EXECUTION_STATUS.RESOLVED);
627
- const [j1] = await e2.getJobs();
628
- expect(j1.status).toBe(JOB_STATUS.RESOLVED);
629
- expect(j1.result).toMatchObject({ f1: { title: 't2' } });
630
-
631
- const postsAfter = await PostRepo.find();
632
- expect(postsAfter.length).toBe(1);
633
- expect(postsAfter[0]).toMatchObject({ title: 't2' });
634
- });
635
- });
636
- });
637
- });