Method *create_colletion* behaves the same way as *collection*
when options are passed.
This commit is contained in:
parent
c9da58965a
commit
baa1d0b802
@ -69,7 +69,7 @@ module Mongo
|
||||
# the factory should not inject a new key).
|
||||
#
|
||||
# @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
|
||||
# default can be overridden upon instantiation of any collection by explicity setting a :safe value
|
||||
# on initialization
|
||||
@ -272,7 +272,7 @@ module Mongo
|
||||
if strict?
|
||||
raise MongoDBError, "Collection #{name} already exists. Currently in strict mode."
|
||||
else
|
||||
return Collection.new(name, self)
|
||||
return Collection.new(name, self, opts)
|
||||
end
|
||||
end
|
||||
|
||||
@ -287,7 +287,7 @@ module Mongo
|
||||
# Get a collection by 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.
|
||||
#
|
||||
|
@ -270,6 +270,17 @@ class DBAPITest < Test::Unit::TestCase
|
||||
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
|
||||
assert_equal @@coll.index_information.length, 1
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user