parallel_history.xml 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. <?xml version="1.0" ?>
  2. <diagram
  3. xmlns="msdl.uantwerpen.be/sccd"
  4. author="Glenn De Jonghe"
  5. name="TestParallelHistory">
  6. <description>
  7. Testing history in parallel.
  8. </description>
  9. <inport name="test_input" />
  10. <outport name="test_output" />
  11. <class name="TestClass" default="true">
  12. <scxml>
  13. <parallel id="parallel">
  14. <state id="orthogonal_1" initial="orthogonal_inner_1">
  15. <state id="orthogonal_inner_1" initial="state_1">
  16. <state id="state_1">
  17. <onentry>
  18. <raise port="test_output" event="in_state_1" />
  19. </onentry>
  20. <transition port="test_input" event="to_state_2" target="../state_2"/>
  21. </state>
  22. <state id="state_2">
  23. <onentry>
  24. <raise port="test_output" event="in_state_2" />
  25. </onentry>
  26. </state>
  27. <transition port="test_input" event="to_outer_1" target="../outer_1"/>
  28. <history id="history_1" type="shallow">
  29. <transition target="../state_1"/>
  30. </history>
  31. </state>
  32. <state id="outer_1">
  33. <onentry>
  34. <raise port="test_output" event="in_outer_1" />
  35. </onentry>
  36. <transition port="test_input" event="to_history_1" target="../orthogonal_inner_1/history_1"/>
  37. </state>
  38. </state>
  39. <state id="orthogonal_2" initial="orthogonal_inner_2">
  40. <state id="orthogonal_inner_2" initial="state_3">
  41. <state id="state_3">
  42. <onentry>
  43. <raise port="test_output" event="in_state_3" />
  44. </onentry>
  45. <transition port="test_input" event="to_state_4" target="../state_4"/>
  46. </state>
  47. <state id="state_4">
  48. <onentry>
  49. <raise port="test_output" event="in_state_4" />
  50. </onentry>
  51. </state>
  52. <transition port="test_input" event="to_outer_2" target="../outer_2"/>
  53. <history id="history_2" type="shallow">
  54. <transition target="../state_3"/>
  55. </history>
  56. </state>
  57. <state id="outer_2">
  58. <onentry>
  59. <raise port="test_output" event="in_outer_2" />
  60. </onentry>
  61. <transition port="test_input" event="to_history_2" target="../orthogonal_inner_2/history_2"/>
  62. </state>
  63. </state>
  64. </parallel>
  65. </scxml>
  66. </class>
  67. <test>
  68. <input>
  69. <event name="to_state_2" port="test_input" time="0.0"/>
  70. <event name="to_state_4" port="test_input" time="0.0"/>
  71. <event name="to_outer_1" port="test_input" time="0.0"/>
  72. <event name="to_outer_2" port="test_input" time="0.0"/>
  73. <event name="to_history_1" port="test_input" time="0.0"/>
  74. <event name="to_history_2" port="test_input" time="0.0"/>
  75. </input>
  76. <expected>
  77. <slot>
  78. <event name="in_state_1" port="test_output"/>
  79. <event name="in_state_3" port="test_output"/>
  80. </slot>
  81. <slot>
  82. <event name="in_state_2" port="test_output"/>
  83. </slot>
  84. <slot>
  85. <event name="in_state_4" port="test_output"/>
  86. </slot>
  87. <slot>
  88. <event name="in_outer_1" port="test_output"/>
  89. </slot>
  90. <slot>
  91. <event name="in_outer_2" port="test_output"/>
  92. </slot>
  93. <slot>
  94. <event name="in_state_2" port="test_output"/>
  95. </slot>
  96. <slot>
  97. <event name="in_state_4" port="test_output"/>
  98. </slot>
  99. </expected>
  100. </test>
  101. </diagram>