aasm 5.1.1 → 5.5.0

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 (228) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +74 -15
  3. data/lib/aasm/base.rb +44 -12
  4. data/lib/aasm/configuration.rb +3 -0
  5. data/lib/aasm/core/event.rb +12 -6
  6. data/lib/aasm/core/invokers/class_invoker.rb +1 -1
  7. data/lib/aasm/core/invokers/literal_invoker.rb +3 -1
  8. data/lib/aasm/core/state.rb +6 -5
  9. data/lib/aasm/core/transition.rb +1 -1
  10. data/lib/aasm/dsl_helper.rb +24 -22
  11. data/lib/aasm/errors.rb +1 -0
  12. data/lib/aasm/instance_base.rb +14 -3
  13. data/lib/aasm/localizer.rb +13 -3
  14. data/lib/aasm/persistence/active_record_persistence.rb +1 -1
  15. data/lib/aasm/persistence/base.rb +13 -2
  16. data/lib/aasm/version.rb +1 -1
  17. data/lib/generators/aasm/orm_helpers.rb +1 -1
  18. data/lib/generators/active_record/templates/migration.rb +1 -1
  19. metadata +6 -402
  20. data/.document +0 -6
  21. data/.github/ISSUE_TEMPLATE/bug_report.md +0 -27
  22. data/.github/ISSUE_TEMPLATE/feature_request.md +0 -20
  23. data/.gitignore +0 -20
  24. data/.travis.yml +0 -82
  25. data/API +0 -34
  26. data/Appraisals +0 -67
  27. data/CHANGELOG.md +0 -442
  28. data/CODE_OF_CONDUCT.md +0 -13
  29. data/CONTRIBUTING.md +0 -24
  30. data/Dockerfile +0 -44
  31. data/Gemfile +0 -6
  32. data/Gemfile.lock_old +0 -151
  33. data/HOWTO +0 -12
  34. data/PLANNED_CHANGES.md +0 -11
  35. data/README_FROM_VERSION_3_TO_4.md +0 -240
  36. data/Rakefile +0 -31
  37. data/TESTING.md +0 -25
  38. data/aasm.gemspec +0 -37
  39. data/docker-compose.yml +0 -40
  40. data/gemfiles/norails.gemfile +0 -10
  41. data/gemfiles/rails_4.2.gemfile +0 -17
  42. data/gemfiles/rails_4.2_mongoid_5.gemfile +0 -12
  43. data/gemfiles/rails_4.2_nobrainer.gemfile +0 -9
  44. data/gemfiles/rails_5.0.gemfile +0 -14
  45. data/gemfiles/rails_5.0_nobrainer.gemfile +0 -9
  46. data/gemfiles/rails_5.1.gemfile +0 -14
  47. data/gemfiles/rails_5.2.gemfile +0 -14
  48. data/spec/database.rb +0 -59
  49. data/spec/database.yml +0 -3
  50. data/spec/en.yml +0 -9
  51. data/spec/generators/active_record_generator_spec.rb +0 -53
  52. data/spec/generators/mongoid_generator_spec.rb +0 -31
  53. data/spec/generators/no_brainer_generator_spec.rb +0 -29
  54. data/spec/localizer_test_model_deprecated_style.yml +0 -6
  55. data/spec/localizer_test_model_new_style.yml +0 -5
  56. data/spec/models/active_record/active_record_callback.rb +0 -93
  57. data/spec/models/active_record/basic_active_record_two_state_machines_example.rb +0 -25
  58. data/spec/models/active_record/complex_active_record_example.rb +0 -37
  59. data/spec/models/active_record/derivate_new_dsl.rb +0 -7
  60. data/spec/models/active_record/false_state.rb +0 -35
  61. data/spec/models/active_record/gate.rb +0 -39
  62. data/spec/models/active_record/instance_level_skip_validation_example.rb +0 -19
  63. data/spec/models/active_record/invalid_persistor.rb +0 -29
  64. data/spec/models/active_record/localizer_test_model.rb +0 -34
  65. data/spec/models/active_record/no_direct_assignment.rb +0 -21
  66. data/spec/models/active_record/no_scope.rb +0 -21
  67. data/spec/models/active_record/persisted_state.rb +0 -12
  68. data/spec/models/active_record/person.rb +0 -23
  69. data/spec/models/active_record/provided_and_persisted_state.rb +0 -24
  70. data/spec/models/active_record/reader.rb +0 -7
  71. data/spec/models/active_record/readme_job.rb +0 -21
  72. data/spec/models/active_record/silent_persistor.rb +0 -29
  73. data/spec/models/active_record/simple_new_dsl.rb +0 -32
  74. data/spec/models/active_record/thief.rb +0 -29
  75. data/spec/models/active_record/transactor.rb +0 -124
  76. data/spec/models/active_record/transient.rb +0 -6
  77. data/spec/models/active_record/validator.rb +0 -118
  78. data/spec/models/active_record/with_enum.rb +0 -39
  79. data/spec/models/active_record/with_enum_without_column.rb +0 -38
  80. data/spec/models/active_record/with_false_enum.rb +0 -31
  81. data/spec/models/active_record/with_true_enum.rb +0 -39
  82. data/spec/models/active_record/work.rb +0 -3
  83. data/spec/models/active_record/worker.rb +0 -2
  84. data/spec/models/active_record/writer.rb +0 -6
  85. data/spec/models/basic_two_state_machines_example.rb +0 -25
  86. data/spec/models/callbacks/basic.rb +0 -98
  87. data/spec/models/callbacks/basic_multiple.rb +0 -75
  88. data/spec/models/callbacks/guard_within_block.rb +0 -67
  89. data/spec/models/callbacks/guard_within_block_multiple.rb +0 -66
  90. data/spec/models/callbacks/multiple_transitions_transition_guard.rb +0 -66
  91. data/spec/models/callbacks/multiple_transitions_transition_guard_multiple.rb +0 -65
  92. data/spec/models/callbacks/private_method.rb +0 -44
  93. data/spec/models/callbacks/private_method_multiple.rb +0 -44
  94. data/spec/models/callbacks/with_args.rb +0 -62
  95. data/spec/models/callbacks/with_args_multiple.rb +0 -61
  96. data/spec/models/callbacks/with_state_arg.rb +0 -34
  97. data/spec/models/callbacks/with_state_arg_multiple.rb +0 -29
  98. data/spec/models/complex_example.rb +0 -222
  99. data/spec/models/conversation.rb +0 -93
  100. data/spec/models/default_state.rb +0 -12
  101. data/spec/models/double_definer.rb +0 -21
  102. data/spec/models/dynamoid/complex_dynamoid_example.rb +0 -37
  103. data/spec/models/dynamoid/dynamoid_multiple.rb +0 -18
  104. data/spec/models/dynamoid/dynamoid_simple.rb +0 -18
  105. data/spec/models/foo.rb +0 -106
  106. data/spec/models/foo_callback_multiple.rb +0 -45
  107. data/spec/models/guard_arguments_check.rb +0 -17
  108. data/spec/models/guard_with_params.rb +0 -24
  109. data/spec/models/guard_with_params_multiple.rb +0 -18
  110. data/spec/models/guardian.rb +0 -58
  111. data/spec/models/guardian_multiple.rb +0 -48
  112. data/spec/models/guardian_without_from_specified.rb +0 -18
  113. data/spec/models/initial_state_proc.rb +0 -31
  114. data/spec/models/mongoid/complex_mongoid_example.rb +0 -37
  115. data/spec/models/mongoid/invalid_persistor_mongoid.rb +0 -39
  116. data/spec/models/mongoid/mongoid_relationships.rb +0 -26
  117. data/spec/models/mongoid/no_scope_mongoid.rb +0 -21
  118. data/spec/models/mongoid/silent_persistor_mongoid.rb +0 -39
  119. data/spec/models/mongoid/simple_mongoid.rb +0 -23
  120. data/spec/models/mongoid/simple_new_dsl_mongoid.rb +0 -25
  121. data/spec/models/mongoid/validator_mongoid.rb +0 -100
  122. data/spec/models/multi_transitioner.rb +0 -34
  123. data/spec/models/multiple_transitions_that_differ_only_by_guard.rb +0 -31
  124. data/spec/models/namespaced_multiple_example.rb +0 -42
  125. data/spec/models/no_initial_state.rb +0 -25
  126. data/spec/models/nobrainer/complex_no_brainer_example.rb +0 -36
  127. data/spec/models/nobrainer/invalid_persistor_no_brainer.rb +0 -39
  128. data/spec/models/nobrainer/no_scope_no_brainer.rb +0 -21
  129. data/spec/models/nobrainer/nobrainer_relationships.rb +0 -25
  130. data/spec/models/nobrainer/silent_persistor_no_brainer.rb +0 -39
  131. data/spec/models/nobrainer/simple_new_dsl_nobrainer.rb +0 -25
  132. data/spec/models/nobrainer/simple_no_brainer.rb +0 -23
  133. data/spec/models/nobrainer/validator_no_brainer.rb +0 -98
  134. data/spec/models/not_auto_loaded/process.rb +0 -21
  135. data/spec/models/parametrised_event.rb +0 -42
  136. data/spec/models/parametrised_event_multiple.rb +0 -29
  137. data/spec/models/process_with_new_dsl.rb +0 -31
  138. data/spec/models/provided_state.rb +0 -24
  139. data/spec/models/redis/complex_redis_example.rb +0 -40
  140. data/spec/models/redis/redis_multiple.rb +0 -20
  141. data/spec/models/redis/redis_simple.rb +0 -20
  142. data/spec/models/sequel/complex_sequel_example.rb +0 -46
  143. data/spec/models/sequel/invalid_persistor.rb +0 -52
  144. data/spec/models/sequel/sequel_multiple.rb +0 -25
  145. data/spec/models/sequel/sequel_simple.rb +0 -26
  146. data/spec/models/sequel/silent_persistor.rb +0 -50
  147. data/spec/models/sequel/transactor.rb +0 -112
  148. data/spec/models/sequel/validator.rb +0 -93
  149. data/spec/models/sequel/worker.rb +0 -12
  150. data/spec/models/silencer.rb +0 -27
  151. data/spec/models/simple_custom_example.rb +0 -53
  152. data/spec/models/simple_example.rb +0 -23
  153. data/spec/models/simple_example_with_guard_args.rb +0 -17
  154. data/spec/models/simple_multiple_example.rb +0 -42
  155. data/spec/models/state_machine_with_failed_event.rb +0 -20
  156. data/spec/models/states_on_one_line_example.rb +0 -8
  157. data/spec/models/sub_class.rb +0 -41
  158. data/spec/models/sub_class_with_more_states.rb +0 -18
  159. data/spec/models/sub_classing.rb +0 -3
  160. data/spec/models/super_class.rb +0 -46
  161. data/spec/models/this_name_better_not_be_in_use.rb +0 -11
  162. data/spec/models/valid_state_name.rb +0 -23
  163. data/spec/spec_helper.rb +0 -41
  164. data/spec/spec_helpers/active_record.rb +0 -8
  165. data/spec/spec_helpers/dynamoid.rb +0 -35
  166. data/spec/spec_helpers/mongoid.rb +0 -26
  167. data/spec/spec_helpers/nobrainer.rb +0 -15
  168. data/spec/spec_helpers/redis.rb +0 -18
  169. data/spec/spec_helpers/remove_warnings.rb +0 -1
  170. data/spec/spec_helpers/sequel.rb +0 -7
  171. data/spec/unit/abstract_class_spec.rb +0 -27
  172. data/spec/unit/api_spec.rb +0 -104
  173. data/spec/unit/basic_two_state_machines_example_spec.rb +0 -10
  174. data/spec/unit/callback_multiple_spec.rb +0 -304
  175. data/spec/unit/callbacks_spec.rb +0 -521
  176. data/spec/unit/complex_example_spec.rb +0 -93
  177. data/spec/unit/complex_multiple_example_spec.rb +0 -115
  178. data/spec/unit/edge_cases_spec.rb +0 -16
  179. data/spec/unit/event_multiple_spec.rb +0 -73
  180. data/spec/unit/event_naming_spec.rb +0 -16
  181. data/spec/unit/event_spec.rb +0 -394
  182. data/spec/unit/exception_spec.rb +0 -11
  183. data/spec/unit/guard_arguments_check_spec.rb +0 -9
  184. data/spec/unit/guard_multiple_spec.rb +0 -60
  185. data/spec/unit/guard_spec.rb +0 -89
  186. data/spec/unit/guard_with_params_multiple_spec.rb +0 -10
  187. data/spec/unit/guard_with_params_spec.rb +0 -14
  188. data/spec/unit/guard_without_from_specified_spec.rb +0 -10
  189. data/spec/unit/initial_state_multiple_spec.rb +0 -15
  190. data/spec/unit/initial_state_spec.rb +0 -12
  191. data/spec/unit/inspection_multiple_spec.rb +0 -205
  192. data/spec/unit/inspection_spec.rb +0 -153
  193. data/spec/unit/invoker_spec.rb +0 -189
  194. data/spec/unit/invokers/base_invoker_spec.rb +0 -72
  195. data/spec/unit/invokers/class_invoker_spec.rb +0 -95
  196. data/spec/unit/invokers/literal_invoker_spec.rb +0 -86
  197. data/spec/unit/invokers/proc_invoker_spec.rb +0 -86
  198. data/spec/unit/localizer_spec.rb +0 -77
  199. data/spec/unit/memory_leak_spec.rb +0 -38
  200. data/spec/unit/multiple_transitions_that_differ_only_by_guard_spec.rb +0 -14
  201. data/spec/unit/namespaced_multiple_example_spec.rb +0 -75
  202. data/spec/unit/new_dsl_spec.rb +0 -12
  203. data/spec/unit/override_warning_spec.rb +0 -94
  204. data/spec/unit/persistence/active_record_persistence_multiple_spec.rb +0 -618
  205. data/spec/unit/persistence/active_record_persistence_spec.rb +0 -840
  206. data/spec/unit/persistence/dynamoid_persistence_multiple_spec.rb +0 -135
  207. data/spec/unit/persistence/dynamoid_persistence_spec.rb +0 -84
  208. data/spec/unit/persistence/mongoid_persistence_multiple_spec.rb +0 -200
  209. data/spec/unit/persistence/mongoid_persistence_spec.rb +0 -165
  210. data/spec/unit/persistence/no_brainer_persistence_multiple_spec.rb +0 -198
  211. data/spec/unit/persistence/no_brainer_persistence_spec.rb +0 -158
  212. data/spec/unit/persistence/redis_persistence_multiple_spec.rb +0 -88
  213. data/spec/unit/persistence/redis_persistence_spec.rb +0 -53
  214. data/spec/unit/persistence/sequel_persistence_multiple_spec.rb +0 -148
  215. data/spec/unit/persistence/sequel_persistence_spec.rb +0 -368
  216. data/spec/unit/readme_spec.rb +0 -41
  217. data/spec/unit/reloading_spec.rb +0 -15
  218. data/spec/unit/rspec_matcher_spec.rb +0 -88
  219. data/spec/unit/simple_custom_example_spec.rb +0 -39
  220. data/spec/unit/simple_example_spec.rb +0 -57
  221. data/spec/unit/simple_multiple_example_spec.rb +0 -91
  222. data/spec/unit/state_spec.rb +0 -105
  223. data/spec/unit/states_on_one_line_example_spec.rb +0 -16
  224. data/spec/unit/subclassing_multiple_spec.rb +0 -74
  225. data/spec/unit/subclassing_spec.rb +0 -46
  226. data/spec/unit/transition_spec.rb +0 -436
  227. data/test/minitest_helper.rb +0 -57
  228. data/test/unit/minitest_matcher_test.rb +0 -80
@@ -1,89 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe "per-transition guards" do
4
- let(:guardian) { Guardian.new }
5
-
6
- it "allows the transition if the guard succeeds" do
7
- expect { guardian.use_one_guard_that_succeeds! }.to_not raise_error
8
- expect(guardian).to be_beta
9
- end
10
-
11
- it "stops the transition if the guard fails" do
12
- expect { guardian.use_one_guard_that_fails! }.to raise_error(AASM::InvalidTransition)
13
- expect(guardian).to be_alpha
14
- end
15
-
16
- it "allows the transition if all guards succeeds" do
17
- expect { guardian.use_guards_that_succeed! }.to_not raise_error
18
- expect(guardian).to be_beta
19
- end
20
-
21
- it "stops the transition if the first guard fails" do
22
- expect { guardian.use_guards_where_the_first_fails! }.to raise_error(AASM::InvalidTransition)
23
- expect(guardian).to be_alpha
24
- end
25
-
26
- it "stops the transition if the second guard fails" do
27
- expect { guardian.use_guards_where_the_second_fails! }.to raise_error(AASM::InvalidTransition)
28
- expect(guardian).to be_alpha
29
- end
30
-
31
- describe "with params" do
32
- it "using a Proc" do
33
- expect(guardian).to receive(:inner_guard).with({:flag => true}).and_return(true)
34
- guardian.use_proc_guard_with_params(:flag => true)
35
- end
36
-
37
- it "using a lambda" do
38
- expect(guardian).to receive(:inner_guard).with({:flag => true}).and_return(true)
39
- guardian.use_lambda_guard_with_params(:flag => true)
40
- end
41
- end
42
- end
43
-
44
- describe "event guards" do
45
- let(:guardian) { Guardian.new }
46
-
47
- it "allows the transition if the event guards succeed" do
48
- expect { guardian.use_event_guards_that_succeed! }.to_not raise_error
49
- expect(guardian).to be_beta
50
- end
51
-
52
- it "allows the transition if the event and transition guards succeed" do
53
- expect { guardian.use_event_and_transition_guards_that_succeed! }.to_not raise_error
54
- expect(guardian).to be_beta
55
- end
56
-
57
- it "stops the transition if the first event guard fails" do
58
- expect { guardian.use_event_guards_where_the_first_fails! }.to raise_error(AASM::InvalidTransition)
59
- expect(guardian).to be_alpha
60
- end
61
-
62
- it "stops the transition if the second event guard fails" do
63
- expect { guardian.use_event_guards_where_the_second_fails! }.to raise_error(AASM::InvalidTransition)
64
- expect(guardian).to be_alpha
65
- end
66
-
67
- it "stops the transition if the transition guard fails" do
68
- expect { guardian.use_event_and_transition_guards_where_third_fails! }.to raise_error(AASM::InvalidTransition)
69
- expect(guardian).to be_alpha
70
- end
71
-
72
- end
73
-
74
- if defined?(ActiveRecord)
75
-
76
- Dir[File.dirname(__FILE__) + "/../models/active_record/*.rb"].sort.each do |f|
77
- require File.expand_path(f)
78
- end
79
-
80
- load_schema
81
-
82
- describe "ActiveRecord per-transition guards" do
83
- let(:example) { ComplexActiveRecordExample.new }
84
-
85
- it "should be able to increment" do
86
- expect(example.may_increment?).to be true
87
- end
88
- end
89
- end
@@ -1,10 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe "guards with params" do
4
- let(:guard) { GuardWithParamsMultiple.new }
5
- let(:user) {GuardParamsClass.new}
6
-
7
- it "list permitted states" do
8
- expect(guard.aasm(:left).states({:permitted => true}, user).map(&:name)).to eql [:reviewed]
9
- end
10
- end
@@ -1,14 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe "guards with params" do
4
- let(:guard) { GuardWithParams.new }
5
- let(:user) {GuardParamsClass.new}
6
-
7
- it "list permitted states" do
8
- expect(guard.aasm.states({:permitted => true}, user).map(&:name)).to eql [:reviewed]
9
- end
10
-
11
- it "list no states if user is blank" do
12
- expect(guard.aasm.states({:permitted => true}, nil).map(&:name)).to eql []
13
- end
14
- end
@@ -1,10 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe "transitions without from specified" do
4
- let(:guardian) { GuardianWithoutFromSpecified.new }
5
-
6
- it "allows the transitions if guard succeeds" do
7
- expect { guardian.use_guards_where_the_first_fails! }.to_not raise_error
8
- expect(guardian).to be_gamma
9
- end
10
- end
@@ -1,15 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe 'initial states' do
4
- it 'should use the first state defined if no initial state is given' do
5
- expect(NoInitialStateMultiple.new.aasm(:left).current_state).to eq(:read)
6
- end
7
-
8
- it 'should determine initial state from the Proc results' do
9
- balance = InitialStateProcMultiple::RICH - 1
10
- expect(InitialStateProcMultiple.new(balance).aasm(:left).current_state).to eq(:selling_bad_mortgages)
11
-
12
- balance = InitialStateProcMultiple::RICH + 1
13
- expect(InitialStateProcMultiple.new(balance).aasm(:left).current_state).to eq(:retired)
14
- end
15
- end
@@ -1,12 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe 'initial states' do
4
- it 'should use the first state defined if no initial state is given' do
5
- expect(NoInitialState.new.aasm.current_state).to eq(:read)
6
- end
7
-
8
- it 'should determine initial state from the Proc results' do
9
- expect(InitialStateProc.new(InitialStateProc::RICH - 1).aasm.current_state).to eq(:selling_bad_mortgages)
10
- expect(InitialStateProc.new(InitialStateProc::RICH + 1).aasm.current_state).to eq(:retired)
11
- end
12
- end
@@ -1,205 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe 'inspection for common cases' do
4
- it 'should support the new DSL' do
5
- # 1st state machine
6
- expect(FooMultiple.aasm(:left)).to respond_to(:states)
7
- expect(FooMultiple.aasm(:left).states.size).to eql 3
8
- expect(FooMultiple.aasm(:left).states).to include(:open)
9
- expect(FooMultiple.aasm(:left).states).to include(:closed)
10
- expect(FooMultiple.aasm(:left).states).to include(:final)
11
-
12
- expect(FooMultiple.aasm(:left)).to respond_to(:initial_state)
13
- expect(FooMultiple.aasm(:left).initial_state).to eq(:open)
14
-
15
- expect(FooMultiple.aasm(:left)).to respond_to(:events)
16
- expect(FooMultiple.aasm(:left).events.size).to eql 2
17
- expect(FooMultiple.aasm(:left).events).to include(:close)
18
- expect(FooMultiple.aasm(:left).events).to include(:null)
19
-
20
- # 2nd state machine
21
- expect(FooMultiple.aasm(:right)).to respond_to(:states)
22
- expect(FooMultiple.aasm(:right).states.size).to eql 3
23
- expect(FooMultiple.aasm(:right).states).to include(:green)
24
- expect(FooMultiple.aasm(:right).states).to include(:yellow)
25
- expect(FooMultiple.aasm(:right).states).to include(:red)
26
-
27
- expect(FooMultiple.aasm(:right)).to respond_to(:initial_state)
28
- expect(FooMultiple.aasm(:right).initial_state).to eq(:green)
29
-
30
- expect(FooMultiple.aasm(:right)).to respond_to(:events)
31
- expect(FooMultiple.aasm(:right).events.size).to eql 3
32
- expect(FooMultiple.aasm(:right).events).to include(:green)
33
- expect(FooMultiple.aasm(:right).events).to include(:yellow)
34
- expect(FooMultiple.aasm(:right).events).to include(:red)
35
- end
36
-
37
- context "instance level inspection" do
38
- let(:foo) { FooMultiple.new }
39
- let(:two) { FooTwoMultiple.new }
40
-
41
- it "delivers all states" do
42
- # 1st state machine
43
- states = foo.aasm(:left).states
44
- expect(states.size).to eql 3
45
- expect(states).to include(:open)
46
- expect(states).to include(:closed)
47
- expect(states).to include(:final)
48
-
49
- states = foo.aasm(:left).states(:permitted => true)
50
- expect(states.size).to eql 1
51
- expect(states).to include(:closed)
52
- expect(states).not_to include(:open)
53
- expect(states).not_to include(:final)
54
-
55
- foo.close
56
- expect(foo.aasm(:left).states(:permitted => true)).to be_empty
57
-
58
- # 2nd state machine
59
- states = foo.aasm(:right).states
60
- expect(states.size).to eql 3
61
- expect(states).to include(:green)
62
- expect(states).to include(:yellow)
63
- expect(states).to include(:red)
64
-
65
- states = foo.aasm(:right).states(:permitted => true)
66
- expect(states.size).to eql 1
67
- expect(states).to include(:yellow)
68
- expect(states).not_to include(:green)
69
- expect(states).not_to include(:red)
70
-
71
- foo.yellow
72
- states = foo.aasm(:right).states(:permitted => true)
73
- expect(states.size).to eql 2
74
- expect(states).to include(:red)
75
- expect(states).to include(:green)
76
- expect(states).not_to include(:yellow)
77
- end
78
-
79
- it "delivers all states for subclasses" do
80
- # 1st state machine
81
- states = two.aasm(:left).states
82
- expect(states.size).to eql 4
83
- expect(states).to include(:open)
84
- expect(states).to include(:closed)
85
- expect(states).to include(:final)
86
- expect(states).to include(:foo)
87
-
88
- states = two.aasm(:left).states(:permitted => true)
89
- expect(states.size).to eql 1
90
- expect(states).to include(:closed)
91
- expect(states).not_to include(:open)
92
-
93
- two.close
94
- expect(two.aasm(:left).states(:permitted => true)).to be_empty
95
-
96
- # 2nd state machine
97
- states = two.aasm(:right).states
98
- expect(states.size).to eql 4
99
- expect(states).to include(:green)
100
- expect(states).to include(:yellow)
101
- expect(states).to include(:red)
102
- expect(states).to include(:bar)
103
-
104
- states = two.aasm(:right).states(:permitted => true)
105
- expect(states.size).to eql 1
106
- expect(states).to include(:yellow)
107
- expect(states).not_to include(:red)
108
- expect(states).not_to include(:green)
109
- expect(states).not_to include(:bar)
110
-
111
- two.yellow
112
- states = two.aasm(:right).states(:permitted => true)
113
- expect(states.size).to eql 2
114
- expect(states).to include(:green)
115
- expect(states).to include(:red)
116
- expect(states).not_to include(:yellow)
117
- expect(states).not_to include(:bar)
118
- end
119
-
120
- it "delivers all events" do
121
- # 1st state machine
122
- events = foo.aasm(:left).events
123
- expect(events.size).to eql 2
124
- expect(events).to include(:close)
125
- expect(events).to include(:null)
126
-
127
- foo.close
128
- expect(foo.aasm(:left).events).to be_empty
129
-
130
- # 2nd state machine
131
- events = foo.aasm(:right).events
132
- expect(events.size).to eql 1
133
- expect(events).to include(:yellow)
134
- expect(events).not_to include(:green)
135
- expect(events).not_to include(:red)
136
-
137
- foo.yellow
138
- events = foo.aasm(:right).events
139
- expect(events.size).to eql 2
140
- expect(events).to include(:green)
141
- expect(events).to include(:red)
142
- expect(events).not_to include(:yellow)
143
- end
144
- end
145
-
146
- it 'should list states in the order they have been defined' do
147
- expect(ConversationMultiple.aasm(:left).states).to eq([
148
- :needs_attention, :read, :closed, :awaiting_response, :junk
149
- ])
150
- end
151
- end
152
-
153
- describe "special cases" do
154
- it "should support valid as state name" do
155
- expect(ValidStateNameMultiple.aasm(:left).states).to include(:invalid)
156
- expect(ValidStateNameMultiple.aasm(:left).states).to include(:valid)
157
-
158
- argument = ValidStateNameMultiple.new
159
- expect(argument.invalid?).to be_truthy
160
- expect(argument.aasm(:left).current_state).to eq(:invalid)
161
-
162
- argument.valid!
163
- expect(argument.valid?).to be_truthy
164
- expect(argument.aasm(:left).current_state).to eq(:valid)
165
- end
166
- end
167
-
168
- describe 'aasm.states_for_select' do
169
- context 'without I18n' do
170
- before { allow(Module).to receive(:const_defined?).with(:I18n).and_return(nil) }
171
-
172
- it "should return a select friendly array of states" do
173
- expect(FooMultiple.aasm(:left)).to respond_to(:states_for_select)
174
- expect(FooMultiple.aasm(:left).states_for_select).to eq(
175
- [['Open', 'open'], ['Closed', 'closed'], ['Final', 'final']]
176
- )
177
- end
178
- end
179
- end
180
-
181
- describe 'aasm.from_states_for_state' do
182
- it "should return all from states for a state" do
183
- expect(ComplexExampleMultiple.aasm(:left)).to respond_to(:from_states_for_state)
184
- froms = ComplexExampleMultiple.aasm(:left).from_states_for_state(:active)
185
- [:pending, :passive, :suspended].each {|from| expect(froms).to include(from)}
186
- end
187
-
188
- it "should return from states for a state for a particular transition only" do
189
- froms = ComplexExampleMultiple.aasm(:left).from_states_for_state(:active, :transition => :left_unsuspend)
190
- [:suspended].each {|from| expect(froms).to include(from)}
191
- end
192
- end
193
-
194
- describe 'permitted events' do
195
- let(:foo) {FooMultiple.new}
196
-
197
- it 'work' do
198
- expect(foo.aasm(:left).events(:permitted => true)).to include(:close)
199
- expect(foo.aasm(:left).events(:permitted => true)).not_to include(:null)
200
-
201
- expect(foo.aasm(:right).events(:permitted => true)).to include(:yellow)
202
- expect(foo.aasm(:right).events(:permitted => true)).not_to include(:green)
203
- expect(foo.aasm(:right).events(:permitted => true)).not_to include(:red)
204
- end
205
- end
@@ -1,153 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe 'inspection for common cases' do
4
- it 'should support the new DSL' do
5
- expect(Foo.aasm).to respond_to(:states)
6
- expect(Foo.aasm.states).to include(:open)
7
- expect(Foo.aasm.states).to include(:closed)
8
-
9
- expect(Foo.aasm).to respond_to(:initial_state)
10
- expect(Foo.aasm.initial_state).to eq(:open)
11
-
12
- expect(Foo.aasm).to respond_to(:events)
13
- expect(Foo.aasm.events).to include(:close)
14
- expect(Foo.aasm.events).to include(:null)
15
- end
16
-
17
- context "instance level inspection" do
18
- let(:foo) { Foo.new }
19
- let(:two) { FooTwo.new }
20
- let(:multi) { MultiTransitioner.new }
21
-
22
- it "delivers all states" do
23
- states = foo.aasm.states
24
- expect(states).to include(:open)
25
- expect(states).to include(:closed)
26
- expect(states).to include(:final)
27
-
28
- permitted_states = foo.aasm.states(:permitted => true)
29
- expect(permitted_states).to include(:closed)
30
- expect(permitted_states).not_to include(:open)
31
- expect(permitted_states).not_to include(:final)
32
-
33
- blocked_states = foo.aasm.states(:permitted => false)
34
- expect(blocked_states).to include(:closed)
35
- expect(blocked_states).not_to include(:open)
36
- expect(blocked_states).to include(:final)
37
-
38
- foo.close
39
- expect(foo.aasm.states(:permitted => true)).to be_empty
40
- end
41
-
42
- it "delivers all states for subclasses" do
43
- states = two.aasm.states
44
- expect(states).to include(:open)
45
- expect(states).to include(:closed)
46
- expect(states).to include(:final)
47
- expect(states).to include(:foo)
48
-
49
- states = two.aasm.states(:permitted => true)
50
- expect(states).to include(:closed)
51
- expect(states).not_to include(:open)
52
- expect(states).not_to include(:final)
53
-
54
- two.close
55
- expect(two.aasm.states(:permitted => true)).to be_empty
56
- end
57
-
58
- it "delivers all events" do
59
- events = foo.aasm.events
60
- expect(events).to include(:close)
61
- expect(events).to include(:null)
62
- foo.close
63
- expect(foo.aasm.events).to be_empty
64
- end
65
-
66
- it "delivers permitted states when multiple transitions are defined" do
67
- multi.can_run = false
68
- states = multi.aasm.states(:permitted => true)
69
- expect(states).to_not include(:running)
70
- expect(states).to include(:dancing)
71
-
72
- multi.can_run = true
73
- states = multi.aasm.states(:permitted => true)
74
- expect(states).to include(:running)
75
- expect(states).to_not include(:dancing)
76
- end
77
-
78
- it "transitions to correct state if from state is missing from one transitions" do
79
- multi.sleep
80
- expect(multi.aasm.current_state).to eq(:sleeping)
81
- end
82
- end
83
-
84
- it 'should list states in the order they have been defined' do
85
- expect(Conversation.aasm.states).to eq([:needs_attention, :read, :closed, :awaiting_response, :junk])
86
- end
87
- end
88
-
89
- describe "special cases" do
90
- it "should support valid as state name" do
91
- expect(ValidStateName.aasm.states).to include(:invalid)
92
- expect(ValidStateName.aasm.states).to include(:valid)
93
-
94
- argument = ValidStateName.new
95
- expect(argument.invalid?).to be_truthy
96
- expect(argument.aasm.current_state).to eq(:invalid)
97
-
98
- argument.valid!
99
- expect(argument.valid?).to be_truthy
100
- expect(argument.aasm.current_state).to eq(:valid)
101
- end
102
- end
103
-
104
- describe 'aasm.states_for_select' do
105
- context 'without I18n' do
106
- before { allow(Module).to receive(:const_defined?).with(:I18n).and_return(nil) }
107
-
108
- it "should return a select friendly array of states" do
109
- expect(Foo.aasm).to respond_to(:states_for_select)
110
- expect(Foo.aasm.states_for_select).to eq([['Open', 'open'], ['Closed', 'closed'], ['Final', 'final']])
111
- end
112
- end
113
- end
114
-
115
- describe 'aasm.from_states_for_state' do
116
- it "should return all from states for a state" do
117
- expect(ComplexExample.aasm).to respond_to(:from_states_for_state)
118
- froms = ComplexExample.aasm.from_states_for_state(:active)
119
- [:pending, :passive, :suspended].each {|from| expect(froms).to include(from)}
120
- end
121
-
122
- it "should return from states for a state for a particular transition only" do
123
- froms = ComplexExample.aasm.from_states_for_state(:active, :transition => :unsuspend)
124
- [:suspended].each {|from| expect(froms).to include(from)}
125
- end
126
- end
127
-
128
- describe 'permitted events' do
129
- let(:foo) {Foo.new}
130
-
131
- it 'work' do
132
- expect(foo.aasm.events(:permitted => true)).to include(:close)
133
- expect(foo.aasm.events(:permitted => true)).not_to include(:null)
134
- end
135
-
136
- it 'should not include events in the reject option' do
137
- expect(foo.aasm.events(:permitted => true, reject: :close)).not_to include(:close)
138
- expect(foo.aasm.events(:permitted => true, reject: [:close])).not_to include(:close)
139
- end
140
- end
141
-
142
- describe 'not permitted events' do
143
- let(:foo) {Foo.new}
144
-
145
- it 'work' do
146
- expect(foo.aasm.events(:permitted => false)).to include(:null)
147
- expect(foo.aasm.events(:permitted => false)).not_to include(:close)
148
- end
149
-
150
- it 'should not include events in the reject option' do
151
- expect(foo.aasm.events(:permitted => false, reject: :null)).to eq([])
152
- end
153
- end