Specify pk factory on Collection.new as a :pk option
This commit is contained in:
parent
888c318ad2
commit
a2f501924e
@ -28,6 +28,9 @@ module Mongo
|
|||||||
# @param [DB] db a MongoDB database instance.
|
# @param [DB] db a MongoDB database instance.
|
||||||
# @param [String, Symbol] name the name of the collection.
|
# @param [String, Symbol] name the name of the collection.
|
||||||
#
|
#
|
||||||
|
# @option options [:create_pk] :pk (BSON::ObjectId) A primary key factory to use
|
||||||
|
# other than the default BSON::ObjectId.
|
||||||
|
#
|
||||||
# @option options [Boolean, Hash] :safe (false) Set the default safe-mode options
|
# @option options [Boolean, Hash] :safe (false) Set the default safe-mode options
|
||||||
# for insert, update, and remove method called on this Collection instance. If no
|
# for insert, update, and remove method called on this Collection instance. If no
|
||||||
# value is provided, the default value set on this instance's DB will be used. This
|
# value is provided, the default value set on this instance's DB will be used. This
|
||||||
@ -42,7 +45,7 @@ module Mongo
|
|||||||
# @return [Collection]
|
# @return [Collection]
|
||||||
#
|
#
|
||||||
# @core collections constructor_details
|
# @core collections constructor_details
|
||||||
def initialize(db, name, pk_factory=nil, options={})
|
def initialize(db, name, options={})
|
||||||
case name
|
case name
|
||||||
when Symbol, String
|
when Symbol, String
|
||||||
else
|
else
|
||||||
@ -61,11 +64,21 @@ module Mongo
|
|||||||
raise Mongo::InvalidNSName, "collection names must not start or end with '.'"
|
raise Mongo::InvalidNSName, "collection names must not start or end with '.'"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if options.respond_to?(:create_pk) || !options.is_a?(Hash)
|
||||||
|
warn "The method for specifying a primary key factory on a Collection has changed.\n" +
|
||||||
|
"Please specify it as an option (e.g., :pk => PkFactory)."
|
||||||
|
pk_factory = options
|
||||||
|
else
|
||||||
|
pk_factory = nil
|
||||||
|
end
|
||||||
|
|
||||||
@db, @name = db, name
|
@db, @name = db, name
|
||||||
@connection = @db.connection
|
@connection = @db.connection
|
||||||
@logger = @connection.logger
|
@logger = @connection.logger
|
||||||
@pk_factory = pk_factory || BSON::ObjectId
|
unless pk_factory
|
||||||
@safe = options.has_key?(:safe) ? options[:safe] : @db.safe
|
@safe = options.has_key?(:safe) ? options[:safe] : @db.safe
|
||||||
|
end
|
||||||
|
@pk_factory = pk_factory || options[:pk] || BSON::ObjectId
|
||||||
@hint = nil
|
@hint = nil
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -255,13 +255,14 @@ module Mongo
|
|||||||
oh = BSON::OrderedHash.new
|
oh = BSON::OrderedHash.new
|
||||||
oh[:create] = name
|
oh[:create] = name
|
||||||
doc = command(oh.merge(options || {}))
|
doc = command(oh.merge(options || {}))
|
||||||
return Collection.new(self, name, @pk_factory) if ok?(doc)
|
return Collection.new(self, name, :pk => @pk_factory) if ok?(doc)
|
||||||
raise MongoDBError, "Error creating collection: #{doc.inspect}"
|
raise MongoDBError, "Error creating collection: #{doc.inspect}"
|
||||||
end
|
end
|
||||||
|
|
||||||
# Get a collection by name.
|
# Get a collection by name.
|
||||||
#
|
#
|
||||||
# @param [String] name the collection name.
|
# @param [String] name the collection name.
|
||||||
|
# @param [Hash] options any valid options that can me 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.
|
||||||
#
|
#
|
||||||
@ -271,7 +272,8 @@ module Mongo
|
|||||||
raise Mongo::MongoDBError, "Collection #{name} doesn't exist. Currently in strict mode."
|
raise Mongo::MongoDBError, "Collection #{name} doesn't exist. Currently in strict mode."
|
||||||
else
|
else
|
||||||
options[:safe] = options.has_key?(:safe) ? options[:safe] : @safe
|
options[:safe] = options.has_key?(:safe) ? options[:safe] : @safe
|
||||||
Collection.new(self, name, @pk_factory, options)
|
options.merge!(:pk => @pk_factory) unless options[:pk]
|
||||||
|
Collection.new(self, name, options)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
alias_method :[], :collection
|
alias_method :[], :collection
|
||||||
|
@ -26,6 +26,20 @@ class TestCollection < Test::Unit::TestCase
|
|||||||
assert @coll.pk_factory.is_a?(Object)
|
assert @coll.pk_factory.is_a?(Object)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
class TestPK
|
||||||
|
def self.create_pk
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def test_pk_factory_on_collection
|
||||||
|
@coll = Collection.new(@@db, 'foo', TestPK)
|
||||||
|
assert_equal TestPK, @coll.pk_factory
|
||||||
|
|
||||||
|
|
||||||
|
@coll2 = Collection.new(@@db, 'foo', :pk => TestPK)
|
||||||
|
assert_equal TestPK, @coll2.pk_factory
|
||||||
|
end
|
||||||
|
|
||||||
def test_valid_names
|
def test_valid_names
|
||||||
assert_raise Mongo::InvalidNSName do
|
assert_raise Mongo::InvalidNSName do
|
||||||
@@db["te$t"]
|
@@db["te$t"]
|
||||||
|
@ -48,7 +48,7 @@ class SafeTest < Test::Unit::TestCase
|
|||||||
col = @db.collection('bar', :safe => false)
|
col = @db.collection('bar', :safe => false)
|
||||||
assert_equal false, col.safe
|
assert_equal false, col.safe
|
||||||
|
|
||||||
col = Collection.new(@db, 'bar', nil, :safe => false)
|
col = Collection.new(@db, 'bar', :safe => false)
|
||||||
assert_equal false, col.safe
|
assert_equal false, col.safe
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user