Method *create_colletion* behaves the same way as *collection*

when options are passed.
This commit is contained in:
Mauro Pompilio 2011-03-28 04:37:48 +01:00 committed by Kyle Banker
parent c9da58965a
commit baa1d0b802
2 changed files with 14 additions and 3 deletions

View File

@ -69,7 +69,7 @@ module Mongo
# the factory should not inject a new key). # the factory should not inject a new key).
# #
# @option opts [Boolean, Hash] :safe (false) Set the default safe-mode options # @option opts [Boolean, Hash] :safe (false) Set the default safe-mode options
# propogated to Collection objects instantiated off of this DB. If no # propagated to Collection objects instantiated off of this DB. If no
# value is provided, the default value set on this instance's Connection object will be used. This # value is provided, the default value set on this instance's Connection object will be used. This
# default can be overridden upon instantiation of any collection by explicity setting a :safe value # default can be overridden upon instantiation of any collection by explicity setting a :safe value
# on initialization # on initialization
@ -272,7 +272,7 @@ module Mongo
if strict? if strict?
raise MongoDBError, "Collection #{name} already exists. Currently in strict mode." raise MongoDBError, "Collection #{name} already exists. Currently in strict mode."
else else
return Collection.new(name, self) return Collection.new(name, self, opts)
end end
end end
@ -287,7 +287,7 @@ module Mongo
# Get a collection by name. # Get a collection by name.
# #
# @param [String] name the collection name. # @param [String] name the collection name.
# @param [Hash] opts any valid options that can me passed to Collection#new. # @param [Hash] opts any valid options that can be passed to Collection#new.
# #
# @raise [MongoDBError] if collection does not already exist and we're in +strict+ mode. # @raise [MongoDBError] if collection does not already exist and we're in +strict+ mode.
# #

View File

@ -270,6 +270,17 @@ class DBAPITest < Test::Unit::TestCase
end end
end end
def test_collection_options_are_passed_to_the_existing_ones
@@db.drop_collection('foobar')
@@db.create_collection('foobar')
opts = {:safe => true}
coll = @@db.create_collection('foobar', opts)
assert_equal true, coll.safe
end
def test_index_information def test_index_information
assert_equal @@coll.index_information.length, 1 assert_equal @@coll.index_information.length, 1