RUBY-204 Collection construct now has analogous API
to DB constructor (i.e., name comes first)
This commit is contained in:
parent
fa583762e7
commit
af0ecde925
@ -24,8 +24,8 @@ module Mongo
|
|||||||
|
|
||||||
# Initialize a collection object.
|
# Initialize a collection object.
|
||||||
#
|
#
|
||||||
# @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.
|
||||||
|
# @param [DB] db a MongoDB database instance.
|
||||||
#
|
#
|
||||||
# @option options [:create_pk] :pk (BSON::ObjectId) A primary key factory to use
|
# @option options [:create_pk] :pk (BSON::ObjectId) A primary key factory to use
|
||||||
# other than the default BSON::ObjectId.
|
# other than the default BSON::ObjectId.
|
||||||
@ -44,7 +44,13 @@ module Mongo
|
|||||||
# @return [Collection]
|
# @return [Collection]
|
||||||
#
|
#
|
||||||
# @core collections constructor_details
|
# @core collections constructor_details
|
||||||
def initialize(db, name, options={})
|
def initialize(name, db, options={})
|
||||||
|
if db.is_a?(String) && name.is_a?(Mongo::DB)
|
||||||
|
warn "Warning: the order of parameters to initialize a collection have changed. " +
|
||||||
|
"Please specify the collection name first, followed by the db."
|
||||||
|
db, name = name, db
|
||||||
|
end
|
||||||
|
|
||||||
case name
|
case name
|
||||||
when Symbol, String
|
when Symbol, String
|
||||||
else
|
else
|
||||||
@ -96,7 +102,7 @@ module Mongo
|
|||||||
# the specified sub-collection
|
# the specified sub-collection
|
||||||
def [](name)
|
def [](name)
|
||||||
name = "#{self.name}.#{name}"
|
name = "#{self.name}.#{name}"
|
||||||
return Collection.new(db, name) if !db.strict? || db.collection_names.include?(name)
|
return Collection.new(name, db) if !db.strict? || db.collection_names.include?(name)
|
||||||
raise "Collection #{name} doesn't exist. Currently in strict mode."
|
raise "Collection #{name} doesn't exist. Currently in strict mode."
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ module Mongo
|
|||||||
|
|
||||||
# Instances of DB are normally obtained by calling Mongo#db.
|
# Instances of DB are normally obtained by calling Mongo#db.
|
||||||
#
|
#
|
||||||
# @param [String] db_name the database name.
|
# @param [String] name the database name.
|
||||||
# @param [Mongo::Connection] connection a connection object pointing to MongoDB. Note
|
# @param [Mongo::Connection] connection a connection object pointing to MongoDB. Note
|
||||||
# that databases are usually instantiated via the Connection class. See the examples below.
|
# that databases are usually instantiated via the Connection class. See the examples below.
|
||||||
#
|
#
|
||||||
@ -76,8 +76,8 @@ module Mongo
|
|||||||
# @option options [Integer] :cache_time (300) Set the time that all ensure_index calls should cache the command.
|
# @option options [Integer] :cache_time (300) Set the time that all ensure_index calls should cache the command.
|
||||||
#
|
#
|
||||||
# @core databases constructor_details
|
# @core databases constructor_details
|
||||||
def initialize(db_name, connection, options={})
|
def initialize(name, connection, options={})
|
||||||
@name = Mongo::Support.validate_db_name(db_name)
|
@name = Mongo::Support.validate_db_name(name)
|
||||||
@connection = connection
|
@connection = connection
|
||||||
@strict = options[:strict]
|
@strict = options[:strict]
|
||||||
@pk_factory = options[:pk]
|
@pk_factory = options[:pk]
|
||||||
@ -208,8 +208,8 @@ module Mongo
|
|||||||
#
|
#
|
||||||
# @return [Array<Mongo::Collection>]
|
# @return [Array<Mongo::Collection>]
|
||||||
def collections
|
def collections
|
||||||
collection_names.map do |collection_name|
|
collection_names.map do |name|
|
||||||
Collection.new(self, collection_name)
|
Collection.new(name, self)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -223,7 +223,7 @@ module Mongo
|
|||||||
def collections_info(coll_name=nil)
|
def collections_info(coll_name=nil)
|
||||||
selector = {}
|
selector = {}
|
||||||
selector[:name] = full_collection_name(coll_name) if coll_name
|
selector[:name] = full_collection_name(coll_name) if coll_name
|
||||||
Cursor.new(Collection.new(self, SYSTEM_NAMESPACE_COLLECTION), :selector => selector)
|
Cursor.new(Collection.new(SYSTEM_NAMESPACE_COLLECTION, self), :selector => selector)
|
||||||
end
|
end
|
||||||
|
|
||||||
# Create a collection.
|
# Create a collection.
|
||||||
@ -252,7 +252,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(self, name)
|
return Collection.new(name, self)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -260,7 +260,7 @@ 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 => @pk_factory) if ok?(doc)
|
return Collection.new(name, self, :pk => @pk_factory) if ok?(doc)
|
||||||
raise MongoDBError, "Error creating collection: #{doc.inspect}"
|
raise MongoDBError, "Error creating collection: #{doc.inspect}"
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -278,7 +278,7 @@ module Mongo
|
|||||||
else
|
else
|
||||||
options[:safe] = options.fetch(:safe, @safe)
|
options[:safe] = options.fetch(:safe, @safe)
|
||||||
options.merge!(:pk => @pk_factory) unless options[:pk]
|
options.merge!(:pk => @pk_factory) unless options[:pk]
|
||||||
Collection.new(self, name, options)
|
Collection.new(name, self, options)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
alias_method :[], :collection
|
alias_method :[], :collection
|
||||||
@ -418,7 +418,7 @@ module Mongo
|
|||||||
def index_information(collection_name)
|
def index_information(collection_name)
|
||||||
sel = {:ns => full_collection_name(collection_name)}
|
sel = {:ns => full_collection_name(collection_name)}
|
||||||
info = {}
|
info = {}
|
||||||
Cursor.new(Collection.new(self, SYSTEM_INDEX_COLLECTION), :selector => sel).each do |index|
|
Cursor.new(Collection.new(SYSTEM_INDEX_COLLECTION, self), :selector => sel).each do |index|
|
||||||
info[index['name']] = index
|
info[index['name']] = index
|
||||||
end
|
end
|
||||||
info
|
info
|
||||||
@ -558,7 +558,7 @@ module Mongo
|
|||||||
#
|
#
|
||||||
# @return [Array] a list of documents containing profiling information.
|
# @return [Array] a list of documents containing profiling information.
|
||||||
def profiling_info
|
def profiling_info
|
||||||
Cursor.new(Collection.new(self, DB::SYSTEM_PROFILE_COLLECTION), :selector => {}).to_a
|
Cursor.new(Collection.new(SYSTEM_PROFILE_COLLECTION, self), :selector => {}).to_a
|
||||||
end
|
end
|
||||||
|
|
||||||
# Validate a named collection.
|
# Validate a named collection.
|
||||||
@ -581,7 +581,7 @@ module Mongo
|
|||||||
private
|
private
|
||||||
|
|
||||||
def system_command_collection
|
def system_command_collection
|
||||||
Collection.new(self, SYSTEM_COMMAND_COLLECTION)
|
Collection.new(SYSTEM_COMMAND_COLLECTION, self)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -32,11 +32,11 @@ class TestCollection < Test::Unit::TestCase
|
|||||||
end
|
end
|
||||||
|
|
||||||
def test_pk_factory_on_collection
|
def test_pk_factory_on_collection
|
||||||
@coll = Collection.new(@@db, 'foo', TestPK)
|
@coll = Collection.new('foo', @@db, TestPK)
|
||||||
assert_equal TestPK, @coll.pk_factory
|
assert_equal TestPK, @coll.pk_factory
|
||||||
|
|
||||||
|
|
||||||
@coll2 = Collection.new(@@db, 'foo', :pk => TestPK)
|
@coll2 = Collection.new('foo', @@db, :pk => TestPK)
|
||||||
assert_equal TestPK, @coll2.pk_factory
|
assert_equal TestPK, @coll2.pk_factory
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ class SafeTest < Test::Unit::TestCase
|
|||||||
col = @db['bar']
|
col = @db['bar']
|
||||||
assert_equal @safe_value, col.safe
|
assert_equal @safe_value, col.safe
|
||||||
|
|
||||||
col = Collection.new(@db, 'bar')
|
col = Collection.new('bar', @db)
|
||||||
assert_equal @safe_value, col.safe
|
assert_equal @safe_value, col.safe
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -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', :safe => false)
|
col = Collection.new('bar', @db, :safe => false)
|
||||||
assert_equal false, col.safe
|
assert_equal false, col.safe
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user