mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
db5d26c9d7
It was causing error when using `with_options` passing a lambda as its
last argument.
class User < ActiveRecord::Base
with_options dependent: :destroy do |assoc|
assoc.has_many :profiles, -> { where(active: true) }
end
end
It was happening because the `option_merger` was taking the last
argument and checking if it was a Hash. This breaks the HasMany usage,
because its last argument can be a Hash or a Proc.
As the behavior described in this test:
https://github.com/rails/rails/blob/master/activesupport/test/option_merger_test.rb#L69
the method will only accept the lambda, this way it will keep the expected behavior. See 9eaa0a34
4 lines
96 B
Ruby
4 lines
96 B
Ruby
class Student < ActiveRecord::Base
|
|
has_and_belongs_to_many :lessons
|
|
belongs_to :college
|
|
end
|