1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

Merge pull request #10992 from Empact/find-each-enumerator

When .find_each is called without a block, return an Enumerator.
This commit is contained in:
Carlos Antonio da Silva 2013-06-25 20:09:17 -03:00
commit 840c552047
3 changed files with 36 additions and 2 deletions

View file

@ -1,3 +1,8 @@
* `find_each` now returns an `Enumerator` when called without a block, so that it
can be chained with other `Enumerable` methods.
*Ben Woosley*
* `ActiveRecord::Result.each` now returns an `Enumerator` when called without
a block, so that it can be chained with other `Enumerable` methods.

View file

@ -19,6 +19,13 @@ module ActiveRecord
# person.party_all_night!
# end
#
# If you do not provide a block to #find_each, it will return an Enumerator
# for chaining with other methods:
#
# Person.find_each.with_index do |person, index|
# person.award_trophy(index + 1)
# end
#
# ==== Options
# * <tt>:batch_size</tt> - Specifies the size of the batch. Default to 1000.
# * <tt>:start</tt> - Specifies the starting point for the batch processing.
@ -40,8 +47,12 @@ module ActiveRecord
# NOTE: You can't set the limit either, that's used to control
# the batch sizes.
def find_each(options = {})
find_in_batches(options) do |records|
records.each { |record| yield record }
if block_given?
find_in_batches(options) do |records|
records.each { |record| yield record }
end
else
enum_for :find_each, options
end
end

View file

@ -26,6 +26,24 @@ class EachTest < ActiveRecord::TestCase
end
end
def test_each_should_return_an_enumerator_if_no_block_is_present
assert_queries(1) do
Post.find_each(:batch_size => 100000).with_index do |post, index|
assert_kind_of Post, post
assert_kind_of Integer, index
end
end
end
def test_each_enumerator_should_execute_one_query_per_batch
assert_queries(@total + 1) do
Post.find_each(:batch_size => 1).with_index do |post, index|
assert_kind_of Post, post
assert_kind_of Integer, index
end
end
end
def test_each_should_raise_if_select_is_set_without_id
assert_raise(RuntimeError) do
Post.select(:title).find_each(:batch_size => 1) { |post| post }