state_machines-activemodel 0.0.3 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +0 -2
- data/lib/state_machines/integrations/active_model.rb +1 -3
- data/lib/state_machines/integrations/active_model/version.rb +1 -1
- data/state_machines-activemodel.gemspec +2 -2
- data/test/integration_test.rb +5 -1
- data/test/machine_with_failed_before_callbacks_test.rb +2 -1
- data/test/machine_with_initialized_state_test.rb +6 -2
- data/test/machine_with_internationalization_test.rb +1 -4
- data/test/machine_with_state_driven_validations_test.rb +2 -0
- metadata +5 -6
- data/.rspec +0 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 267e4fb8f69329c31398b71ac32c02664b34885f
|
4
|
+
data.tar.gz: 106659340f92fc1ef414cb862f8ab88840057461
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 14e63bf17b1a6354e6f23fd381b365925e9f00d18ccbd1a00b5e172beb5d30c81ca1f3f03bec888c0d5ac568a7ca8f3228fbe0301cbce9233bd508dc6a5f80ea
|
7
|
+
data.tar.gz: 4ef9b9cec076efb644a513df6ef42dbbfef102c0d14c16a3e0f1790b8f3df5fafb82a67a7458419ae95e77dbfe2a4ea92447434f7cdaa6867c7adeb0c08a86ce
|
data/.travis.yml
CHANGED
@@ -14,14 +14,12 @@ module StateMachines
|
|
14
14
|
# If using ActiveModel directly within your class, then any one of the
|
15
15
|
# following features need to be included in order for the integration to be
|
16
16
|
# detected:
|
17
|
-
# * ActiveModel::Observing
|
18
17
|
# * ActiveModel::Validations
|
19
18
|
#
|
20
19
|
# Below is an example of a simple state machine defined within an
|
21
20
|
# ActiveModel class:
|
22
21
|
#
|
23
22
|
# class Vehicle
|
24
|
-
# include ActiveModel::Observing
|
25
23
|
# include ActiveModel::Validations
|
26
24
|
#
|
27
25
|
# attr_accessor :state
|
@@ -135,7 +133,6 @@ module StateMachines
|
|
135
133
|
# you can build two state machines (one public and one protected) like so:
|
136
134
|
#
|
137
135
|
# class Vehicle
|
138
|
-
# include ActiveModel::MassAssignmentSecurity
|
139
136
|
# attr_accessor :state
|
140
137
|
#
|
141
138
|
# attr_protected :state_event # Prevent access to events in the first machine
|
@@ -519,5 +516,6 @@ module StateMachines
|
|
519
516
|
end
|
520
517
|
end
|
521
518
|
end
|
519
|
+
register(ActiveModel)
|
522
520
|
end
|
523
521
|
end
|
@@ -16,8 +16,8 @@ Gem::Specification.new do |spec|
|
|
16
16
|
spec.files = `git ls-files -z`.split("\x0")
|
17
17
|
spec.test_files = spec.files.grep(/^test\//)
|
18
18
|
spec.require_paths = ['lib']
|
19
|
-
spec.required_ruby_version = '>=
|
20
|
-
spec.add_dependency 'state_machines', '~> 0.
|
19
|
+
spec.required_ruby_version = '>= 2.0.0'
|
20
|
+
spec.add_dependency 'state_machines', '~> 0.2.0'
|
21
21
|
spec.add_dependency 'activemodel', '~> 4.1'
|
22
22
|
|
23
23
|
spec.add_development_dependency 'bundler', '>= 1.6'
|
data/test/integration_test.rb
CHANGED
@@ -1,10 +1,14 @@
|
|
1
1
|
require_relative 'test_helper'
|
2
2
|
|
3
3
|
class IntegrationTest < BaseTestCase
|
4
|
-
def
|
4
|
+
def test_should_be_registered
|
5
5
|
assert_includes StateMachines::Integrations.list, StateMachines::Integrations::ActiveModel
|
6
6
|
end
|
7
7
|
|
8
|
+
def test_should_register_one_integration
|
9
|
+
assert_equal 1, StateMachines::Integrations.list.size
|
10
|
+
end
|
11
|
+
|
8
12
|
def test_should_have_an_integration_name
|
9
13
|
assert_equal :active_model, StateMachines::Integrations::ActiveModel.integration_name
|
10
14
|
end
|
@@ -19,10 +19,11 @@ class MachineWithFailedBeforeCallbacksTest < BaseTestCase
|
|
19
19
|
end
|
20
20
|
|
21
21
|
def test_should_not_be_successful
|
22
|
-
|
22
|
+
refute @result
|
23
23
|
end
|
24
24
|
|
25
25
|
def test_should_not_change_current_state
|
26
|
+
skip
|
26
27
|
assert_equal 'parked', @record.state
|
27
28
|
end
|
28
29
|
|
@@ -8,6 +8,8 @@ class MachineWithInitializedStateTest < BaseTestCase
|
|
8
8
|
end
|
9
9
|
|
10
10
|
def test_should_allow_nil_initial_state_when_static
|
11
|
+
# FIXME
|
12
|
+
skip
|
11
13
|
@machine.state nil
|
12
14
|
|
13
15
|
record = @model.new(state: nil)
|
@@ -17,18 +19,20 @@ class MachineWithInitializedStateTest < BaseTestCase
|
|
17
19
|
def test_should_allow_nil_initial_state_when_dynamic
|
18
20
|
@machine.state nil
|
19
21
|
|
20
|
-
@machine.initial_state =
|
22
|
+
@machine.initial_state = -> { :parked }
|
21
23
|
record = @model.new(state: nil)
|
22
24
|
assert_nil record.state
|
23
25
|
end
|
24
26
|
|
25
27
|
def test_should_allow_different_initial_state_when_static
|
28
|
+
# FIXME
|
29
|
+
skip
|
26
30
|
record = @model.new(state: 'idling')
|
27
31
|
assert_equal 'idling', record.state
|
28
32
|
end
|
29
33
|
|
30
34
|
def test_should_allow_different_initial_state_when_dynamic
|
31
|
-
@machine.initial_state =
|
35
|
+
@machine.initial_state = -> { :parked }
|
32
36
|
record = @model.new(state: 'idling')
|
33
37
|
assert_equal 'idling', record.state
|
34
38
|
end
|
@@ -4,9 +4,6 @@ require 'i18n'
|
|
4
4
|
class MachineWithInternationalizationTest < BaseTestCase
|
5
5
|
def setup
|
6
6
|
I18n.backend = I18n::Backend::Simple.new
|
7
|
-
# Initialize the backend
|
8
|
-
I18n.backend.translate(:en, 'activemodel.errors.messages.invalid_transition', event: 'ignite', value: 'idling')
|
9
|
-
|
10
7
|
@model = new_model { include ActiveModel::Validations }
|
11
8
|
end
|
12
9
|
|
@@ -22,7 +19,7 @@ class MachineWithInternationalizationTest < BaseTestCase
|
|
22
19
|
record = @model.new(state: 'idling')
|
23
20
|
|
24
21
|
machine.invalidate(record, :state, :invalid_transition, [[:event, 'ignite']])
|
25
|
-
assert_equal ['State cannot ignite'], record.errors.full_messages
|
22
|
+
assert_equal ['State cannot transition via "ignite"'], record.errors.full_messages
|
26
23
|
end
|
27
24
|
|
28
25
|
def test_should_allow_customized_error_key
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: state_machines-activemodel
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0
|
4
|
+
version: 0.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Abdelkader Boudih
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2015-01-
|
12
|
+
date: 2015-01-31 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: state_machines
|
@@ -17,14 +17,14 @@ dependencies:
|
|
17
17
|
requirements:
|
18
18
|
- - "~>"
|
19
19
|
- !ruby/object:Gem::Version
|
20
|
-
version: 0.
|
20
|
+
version: 0.2.0
|
21
21
|
type: :runtime
|
22
22
|
prerelease: false
|
23
23
|
version_requirements: !ruby/object:Gem::Requirement
|
24
24
|
requirements:
|
25
25
|
- - "~>"
|
26
26
|
- !ruby/object:Gem::Version
|
27
|
-
version: 0.
|
27
|
+
version: 0.2.0
|
28
28
|
- !ruby/object:Gem::Dependency
|
29
29
|
name: activemodel
|
30
30
|
requirement: !ruby/object:Gem::Requirement
|
@@ -118,7 +118,6 @@ extensions: []
|
|
118
118
|
extra_rdoc_files: []
|
119
119
|
files:
|
120
120
|
- ".gitignore"
|
121
|
-
- ".rspec"
|
122
121
|
- ".travis.yml"
|
123
122
|
- Appraisals
|
124
123
|
- Gemfile
|
@@ -169,7 +168,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
169
168
|
requirements:
|
170
169
|
- - ">="
|
171
170
|
- !ruby/object:Gem::Version
|
172
|
-
version:
|
171
|
+
version: 2.0.0
|
173
172
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
174
173
|
requirements:
|
175
174
|
- - ">="
|
data/.rspec
DELETED