Updated map-reduce tests and docs for v1.8 map-reduce options

This commit is contained in:
Kyle Banker 2011-02-22 17:47:47 -05:00
parent 9772328948
commit 24cfde5ef6
2 changed files with 33 additions and 5 deletions

View File

@ -521,13 +521,18 @@ module Mongo
# @option opts [Integer] :limit (nil) if passing a query, number of objects to return from the collection. # @option opts [Integer] :limit (nil) if passing a query, number of objects to return from the collection.
# @option opts [String, BSON::Code] :finalize (nil) a javascript function to apply to the result set after the # @option opts [String, BSON::Code] :finalize (nil) a javascript function to apply to the result set after the
# map/reduce operation has finished. # map/reduce operation has finished.
# @option opts [String] :out (nil) the name of the output collection. If specified, the collection will not be treated as temporary. # @option opts [String] :out (nil) a valid output type. In versions of MongoDB prior to v1.7.6,
# @option opts [Boolean] :keeptemp (false) if true, the generated collection will be persisted. default is false. # this option takes the name of a collection for the output results. In versions 1.7.6 and later,
# this option specifies the output type. See the core docs for available output types.
# @option opts [Boolean] :keeptemp (false) if true, the generated collection will be persisted. The defualt
# is false. Note that this option has no effect is versions of MongoDB > v1.7.6.
# @option opts [Boolean ] :verbose (false) if true, provides statistics on job execution time. # @option opts [Boolean ] :verbose (false) if true, provides statistics on job execution time.
# @option opts [Boolean] :raw (false) if true, return the raw result object from the map_reduce command, and not # @option opts [Boolean] :raw (false) if true, return the raw result object from the map_reduce command, and not
# the instantiated collection that's returned by default. # the instantiated collection that's returned by default. Note if a collection name isn't returned in the
# map-reduce output (as, for example, when using :out => {:inline => 1}), then this option will be
# forced to true.
# #
# @return [Collection] a collection containing the results of the operation. # @return [Collection, Hash] a Mongo::Collection object or a Hash with the map-reduce command's results.
# #
# @see http://www.mongodb.org/display/DOCS/MapReduce Offical MongoDB map/reduce documentation. # @see http://www.mongodb.org/display/DOCS/MapReduce Offical MongoDB map/reduce documentation.
# #
@ -548,7 +553,7 @@ module Mongo
raise Mongo::OperationFailure, "map-reduce failed: #{result['errmsg']}" raise Mongo::OperationFailure, "map-reduce failed: #{result['errmsg']}"
end end
if raw if raw || !result["result"]
result result
else else
@db[result["result"]] @db[result["result"]]

View File

@ -465,6 +465,29 @@ class TestCollection < Test::Unit::TestCase
assert res["counts"] assert res["counts"]
assert res["timeMillis"] assert res["timeMillis"]
end end
def test_map_reduce_with_collection_merge
@@test << {:user_id => 1}
@@test << {:user_id => 2}
output_collection = "test-map-coll"
m = Code.new("function() { emit(this.user_id, {count: 1}); }")
r = Code.new("function(k,vals) { var sum = 0;" +
" vals.forEach(function(v) { sum += v.count;} ); return {count: sum}; }")
res = @@test.map_reduce(m, r, :out => output_collection)
@@test.remove
@@test << {:user_id => 3}
res = @@test.map_reduce(m, r, :out => {:merge => output_collection})
assert res.find.to_a.any? {|doc| doc["_id"] == 3 && doc["value"]["count"] == 1}
@@test.remove
@@test << {:user_id => 3}
res = @@test.map_reduce(m, r, :out => {:reduce => output_collection})
assert res.find.to_a.any? {|doc| doc["_id"] == 3 && doc["value"]["count"] == 2}
res = @@test.map_reduce(m, r, :out => {:inline => 1})
assert res["results"]
end
end end
if @@version > "1.3.0" if @@version > "1.3.0"