jamieorc-mongo_mapper 0.11.1.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (176) hide show
  1. data/LICENSE +20 -0
  2. data/README.rdoc +33 -0
  3. data/UPGRADES +26 -0
  4. data/bin/mmconsole +59 -0
  5. data/examples/attr_accessible.rb +22 -0
  6. data/examples/attr_protected.rb +22 -0
  7. data/examples/cache_key.rb +24 -0
  8. data/examples/custom_types.rb +24 -0
  9. data/examples/identity_map.rb +33 -0
  10. data/examples/identity_map/automatic.rb +2 -0
  11. data/examples/keys.rb +40 -0
  12. data/examples/modifiers/set.rb +25 -0
  13. data/examples/plugins.rb +38 -0
  14. data/examples/querying.rb +35 -0
  15. data/examples/safe.rb +43 -0
  16. data/examples/scopes.rb +52 -0
  17. data/examples/validating/embedded_docs.rb +29 -0
  18. data/lib/mongo_mapper.rb +94 -0
  19. data/lib/mongo_mapper/connection.rb +96 -0
  20. data/lib/mongo_mapper/document.rb +42 -0
  21. data/lib/mongo_mapper/embedded_document.rb +32 -0
  22. data/lib/mongo_mapper/exceptions.rb +27 -0
  23. data/lib/mongo_mapper/extensions/array.rb +19 -0
  24. data/lib/mongo_mapper/extensions/binary.rb +22 -0
  25. data/lib/mongo_mapper/extensions/boolean.rb +44 -0
  26. data/lib/mongo_mapper/extensions/date.rb +25 -0
  27. data/lib/mongo_mapper/extensions/float.rb +14 -0
  28. data/lib/mongo_mapper/extensions/hash.rb +14 -0
  29. data/lib/mongo_mapper/extensions/integer.rb +19 -0
  30. data/lib/mongo_mapper/extensions/kernel.rb +9 -0
  31. data/lib/mongo_mapper/extensions/nil_class.rb +18 -0
  32. data/lib/mongo_mapper/extensions/object.rb +26 -0
  33. data/lib/mongo_mapper/extensions/object_id.rb +32 -0
  34. data/lib/mongo_mapper/extensions/set.rb +20 -0
  35. data/lib/mongo_mapper/extensions/string.rb +18 -0
  36. data/lib/mongo_mapper/extensions/time.rb +28 -0
  37. data/lib/mongo_mapper/locale/en.yml +5 -0
  38. data/lib/mongo_mapper/middleware/identity_map.rb +16 -0
  39. data/lib/mongo_mapper/plugins.rb +22 -0
  40. data/lib/mongo_mapper/plugins/accessible.rb +36 -0
  41. data/lib/mongo_mapper/plugins/active_model.rb +18 -0
  42. data/lib/mongo_mapper/plugins/associations.rb +90 -0
  43. data/lib/mongo_mapper/plugins/associations/base.rb +92 -0
  44. data/lib/mongo_mapper/plugins/associations/belongs_to_association.rb +53 -0
  45. data/lib/mongo_mapper/plugins/associations/belongs_to_polymorphic_proxy.rb +34 -0
  46. data/lib/mongo_mapper/plugins/associations/belongs_to_proxy.rb +52 -0
  47. data/lib/mongo_mapper/plugins/associations/collection.rb +27 -0
  48. data/lib/mongo_mapper/plugins/associations/embedded_collection.rb +44 -0
  49. data/lib/mongo_mapper/plugins/associations/in_array_proxy.rb +133 -0
  50. data/lib/mongo_mapper/plugins/associations/many_association.rb +63 -0
  51. data/lib/mongo_mapper/plugins/associations/many_documents_as_proxy.rb +28 -0
  52. data/lib/mongo_mapper/plugins/associations/many_documents_proxy.rb +117 -0
  53. data/lib/mongo_mapper/plugins/associations/many_embedded_polymorphic_proxy.rb +32 -0
  54. data/lib/mongo_mapper/plugins/associations/many_embedded_proxy.rb +24 -0
  55. data/lib/mongo_mapper/plugins/associations/many_polymorphic_proxy.rb +14 -0
  56. data/lib/mongo_mapper/plugins/associations/one_as_proxy.rb +22 -0
  57. data/lib/mongo_mapper/plugins/associations/one_association.rb +48 -0
  58. data/lib/mongo_mapper/plugins/associations/one_embedded_polymorphic_proxy.rb +30 -0
  59. data/lib/mongo_mapper/plugins/associations/one_embedded_proxy.rb +44 -0
  60. data/lib/mongo_mapper/plugins/associations/one_proxy.rb +95 -0
  61. data/lib/mongo_mapper/plugins/associations/proxy.rb +134 -0
  62. data/lib/mongo_mapper/plugins/associations/single_association.rb +46 -0
  63. data/lib/mongo_mapper/plugins/caching.rb +21 -0
  64. data/lib/mongo_mapper/plugins/callbacks.rb +29 -0
  65. data/lib/mongo_mapper/plugins/clone.rb +22 -0
  66. data/lib/mongo_mapper/plugins/dirty.rb +60 -0
  67. data/lib/mongo_mapper/plugins/document.rb +41 -0
  68. data/lib/mongo_mapper/plugins/dynamic_querying.rb +45 -0
  69. data/lib/mongo_mapper/plugins/dynamic_querying/dynamic_finder.rb +44 -0
  70. data/lib/mongo_mapper/plugins/embedded_callbacks.rb +56 -0
  71. data/lib/mongo_mapper/plugins/embedded_document.rb +53 -0
  72. data/lib/mongo_mapper/plugins/equality.rb +23 -0
  73. data/lib/mongo_mapper/plugins/identity_map.rb +128 -0
  74. data/lib/mongo_mapper/plugins/indexes.rb +13 -0
  75. data/lib/mongo_mapper/plugins/inspect.rb +16 -0
  76. data/lib/mongo_mapper/plugins/keys.rb +313 -0
  77. data/lib/mongo_mapper/plugins/keys/key.rb +61 -0
  78. data/lib/mongo_mapper/plugins/logger.rb +18 -0
  79. data/lib/mongo_mapper/plugins/modifiers.rb +132 -0
  80. data/lib/mongo_mapper/plugins/pagination.rb +16 -0
  81. data/lib/mongo_mapper/plugins/persistence.rb +69 -0
  82. data/lib/mongo_mapper/plugins/protected.rb +45 -0
  83. data/lib/mongo_mapper/plugins/querying.rb +171 -0
  84. data/lib/mongo_mapper/plugins/querying/decorator.rb +34 -0
  85. data/lib/mongo_mapper/plugins/querying/plucky_methods.rb +21 -0
  86. data/lib/mongo_mapper/plugins/rails.rb +58 -0
  87. data/lib/mongo_mapper/plugins/rails/active_record_association_adapter.rb +33 -0
  88. data/lib/mongo_mapper/plugins/safe.rb +28 -0
  89. data/lib/mongo_mapper/plugins/sci.rb +36 -0
  90. data/lib/mongo_mapper/plugins/scopes.rb +27 -0
  91. data/lib/mongo_mapper/plugins/serialization.rb +109 -0
  92. data/lib/mongo_mapper/plugins/timestamps.rb +22 -0
  93. data/lib/mongo_mapper/plugins/touch.rb +18 -0
  94. data/lib/mongo_mapper/plugins/userstamps.rb +18 -0
  95. data/lib/mongo_mapper/plugins/validations.rb +86 -0
  96. data/lib/mongo_mapper/railtie.rb +48 -0
  97. data/lib/mongo_mapper/railtie/database.rake +65 -0
  98. data/lib/mongo_mapper/translation.rb +10 -0
  99. data/lib/mongo_mapper/version.rb +4 -0
  100. data/lib/rails/generators/mongo_mapper/config/config_generator.rb +24 -0
  101. data/lib/rails/generators/mongo_mapper/config/templates/mongo.yml +18 -0
  102. data/lib/rails/generators/mongo_mapper/model/model_generator.rb +23 -0
  103. data/lib/rails/generators/mongo_mapper/model/templates/model.rb +13 -0
  104. data/test/_NOTE_ON_TESTING +1 -0
  105. data/test/functional/associations/test_belongs_to_polymorphic_proxy.rb +64 -0
  106. data/test/functional/associations/test_belongs_to_proxy.rb +238 -0
  107. data/test/functional/associations/test_in_array_proxy.rb +349 -0
  108. data/test/functional/associations/test_many_documents_as_proxy.rb +229 -0
  109. data/test/functional/associations/test_many_documents_proxy.rb +866 -0
  110. data/test/functional/associations/test_many_embedded_polymorphic_proxy.rb +239 -0
  111. data/test/functional/associations/test_many_embedded_proxy.rb +289 -0
  112. data/test/functional/associations/test_many_polymorphic_proxy.rb +303 -0
  113. data/test/functional/associations/test_one_as_proxy.rb +491 -0
  114. data/test/functional/associations/test_one_embedded_polymorphic_proxy.rb +208 -0
  115. data/test/functional/associations/test_one_embedded_proxy.rb +100 -0
  116. data/test/functional/associations/test_one_proxy.rb +383 -0
  117. data/test/functional/test_accessible.rb +198 -0
  118. data/test/functional/test_associations.rb +46 -0
  119. data/test/functional/test_binary.rb +27 -0
  120. data/test/functional/test_caching.rb +77 -0
  121. data/test/functional/test_callbacks.rb +232 -0
  122. data/test/functional/test_dirty.rb +301 -0
  123. data/test/functional/test_document.rb +282 -0
  124. data/test/functional/test_dynamic_querying.rb +75 -0
  125. data/test/functional/test_embedded_document.rb +288 -0
  126. data/test/functional/test_equality.rb +20 -0
  127. data/test/functional/test_identity_map.rb +513 -0
  128. data/test/functional/test_indexes.rb +50 -0
  129. data/test/functional/test_logger.rb +20 -0
  130. data/test/functional/test_modifiers.rb +483 -0
  131. data/test/functional/test_pagination.rb +91 -0
  132. data/test/functional/test_protected.rb +201 -0
  133. data/test/functional/test_querying.rb +935 -0
  134. data/test/functional/test_safe.rb +76 -0
  135. data/test/functional/test_sci.rb +240 -0
  136. data/test/functional/test_scopes.rb +171 -0
  137. data/test/functional/test_timestamps.rb +62 -0
  138. data/test/functional/test_touch.rb +125 -0
  139. data/test/functional/test_userstamps.rb +44 -0
  140. data/test/functional/test_validations.rb +405 -0
  141. data/test/models.rb +261 -0
  142. data/test/support/railtie.rb +4 -0
  143. data/test/support/railtie/autoloaded.rb +2 -0
  144. data/test/support/railtie/not_autoloaded.rb +3 -0
  145. data/test/support/railtie/parent.rb +3 -0
  146. data/test/test_active_model_lint.rb +18 -0
  147. data/test/test_helper.rb +94 -0
  148. data/test/unit/associations/test_base.rb +146 -0
  149. data/test/unit/associations/test_belongs_to_association.rb +29 -0
  150. data/test/unit/associations/test_many_association.rb +63 -0
  151. data/test/unit/associations/test_one_association.rb +47 -0
  152. data/test/unit/associations/test_proxy.rb +100 -0
  153. data/test/unit/serializers/test_json_serializer.rb +216 -0
  154. data/test/unit/serializers/test_xml_serializer.rb +196 -0
  155. data/test/unit/test_clone.rb +69 -0
  156. data/test/unit/test_document.rb +249 -0
  157. data/test/unit/test_dynamic_finder.rb +125 -0
  158. data/test/unit/test_embedded_document.rb +682 -0
  159. data/test/unit/test_equality.rb +38 -0
  160. data/test/unit/test_extensions.rb +380 -0
  161. data/test/unit/test_identity_map_middleware.rb +34 -0
  162. data/test/unit/test_inspect.rb +47 -0
  163. data/test/unit/test_key.rb +205 -0
  164. data/test/unit/test_keys.rb +65 -0
  165. data/test/unit/test_mongo_mapper.rb +143 -0
  166. data/test/unit/test_pagination.rb +11 -0
  167. data/test/unit/test_plugins.rb +89 -0
  168. data/test/unit/test_rails.rb +183 -0
  169. data/test/unit/test_rails_compatibility.rb +38 -0
  170. data/test/unit/test_rails_reflect_on_association.rb +118 -0
  171. data/test/unit/test_railtie.rb +61 -0
  172. data/test/unit/test_serialization.rb +166 -0
  173. data/test/unit/test_time_zones.rb +44 -0
  174. data/test/unit/test_translation.rb +27 -0
  175. data/test/unit/test_validations.rb +562 -0
  176. metadata +262 -0
@@ -0,0 +1,50 @@
1
+ require 'test_helper'
2
+
3
+ class IndexingTest < Test::Unit::TestCase
4
+ context "Indexing" do
5
+ setup do
6
+ @document = Doc do
7
+ key :first_name, String
8
+ key :last_name, String
9
+ key :age, Integer
10
+ key :date, Date
11
+ end
12
+ end
13
+ teardown { drop_indexes(@document) }
14
+
15
+ [:create_index, :ensure_index, :drop_index, :drop_indexes].each do |method|
16
+ should "delegate #{method} to collection" do
17
+ @document.stubs(:collection).returns(mock(:name => :foo))
18
+ @document.collection.expects(method).with(:arg)
19
+ @document.send(method, :arg)
20
+ end
21
+ end
22
+
23
+ should "allow creating index for a key" do
24
+ @document.ensure_index :first_name
25
+ @document.should have_index('first_name_1')
26
+ end
27
+
28
+ should "allow creating unique index for a key" do
29
+ @document.ensure_index :first_name, :unique => true
30
+ @document.should have_index('first_name_1')
31
+ end
32
+
33
+ should "allow creating index on multiple keys" do
34
+ @document.ensure_index [[:first_name, 1], [:last_name, -1]]
35
+
36
+ # order is different for different versions of ruby so instead of
37
+ # just checking have_index('first_name_1_last_name_-1') I'm checking
38
+ # the values of the indexes to make sure the index creation was successful
39
+ @document.collection.index_information.detect do |index|
40
+ keys = index[0]
41
+ keys.include?('first_name_1') && keys.include?('last_name_-1')
42
+ end.should_not be_nil
43
+ end
44
+
45
+ should "work with :index shortcut when defining key" do
46
+ silence_stderr { @document.key :father, String, :index => true }
47
+ @document.should have_index('father_1')
48
+ end
49
+ end
50
+ end
@@ -0,0 +1,20 @@
1
+ require 'test_helper'
2
+
3
+ class LoggerTest < Test::Unit::TestCase
4
+ context "with connection that has logger" do
5
+ setup do
6
+ @output = StringIO.new
7
+ @logger = Logger.new(@output)
8
+ MongoMapper.connection = Mongo::Connection.new('127.0.0.1', 27017, :logger => @logger)
9
+ end
10
+
11
+ should "be able to get access to that logger" do
12
+ MongoMapper.logger.should == @logger
13
+ end
14
+
15
+ should "be able to log messages" do
16
+ MongoMapper.logger.debug 'testing'
17
+ @output.string.include?('testing').should be_true
18
+ end
19
+ end
20
+ end
@@ -0,0 +1,483 @@
1
+ require 'test_helper'
2
+
3
+ class ModifierTest < Test::Unit::TestCase
4
+ def setup
5
+ @page_class = Doc do
6
+ key :title, String
7
+ key :day_count, Integer, :default => 0
8
+ key :week_count, Integer, :default => 0
9
+ key :month_count, Integer, :default => 0
10
+ key :tags, Array
11
+ end
12
+ end
13
+
14
+ def assert_page_counts(page, day_count, week_count, month_count)
15
+ page.reload
16
+ page.day_count.should == day_count
17
+ page.week_count.should == week_count
18
+ page.month_count.should == month_count
19
+ end
20
+
21
+ def assert_keys_removed(page, *keys)
22
+ keys.each do |key|
23
+ doc = @page_class.collection.find_one({:_id => page.id})
24
+ doc.keys.should_not include(key)
25
+ end
26
+ end
27
+
28
+ context "ClassMethods" do
29
+ context "unset" do
30
+ setup do
31
+ @page = @page_class.create(:title => 'Home', :tags => %w(foo bar))
32
+ @page2 = @page_class.create(:title => 'Home')
33
+ end
34
+
35
+ should "work with criteria and keys" do
36
+ @page_class.unset({:title => 'Home'}, :title, :tags)
37
+ assert_keys_removed @page, :title, :tags
38
+ assert_keys_removed @page2, :title, :tags
39
+ end
40
+
41
+ should "work with ids and keys" do
42
+ @page_class.unset(@page.id, @page2.id, :title, :tags)
43
+ assert_keys_removed @page, :title, :tags
44
+ assert_keys_removed @page2, :title, :tags
45
+ end
46
+ end
47
+
48
+ context "increment" do
49
+ setup do
50
+ @page = @page_class.create(:title => 'Home')
51
+ @page2 = @page_class.create(:title => 'Home')
52
+ end
53
+
54
+ should "work with criteria and modifier hashes" do
55
+ @page_class.increment({:title => 'Home'}, :day_count => 1, :week_count => 2, :month_count => 3)
56
+
57
+ assert_page_counts @page, 1, 2, 3
58
+ assert_page_counts @page2, 1, 2, 3
59
+ end
60
+
61
+ should "work with ids and modifier hash" do
62
+ @page_class.increment(@page.id, @page2.id, :day_count => 1, :week_count => 2, :month_count => 3)
63
+
64
+ assert_page_counts @page, 1, 2, 3
65
+ assert_page_counts @page2, 1, 2, 3
66
+ end
67
+ end
68
+
69
+ context "decrement" do
70
+ setup do
71
+ @page = @page_class.create(:title => 'Home', :day_count => 1, :week_count => 2, :month_count => 3)
72
+ @page2 = @page_class.create(:title => 'Home', :day_count => 1, :week_count => 2, :month_count => 3)
73
+ end
74
+
75
+ should "work with criteria and modifier hashes" do
76
+ @page_class.decrement({:title => 'Home'}, :day_count => 1, :week_count => 2, :month_count => 3)
77
+
78
+ assert_page_counts @page, 0, 0, 0
79
+ assert_page_counts @page2, 0, 0, 0
80
+ end
81
+
82
+ should "work with ids and modifier hash" do
83
+ @page_class.decrement(@page.id, @page2.id, :day_count => 1, :week_count => 2, :month_count => 3)
84
+
85
+ assert_page_counts @page, 0, 0, 0
86
+ assert_page_counts @page2, 0, 0, 0
87
+ end
88
+
89
+ should "decrement with positive or negative numbers" do
90
+ @page_class.decrement(@page.id, @page2.id, :day_count => -1, :week_count => 2, :month_count => -3)
91
+
92
+ assert_page_counts @page, 0, 0, 0
93
+ assert_page_counts @page2, 0, 0, 0
94
+ end
95
+ end
96
+
97
+ context "set" do
98
+ setup do
99
+ @page = @page_class.create(:title => 'Home')
100
+ @page2 = @page_class.create(:title => 'Home')
101
+ end
102
+
103
+ should "work with criteria and modifier hashes" do
104
+ @page_class.set({:title => 'Home'}, :title => 'Home Revised')
105
+
106
+ @page.reload
107
+ @page.title.should == 'Home Revised'
108
+
109
+ @page2.reload
110
+ @page2.title.should == 'Home Revised'
111
+ end
112
+
113
+ should "work with ids and modifier hash" do
114
+ @page_class.set(@page.id, @page2.id, :title => 'Home Revised')
115
+
116
+ @page.reload
117
+ @page.title.should == 'Home Revised'
118
+
119
+ @page2.reload
120
+ @page2.title.should == 'Home Revised'
121
+ end
122
+
123
+ should "typecast values before querying" do
124
+ @page_class.key :tags, Set
125
+
126
+ assert_nothing_raised do
127
+ @page_class.set(@page.id, :tags => ['foo', 'bar'].to_set)
128
+ @page.reload
129
+ @page.tags.should == Set.new(['foo', 'bar'])
130
+ end
131
+ end
132
+
133
+ should "not typecast keys that are not defined in document" do
134
+ assert_raises(BSON::InvalidDocument) do
135
+ @page_class.set(@page.id, :colors => ['red', 'green'].to_set)
136
+ end
137
+ end
138
+
139
+ should "set keys that are not defined in document" do
140
+ @page_class.set(@page.id, :colors => %w[red green])
141
+ @page.reload
142
+ @page[:colors].should == %w[red green]
143
+ end
144
+ end
145
+
146
+ context "push" do
147
+ setup do
148
+ @page = @page_class.create(:title => 'Home')
149
+ @page2 = @page_class.create(:title => 'Home')
150
+ end
151
+
152
+ should "work with criteria and modifier hashes" do
153
+ @page_class.push({:title => 'Home'}, :tags => 'foo')
154
+
155
+ @page.reload
156
+ @page.tags.should == %w(foo)
157
+
158
+ @page2.reload
159
+ @page2.tags.should == %w(foo)
160
+ end
161
+
162
+ should "work with ids and modifier hash" do
163
+ @page_class.push(@page.id, @page2.id, :tags => 'foo')
164
+
165
+ @page.reload
166
+ @page.tags.should == %w(foo)
167
+
168
+ @page2.reload
169
+ @page2.tags.should == %w(foo)
170
+ end
171
+ end
172
+
173
+ context "push_all" do
174
+ setup do
175
+ @page = @page_class.create(:title => 'Home')
176
+ @page2 = @page_class.create(:title => 'Home')
177
+ @tags = %w(foo bar)
178
+ end
179
+
180
+ should "work with criteria and modifier hashes" do
181
+ @page_class.push_all({:title => 'Home'}, :tags => @tags)
182
+
183
+ @page.reload
184
+ @page.tags.should == @tags
185
+
186
+ @page2.reload
187
+ @page2.tags.should == @tags
188
+ end
189
+
190
+ should "work with ids and modifier hash" do
191
+ @page_class.push_all(@page.id, @page2.id, :tags => @tags)
192
+
193
+ @page.reload
194
+ @page.tags.should == @tags
195
+
196
+ @page2.reload
197
+ @page2.tags.should == @tags
198
+ end
199
+ end
200
+
201
+ context "pull" do
202
+ setup do
203
+ @page = @page_class.create(:title => 'Home', :tags => %w(foo bar))
204
+ @page2 = @page_class.create(:title => 'Home', :tags => %w(foo bar))
205
+ end
206
+
207
+ should "work with criteria and modifier hashes" do
208
+ @page_class.pull({:title => 'Home'}, :tags => 'foo')
209
+
210
+ @page.reload
211
+ @page.tags.should == %w(bar)
212
+
213
+ @page2.reload
214
+ @page2.tags.should == %w(bar)
215
+ end
216
+
217
+ should "be able to pull with ids and modifier hash" do
218
+ @page_class.pull(@page.id, @page2.id, :tags => 'foo')
219
+
220
+ @page.reload
221
+ @page.tags.should == %w(bar)
222
+
223
+ @page2.reload
224
+ @page2.tags.should == %w(bar)
225
+ end
226
+ end
227
+
228
+ context "pull_all" do
229
+ setup do
230
+ @page = @page_class.create(:title => 'Home', :tags => %w(foo bar baz))
231
+ @page2 = @page_class.create(:title => 'Home', :tags => %w(foo bar baz))
232
+ end
233
+
234
+ should "work with criteria and modifier hashes" do
235
+ @page_class.pull_all({:title => 'Home'}, :tags => %w(foo bar))
236
+
237
+ @page.reload
238
+ @page.tags.should == %w(baz)
239
+
240
+ @page2.reload
241
+ @page2.tags.should == %w(baz)
242
+ end
243
+
244
+ should "work with ids and modifier hash" do
245
+ @page_class.pull_all(@page.id, @page2.id, :tags => %w(foo bar))
246
+
247
+ @page.reload
248
+ @page.tags.should == %w(baz)
249
+
250
+ @page2.reload
251
+ @page2.tags.should == %w(baz)
252
+ end
253
+ end
254
+
255
+ context "add_to_set" do
256
+ setup do
257
+ @page = @page_class.create(:title => 'Home', :tags => 'foo')
258
+ @page2 = @page_class.create(:title => 'Home')
259
+ end
260
+
261
+ should "be able to add to set with criteria and modifier hash" do
262
+ @page_class.add_to_set({:title => 'Home'}, :tags => 'foo')
263
+
264
+ @page.reload
265
+ @page.tags.should == %w(foo)
266
+
267
+ @page2.reload
268
+ @page2.tags.should == %w(foo)
269
+ end
270
+
271
+ should "be able to add to set with ids and modifier hash" do
272
+ @page_class.add_to_set(@page.id, @page2.id, :tags => 'foo')
273
+
274
+ @page.reload
275
+ @page.tags.should == %w(foo)
276
+
277
+ @page2.reload
278
+ @page2.tags.should == %w(foo)
279
+ end
280
+ end
281
+
282
+ context "push_uniq" do
283
+ setup do
284
+ @page = @page_class.create(:title => 'Home', :tags => 'foo')
285
+ @page2 = @page_class.create(:title => 'Home')
286
+ end
287
+
288
+ should "be able to push uniq with criteria and modifier hash" do
289
+ @page_class.push_uniq({:title => 'Home'}, :tags => 'foo')
290
+
291
+ @page.reload
292
+ @page.tags.should == %w(foo)
293
+
294
+ @page2.reload
295
+ @page2.tags.should == %w(foo)
296
+ end
297
+
298
+ should "be able to push uniq with ids and modifier hash" do
299
+ @page_class.push_uniq(@page.id, @page2.id, :tags => 'foo')
300
+
301
+ @page.reload
302
+ @page.tags.should == %w(foo)
303
+
304
+ @page2.reload
305
+ @page2.tags.should == %w(foo)
306
+ end
307
+ end
308
+
309
+ context "pop" do
310
+ setup do
311
+ @page = @page_class.create(:title => 'Home', :tags => %w(foo bar))
312
+ end
313
+
314
+ should "be able to remove the last element the array" do
315
+ @page_class.pop(@page.id, :tags => 1)
316
+ @page.reload
317
+ @page.tags.should == %w(foo)
318
+ end
319
+
320
+ should "be able to remove the first element of the array" do
321
+ @page_class.pop(@page.id, :tags => -1)
322
+ @page.reload
323
+ @page.tags.should == %w(bar)
324
+ end
325
+ end
326
+
327
+ context "additional options (upsert & safe)" do
328
+ should "be able to pass upsert option" do
329
+ new_key_value = DateTime.now.to_s
330
+ @page_class.increment({:title => new_key_value}, {:day_count => 1}, {:upsert => true})
331
+ @page_class.count(:title => new_key_value).should == 1
332
+ @page_class.first(:title => new_key_value).day_count.should == 1
333
+ end
334
+
335
+ should "be able to pass safe option" do
336
+ @page_class.create(:title => "Better Be Safe than Sorry")
337
+
338
+ # We are trying to increment a key of type string here which should fail
339
+ assert_raises(Mongo::OperationFailure) do
340
+ @page_class.increment({:title => "Better Be Safe than Sorry"}, {:title => 1}, {:safe => true})
341
+ end
342
+ end
343
+
344
+ should "be able to pass both safe and upsert options" do
345
+ new_key_value = DateTime.now.to_s
346
+ @page_class.increment({:title => new_key_value}, {:day_count => 1}, {:upsert => true, :safe => true})
347
+ @page_class.count(:title => new_key_value).should == 1
348
+ @page_class.first(:title => new_key_value).day_count.should == 1
349
+ end
350
+ end
351
+ end
352
+
353
+ context "instance methods" do
354
+ should "be able to unset with keys" do
355
+ page = @page_class.create(:title => 'Foo', :tags => %w(foo))
356
+ page.unset(:title, :tags)
357
+ assert_keys_removed page, :title, :tags
358
+ end
359
+
360
+ should "be able to increment with modifier hashes" do
361
+ page = @page_class.create
362
+ page.increment(:day_count => 1, :week_count => 2, :month_count => 3)
363
+
364
+ assert_page_counts page, 1, 2, 3
365
+ end
366
+
367
+ should "be able to decrement with modifier hashes" do
368
+ page = @page_class.create(:day_count => 1, :week_count => 2, :month_count => 3)
369
+ page.decrement(:day_count => 1, :week_count => 2, :month_count => 3)
370
+
371
+ assert_page_counts page, 0, 0, 0
372
+ end
373
+
374
+ should "always decrement when decrement is called whether number is positive or negative" do
375
+ page = @page_class.create(:day_count => 1, :week_count => 2, :month_count => 3)
376
+ page.decrement(:day_count => -1, :week_count => 2, :month_count => -3)
377
+
378
+ assert_page_counts page, 0, 0, 0
379
+ end
380
+
381
+ should "be able to set with modifier hashes" do
382
+ page = @page_class.create(:title => 'Home')
383
+ page.set(:title => 'Home Revised')
384
+
385
+ page.reload
386
+ page.title.should == 'Home Revised'
387
+ end
388
+
389
+ should "be able to push with modifier hashes" do
390
+ page = @page_class.create
391
+ page.push(:tags => 'foo')
392
+
393
+ page.reload
394
+ page.tags.should == %w(foo)
395
+ end
396
+
397
+ should "be able to push_all with modifier hashes" do
398
+ page = @page_class.create
399
+ page.push_all(:tags => %w(foo bar))
400
+
401
+ page.reload
402
+ page.tags.should == %w(foo bar)
403
+ end
404
+
405
+ should "be able to pull with criteria and modifier hashes" do
406
+ page = @page_class.create(:tags => %w(foo bar))
407
+ page.pull(:tags => 'foo')
408
+
409
+ page.reload
410
+ page.tags.should == %w(bar)
411
+ end
412
+
413
+ should "be able to pull_all with criteria and modifier hashes" do
414
+ page = @page_class.create(:tags => %w(foo bar baz))
415
+ page.pull_all(:tags => %w(foo bar))
416
+
417
+ page.reload
418
+ page.tags.should == %w(baz)
419
+ end
420
+
421
+ should "be able to add_to_set with criteria and modifier hash" do
422
+ page = @page_class.create(:tags => 'foo')
423
+ page2 = @page_class.create
424
+
425
+ page.add_to_set(:tags => 'foo')
426
+ page2.add_to_set(:tags => 'foo')
427
+
428
+ page.reload
429
+ page.tags.should == %w(foo)
430
+
431
+ page2.reload
432
+ page2.tags.should == %w(foo)
433
+ end
434
+
435
+ should "be able to push uniq with criteria and modifier hash" do
436
+ page = @page_class.create(:tags => 'foo')
437
+ page2 = @page_class.create
438
+
439
+ page.push_uniq(:tags => 'foo')
440
+ page2.push_uniq(:tags => 'foo')
441
+
442
+ page.reload
443
+ page.tags.should == %w(foo)
444
+
445
+ page2.reload
446
+ page2.tags.should == %w(foo)
447
+ end
448
+
449
+ should "be able to pop with modifier hashes" do
450
+ page = @page_class.create(:tags => %w(foo bar))
451
+ page.pop(:tags => 1)
452
+
453
+ page.reload
454
+ page.tags.should == %w(foo)
455
+ end
456
+
457
+ should "be able to pass upsert option" do
458
+ page = @page_class.create(:title => "Upsert Page")
459
+ page.increment({:new_count => 1}, {:upsert => true})
460
+
461
+ page.reload
462
+ page.new_count.should == 1
463
+ end
464
+
465
+ should "be able to pass safe option" do
466
+ page = @page_class.create(:title => "Safe Page")
467
+
468
+ # We are trying to increment a key of type string here which should fail
469
+ assert_raises(Mongo::OperationFailure) do
470
+ page.increment({:title => 1}, {:safe => true})
471
+ end
472
+ end
473
+
474
+ should "be able to pass upsert and safe options" do
475
+ page = @page_class.create(:title => "Upsert and Safe Page")
476
+ page.increment({:another_count => 1}, {:upsert => true, :safe => true})
477
+
478
+ page.reload
479
+ page.another_count.should == 1
480
+ end
481
+
482
+ end
483
+ end