Skip to content

Commit

Permalink
Merge pull request #4715 from pwim/find-create-multi-args
Browse files Browse the repository at this point in the history
Fix regression from Rails 3.1
  • Loading branch information
jonleighton committed Jan 27, 2012
2 parents faaf694 + 7b9baee commit f22a0e2
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 1 deletion.
2 changes: 1 addition & 1 deletion activerecord/lib/active_record/dynamic_matchers.rb
Expand Up @@ -25,7 +25,7 @@ def method_missing(method_id, *arguments, &block)
if match = (DynamicFinderMatch.match(method_id) || DynamicScopeMatch.match(method_id))
attribute_names = match.attribute_names
super unless all_attributes_exists?(attribute_names)
if arguments.size < attribute_names.size
if !(match.is_a?(DynamicFinderMatch) && match.instantiator? && arguments.first.is_a?(Hash)) && arguments.size < attribute_names.size
method_trace = "#{__FILE__}:#{__LINE__}:in `#{method_id}'"
backtrace = [method_trace] + caller
raise ArgumentError, "wrong number of arguments (#{arguments.size} for #{attribute_names.size})", backtrace
Expand Down
11 changes: 11 additions & 0 deletions activerecord/test/cases/finder_test.rb
Expand Up @@ -881,6 +881,17 @@ def test_find_or_create_from_one_attribute_and_hash
assert_equal 23, sig38.client_of
end

def test_find_or_create_from_two_attributes_and_hash
number_of_companies = Company.count
sig38 = Company.find_or_create_by_name_and_firm_id({:name => "38signals", :firm_id => 17, :client_of => 23})
assert_equal number_of_companies + 1, Company.count
assert_equal sig38, Company.find_or_create_by_name_and_firm_id({:name => "38signals", :firm_id => 17, :client_of => 23})
assert sig38.persisted?
assert_equal "38signals", sig38.name
assert_equal 17, sig38.firm_id
assert_equal 23, sig38.client_of
end

def test_find_or_create_from_one_aggregate_attribute
number_of_customers = Customer.count
created_customer = Customer.find_or_create_by_balance(Money.new(123))
Expand Down

0 comments on commit f22a0e2

Please sign in to comment.