/
states_test.rb
148 lines (112 loc) · 4.49 KB
/
states_test.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
require 'test_helper'
require 'active_support/core_ext/time/zones'
class StatesTest < Test::Unit::TestCase
include ClassCreateHelper
test "assumes :created as default initial state" do
object = create_class.new
assert_equal :created, object.state
assert object.created?
end
test "uses a custom initial state" do
object = create_class { states :initial => :started }.new
assert_equal :started, object.state
assert object.started?
end
test "tries to look up a target state from the states list unless given as a :to option" do
object = create_class { states :started; event :start }.new
object.start
assert object.state?(:started)
end
test "raises TransitionException if no :to option is given and the state can not be derived from the states list" do
object = create_class { event :start }.new
assert_raises(SimpleStates::TransitionException) { object.start }
end
test "doesn't raise TransitionException if the state is persisted as a string" do
klass = create_class { states :created, :started; event :start, :from => :created, :to => :started }
klass.class_eval { def state=(state); @state = state.to_s; end }
object = klass.new
assert_nothing_raised(SimpleStates::TransitionException) { object.start }
end
test "state? returns true if the object has the given state" do
object = create_class { event :start, :from => :created, :to => :started }.new
assert object.state?(:created)
assert !object.state?(:started)
object.start
assert !object.state?(:created)
assert object.state?(:created, true)
assert object.state?(:started)
end
test "was_state? returns true if the object has or ever had the given state" do
object = create_class { event :start, :from => :created, :to => :started }.new
assert object.was_state?(:created)
assert !object.was_state?(:started)
object.start
assert object.was_state?(:created)
assert object.was_state?(:started)
end
test "responds to [state]? if the class defines this state" do
object = create_class { states :started }.new
assert object.respond_to?(:created?)
assert object.respond_to?(:started?)
assert !object.respond_to?(:finished?)
end
test "[state]? predicates" do
object = create_class { event :start, :from => :created, :to => :started }.new
assert object.created?
assert !object.started?
object.start
assert !object.created?
assert object.created?(true)
assert object.started?
end
test "was_[state]? predicates" do
object = create_class { event :start, :from => :created, :to => :started }.new
assert object.was_created?
assert !object.was_started?
object.start
assert object.was_created?
assert object.was_started?
end
test "[state]_at is set if a writer is defined" do
now = Time.now.tap { |now| Time.stubs(:now).returns(now) }
object = create_class { event :start, :from => :created, :to => :started }.new
object.singleton_class.send(:attr_accessor, :started_at)
object.start
assert_equal now, object.started_at
end
# test "set_state sets the state manually" do
# object = create_class { states :mockiewocked }.new
# object.set_state(:mockiewocked)
# assert object.mockiewocked?
# end
test "merge_events (:all first)" do
klass = create_class do
event :all, :before => :notify
event :start, :to => :started, :before => :prepare
event :finish, :to => :finished, :before => :cleanup
end
first, second = SimpleStates::States.new(klass.events).events
assert_equal [:notify, :prepare], first.options[:before]
assert_equal [:notify, :cleanup], second.options[:before]
end
test "merge_events (:all second)" do
klass = create_class do
event :start, :to => :started, :before => :prepare
event :all, :before => :notify
event :finish, :to => :finished, :before => :cleanup
end
first, second = SimpleStates::States.new(klass.events).events
assert_equal [:prepare, :notify], first.options[:before]
assert_equal [:notify, :cleanup], second.options[:before]
end
test "merge_events (:all last)" do
klass = create_class do
event :start, :to => :started, :before => :prepare
event :finish, :to => :finished, :before => :cleanup
event :all, :before => :notify
end
first, second = SimpleStates::States.new(klass.events).events
assert_equal [:prepare, :notify], first.options[:before]
assert_equal [:cleanup, :notify], second.options[:before]
end
end