djsun-mongo_mapper 0.5.6.6 → 0.5.8.1
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +3 -1
- data/Rakefile +13 -8
- data/VERSION +1 -1
- data/djsun-mongo_mapper.gemspec +17 -21
- data/lib/mongo_mapper/associations/base.rb +32 -36
- data/lib/mongo_mapper/associations/many_documents_as_proxy.rb +0 -2
- data/lib/mongo_mapper/associations/many_documents_proxy.rb +19 -10
- data/lib/mongo_mapper/associations/many_embedded_polymorphic_proxy.rb +2 -2
- data/lib/mongo_mapper/associations/many_embedded_proxy.rb +21 -36
- data/lib/mongo_mapper/associations/many_polymorphic_proxy.rb +1 -1
- data/lib/mongo_mapper/associations/proxy.rb +3 -2
- data/lib/mongo_mapper/associations.rb +114 -8
- data/lib/mongo_mapper/callbacks.rb +18 -0
- data/lib/mongo_mapper/document.rb +173 -37
- data/lib/mongo_mapper/dynamic_finder.rb +1 -1
- data/lib/mongo_mapper/embedded_document.rb +9 -13
- data/lib/mongo_mapper/finder_options.rb +67 -44
- data/lib/mongo_mapper/pagination.rb +2 -0
- data/lib/mongo_mapper/serialization.rb +1 -1
- data/lib/mongo_mapper/serializers/json_serializer.rb +1 -1
- data/lib/mongo_mapper/support.rb +9 -0
- data/lib/mongo_mapper/validations.rb +12 -42
- data/lib/mongo_mapper.rb +11 -5
- data/test/functional/associations/test_belongs_to_polymorphic_proxy.rb +5 -5
- data/test/functional/associations/test_belongs_to_proxy.rb +29 -31
- data/test/functional/associations/test_many_documents_as_proxy.rb +5 -5
- data/test/functional/associations/test_many_embedded_polymorphic_proxy.rb +27 -3
- data/test/functional/associations/test_many_embedded_proxy.rb +58 -38
- data/test/functional/associations/test_many_polymorphic_proxy.rb +45 -3
- data/test/functional/associations/test_many_proxy.rb +61 -11
- data/test/functional/test_associations.rb +3 -3
- data/test/functional/test_binary.rb +1 -1
- data/test/functional/test_callbacks.rb +1 -1
- data/test/functional/test_dirty.rb +3 -3
- data/test/functional/test_document.rb +62 -58
- data/test/functional/test_embedded_document.rb +1 -1
- data/test/functional/test_pagination.rb +1 -1
- data/test/functional/test_rails_compatibility.rb +1 -1
- data/test/functional/test_validations.rb +46 -14
- data/test/models.rb +87 -35
- data/test/support/{test_timing.rb → timing.rb} +1 -1
- data/test/test_helper.rb +8 -13
- data/test/unit/serializers/test_json_serializer.rb +0 -4
- data/test/unit/test_association_base.rb +24 -8
- data/test/unit/test_document.rb +40 -71
- data/test/unit/test_embedded_document.rb +27 -67
- data/test/unit/test_finder_options.rb +16 -0
- data/test/unit/test_key.rb +5 -17
- data/test/unit/test_mongomapper.rb +2 -2
- data/test/unit/test_pagination.rb +4 -0
- metadata +10 -12
- data/mongo_mapper.gemspec +0 -170
- data/test/functional/associations/test_namespace.rb +0 -27
data/test/test_helper.rb
CHANGED
@@ -1,9 +1,9 @@
|
|
1
|
-
require File.
|
1
|
+
require File.expand_path(File.dirname(__FILE__) + '/../lib/mongo_mapper')
|
2
2
|
|
3
3
|
gem 'jnunemaker-matchy', '>= 0.4.0'
|
4
4
|
gem 'shoulda', '>= 2.10.2'
|
5
|
-
gem 'timecop', '>= 0.3.
|
6
|
-
gem 'mocha', '>= 0.9.
|
5
|
+
gem 'timecop', '>= 0.3.2'
|
6
|
+
gem 'mocha', '>= 0.9.8'
|
7
7
|
|
8
8
|
require 'matchy'
|
9
9
|
require 'shoulda'
|
@@ -12,21 +12,16 @@ require 'mocha'
|
|
12
12
|
require 'pp'
|
13
13
|
|
14
14
|
require 'support/custom_matchers'
|
15
|
-
require 'support/
|
15
|
+
require 'support/timing'
|
16
16
|
|
17
17
|
class Test::Unit::TestCase
|
18
18
|
include CustomMatchers
|
19
|
-
|
20
|
-
def clear_all_collections
|
21
|
-
MongoMapper::Document.descendants.map { |d| d.collection.clear }
|
22
|
-
end
|
23
19
|
end
|
24
20
|
|
25
|
-
DefaultDatabase = 'test' unless defined?(DefaultDatabase)
|
26
|
-
AlternateDatabase = 'test2' unless defined?(AlternateDatabase)
|
27
|
-
|
28
21
|
test_dir = File.expand_path(File.dirname(__FILE__) + '/../tmp')
|
29
22
|
FileUtils.mkdir_p(test_dir) unless File.exist?(test_dir)
|
30
23
|
|
31
|
-
MongoMapper.connection = Mongo::Connection.new('127.0.0.1', 27017,
|
32
|
-
|
24
|
+
MongoMapper.connection = Mongo::Connection.new('127.0.0.1', 27017, {
|
25
|
+
:logger => Logger.new(test_dir + '/test.log')
|
26
|
+
})
|
27
|
+
MongoMapper.database = 'test'
|
@@ -13,7 +13,6 @@ class JsonSerializationTest < Test::Unit::TestCase
|
|
13
13
|
key :created_at, Time
|
14
14
|
key :awesome, Boolean
|
15
15
|
key :preferences, Hash
|
16
|
-
key :hiding, String
|
17
16
|
|
18
17
|
many :tags, :class_name => 'JsonSerializationTest::Tag'
|
19
18
|
end
|
@@ -43,7 +42,6 @@ class JsonSerializationTest < Test::Unit::TestCase
|
|
43
42
|
assert json.include?(%("created_at":#{ActiveSupport::JSON.encode(Time.utc(2006, 8, 1))}))
|
44
43
|
assert_match %r{"awesome":true}, json
|
45
44
|
assert_match %r{"preferences":\{"shows":"anime"\}}, json
|
46
|
-
assert_match %r{"hiding":null}, json
|
47
45
|
end
|
48
46
|
|
49
47
|
should "allow attribute filtering with only" do
|
@@ -55,7 +53,6 @@ class JsonSerializationTest < Test::Unit::TestCase
|
|
55
53
|
assert_no_match %r{"awesome"}, json
|
56
54
|
assert_no_match %r{"created_at"}, json
|
57
55
|
assert_no_match %r{"preferences"}, json
|
58
|
-
assert_no_match %r{"hiding"}, json
|
59
56
|
end
|
60
57
|
|
61
58
|
should "allow attribute filtering with except" do
|
@@ -67,7 +64,6 @@ class JsonSerializationTest < Test::Unit::TestCase
|
|
67
64
|
assert_match %r{"awesome"}, json
|
68
65
|
assert_match %r{"created_at"}, json
|
69
66
|
assert_match %r{"preferences"}, json
|
70
|
-
assert_match %r{"hiding"}, json
|
71
67
|
end
|
72
68
|
|
73
69
|
context "_id key" do
|
@@ -26,22 +26,21 @@ class AssociationBaseTest < Test::Unit::TestCase
|
|
26
26
|
Base.new(:many, :smart_people).class_name.should == 'SmartPerson'
|
27
27
|
end
|
28
28
|
|
29
|
-
should "be changeable using class_name option
|
29
|
+
should "be changeable using class_name option" do
|
30
30
|
base = Base.new(:many, :smart_people, :class_name => 'IntelligentPerson')
|
31
31
|
base.class_name.should == 'IntelligentPerson'
|
32
32
|
end
|
33
|
-
|
34
|
-
should "be changeable using class_name option with a constant" do
|
35
|
-
class IntelligentPerson; end
|
36
|
-
base = Base.new(:many, :smart_people, :class_name => IntelligentPerson)
|
37
|
-
base.class_name.should == IntelligentPerson
|
38
|
-
end
|
39
33
|
end
|
40
34
|
|
41
35
|
context "klass" do
|
42
|
-
should "
|
36
|
+
should "default to class_name constantized" do
|
43
37
|
Base.new(:belongs_to, :foo_monster).klass.should == FooMonster
|
44
38
|
end
|
39
|
+
|
40
|
+
should "be the specified class" do
|
41
|
+
anonnymous_class = Class.new
|
42
|
+
Base.new(:belongs_to, :foo_monster, :class => anonnymous_class).klass.should == anonnymous_class
|
43
|
+
end
|
45
44
|
end
|
46
45
|
|
47
46
|
context "many?" do
|
@@ -54,6 +53,23 @@ class AssociationBaseTest < Test::Unit::TestCase
|
|
54
53
|
end
|
55
54
|
end
|
56
55
|
|
56
|
+
context "finder_options" do
|
57
|
+
should "default to empty hash" do
|
58
|
+
base = Base.new(:many, :foos)
|
59
|
+
base.finder_options.should == {}
|
60
|
+
end
|
61
|
+
|
62
|
+
should "work with order" do
|
63
|
+
base = Base.new(:many, :foos, :order => 'position')
|
64
|
+
base.finder_options.should == {:order => 'position'}
|
65
|
+
end
|
66
|
+
|
67
|
+
should "correctly parse from options" do
|
68
|
+
base = Base.new(:many, :foos, :order => 'position', :somekey => 'somevalue')
|
69
|
+
base.finder_options.should == {:order => 'position', :somekey => 'somevalue'}
|
70
|
+
end
|
71
|
+
end
|
72
|
+
|
57
73
|
context "belongs_to?" do
|
58
74
|
should "be true if belongs_to" do
|
59
75
|
Base.new(:belongs_to, :foo).belongs_to?.should be_true
|
data/test/unit/test_document.rb
CHANGED
@@ -8,7 +8,7 @@ class DocumentTest < Test::Unit::TestCase
|
|
8
8
|
include MongoMapper::Document
|
9
9
|
set_collection_name 'test'
|
10
10
|
end
|
11
|
-
@document.collection.
|
11
|
+
@document.collection.remove
|
12
12
|
end
|
13
13
|
|
14
14
|
should "have logger method" do
|
@@ -36,8 +36,9 @@ class DocumentTest < Test::Unit::TestCase
|
|
36
36
|
end
|
37
37
|
|
38
38
|
should "allow setting a different database without affecting the default" do
|
39
|
-
@document.
|
40
|
-
@document.
|
39
|
+
@document.set_database_name 'test2'
|
40
|
+
@document.database_name.should == 'test2'
|
41
|
+
@document.database.name.should == 'test2'
|
41
42
|
|
42
43
|
another_document = Class.new do
|
43
44
|
include MongoMapper::Document
|
@@ -47,13 +48,24 @@ class DocumentTest < Test::Unit::TestCase
|
|
47
48
|
end
|
48
49
|
|
49
50
|
should "default collection name to class name tableized" do
|
50
|
-
class Item
|
51
|
+
class ::Item
|
51
52
|
include MongoMapper::Document
|
52
53
|
end
|
53
54
|
|
54
55
|
Item.collection.should be_instance_of(Mongo::Collection)
|
55
56
|
Item.collection.name.should == 'items'
|
56
57
|
end
|
58
|
+
|
59
|
+
should "default collection name of namespaced class to tableized with dot separation" do
|
60
|
+
module ::BloggyPoo
|
61
|
+
class Post
|
62
|
+
include MongoMapper::Document
|
63
|
+
end
|
64
|
+
end
|
65
|
+
|
66
|
+
BloggyPoo::Post.collection.should be_instance_of(Mongo::Collection)
|
67
|
+
BloggyPoo::Post.collection.name.should == 'bloggy_poo.posts'
|
68
|
+
end
|
57
69
|
|
58
70
|
should "allow setting the collection name" do
|
59
71
|
@document.set_collection_name('foobar')
|
@@ -91,7 +103,7 @@ class DocumentTest < Test::Unit::TestCase
|
|
91
103
|
key :name, String
|
92
104
|
key :age, Integer
|
93
105
|
end
|
94
|
-
@document.collection.
|
106
|
+
@document.collection.remove
|
95
107
|
end
|
96
108
|
|
97
109
|
should "have access to logger" do
|
@@ -102,7 +114,7 @@ class DocumentTest < Test::Unit::TestCase
|
|
102
114
|
|
103
115
|
should "have access to the class's collection" do
|
104
116
|
doc = @document.new
|
105
|
-
doc.collection.should == @document.collection
|
117
|
+
doc.collection.name.should == @document.collection.name
|
106
118
|
end
|
107
119
|
|
108
120
|
should "use default values if defined for keys" do
|
@@ -124,13 +136,18 @@ class DocumentTest < Test::Unit::TestCase
|
|
124
136
|
@document.new._root_document.should be_nil
|
125
137
|
end
|
126
138
|
|
127
|
-
should "set self to the root document on embedded documents" do
|
128
|
-
|
129
|
-
|
139
|
+
should "set self to the root document on embedded documents" do
|
140
|
+
klass = Class.new do
|
141
|
+
include MongoMapper::Document
|
130
142
|
end
|
131
|
-
|
132
|
-
|
133
|
-
|
143
|
+
|
144
|
+
pets = Class.new do
|
145
|
+
include MongoMapper::EmbeddedDocument
|
146
|
+
end
|
147
|
+
klass.many :pets, :class => pets
|
148
|
+
|
149
|
+
doc = klass.new(:pets => [{}])
|
150
|
+
doc.pets.first._root_document.should == doc
|
134
151
|
end
|
135
152
|
end
|
136
153
|
|
@@ -160,72 +177,24 @@ class DocumentTest < Test::Unit::TestCase
|
|
160
177
|
clone.age.should == 27
|
161
178
|
end
|
162
179
|
end
|
180
|
+
|
163
181
|
|
164
|
-
context "
|
165
|
-
should "be
|
166
|
-
|
167
|
-
doc_2 = @document.new('name' => "Doc 1")
|
168
|
-
doc_1.should == doc_2
|
182
|
+
context "equality" do
|
183
|
+
should "be equal if id and class are the same" do
|
184
|
+
(@document.new('_id' => 1) == @document.new('_id' => 1)).should be(true)
|
169
185
|
end
|
170
186
|
|
171
|
-
should "not be
|
172
|
-
|
173
|
-
doc_2 = @document.new('name' => "Doc 2")
|
174
|
-
doc_1.should_not == doc_2
|
187
|
+
should "not be equal if class same but id different" do
|
188
|
+
(@document.new('_id' => 1) == @document.new('_id' => 2)).should be(false)
|
175
189
|
end
|
176
|
-
|
177
|
-
should "not be == when comparing other object types" do
|
178
|
-
doc = @document.new('name' => "Doc")
|
179
|
-
doc.should_not == nil
|
180
|
-
doc.should_not == false
|
181
|
-
doc.should_not == { 'name' => "Doc" }
|
182
|
-
end
|
183
|
-
|
184
|
-
should "not care about document type" do
|
185
|
-
@person = Class.new do
|
186
|
-
include MongoMapper::EmbeddedDocument
|
187
190
|
|
188
|
-
|
189
|
-
|
191
|
+
should "not be equal if id same but class different" do
|
192
|
+
@another_document = Class.new do
|
193
|
+
include MongoMapper::Document
|
194
|
+
set_collection_name 'test'
|
190
195
|
end
|
191
|
-
doc = @document.new('name' => "Doc 1")
|
192
|
-
person = @person.new('name' => "Doc 1")
|
193
|
-
doc.should == person
|
194
|
-
person.should == doc # test commutativity
|
195
|
-
end
|
196
|
-
end
|
197
|
-
|
198
|
-
context "eql?" do
|
199
|
-
should "be eql? if type matches and key values are the same" do
|
200
|
-
doc_1 = @document.new('name' => "Doc 1")
|
201
|
-
doc_2 = @document.new('name' => "Doc 1")
|
202
|
-
doc_1.should eql?(doc_2)
|
203
|
-
end
|
204
|
-
|
205
|
-
should "not be eql? if type matches but key values are different" do
|
206
|
-
doc_1 = @document.new('name' => "Doc 1")
|
207
|
-
doc_2 = @document.new('name' => "Doc 2")
|
208
|
-
doc_1.should_not eql?(doc_2)
|
209
|
-
end
|
210
|
-
|
211
|
-
should "not be eql? when comparing other object types" do
|
212
|
-
doc = @document.new('name' => "Doc")
|
213
|
-
doc.should_not eql?(nil)
|
214
|
-
doc.should_not eql?(false)
|
215
|
-
doc.should_not eql?({ 'name' => "Doc" })
|
216
|
-
end
|
217
196
|
|
218
|
-
|
219
|
-
@person = Class.new do
|
220
|
-
include MongoMapper::EmbeddedDocument
|
221
|
-
|
222
|
-
key :name, String
|
223
|
-
key :age, Integer
|
224
|
-
end
|
225
|
-
doc = @document.new('name' => "Doc 1")
|
226
|
-
person = @person.new('name' => "Doc 1")
|
227
|
-
doc.should_not eql?(person)
|
228
|
-
person.should_not eql?(doc) # test commutativity
|
197
|
+
(@document.new('_id' => 1) == @another_document.new('_id' => 1)).should be(false)
|
229
198
|
end
|
230
199
|
end
|
231
200
|
end # instance of a document
|
@@ -430,12 +430,14 @@ class EmbeddedDocumentTest < Test::Unit::TestCase
|
|
430
430
|
context "to_mongo" do
|
431
431
|
should "default to hash with _id key" do
|
432
432
|
doc = @document.new
|
433
|
-
doc.to_mongo.keys.
|
433
|
+
doc.to_mongo.keys.should == ['_id']
|
434
434
|
end
|
435
435
|
|
436
|
-
should "return all keys" do
|
436
|
+
should "return all keys with non nil values" do
|
437
437
|
doc = @document.new(:name => 'string', :age => nil)
|
438
|
-
doc.to_mongo.keys.sort.should ==
|
438
|
+
doc.to_mongo.keys.sort.should == ['_id', 'name']
|
439
|
+
doc.to_mongo.values.should include('string')
|
440
|
+
doc.to_mongo.values.should_not include(nil)
|
439
441
|
end
|
440
442
|
end
|
441
443
|
|
@@ -463,11 +465,20 @@ class EmbeddedDocumentTest < Test::Unit::TestCase
|
|
463
465
|
clone.age.should == 27
|
464
466
|
end
|
465
467
|
end
|
466
|
-
|
468
|
+
|
467
469
|
context "key shorcut access" do
|
468
|
-
|
469
|
-
|
470
|
-
|
470
|
+
context "[]" do
|
471
|
+
should "work when key found" do
|
472
|
+
doc = @document.new(:name => 'string')
|
473
|
+
doc[:name].should == 'string'
|
474
|
+
end
|
475
|
+
|
476
|
+
should "raise exception when key not found" do
|
477
|
+
doc = @document.new(:name => 'string')
|
478
|
+
lambda {
|
479
|
+
doc[:not_here]
|
480
|
+
}.should raise_error(MongoMapper::KeyNotFound)
|
481
|
+
end
|
471
482
|
end
|
472
483
|
|
473
484
|
context "[]=" do
|
@@ -644,73 +655,22 @@ class EmbeddedDocumentTest < Test::Unit::TestCase
|
|
644
655
|
end
|
645
656
|
end
|
646
657
|
|
647
|
-
context "
|
648
|
-
should "be
|
649
|
-
|
650
|
-
doc_2 = @document.new('name' => "Doc 1")
|
651
|
-
doc_1.should == doc_2
|
652
|
-
end
|
653
|
-
|
654
|
-
should "not be == if key values are different" do
|
655
|
-
doc_1 = @document.new('name' => "Doc 1")
|
656
|
-
doc_2 = @document.new('name' => "Doc 2")
|
657
|
-
doc_1.should_not == doc_2
|
658
|
+
context "equality" do
|
659
|
+
should "be equal if id and class are the same" do
|
660
|
+
(@document.new('_id' => 1) == @document.new('_id' => 1)).should be(true)
|
658
661
|
end
|
659
662
|
|
660
|
-
should "not be
|
661
|
-
|
662
|
-
doc.should_not == nil
|
663
|
-
doc.should_not == false
|
664
|
-
doc.should_not == { 'name' => "Doc" }
|
663
|
+
should "not be equal if class same but id different" do
|
664
|
+
(@document.new('_id' => 1) == @document.new('_id' => 2)).should be(false)
|
665
665
|
end
|
666
666
|
|
667
|
-
should "not
|
668
|
-
@
|
669
|
-
include MongoMapper::
|
670
|
-
|
671
|
-
key :name, String
|
672
|
-
key :age, Integer
|
667
|
+
should "not be equal if id same but class different" do
|
668
|
+
@another_document = Class.new do
|
669
|
+
include MongoMapper::Document
|
673
670
|
end
|
674
|
-
doc = @document.new('name' => "Doc 1")
|
675
|
-
person = @person.new('name' => "Doc 1")
|
676
|
-
doc.should == person
|
677
|
-
person.should == doc # test commutativity
|
678
|
-
end
|
679
|
-
end
|
680
|
-
|
681
|
-
context "eql?" do
|
682
|
-
should "be eql? if type matches and key values are the same" do
|
683
|
-
doc_1 = @document.new('name' => "Doc 1")
|
684
|
-
doc_2 = @document.new('name' => "Doc 1")
|
685
|
-
doc_1.should eql?(doc_2)
|
686
|
-
end
|
687
|
-
|
688
|
-
should "not be eql? if type matches but key values are different" do
|
689
|
-
doc_1 = @document.new('name' => "Doc 1")
|
690
|
-
doc_2 = @document.new('name' => "Doc 2")
|
691
|
-
doc_1.should_not eql?(doc_2)
|
692
|
-
end
|
693
671
|
|
694
|
-
|
695
|
-
doc = @document.new('name' => "Doc")
|
696
|
-
doc.should_not eql?(nil)
|
697
|
-
doc.should_not eql?(false)
|
698
|
-
doc.should_not eql?({ 'name' => "Doc" })
|
699
|
-
end
|
700
|
-
|
701
|
-
should "not be eql? if types are different even if values are the same" do
|
702
|
-
@person = Class.new do
|
703
|
-
include MongoMapper::EmbeddedDocument
|
704
|
-
|
705
|
-
key :name, String
|
706
|
-
key :age, Integer
|
707
|
-
end
|
708
|
-
doc = @document.new('name' => "Doc 1")
|
709
|
-
person = @person.new('name' => "Doc 1")
|
710
|
-
doc.should_not eql?(person)
|
711
|
-
person.should_not eql?(doc) # check commutativity
|
672
|
+
(@document.new('_id' => 1) == @another_document.new('_id' => 1)).should be(false)
|
712
673
|
end
|
713
674
|
end
|
714
|
-
|
715
675
|
end # instance of a embedded document
|
716
676
|
end
|
@@ -22,6 +22,22 @@ class FinderOptionsTest < Test::Unit::TestCase
|
|
22
22
|
}
|
23
23
|
end
|
24
24
|
|
25
|
+
should "not add _type to nested conditions" do
|
26
|
+
FinderOptions.new(Enter, :foo => 'bar', :age => {'$gt' => 21}).criteria.should == {
|
27
|
+
:foo => 'bar',
|
28
|
+
:age => {'$gt' => 21},
|
29
|
+
:_type => 'Enter'
|
30
|
+
}
|
31
|
+
end
|
32
|
+
|
33
|
+
%w{gt lt gte lte ne in nin mod size where exists}.each do |operator|
|
34
|
+
should "convert #{operator} conditions" do
|
35
|
+
FinderOptions.new(Room, :age.send(operator) => 21).criteria.should == {
|
36
|
+
:age => {"$#{operator}" => 21}
|
37
|
+
}
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
25
41
|
should "automatically add _type to query if model is single collection inherited" do
|
26
42
|
FinderOptions.new(Enter, :foo => 'bar').criteria.should == {
|
27
43
|
:foo => 'bar',
|
data/test/unit/test_key.rb
CHANGED
@@ -148,7 +148,7 @@ class KeyTest < Test::Unit::TestCase
|
|
148
148
|
end
|
149
149
|
end
|
150
150
|
|
151
|
-
context "
|
151
|
+
context "getting a value with a default set" do
|
152
152
|
setup do
|
153
153
|
@key = Key.new(:foo, String, :default => 'baz')
|
154
154
|
end
|
@@ -157,27 +157,15 @@ class KeyTest < Test::Unit::TestCase
|
|
157
157
|
@key.get(nil).should == 'baz'
|
158
158
|
end
|
159
159
|
|
160
|
-
should "return value if not
|
160
|
+
should "return value if not blank" do
|
161
161
|
@key.get('foobar').should == 'foobar'
|
162
162
|
end
|
163
|
-
|
164
|
-
|
165
|
-
context "string key with '' default" do
|
166
|
-
setup do
|
167
|
-
@key = Key.new(:foo, String, :default => '')
|
168
|
-
end
|
169
|
-
|
170
|
-
should "return default value if value nil" do
|
171
|
-
@key.get(nil).should == ''
|
172
|
-
end
|
173
|
-
end
|
174
|
-
|
175
|
-
context "boolean key" do
|
176
|
-
should "with false default" do
|
163
|
+
|
164
|
+
should "work with Boolean type and false value" do
|
177
165
|
Key.new(:active, Boolean, :default => false).get(nil).should be_false
|
178
166
|
end
|
179
167
|
|
180
|
-
should "with true
|
168
|
+
should "work with Boolean type and true value" do
|
181
169
|
Key.new(:active, Boolean, :default => true).get(nil).should be_true
|
182
170
|
end
|
183
171
|
end
|
@@ -15,9 +15,9 @@ class MongoMapperTest < Test::Unit::TestCase
|
|
15
15
|
end
|
16
16
|
|
17
17
|
should "be able to write and read default database" do
|
18
|
-
MongoMapper.database =
|
18
|
+
MongoMapper.database = 'test'
|
19
19
|
MongoMapper.database.should be_instance_of(Mongo::DB)
|
20
|
-
MongoMapper.database.name.should ==
|
20
|
+
MongoMapper.database.name.should == 'test'
|
21
21
|
end
|
22
22
|
|
23
23
|
should "have document not found error" do
|
@@ -58,6 +58,10 @@ class PaginationTest < Test::Unit::TestCase
|
|
58
58
|
should "know how many records to skip" do
|
59
59
|
PaginationProxy.new(25, 2, 10).skip.should == 10
|
60
60
|
end
|
61
|
+
|
62
|
+
should "alias offset to skip" do
|
63
|
+
PaginationProxy.new(25, 2, 10).offset.should == 10
|
64
|
+
end
|
61
65
|
|
62
66
|
context "previous_page" do
|
63
67
|
should "be nil if current page 1" do
|
metadata
CHANGED
@@ -1,10 +1,11 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: djsun-mongo_mapper
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.5.
|
4
|
+
version: 0.5.8.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- John Nunemaker
|
8
|
+
- David James
|
8
9
|
autorequire:
|
9
10
|
bindir: bin
|
10
11
|
cert_chain: []
|
@@ -30,7 +31,7 @@ dependencies:
|
|
30
31
|
requirements:
|
31
32
|
- - ">="
|
32
33
|
- !ruby/object:Gem::Version
|
33
|
-
version: 0.
|
34
|
+
version: "0.16"
|
34
35
|
version:
|
35
36
|
- !ruby/object:Gem::Dependency
|
36
37
|
name: jnunemaker-validatable
|
@@ -40,7 +41,7 @@ dependencies:
|
|
40
41
|
requirements:
|
41
42
|
- - ">="
|
42
43
|
- !ruby/object:Gem::Version
|
43
|
-
version: 1.8.
|
44
|
+
version: 1.8.1
|
44
45
|
version:
|
45
46
|
- !ruby/object:Gem::Dependency
|
46
47
|
name: jnunemaker-matchy
|
@@ -70,7 +71,7 @@ dependencies:
|
|
70
71
|
requirements:
|
71
72
|
- - ">="
|
72
73
|
- !ruby/object:Gem::Version
|
73
|
-
version: 0.3.
|
74
|
+
version: 0.3.2
|
74
75
|
version:
|
75
76
|
- !ruby/object:Gem::Dependency
|
76
77
|
name: mocha
|
@@ -80,9 +81,9 @@ dependencies:
|
|
80
81
|
requirements:
|
81
82
|
- - ">="
|
82
83
|
- !ruby/object:Gem::Version
|
83
|
-
version: 0.9.
|
84
|
+
version: 0.9.8
|
84
85
|
version:
|
85
|
-
description:
|
86
|
+
description:
|
86
87
|
email: nunemaker@gmail.com
|
87
88
|
executables:
|
88
89
|
- mmconsole
|
@@ -126,7 +127,6 @@ files:
|
|
126
127
|
- lib/mongo_mapper/serializers/json_serializer.rb
|
127
128
|
- lib/mongo_mapper/support.rb
|
128
129
|
- lib/mongo_mapper/validations.rb
|
129
|
-
- mongo_mapper.gemspec
|
130
130
|
- specs.watchr
|
131
131
|
- test/NOTE_ON_TESTING
|
132
132
|
- test/functional/associations/test_belongs_to_polymorphic_proxy.rb
|
@@ -136,7 +136,6 @@ files:
|
|
136
136
|
- test/functional/associations/test_many_embedded_proxy.rb
|
137
137
|
- test/functional/associations/test_many_polymorphic_proxy.rb
|
138
138
|
- test/functional/associations/test_many_proxy.rb
|
139
|
-
- test/functional/associations/test_namespace.rb
|
140
139
|
- test/functional/test_associations.rb
|
141
140
|
- test/functional/test_binary.rb
|
142
141
|
- test/functional/test_callbacks.rb
|
@@ -149,7 +148,7 @@ files:
|
|
149
148
|
- test/functional/test_validations.rb
|
150
149
|
- test/models.rb
|
151
150
|
- test/support/custom_matchers.rb
|
152
|
-
- test/support/
|
151
|
+
- test/support/timing.rb
|
153
152
|
- test/test_helper.rb
|
154
153
|
- test/unit/serializers/test_json_serializer.rb
|
155
154
|
- test/unit/test_association_base.rb
|
@@ -193,7 +192,7 @@ rubyforge_project:
|
|
193
192
|
rubygems_version: 1.3.5
|
194
193
|
signing_key:
|
195
194
|
specification_version: 3
|
196
|
-
summary:
|
195
|
+
summary: Model your domain, store it in MongoDB
|
197
196
|
test_files:
|
198
197
|
- test/functional/associations/test_belongs_to_polymorphic_proxy.rb
|
199
198
|
- test/functional/associations/test_belongs_to_proxy.rb
|
@@ -202,7 +201,6 @@ test_files:
|
|
202
201
|
- test/functional/associations/test_many_embedded_proxy.rb
|
203
202
|
- test/functional/associations/test_many_polymorphic_proxy.rb
|
204
203
|
- test/functional/associations/test_many_proxy.rb
|
205
|
-
- test/functional/associations/test_namespace.rb
|
206
204
|
- test/functional/test_associations.rb
|
207
205
|
- test/functional/test_binary.rb
|
208
206
|
- test/functional/test_callbacks.rb
|
@@ -215,7 +213,7 @@ test_files:
|
|
215
213
|
- test/functional/test_validations.rb
|
216
214
|
- test/models.rb
|
217
215
|
- test/support/custom_matchers.rb
|
218
|
-
- test/support/
|
216
|
+
- test/support/timing.rb
|
219
217
|
- test/test_helper.rb
|
220
218
|
- test/unit/serializers/test_json_serializer.rb
|
221
219
|
- test/unit/test_association_base.rb
|