xstate 3.3.2 → 3.3.3
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.
- package/README.md +21 -1
- package/dist/xstate.js +1 -1
- package/dist/xstate.utils.js +1 -1
- package/es/State.d.ts +8 -7
- package/es/State.js +3 -2
- package/es/StateNode.d.ts +35 -20
- package/es/StateNode.js +119 -46
- package/es/graph.d.ts +4 -1
- package/es/graph.js +5 -4
- package/es/patterns.js +1 -1
- package/es/scxml.d.ts +2 -1
- package/es/scxml.js +9 -8
- package/es/types.d.ts +4 -7
- package/es/utils.d.ts +6 -1
- package/es/utils.js +17 -1
- package/lib/State.d.ts +8 -7
- package/lib/State.js +3 -2
- package/lib/StateNode.d.ts +35 -20
- package/lib/StateNode.js +118 -45
- package/lib/graph.d.ts +4 -1
- package/lib/graph.js +5 -3
- package/lib/patterns.js +1 -1
- package/lib/scxml.d.ts +2 -1
- package/lib/scxml.js +9 -8
- package/lib/types.d.ts +4 -7
- package/lib/utils.d.ts +6 -1
- package/lib/utils.js +18 -1
- package/package.json +3 -3
- package/src/State.ts +4 -1
- package/src/StateNode.ts +221 -89
- package/src/graph.ts +14 -12
- package/src/scxml.ts +52 -49
- package/src/types.ts +6 -9
- package/src/utils.ts +25 -4
- package/test/activities.test.ts +28 -1
- package/test/deterministic.test.ts +1 -1
- package/test/history.test.ts +139 -0
- package/test/invalid.test.ts +48 -0
- package/test/parallel.test.ts +229 -1
package/test/parallel.test.ts
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { assert } from 'chai';
|
|
2
|
-
import {
|
|
2
|
+
import { raise } from '../src/actions';
|
|
3
|
+
import { Machine } from '../src/StateNode';
|
|
3
4
|
import { testMultiTransition } from './utils';
|
|
4
5
|
|
|
5
6
|
const composerMachine = Machine({
|
|
@@ -300,6 +301,157 @@ const flatParallelMachine = Machine({
|
|
|
300
301
|
}
|
|
301
302
|
});
|
|
302
303
|
|
|
304
|
+
const raisingParallelMachine = Machine({
|
|
305
|
+
strict: true,
|
|
306
|
+
parallel: true,
|
|
307
|
+
states: {
|
|
308
|
+
OUTER1: {
|
|
309
|
+
initial: 'C',
|
|
310
|
+
states: {
|
|
311
|
+
A: {
|
|
312
|
+
onEntry: [raise('TURN_OFF')],
|
|
313
|
+
on: {
|
|
314
|
+
EVENT_OUTER1_B: 'B',
|
|
315
|
+
EVENT_OUTER1_C: 'C'
|
|
316
|
+
}
|
|
317
|
+
},
|
|
318
|
+
B: {
|
|
319
|
+
onEntry: [raise('TURN_ON')],
|
|
320
|
+
on: {
|
|
321
|
+
EVENT_OUTER1_A: 'A',
|
|
322
|
+
EVENT_OUTER1_C: 'C'
|
|
323
|
+
}
|
|
324
|
+
},
|
|
325
|
+
C: {
|
|
326
|
+
onEntry: [raise('CLEAR')],
|
|
327
|
+
on: {
|
|
328
|
+
EVENT_OUTER1_A: 'A',
|
|
329
|
+
EVENT_OUTER1_B: 'B'
|
|
330
|
+
}
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
},
|
|
334
|
+
OUTER2: {
|
|
335
|
+
parallel: true,
|
|
336
|
+
states: {
|
|
337
|
+
INNER1: {
|
|
338
|
+
initial: 'ON',
|
|
339
|
+
states: {
|
|
340
|
+
OFF: {
|
|
341
|
+
on: {
|
|
342
|
+
TURN_ON: 'ON'
|
|
343
|
+
}
|
|
344
|
+
},
|
|
345
|
+
ON: {
|
|
346
|
+
on: {
|
|
347
|
+
CLEAR: 'OFF'
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
},
|
|
352
|
+
INNER2: {
|
|
353
|
+
initial: 'OFF',
|
|
354
|
+
states: {
|
|
355
|
+
OFF: {
|
|
356
|
+
on: {
|
|
357
|
+
TURN_ON: 'ON'
|
|
358
|
+
}
|
|
359
|
+
},
|
|
360
|
+
ON: {
|
|
361
|
+
on: {
|
|
362
|
+
TURN_OFF: 'OFF'
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
});
|
|
371
|
+
|
|
372
|
+
const nestedParallelState = Machine({
|
|
373
|
+
parallel: true,
|
|
374
|
+
states: {
|
|
375
|
+
OUTER1: {
|
|
376
|
+
initial: 'STATE_OFF',
|
|
377
|
+
states: {
|
|
378
|
+
STATE_OFF: {
|
|
379
|
+
on: {
|
|
380
|
+
EVENT_COMPLEX: 'STATE_ON',
|
|
381
|
+
EVENT_SIMPLE: 'STATE_ON'
|
|
382
|
+
}
|
|
383
|
+
},
|
|
384
|
+
STATE_ON: {
|
|
385
|
+
parallel: true,
|
|
386
|
+
states: {
|
|
387
|
+
STATE_NTJ0: {
|
|
388
|
+
initial: 'STATE_IDLE_0',
|
|
389
|
+
states: {
|
|
390
|
+
STATE_IDLE_0: {
|
|
391
|
+
on: {
|
|
392
|
+
EVENT_STATE_NTJ0_WORK: 'STATE_WORKING_0'
|
|
393
|
+
}
|
|
394
|
+
},
|
|
395
|
+
STATE_WORKING_0: {
|
|
396
|
+
on: {
|
|
397
|
+
EVENT_STATE_NTJ0_IDLE: 'STATE_IDLE_0'
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
},
|
|
402
|
+
STATE_NTJ1: {
|
|
403
|
+
initial: 'STATE_IDLE_1',
|
|
404
|
+
states: {
|
|
405
|
+
STATE_IDLE_1: {
|
|
406
|
+
on: {
|
|
407
|
+
EVENT_STATE_NTJ1_WORK: 'STATE_WORKING_1'
|
|
408
|
+
}
|
|
409
|
+
},
|
|
410
|
+
STATE_WORKING_1: {
|
|
411
|
+
on: {
|
|
412
|
+
EVENT_STATE_NTJ1_IDLE: 'STATE_IDLE_1'
|
|
413
|
+
}
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
}
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
}
|
|
420
|
+
},
|
|
421
|
+
OUTER2: {
|
|
422
|
+
initial: 'STATE_OFF',
|
|
423
|
+
states: {
|
|
424
|
+
STATE_OFF: {
|
|
425
|
+
on: {
|
|
426
|
+
EVENT_COMPLEX: 'STATE_ON_COMPLEX',
|
|
427
|
+
EVENT_SIMPLE: 'STATE_ON_SIMPLE'
|
|
428
|
+
}
|
|
429
|
+
},
|
|
430
|
+
STATE_ON_SIMPLE: {},
|
|
431
|
+
STATE_ON_COMPLEX: {
|
|
432
|
+
parallel: true,
|
|
433
|
+
states: {
|
|
434
|
+
STATE_INNER1: {
|
|
435
|
+
initial: 'STATE_OFF',
|
|
436
|
+
states: {
|
|
437
|
+
STATE_OFF: {},
|
|
438
|
+
STATE_ON: {}
|
|
439
|
+
}
|
|
440
|
+
},
|
|
441
|
+
STATE_INNER2: {
|
|
442
|
+
initial: 'STATE_OFF',
|
|
443
|
+
states: {
|
|
444
|
+
STATE_OFF: {},
|
|
445
|
+
STATE_ON: {}
|
|
446
|
+
}
|
|
447
|
+
}
|
|
448
|
+
}
|
|
449
|
+
}
|
|
450
|
+
}
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
});
|
|
454
|
+
|
|
303
455
|
describe('parallel states', () => {
|
|
304
456
|
it('should have initial parallel states', () => {
|
|
305
457
|
const { initialState } = wordMachine;
|
|
@@ -409,4 +561,80 @@ describe('parallel states', () => {
|
|
|
409
561
|
}
|
|
410
562
|
});
|
|
411
563
|
});
|
|
564
|
+
|
|
565
|
+
it('should properly transition according to onEntry events on an initial state', () => {
|
|
566
|
+
assert.deepEqual(raisingParallelMachine.initialState.value, {
|
|
567
|
+
OUTER1: 'C',
|
|
568
|
+
OUTER2: {
|
|
569
|
+
INNER1: 'OFF',
|
|
570
|
+
INNER2: 'OFF'
|
|
571
|
+
}
|
|
572
|
+
});
|
|
573
|
+
});
|
|
574
|
+
|
|
575
|
+
it('should properly transition when raising events for a parallel state', () => {
|
|
576
|
+
const nextState = raisingParallelMachine.transition(
|
|
577
|
+
raisingParallelMachine.initialState,
|
|
578
|
+
'EVENT_OUTER1_B'
|
|
579
|
+
);
|
|
580
|
+
|
|
581
|
+
assert.deepEqual(nextState.value, {
|
|
582
|
+
OUTER1: 'B',
|
|
583
|
+
OUTER2: {
|
|
584
|
+
INNER1: 'ON',
|
|
585
|
+
INNER2: 'ON'
|
|
586
|
+
}
|
|
587
|
+
});
|
|
588
|
+
});
|
|
589
|
+
|
|
590
|
+
describe('transitions with nested parallel states', () => {
|
|
591
|
+
const initialState = nestedParallelState.initialState;
|
|
592
|
+
const simpleNextState = nestedParallelState.transition(
|
|
593
|
+
initialState,
|
|
594
|
+
'EVENT_SIMPLE'
|
|
595
|
+
);
|
|
596
|
+
const complexNextState = nestedParallelState.transition(
|
|
597
|
+
initialState,
|
|
598
|
+
'EVENT_COMPLEX'
|
|
599
|
+
);
|
|
600
|
+
|
|
601
|
+
it('should properly transition when in a simple nested state', () => {
|
|
602
|
+
const nextState = nestedParallelState.transition(
|
|
603
|
+
simpleNextState,
|
|
604
|
+
'EVENT_STATE_NTJ0_WORK'
|
|
605
|
+
);
|
|
606
|
+
|
|
607
|
+
assert.deepEqual(nextState.value, {
|
|
608
|
+
OUTER1: {
|
|
609
|
+
STATE_ON: {
|
|
610
|
+
STATE_NTJ0: 'STATE_WORKING_0',
|
|
611
|
+
STATE_NTJ1: 'STATE_IDLE_1'
|
|
612
|
+
}
|
|
613
|
+
},
|
|
614
|
+
OUTER2: 'STATE_ON_SIMPLE'
|
|
615
|
+
});
|
|
616
|
+
});
|
|
617
|
+
|
|
618
|
+
it('should properly transition when in a complex nested state', () => {
|
|
619
|
+
const nextState = nestedParallelState.transition(
|
|
620
|
+
complexNextState,
|
|
621
|
+
'EVENT_STATE_NTJ0_WORK'
|
|
622
|
+
);
|
|
623
|
+
|
|
624
|
+
assert.deepEqual(nextState.value, {
|
|
625
|
+
OUTER1: {
|
|
626
|
+
STATE_ON: {
|
|
627
|
+
STATE_NTJ0: 'STATE_WORKING_0',
|
|
628
|
+
STATE_NTJ1: 'STATE_IDLE_1'
|
|
629
|
+
}
|
|
630
|
+
},
|
|
631
|
+
OUTER2: {
|
|
632
|
+
STATE_ON_COMPLEX: {
|
|
633
|
+
STATE_INNER1: 'STATE_OFF',
|
|
634
|
+
STATE_INNER2: 'STATE_OFF'
|
|
635
|
+
}
|
|
636
|
+
}
|
|
637
|
+
});
|
|
638
|
+
});
|
|
639
|
+
});
|
|
412
640
|
});
|