Fix Mongo::Cursor#query_options_hash

This commit is contained in:
Wojciech Piekutowski 2011-02-20 16:22:39 +01:00
parent e4867b542e
commit 5dfac28dd4
2 changed files with 15 additions and 7 deletions

View File

@ -307,8 +307,8 @@ module Mongo
def query_options_hash def query_options_hash
{ :selector => @selector, { :selector => @selector,
:fields => @fields, :fields => @fields,
:skip => @skip_num, :skip => @skip,
:limit => @limit_num, :limit => @limit,
:order => @order, :order => @order,
:hint => @hint, :hint => @hint,
:snapshot => @snapshot, :snapshot => @snapshot,

View File

@ -12,28 +12,32 @@ class CursorTest < Test::Unit::TestCase
end end
should "set timeout" do should "set timeout" do
assert_equal true, @cursor.timeout assert @cursor.timeout
assert @cursor.query_options_hash[:timeout]
end end
should "set selector" do should "set selector" do
assert @cursor.selector == {} assert_equal({}, @cursor.selector)
@cursor = Cursor.new(@collection, :selector => {:name => "Jones"}) @cursor = Cursor.new(@collection, :selector => {:name => "Jones"})
assert @cursor.selector == {:name => "Jones"} assert_equal({:name => "Jones"}, @cursor.selector)
assert_equal({:name => "Jones"}, @cursor.query_options_hash[:selector])
end end
should "set fields" do should "set fields" do
assert_nil @cursor.fields assert_nil @cursor.fields
@cursor = Cursor.new(@collection, :fields => [:name, :date]) @cursor = Cursor.new(@collection, :fields => [:name, :date])
assert @cursor.fields == {:name => 1, :date => 1} assert_equal({:name => 1, :date => 1}, @cursor.fields)
assert_equal({:name => 1, :date => 1}, @cursor.query_options_hash[:fields])
end end
should "set mix fields 0 and 1" do should "set mix fields 0 and 1" do
assert_nil @cursor.fields assert_nil @cursor.fields
@cursor = Cursor.new(@collection, :fields => {:name => 1, :date => 0}) @cursor = Cursor.new(@collection, :fields => {:name => 1, :date => 0})
assert @cursor.fields == {:name => 1, :date => 0} assert_equal({:name => 1, :date => 0}, @cursor.fields)
assert_equal({:name => 1, :date => 0}, @cursor.query_options_hash[:fields])
end end
should "set limit" do should "set limit" do
@ -41,6 +45,7 @@ class CursorTest < Test::Unit::TestCase
@cursor = Cursor.new(@collection, :limit => 10) @cursor = Cursor.new(@collection, :limit => 10)
assert_equal 10, @cursor.limit assert_equal 10, @cursor.limit
assert_equal 10, @cursor.query_options_hash[:limit]
end end
@ -49,6 +54,7 @@ class CursorTest < Test::Unit::TestCase
@cursor = Cursor.new(@collection, :skip => 5) @cursor = Cursor.new(@collection, :skip => 5)
assert_equal 5, @cursor.skip assert_equal 5, @cursor.skip
assert_equal 5, @cursor.query_options_hash[:skip]
end end
should "set sort order" do should "set sort order" do
@ -56,6 +62,7 @@ class CursorTest < Test::Unit::TestCase
@cursor = Cursor.new(@collection, :order => "last_name") @cursor = Cursor.new(@collection, :order => "last_name")
assert_equal "last_name", @cursor.order assert_equal "last_name", @cursor.order
assert_equal "last_name", @cursor.query_options_hash[:order]
end end
should "set hint" do should "set hint" do
@ -63,6 +70,7 @@ class CursorTest < Test::Unit::TestCase
@cursor = Cursor.new(@collection, :hint => "name") @cursor = Cursor.new(@collection, :hint => "name")
assert_equal "name", @cursor.hint assert_equal "name", @cursor.hint
assert_equal "name", @cursor.query_options_hash[:hint]
end end
should "cache full collection name" do should "cache full collection name" do