memory_model 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (46) hide show
  1. data/.gitignore +17 -0
  2. data/.rspec +2 -0
  3. data/.travis.yml +6 -0
  4. data/Gemfile +4 -0
  5. data/Guardfile +5 -0
  6. data/LICENSE.txt +22 -0
  7. data/README.md +31 -0
  8. data/Rakefile +1 -0
  9. data/lib/concerned_inheritance/class_methods.rb +28 -0
  10. data/lib/concerned_inheritance/delegator.rb +21 -0
  11. data/lib/concerned_inheritance/module_methods.rb +11 -0
  12. data/lib/concerned_inheritance.rb +27 -0
  13. data/lib/memory_model/base/actionable.rb +95 -0
  14. data/lib/memory_model/base/attributable.rb +76 -0
  15. data/lib/memory_model/base/collectable.rb +22 -0
  16. data/lib/memory_model/base/comparable.rb +16 -0
  17. data/lib/memory_model/base/fieldable/field.rb +35 -0
  18. data/lib/memory_model/base/fieldable/field_set.rb +74 -0
  19. data/lib/memory_model/base/fieldable.rb +45 -0
  20. data/lib/memory_model/base/persistence.rb +15 -0
  21. data/lib/memory_model/base/versionable.rb +17 -0
  22. data/lib/memory_model/base.rb +51 -0
  23. data/lib/memory_model/collection.rb +80 -0
  24. data/lib/memory_model/core_ext/object.rb +5 -0
  25. data/lib/memory_model/version.rb +3 -0
  26. data/lib/memory_model.rb +13 -0
  27. data/memory_model.gemspec +30 -0
  28. data/spec/concerned_inheritance/class_methods_spec.rb +57 -0
  29. data/spec/concerned_inheritance/delegator_spec.rb +52 -0
  30. data/spec/concerned_inheritance/module_methods_spec.rb +27 -0
  31. data/spec/memory_model/base/actionable_spec.rb +359 -0
  32. data/spec/memory_model/base/attributable_spec.rb +143 -0
  33. data/spec/memory_model/base/collectable_spec.rb +24 -0
  34. data/spec/memory_model/base/comparable_spec.rb +155 -0
  35. data/spec/memory_model/base/fieldable/field_set_spec.rb +160 -0
  36. data/spec/memory_model/base/fieldable/field_spec.rb +96 -0
  37. data/spec/memory_model/base/fieldable_spec.rb +23 -0
  38. data/spec/memory_model/base/persistence_spec.rb +37 -0
  39. data/spec/memory_model/base/versionable_spec.rb +31 -0
  40. data/spec/memory_model/base_spec.rb +52 -0
  41. data/spec/memory_model/collection_spec.rb +216 -0
  42. data/spec/memory_model/concerned_inheritance_spec.rb +24 -0
  43. data/spec/memory_model/core_ext/object_spec.rb +12 -0
  44. data/spec/spec_helper.rb +12 -0
  45. data/spec/support/active_model_lint.rb +16 -0
  46. metadata +253 -0
@@ -0,0 +1,143 @@
1
+ require 'spec_helper'
2
+
3
+ describe MemoryModel::Base::Attributable do
4
+
5
+ let(:model) do
6
+ Class.new(MemoryModel::Base) do
7
+ field :foo
8
+ field :bar
9
+ end
10
+ end
11
+ let(:instance) do
12
+ model.new
13
+ end
14
+
15
+ describe '#any_field_name' do
16
+ it 'should read an attribute' do
17
+ instance.write_attribute :foo, "bar"
18
+ instance.foo.should == "bar"
19
+ end
20
+ end
21
+
22
+ describe '#any_field_name=' do
23
+ it 'should read an attribute' do
24
+ instance.foo= "bar"
25
+ instance.read_attribute(:foo).should == "bar"
26
+ end
27
+ end
28
+
29
+ describe '#has_attribute?' do
30
+ context 'given nil' do
31
+ it 'should be false' do
32
+ instance.foo = nil
33
+ instance.has_attribute?(:foo).should be_false
34
+ end
35
+ end
36
+
37
+ context 'given an empty string' do
38
+ it 'should be true' do
39
+ instance.foo = ''
40
+ instance.has_attribute?(:foo).should be_true
41
+ end
42
+ end
43
+
44
+ context 'given a Hash' do
45
+ it 'should be true' do
46
+ instance.foo = { foo: :bar }
47
+ instance.has_attribute?(:foo).should be_true
48
+ end
49
+ end
50
+
51
+ context 'given an emtpy Hash' do
52
+ it 'should be true' do
53
+ instance.foo = {}
54
+ instance.has_attribute?(:foo).should be_false
55
+ end
56
+ end
57
+ end
58
+
59
+ describe '#inspect' do
60
+ it 'inspect into a readable format' do
61
+ instance.inspect.should match /#<#{instance.class}/
62
+ end
63
+
64
+ it 'should contain the attributes' do
65
+ instance.attributes.each do |name, value|
66
+ value = instance.send :attribute_for_inspect, name
67
+ instance.inspect.should include "#{name}: #{value}" if instance.has_attribute? name
68
+ end
69
+ end
70
+
71
+ it 'should read not initialized' do
72
+ model.allocate.inspect.should match /not initialized/
73
+ end
74
+ end
75
+
76
+ describe '#read_attribute' do
77
+ it 'should return a value' do
78
+ instance.write_attribute(:foo, "bar")
79
+ instance.read_attribute(:foo).should == 'bar'
80
+ end
81
+
82
+ it "should return nil if the key doesn't exist" do
83
+ instance.read_attribute(:bar).should be_nil
84
+ end
85
+ end
86
+
87
+ describe '#write_attribute' do
88
+ it 'should raise an error with an invalid field' do
89
+ expect { instance.write_attribute(:baz, 'razzle') }.to raise_error MemoryModel::InvalidFieldError
90
+ end
91
+ end
92
+
93
+ describe '#attribute_for_inspect' do
94
+ it 'truncates values over 50 chars' do
95
+ value = instance.foo = 'barbarbarbarbarbarbarbarbarbarbarbarbarbarbarbarbarbar'
96
+ instance.send(:attribute_for_inspect, :foo).should_not == value.inspect
97
+ end
98
+
99
+ it 'should convert a time to string' do
100
+ instance.foo = Time.now
101
+ instance.send(:attribute_for_inspect, :foo).should be_a String
102
+ end
103
+
104
+ it 'should convert a date to string' do
105
+ instance.foo = Date.today
106
+ instance.send(:attribute_for_inspect, :foo).should be_a String
107
+ end
108
+
109
+ it 'inspects objects' do
110
+ value = instance.foo = 'bar'
111
+ instance.send(:attribute_for_inspect, :foo).should == value.inspect
112
+ end
113
+ end
114
+
115
+ describe '#reset_attribute_to_default' do
116
+ let(:model) do
117
+ Class.new(MemoryModel::Base) do
118
+ field :foo, default: 'bar'
119
+ end
120
+ end
121
+ it 'should reset an attribute to its default value' do
122
+ instance.foo = 'baz'
123
+ instance.foo.should == 'baz'
124
+ instance.reset_foo_to_default!
125
+ instance.foo.should == 'bar'
126
+ end
127
+ end
128
+
129
+ describe '#clear_attribute' do
130
+ let(:model) do
131
+ Class.new(MemoryModel::Base) do
132
+ field :foo
133
+ end
134
+ end
135
+ it 'should reset an attribute to its default value' do
136
+ instance.foo = 'baz'
137
+ instance.foo.should == 'baz'
138
+ instance.clear_foo
139
+ instance.foo.should be_nil
140
+ end
141
+ end
142
+
143
+ end
@@ -0,0 +1,24 @@
1
+ require 'spec_helper'
2
+
3
+ describe MemoryModel::Base::Collectable do
4
+
5
+ let(:model) do
6
+ Class.new(MemoryModel::Base) do
7
+ field :foo
8
+ field :bar
9
+ end
10
+ end
11
+
12
+ describe '.collection' do
13
+ it 'should be a collection' do
14
+ model.collection.should be_a MemoryModel::Collection
15
+ end
16
+ end
17
+
18
+ describe '.inherited' do
19
+ it 'should use its parents collection' do
20
+ Class.new(model).collection.should == model.collection
21
+ end
22
+ end
23
+
24
+ end
@@ -0,0 +1,155 @@
1
+ require 'spec_helper'
2
+
3
+ describe MemoryModel::Base::Comparable do
4
+ let(:model) do
5
+ Class.new(MemoryModel::Base) do
6
+ field :foo
7
+ end
8
+ end
9
+ let(:value) { 'bar' }
10
+ subject(:instance) { model.new(foo: value) }
11
+
12
+ describe '#!=' do
13
+ context 'given a symbolized hash' do
14
+ let(:valid_hash) { { 'foo' => value } }
15
+ let(:invalid_hash) { { 'foo' => 'baz' } }
16
+ it 'should return true when given a valid hash' do
17
+ (instance != valid_hash).should be_false
18
+ end
19
+
20
+ it 'should return false when given a invalid hash' do
21
+ (instance != invalid_hash).should be_true
22
+ end
23
+ end
24
+
25
+ context 'given a symbolized hash' do
26
+ let(:valid_hash) { { foo: value } }
27
+ let(:invalid_hash) { { foo: 'baz' } }
28
+ it 'should return true when given a valid hash' do
29
+ (instance != valid_hash).should be_false
30
+ end
31
+
32
+ it 'should return false when given a invalid hash' do
33
+ (instance != invalid_hash).should be_true
34
+ end
35
+ end
36
+
37
+ context 'given an instance of the same class' do
38
+ let(:valid_instance) { model.new(foo: value) }
39
+ let(:invalid_instance) { model.new(foo: 'baz') }
40
+ it 'should be true when given a valid instance' do
41
+ (instance != valid_instance).should be_false
42
+ end
43
+
44
+ it 'should be false when given a invalid instance' do
45
+ (instance != invalid_instance).should be_true
46
+ end
47
+ end
48
+
49
+ context 'given an instance of a different class' do
50
+ let(:other_class) { Class.new(MemoryModel::Base) }
51
+ let(:valid_instance) { other_class.new(foo: value) }
52
+ let(:invalid_instance) { other_class.new(foo: 'baz') }
53
+ it 'should be true when given a valid instance' do
54
+ (instance != valid_instance).should be_false
55
+ end
56
+
57
+ it 'should be false when given a invalid instance' do
58
+ (instance != invalid_instance).should be_true
59
+ end
60
+ end
61
+ end
62
+
63
+ describe '#==' do
64
+ context 'given a symbolized hash' do
65
+ let(:valid_hash) { { 'foo' => value } }
66
+ let(:invalid_hash) { { 'foo' => 'baz' } }
67
+ it 'should return true when given a valid hash' do
68
+ (instance == valid_hash).should be_true
69
+ end
70
+
71
+ it 'should return false when given a invalid hash' do
72
+ (instance == invalid_hash).should be_false
73
+ end
74
+ end
75
+
76
+ context 'given a symbolized hash' do
77
+ let(:valid_hash) { { foo: value } }
78
+ let(:invalid_hash) { { foo: 'baz' } }
79
+ it 'should return true when given a valid hash' do
80
+ (instance == valid_hash).should be_true
81
+ end
82
+
83
+ it 'should return false when given a invalid hash' do
84
+ (instance == invalid_hash).should be_false
85
+ end
86
+ end
87
+
88
+ context 'given an instance of the same class' do
89
+ let(:valid_instance) { model.new(foo: value) }
90
+ let(:invalid_instance) { model.new(foo: 'baz') }
91
+ it 'should be true when given a valid instance' do
92
+ (instance == valid_instance).should be_true
93
+ end
94
+
95
+ it 'should be false when given a invalid instance' do
96
+ (instance == invalid_instance).should be_false
97
+ end
98
+ end
99
+
100
+ context 'given an instance of a different class' do
101
+ let(:other_class) { Class.new(MemoryModel::Base) }
102
+ let(:valid_instance) { other_class.new(foo: value) }
103
+ let(:invalid_instance) { other_class.new(foo: 'baz') }
104
+ it 'should be true when given a valid instance' do
105
+ (instance == valid_instance).should be_true
106
+ end
107
+
108
+ it 'should be false when given a invalid instance' do
109
+ (instance == invalid_instance).should be_false
110
+ end
111
+ end
112
+ end
113
+
114
+ describe '#===' do
115
+ context 'given a hash' do
116
+ it 'should return false' do
117
+ hash = { foo: value }
118
+ (instance === hash).should be_false
119
+ end
120
+ end
121
+
122
+ context 'given an instance of the same class' do
123
+ let(:valid_instance) { model.new(foo: value) }
124
+ let(:invalid_instance) { model.new(foo: 'baz') }
125
+ it 'should be true when given a valid instance' do
126
+ (instance === valid_instance).should be_true
127
+ end
128
+
129
+ it 'should be false when given a invalid instance' do
130
+ (instance === invalid_instance).should be_false
131
+ end
132
+ end
133
+
134
+ context 'given an instance of an inherited class' do
135
+ let(:inherited_model) { Class.new(model) }
136
+ let(:valid_instance) { inherited_model.new(foo: value) }
137
+ let(:invalid_instance) { inherited_model.new(foo: 'baz') }
138
+ it 'should be true when given a valid instance' do
139
+ (instance === valid_instance).should be_true
140
+ end
141
+
142
+ it 'should be false when given a invalid instance' do
143
+ (instance === invalid_instance).should be_false
144
+ end
145
+ end
146
+
147
+ context 'given an instance of a different class' do
148
+ let(:other_class) { Class.new(MemoryModel::Base) }
149
+ let(:other_instance) { other_class.new(foo: value) }
150
+ it 'should be false' do
151
+ (instance === other_instance).should be_false
152
+ end
153
+ end
154
+ end
155
+ end
@@ -0,0 +1,160 @@
1
+ require 'spec_helper'
2
+
3
+ describe MemoryModel::Base::Fieldable::FieldSet do
4
+
5
+ let(:klass) { MemoryModel::Base::Fieldable::FieldSet }
6
+ subject(:field_set) { klass.new }
7
+
8
+ describe '.new' do
9
+ it "should have an empty array of fields" do
10
+ field_set.instance_variable_get(:@fields).should be_a Array
11
+ field_set.size.should == 0
12
+ end
13
+ end
14
+
15
+ describe '#[]' do
16
+ it "should return a field" do
17
+ field_set.add(:foo)
18
+ field_set[:foo].should be_present
19
+ field_set[:foo].name.should == :foo
20
+ end
21
+ end
22
+
23
+ describe '#<<' do
24
+ it 'should add a field with the symbol' do
25
+ expect { field_set << :foo }.to change { field_set.fields }
26
+ end
27
+ end
28
+
29
+ describe '#add' do
30
+ it "should add a field" do
31
+ expect { field_set.add(:foo) }.to change { field_set.fields }
32
+ end
33
+
34
+ it "should add a field with options" do
35
+ options = { foo: :bar }
36
+ expect { field_set.add(:foo, options) }.to change { field_set.fields }
37
+ field_set[:foo].options[:foo].should == :bar
38
+ end
39
+ end
40
+
41
+ describe '#comparable' do
42
+ it 'should only return comparable fields' do
43
+ field_set.add(:foo, comparable: true)
44
+ field_set.add(:bar, comparable: false)
45
+ field_set.comparable.each do |field|
46
+ field_set[field].should be_comparable
47
+ end
48
+ end
49
+ end
50
+
51
+ describe '#inspect' do
52
+ it 'should delegate inspect to #to_a' do
53
+ names_mock = mock
54
+ names_mock.should_receive(:inspect)
55
+ field_set.stub(:to_a).and_return(names_mock)
56
+ field_set.inspect
57
+ end
58
+ end
59
+
60
+ describe '#default_values' do
61
+ let(:mock_model) { mock }
62
+
63
+ context 'with a symbol' do
64
+ it 'should call the method on the model' do
65
+ mock_model.should_receive :foo_val
66
+ field_set.add :foo, default: :foo_val
67
+ field_set.default_values(mock_model)
68
+ end
69
+ end
70
+
71
+ context 'with a string' do
72
+ it 'should set the string' do
73
+ field_set.add :foo, default: 'foo_val'
74
+ defaults = field_set.default_values(mock_model)
75
+ defaults[:foo].should == 'foo_val'
76
+ end
77
+ end
78
+
79
+ context 'with a lambda with an arity of 0' do
80
+ it 'should evaluate the block' do
81
+ field_set.add :foo, default: -> { 5 + 5 }
82
+ field_set.default_values(mock_model)[:foo].should == 10
83
+ end
84
+ end
85
+
86
+ context 'with a lambda with an arity of 1' do
87
+ it 'should evaluate the block' do
88
+ mock_model.should_receive :foo_val
89
+ field_set.add :foo, default: ->(model) { model.foo_val }
90
+ field_set.default_values(mock_model)
91
+ end
92
+ end
93
+
94
+ context 'with a lambda with an arity of 2' do
95
+ it 'should raise an error' do
96
+ field_set.add :foo, default: ->(model, other_var) { nil }
97
+ expect { field_set.default_values(mock_model) }.to raise_error ArgumentError
98
+ end
99
+ end
100
+
101
+ context 'with a proc with an arity of 0' do
102
+ it 'should evaluate the block' do
103
+ mock_model.should_receive :foo_val
104
+ field_set.add :foo, default: proc { foo_val }
105
+ field_set.default_values(mock_model)
106
+ end
107
+ end
108
+
109
+ context 'with a proc with an arity of 1' do
110
+ it 'should evaluate the block' do
111
+ mock_model.should_receive :foo_val
112
+ field_set.add :foo, default: proc { |model| model.foo_val }
113
+ field_set.default_values(mock_model)
114
+ end
115
+ end
116
+
117
+ context 'with a proc with an arity of 2' do
118
+ it 'should raise an error' do
119
+ field_set.add :foo, default: proc { |model, other_var| model.foo_val }
120
+ expect { field_set.default_values(mock_model) }.to raise_error ArgumentError
121
+ end
122
+ end
123
+
124
+ context 'with a nil value' do
125
+ it 'should return nil' do
126
+ field_set.add :foo
127
+ field_set.default_values(mock_model)[:foo].should be_nil
128
+ end
129
+ end
130
+
131
+ context 'when an invalid object' do
132
+ it 'should raise an error' do
133
+ field_set.add :foo, default: Object.new
134
+ expect { field_set.default_values(mock_model) }.to raise_error ArgumentError
135
+ end
136
+ end
137
+ end
138
+
139
+ describe '#to_a' do
140
+ it 'should return a list of names' do
141
+ field_set.add(:foo, comparable: true)
142
+ field_set.add(:bar, comparable: false)
143
+ field_set.to_a.should include :foo, :bar
144
+ end
145
+ end
146
+
147
+ describe '#method_missing' do
148
+ it 'should delegate off to #to_a' do
149
+ mock_array = mock
150
+ mock_array.should_receive :fubar
151
+ field_set.stub(:to_a).and_return(mock_array)
152
+ field_set.fubar
153
+ end
154
+
155
+ it 'should raise an error' do
156
+ expect { field_set.fubar }.to raise_error NoMethodError
157
+ end
158
+ end
159
+
160
+ end
@@ -0,0 +1,96 @@
1
+ require 'spec_helper'
2
+
3
+ describe MemoryModel::Base::Fieldable::Field do
4
+
5
+ subject(:field) { MemoryModel::Base::Fieldable::Field.new(:foo) }
6
+
7
+ describe '.new' do
8
+ it 'should not raise an error' do
9
+ expect { MemoryModel::Base::Fieldable::Field.new(:foo) }.to_not raise_error
10
+ end
11
+
12
+ it 'should have default options' do
13
+ field = MemoryModel::Base::Fieldable::Field.new(:foo)
14
+ field.options.should be_present
15
+ end
16
+
17
+ it 'should set_options' do
18
+ field = MemoryModel::Base::Fieldable::Field.new(:foo, bar: :baz)
19
+ field.options[:bar].should == :baz
20
+ end
21
+ end
22
+
23
+ describe '#==' do
24
+ context 'given a field' do
25
+ it 'should be equal to an object with the same name' do
26
+ field_a = MemoryModel::Base::Fieldable::Field.new(:foo, comparable: true)
27
+ field_b = MemoryModel::Base::Fieldable::Field.new(:foo, comparable: false)
28
+ (field_a == field_b).should be_true
29
+ end
30
+
31
+ it 'should not be equal to an object with a different name' do
32
+ field_a = MemoryModel::Base::Fieldable::Field.new(:foo)
33
+ field_b = MemoryModel::Base::Fieldable::Field.new(:bar)
34
+ (field_a == field_b).should be_false
35
+ end
36
+ end
37
+
38
+ context 'given a symbol' do
39
+ it 'should be equal to an object with the same name' do
40
+ field_a = MemoryModel::Base::Fieldable::Field.new(:foo, comparable: true)
41
+ field_b = :foo
42
+ (field_a == field_b).should be_true
43
+ end
44
+
45
+ it 'should not be equal to an object with a different name' do
46
+ field_a = MemoryModel::Base::Fieldable::Field.new(:foo)
47
+ field_b = :bar
48
+ (field_a == field_b).should be_false
49
+ end
50
+ end
51
+ end
52
+
53
+ describe '#comparable?' do
54
+ it 'should return true' do
55
+ field = MemoryModel::Base::Fieldable::Field.new(:foo, comparable: true)
56
+ field.comparable?.should be_true
57
+ end
58
+
59
+ it 'should return false' do
60
+ field = MemoryModel::Base::Fieldable::Field.new(:foo, comparable: false)
61
+ field.comparable?.should be_false
62
+ end
63
+ end
64
+
65
+ describe '#default' do
66
+ it 'should return the default value' do
67
+ field = MemoryModel::Base::Fieldable::Field.new(:foo, default: 'foo')
68
+ field.default.should == 'foo'
69
+ end
70
+ end
71
+
72
+ describe '#readonly?' do
73
+ it 'should return true' do
74
+ field = MemoryModel::Base::Fieldable::Field.new(:foo, readonly: true)
75
+ field.readonly?.should be_true
76
+ end
77
+
78
+ it 'should return false' do
79
+ field = MemoryModel::Base::Fieldable::Field.new(:foo, readonly: false)
80
+ field.readonly?.should be_false
81
+ end
82
+ end
83
+
84
+ describe '#to_sym' do
85
+ it 'should be the symbolized name' do
86
+ field.to_sym.should == :foo
87
+ end
88
+ end
89
+
90
+ describe '#to_s' do
91
+ it 'should be the symbolized name' do
92
+ field.to_s.should == 'foo'
93
+ end
94
+ end
95
+
96
+ end
@@ -0,0 +1,23 @@
1
+ require 'spec_helper'
2
+
3
+ describe MemoryModel::Base::Fieldable do
4
+
5
+ let(:model_a) { Class.new(MemoryModel::Base) }
6
+ let(:model_b) { Class.new(MemoryModel::Base) }
7
+
8
+ describe '.field' do
9
+ it 'should add a field to fields' do
10
+ field = :foo
11
+ model_a.send :field, field
12
+ model_a.fields.should include field
13
+ end
14
+
15
+ it 'should not dirty other classes' do
16
+ field = :bar
17
+ model_a.send :field, field
18
+ model_a.fields.should include field
19
+ model_b.fields.should_not include field
20
+ end
21
+ end
22
+
23
+ end
@@ -0,0 +1,37 @@
1
+ require 'spec_helper'
2
+
3
+ describe MemoryModel::Base::Persistence do
4
+ let(:model) do
5
+ Class.new(MemoryModel::Base) do
6
+ field :foo
7
+ end
8
+ end
9
+ let(:value) { 'bar' }
10
+ subject(:instance) { model.new(foo: value) }
11
+ before(:each) do
12
+ stub_const('MyModel', model)
13
+ end
14
+
15
+ describe '#persisted?' do
16
+ it 'should be true if persisted' do
17
+ instance.commit
18
+ instance.persisted?.should be_true
19
+ end
20
+
21
+ it 'should be false if not persisted' do
22
+ instance.persisted?.should be_false
23
+ end
24
+ end
25
+
26
+ describe '#new_record?' do
27
+ it 'should be true unless persisted' do
28
+ instance.commit
29
+ instance.new_record?.should be_false
30
+ end
31
+
32
+ it 'should be false unless not persisted' do
33
+ instance.new_record?.should be_true
34
+ end
35
+ end
36
+
37
+ end
@@ -0,0 +1,31 @@
1
+ require 'spec_helper'
2
+
3
+ describe MemoryModel::Base::Versionable do
4
+
5
+ let(:model) do
6
+ Class.new(MemoryModel::Base)
7
+ end
8
+ let(:instance) do
9
+ model.new
10
+ end
11
+ before(:each) do
12
+ stub_const('MyModel', model)
13
+ end
14
+
15
+ describe '#versions' do
16
+ it 'should have a number of versions' do
17
+ 10.times.each do |index|
18
+ instance.versions.size.should == index
19
+ instance.commit
20
+ end
21
+ end
22
+ end
23
+
24
+ describe '#version' do
25
+ it 'should be the latest version' do
26
+ 3.times.each { instance.commit }
27
+ instance.version.should == instance.versions.keys.last
28
+ end
29
+ end
30
+
31
+ end