aasm 5.0.8 → 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 (230) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +108 -17
  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 +15 -4
  13. data/lib/aasm/localizer.rb +13 -3
  14. data/lib/aasm/persistence/active_record_persistence.rb +18 -0
  15. data/lib/aasm/persistence/base.rb +13 -2
  16. data/lib/aasm/persistence/orm.rb +23 -19
  17. data/lib/aasm/version.rb +1 -1
  18. data/lib/aasm.rb +0 -2
  19. data/lib/generators/aasm/orm_helpers.rb +1 -1
  20. data/lib/generators/active_record/templates/migration.rb +1 -1
  21. metadata +9 -397
  22. data/.document +0 -6
  23. data/.github/ISSUE_TEMPLATE/bug_report.md +0 -27
  24. data/.github/ISSUE_TEMPLATE/feature_request.md +0 -20
  25. data/.gitignore +0 -20
  26. data/.travis.yml +0 -100
  27. data/API +0 -34
  28. data/Appraisals +0 -71
  29. data/CHANGELOG.md +0 -431
  30. data/CODE_OF_CONDUCT.md +0 -13
  31. data/CONTRIBUTING.md +0 -24
  32. data/Dockerfile +0 -44
  33. data/Gemfile +0 -6
  34. data/Gemfile.lock_old +0 -151
  35. data/HOWTO +0 -12
  36. data/PLANNED_CHANGES.md +0 -11
  37. data/README_FROM_VERSION_3_TO_4.md +0 -240
  38. data/Rakefile +0 -31
  39. data/TESTING.md +0 -25
  40. data/aasm.gemspec +0 -37
  41. data/callbacks.txt +0 -51
  42. data/docker-compose.yml +0 -40
  43. data/gemfiles/norails.gemfile +0 -10
  44. data/gemfiles/rails_3.2.gemfile +0 -14
  45. data/gemfiles/rails_4.2.gemfile +0 -16
  46. data/gemfiles/rails_4.2_mongoid_5.gemfile +0 -11
  47. data/gemfiles/rails_4.2_nobrainer.gemfile +0 -9
  48. data/gemfiles/rails_5.0.gemfile +0 -13
  49. data/gemfiles/rails_5.0_nobrainer.gemfile +0 -9
  50. data/gemfiles/rails_5.1.gemfile +0 -13
  51. data/gemfiles/rails_5.2.gemfile +0 -13
  52. data/spec/database.rb +0 -59
  53. data/spec/database.yml +0 -3
  54. data/spec/en.yml +0 -12
  55. data/spec/en_deprecated_style.yml +0 -10
  56. data/spec/generators/active_record_generator_spec.rb +0 -53
  57. data/spec/generators/mongoid_generator_spec.rb +0 -31
  58. data/spec/generators/no_brainer_generator_spec.rb +0 -29
  59. data/spec/models/active_record/basic_active_record_two_state_machines_example.rb +0 -25
  60. data/spec/models/active_record/complex_active_record_example.rb +0 -37
  61. data/spec/models/active_record/derivate_new_dsl.rb +0 -7
  62. data/spec/models/active_record/false_state.rb +0 -35
  63. data/spec/models/active_record/gate.rb +0 -39
  64. data/spec/models/active_record/instance_level_skip_validation_example.rb +0 -19
  65. data/spec/models/active_record/invalid_persistor.rb +0 -29
  66. data/spec/models/active_record/localizer_test_model.rb +0 -34
  67. data/spec/models/active_record/no_direct_assignment.rb +0 -21
  68. data/spec/models/active_record/no_scope.rb +0 -21
  69. data/spec/models/active_record/persisted_state.rb +0 -12
  70. data/spec/models/active_record/person.rb +0 -23
  71. data/spec/models/active_record/provided_and_persisted_state.rb +0 -24
  72. data/spec/models/active_record/reader.rb +0 -7
  73. data/spec/models/active_record/readme_job.rb +0 -21
  74. data/spec/models/active_record/silent_persistor.rb +0 -29
  75. data/spec/models/active_record/simple_new_dsl.rb +0 -32
  76. data/spec/models/active_record/thief.rb +0 -29
  77. data/spec/models/active_record/transactor.rb +0 -124
  78. data/spec/models/active_record/transient.rb +0 -6
  79. data/spec/models/active_record/validator.rb +0 -118
  80. data/spec/models/active_record/with_enum.rb +0 -39
  81. data/spec/models/active_record/with_enum_without_column.rb +0 -38
  82. data/spec/models/active_record/with_false_enum.rb +0 -31
  83. data/spec/models/active_record/with_true_enum.rb +0 -39
  84. data/spec/models/active_record/work.rb +0 -3
  85. data/spec/models/active_record/worker.rb +0 -2
  86. data/spec/models/active_record/writer.rb +0 -6
  87. data/spec/models/basic_two_state_machines_example.rb +0 -25
  88. data/spec/models/callbacks/basic.rb +0 -98
  89. data/spec/models/callbacks/basic_multiple.rb +0 -75
  90. data/spec/models/callbacks/guard_within_block.rb +0 -67
  91. data/spec/models/callbacks/guard_within_block_multiple.rb +0 -66
  92. data/spec/models/callbacks/multiple_transitions_transition_guard.rb +0 -66
  93. data/spec/models/callbacks/multiple_transitions_transition_guard_multiple.rb +0 -65
  94. data/spec/models/callbacks/private_method.rb +0 -44
  95. data/spec/models/callbacks/private_method_multiple.rb +0 -44
  96. data/spec/models/callbacks/with_args.rb +0 -62
  97. data/spec/models/callbacks/with_args_multiple.rb +0 -61
  98. data/spec/models/callbacks/with_state_arg.rb +0 -34
  99. data/spec/models/callbacks/with_state_arg_multiple.rb +0 -29
  100. data/spec/models/complex_example.rb +0 -222
  101. data/spec/models/conversation.rb +0 -93
  102. data/spec/models/default_state.rb +0 -12
  103. data/spec/models/double_definer.rb +0 -21
  104. data/spec/models/dynamoid/complex_dynamoid_example.rb +0 -37
  105. data/spec/models/dynamoid/dynamoid_multiple.rb +0 -18
  106. data/spec/models/dynamoid/dynamoid_simple.rb +0 -18
  107. data/spec/models/foo.rb +0 -106
  108. data/spec/models/foo_callback_multiple.rb +0 -45
  109. data/spec/models/guard_arguments_check.rb +0 -17
  110. data/spec/models/guard_with_params.rb +0 -24
  111. data/spec/models/guard_with_params_multiple.rb +0 -18
  112. data/spec/models/guardian.rb +0 -58
  113. data/spec/models/guardian_multiple.rb +0 -48
  114. data/spec/models/guardian_without_from_specified.rb +0 -18
  115. data/spec/models/initial_state_proc.rb +0 -31
  116. data/spec/models/mongoid/complex_mongoid_example.rb +0 -37
  117. data/spec/models/mongoid/invalid_persistor_mongoid.rb +0 -39
  118. data/spec/models/mongoid/mongoid_relationships.rb +0 -26
  119. data/spec/models/mongoid/no_scope_mongoid.rb +0 -21
  120. data/spec/models/mongoid/silent_persistor_mongoid.rb +0 -39
  121. data/spec/models/mongoid/simple_mongoid.rb +0 -23
  122. data/spec/models/mongoid/simple_new_dsl_mongoid.rb +0 -25
  123. data/spec/models/mongoid/validator_mongoid.rb +0 -100
  124. data/spec/models/multi_transitioner.rb +0 -34
  125. data/spec/models/multiple_transitions_that_differ_only_by_guard.rb +0 -31
  126. data/spec/models/namespaced_multiple_example.rb +0 -42
  127. data/spec/models/no_initial_state.rb +0 -25
  128. data/spec/models/nobrainer/complex_no_brainer_example.rb +0 -36
  129. data/spec/models/nobrainer/invalid_persistor_no_brainer.rb +0 -39
  130. data/spec/models/nobrainer/no_scope_no_brainer.rb +0 -21
  131. data/spec/models/nobrainer/nobrainer_relationships.rb +0 -25
  132. data/spec/models/nobrainer/silent_persistor_no_brainer.rb +0 -39
  133. data/spec/models/nobrainer/simple_new_dsl_nobrainer.rb +0 -25
  134. data/spec/models/nobrainer/simple_no_brainer.rb +0 -23
  135. data/spec/models/nobrainer/validator_no_brainer.rb +0 -98
  136. data/spec/models/not_auto_loaded/process.rb +0 -21
  137. data/spec/models/parametrised_event.rb +0 -42
  138. data/spec/models/parametrised_event_multiple.rb +0 -29
  139. data/spec/models/process_with_new_dsl.rb +0 -31
  140. data/spec/models/provided_state.rb +0 -24
  141. data/spec/models/redis/complex_redis_example.rb +0 -40
  142. data/spec/models/redis/redis_multiple.rb +0 -20
  143. data/spec/models/redis/redis_simple.rb +0 -20
  144. data/spec/models/sequel/complex_sequel_example.rb +0 -46
  145. data/spec/models/sequel/invalid_persistor.rb +0 -52
  146. data/spec/models/sequel/sequel_multiple.rb +0 -25
  147. data/spec/models/sequel/sequel_simple.rb +0 -26
  148. data/spec/models/sequel/silent_persistor.rb +0 -50
  149. data/spec/models/sequel/transactor.rb +0 -112
  150. data/spec/models/sequel/validator.rb +0 -93
  151. data/spec/models/sequel/worker.rb +0 -12
  152. data/spec/models/silencer.rb +0 -27
  153. data/spec/models/simple_custom_example.rb +0 -53
  154. data/spec/models/simple_example.rb +0 -23
  155. data/spec/models/simple_example_with_guard_args.rb +0 -17
  156. data/spec/models/simple_multiple_example.rb +0 -42
  157. data/spec/models/state_machine_with_failed_event.rb +0 -20
  158. data/spec/models/states_on_one_line_example.rb +0 -8
  159. data/spec/models/sub_class.rb +0 -41
  160. data/spec/models/sub_class_with_more_states.rb +0 -18
  161. data/spec/models/sub_classing.rb +0 -3
  162. data/spec/models/super_class.rb +0 -46
  163. data/spec/models/this_name_better_not_be_in_use.rb +0 -11
  164. data/spec/models/valid_state_name.rb +0 -23
  165. data/spec/spec_helper.rb +0 -36
  166. data/spec/spec_helpers/active_record.rb +0 -8
  167. data/spec/spec_helpers/dynamoid.rb +0 -35
  168. data/spec/spec_helpers/mongoid.rb +0 -26
  169. data/spec/spec_helpers/nobrainer.rb +0 -15
  170. data/spec/spec_helpers/redis.rb +0 -18
  171. data/spec/spec_helpers/remove_warnings.rb +0 -1
  172. data/spec/spec_helpers/sequel.rb +0 -7
  173. data/spec/unit/abstract_class_spec.rb +0 -27
  174. data/spec/unit/api_spec.rb +0 -100
  175. data/spec/unit/basic_two_state_machines_example_spec.rb +0 -10
  176. data/spec/unit/callback_multiple_spec.rb +0 -304
  177. data/spec/unit/callbacks_spec.rb +0 -521
  178. data/spec/unit/complex_example_spec.rb +0 -93
  179. data/spec/unit/complex_multiple_example_spec.rb +0 -115
  180. data/spec/unit/edge_cases_spec.rb +0 -16
  181. data/spec/unit/event_multiple_spec.rb +0 -73
  182. data/spec/unit/event_naming_spec.rb +0 -16
  183. data/spec/unit/event_spec.rb +0 -394
  184. data/spec/unit/exception_spec.rb +0 -11
  185. data/spec/unit/guard_arguments_check_spec.rb +0 -9
  186. data/spec/unit/guard_multiple_spec.rb +0 -60
  187. data/spec/unit/guard_spec.rb +0 -89
  188. data/spec/unit/guard_with_params_multiple_spec.rb +0 -10
  189. data/spec/unit/guard_with_params_spec.rb +0 -14
  190. data/spec/unit/guard_without_from_specified_spec.rb +0 -10
  191. data/spec/unit/initial_state_multiple_spec.rb +0 -15
  192. data/spec/unit/initial_state_spec.rb +0 -12
  193. data/spec/unit/inspection_multiple_spec.rb +0 -201
  194. data/spec/unit/inspection_spec.rb +0 -149
  195. data/spec/unit/invoker_spec.rb +0 -189
  196. data/spec/unit/invokers/base_invoker_spec.rb +0 -72
  197. data/spec/unit/invokers/class_invoker_spec.rb +0 -95
  198. data/spec/unit/invokers/literal_invoker_spec.rb +0 -86
  199. data/spec/unit/invokers/proc_invoker_spec.rb +0 -86
  200. data/spec/unit/localizer_spec.rb +0 -78
  201. data/spec/unit/memory_leak_spec.rb +0 -38
  202. data/spec/unit/multiple_transitions_that_differ_only_by_guard_spec.rb +0 -14
  203. data/spec/unit/namespaced_multiple_example_spec.rb +0 -75
  204. data/spec/unit/new_dsl_spec.rb +0 -12
  205. data/spec/unit/override_warning_spec.rb +0 -94
  206. data/spec/unit/persistence/active_record_persistence_multiple_spec.rb +0 -618
  207. data/spec/unit/persistence/active_record_persistence_spec.rb +0 -773
  208. data/spec/unit/persistence/dynamoid_persistence_multiple_spec.rb +0 -135
  209. data/spec/unit/persistence/dynamoid_persistence_spec.rb +0 -84
  210. data/spec/unit/persistence/mongoid_persistence_multiple_spec.rb +0 -200
  211. data/spec/unit/persistence/mongoid_persistence_spec.rb +0 -165
  212. data/spec/unit/persistence/no_brainer_persistence_multiple_spec.rb +0 -198
  213. data/spec/unit/persistence/no_brainer_persistence_spec.rb +0 -158
  214. data/spec/unit/persistence/redis_persistence_multiple_spec.rb +0 -88
  215. data/spec/unit/persistence/redis_persistence_spec.rb +0 -53
  216. data/spec/unit/persistence/sequel_persistence_multiple_spec.rb +0 -148
  217. data/spec/unit/persistence/sequel_persistence_spec.rb +0 -368
  218. data/spec/unit/readme_spec.rb +0 -41
  219. data/spec/unit/reloading_spec.rb +0 -15
  220. data/spec/unit/rspec_matcher_spec.rb +0 -88
  221. data/spec/unit/simple_custom_example_spec.rb +0 -39
  222. data/spec/unit/simple_example_spec.rb +0 -57
  223. data/spec/unit/simple_multiple_example_spec.rb +0 -91
  224. data/spec/unit/state_spec.rb +0 -89
  225. data/spec/unit/states_on_one_line_example_spec.rb +0 -16
  226. data/spec/unit/subclassing_multiple_spec.rb +0 -74
  227. data/spec/unit/subclassing_spec.rb +0 -46
  228. data/spec/unit/transition_spec.rb +0 -436
  229. data/test/minitest_helper.rb +0 -57
  230. 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,201 +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
- it "should return a select friendly array of states" do
170
- expect(FooMultiple.aasm(:left)).to respond_to(:states_for_select)
171
- expect(FooMultiple.aasm(:left).states_for_select).to eq(
172
- [['Open', 'open'], ['Closed', 'closed'], ['Final', 'final']]
173
- )
174
- end
175
- end
176
-
177
- describe 'aasm.from_states_for_state' do
178
- it "should return all from states for a state" do
179
- expect(ComplexExampleMultiple.aasm(:left)).to respond_to(:from_states_for_state)
180
- froms = ComplexExampleMultiple.aasm(:left).from_states_for_state(:active)
181
- [:pending, :passive, :suspended].each {|from| expect(froms).to include(from)}
182
- end
183
-
184
- it "should return from states for a state for a particular transition only" do
185
- froms = ComplexExampleMultiple.aasm(:left).from_states_for_state(:active, :transition => :left_unsuspend)
186
- [:suspended].each {|from| expect(froms).to include(from)}
187
- end
188
- end
189
-
190
- describe 'permitted events' do
191
- let(:foo) {FooMultiple.new}
192
-
193
- it 'work' do
194
- expect(foo.aasm(:left).events(:permitted => true)).to include(:close)
195
- expect(foo.aasm(:left).events(:permitted => true)).not_to include(:null)
196
-
197
- expect(foo.aasm(:right).events(:permitted => true)).to include(:yellow)
198
- expect(foo.aasm(:right).events(:permitted => true)).not_to include(:green)
199
- expect(foo.aasm(:right).events(:permitted => true)).not_to include(:red)
200
- end
201
- end
@@ -1,149 +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
- it "should return a select friendly array of states" do
106
- expect(Foo.aasm).to respond_to(:states_for_select)
107
- expect(Foo.aasm.states_for_select).to eq([['Open', 'open'], ['Closed', 'closed'], ['Final', 'final']])
108
- end
109
- end
110
-
111
- describe 'aasm.from_states_for_state' do
112
- it "should return all from states for a state" do
113
- expect(ComplexExample.aasm).to respond_to(:from_states_for_state)
114
- froms = ComplexExample.aasm.from_states_for_state(:active)
115
- [:pending, :passive, :suspended].each {|from| expect(froms).to include(from)}
116
- end
117
-
118
- it "should return from states for a state for a particular transition only" do
119
- froms = ComplexExample.aasm.from_states_for_state(:active, :transition => :unsuspend)
120
- [:suspended].each {|from| expect(froms).to include(from)}
121
- end
122
- end
123
-
124
- describe 'permitted events' do
125
- let(:foo) {Foo.new}
126
-
127
- it 'work' do
128
- expect(foo.aasm.events(:permitted => true)).to include(:close)
129
- expect(foo.aasm.events(:permitted => true)).not_to include(:null)
130
- end
131
-
132
- it 'should not include events in the reject option' do
133
- expect(foo.aasm.events(:permitted => true, reject: :close)).not_to include(:close)
134
- expect(foo.aasm.events(:permitted => true, reject: [:close])).not_to include(:close)
135
- end
136
- end
137
-
138
- describe 'not permitted events' do
139
- let(:foo) {Foo.new}
140
-
141
- it 'work' do
142
- expect(foo.aasm.events(:permitted => false)).to include(:null)
143
- expect(foo.aasm.events(:permitted => false)).not_to include(:close)
144
- end
145
-
146
- it 'should not include events in the reject option' do
147
- expect(foo.aasm.events(:permitted => false, reject: :null)).to eq([])
148
- end
149
- end
@@ -1,189 +0,0 @@
1
- require 'spec_helper'
2
-
3
- describe AASM::Core::Invoker do
4
- let(:target) { nil }
5
- let(:record) { double }
6
- let(:args) { [] }
7
-
8
- subject { described_class.new(target, record, args) }
9
-
10
- describe '#with_options' do
11
- context 'when passing array as a subject' do
12
- context 'and "guard" option is set to true' do
13
- let(:target) { [subject_1, subject_2] }
14
-
15
- before { subject.with_options(guard: true) }
16
-
17
- context 'and all the subjects are truthy' do
18
- let(:subject_1) { Proc.new { true } }
19
- let(:subject_2) { Proc.new { true } }
20
-
21
- it 'then returns "true" while invoking' do
22
- expect(subject.invoke).to eq(true)
23
- end
24
- end
25
-
26
- context 'and any subject is falsely' do
27
- let(:subject_1) { Proc.new { false } }
28
- let(:subject_2) { Proc.new { true } }
29
-
30
- it 'then returns "false" while invoking' do
31
- expect(subject.invoke).to eq(false)
32
- end
33
- end
34
- end
35
-
36
- context 'and "unless" option is set to true' do
37
- let(:target) { [subject_1, subject_2] }
38
-
39
- before { subject.with_options(unless: true) }
40
-
41
- context 'and all the subjects are falsely' do
42
- let(:subject_1) { Proc.new { false } }
43
- let(:subject_2) { Proc.new { false } }
44
-
45
- it 'then returns "true" while invoking' do
46
- expect(subject.invoke).to eq(true)
47
- end
48
- end
49
-
50
- context 'and any subject is truthy' do
51
- let(:subject_1) { Proc.new { false } }
52
- let(:subject_2) { Proc.new { true } }
53
-
54
- it 'then returns "false" while invoking' do
55
- expect(subject.invoke).to eq(false)
56
- end
57
- end
58
- end
59
- end
60
- end
61
-
62
- describe '#with_failures' do
63
- let(:concrete_invoker) { AASM::Core::Invokers::ProcInvoker }
64
- let(:target) { Proc.new {} }
65
-
66
- it 'then sets failures buffer for concrete invokers' do
67
- expect_any_instance_of(concrete_invoker)
68
- .to receive(:with_failures)
69
- .and_call_original
70
-
71
- subject.invoke
72
- end
73
- end
74
-
75
- describe '#with_default_return_value' do
76
- context 'when return value is "true"' do
77
- before { subject.with_default_return_value(true) }
78
-
79
- it 'then returns "true" when was not picked up by any invoker' do
80
- expect(subject.invoke).to eq(true)
81
- end
82
- end
83
-
84
- context 'when return value is "false"' do
85
- before { subject.with_default_return_value(false) }
86
-
87
- it 'then returns "false" when was not picked up by any invoker' do
88
- expect(subject.invoke).to eq(false)
89
- end
90
- end
91
- end
92
-
93
- describe '#invoke' do
94
- context 'when subject is a proc' do
95
- let(:concrete_invoker) { AASM::Core::Invokers::ProcInvoker }
96
- let(:target) { Proc.new {} }
97
-
98
- it 'then calls proc invoker' do
99
- expect_any_instance_of(concrete_invoker)
100
- .to receive(:invoke)
101
- .and_call_original
102
-
103
- expect(record).to receive(:instance_exec)
104
-
105
- subject.invoke
106
- end
107
- end
108
-
109
- context 'when subject is a class' do
110
- let(:concrete_invoker) { AASM::Core::Invokers::ClassInvoker }
111
- let(:target) { Class.new { def call; end } }
112
-
113
- it 'then calls proc invoker' do
114
- expect_any_instance_of(concrete_invoker)
115
- .to receive(:invoke)
116
- .and_call_original
117
-
118
- expect_any_instance_of(target).to receive(:call)
119
-
120
- subject.invoke
121
- end
122
- end
123
-
124
- context 'when subject is a literal' do
125
- let(:concrete_invoker) { AASM::Core::Invokers::LiteralInvoker }
126
- let(:record) { double(invoke_me: nil) }
127
- let(:target) { :invoke_me }
128
-
129
- it 'then calls literal invoker' do
130
- expect_any_instance_of(concrete_invoker)
131
- .to receive(:invoke)
132
- .and_call_original
133
-
134
- expect(record).to receive(:invoke_me)
135
-
136
- subject.invoke
137
- end
138
- end
139
-
140
- context 'when subject is an array of procs' do
141
- let(:subject_1) { Proc.new {} }
142
- let(:subject_2) { Proc.new {} }
143
- let(:target) { [subject_1, subject_2] }
144
-
145
- it 'then calls each proc' do
146
- expect(record).to receive(:instance_exec).twice
147
-
148
- subject.invoke
149
- end
150
- end
151
-
152
- context 'when subject is an array of classes' do
153
- let(:subject_1) { Class.new { def call; end } }
154
- let(:subject_2) { Class.new { def call; end } }
155
- let(:target) { [subject_1, subject_2] }
156
-
157
- it 'then calls each class' do
158
- expect_any_instance_of(subject_1).to receive(:call)
159
-
160
- expect_any_instance_of(subject_2).to receive(:call)
161
-
162
- subject.invoke
163
- end
164
- end
165
-
166
- context 'when subject is an array of literals' do
167
- let(:subject_1) { :method_one }
168
- let(:subject_2) { :method_two }
169
- let(:record) { double(method_one: nil, method_two: nil) }
170
- let(:target) { [subject_1, subject_2] }
171
-
172
- it 'then calls each class' do
173
- expect(record).to receive(:method_one)
174
-
175
- expect(record).to receive(:method_two)
176
-
177
- subject.invoke
178
- end
179
- end
180
-
181
- context 'when subject is not supported' do
182
- let(:target) { nil }
183
-
184
- it 'then just returns default value' do
185
- expect(subject.invoke).to eq(described_class::DEFAULT_RETURN_VALUE)
186
- end
187
- end
188
- end
189
- end