aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/test/models/project.rb
diff options
context:
space:
mode:
authorSean Griffin <sean@seantheprogrammer.com>2015-10-29 16:46:57 -0600
committerSean Griffin <sean@seantheprogrammer.com>2015-10-29 16:53:49 -0600
commit21a386bb0726cce4f4a5d64d55fbb55d8a2b9837 (patch)
tree2938e27f69482aa6f8adaf7d9d0155bf401c20be /activerecord/test/models/project.rb
parent9f93a5efbba3e1cbf0bfa700a17ec8d1ef60d7c6 (diff)
downloadrails-21a386bb0726cce4f4a5d64d55fbb55d8a2b9837.tar.gz
rails-21a386bb0726cce4f4a5d64d55fbb55d8a2b9837.tar.bz2
rails-21a386bb0726cce4f4a5d64d55fbb55d8a2b9837.zip
Ensure `has_and_belongs_to_many` works with `belongs_to_required_by_default`
Before this commit, if `ActiveRecord::Base.belongs_to_required_by_default` is set to `true`, then creating a record through `has_and_belongs_to_many` fails with the cryptic error message `Left side must exist`. This is because `inverse_of` isn't working properly in this case, presumably since we're doing trickery with anonymous classes in the middle. Rather than following this rabbit hole to try and get `inverse_of` to work in a case that we know is not publicly supported, we can just turn off this validation to match the behavior of 4.2 and earlier.
Diffstat (limited to 'activerecord/test/models/project.rb')
-rw-r--r--activerecord/test/models/project.rb8
1 files changed, 8 insertions, 0 deletions
diff --git a/activerecord/test/models/project.rb b/activerecord/test/models/project.rb
index b034e0e267..efa8246f1e 100644
--- a/activerecord/test/models/project.rb
+++ b/activerecord/test/models/project.rb
@@ -15,6 +15,14 @@ class Project < ActiveRecord::Base
belongs_to :firm
has_one :lead_developer, through: :firm, inverse_of: :contracted_projects
+ begin
+ previous_value, ActiveRecord::Base.belongs_to_required_by_default =
+ ActiveRecord::Base.belongs_to_required_by_default, true
+ has_and_belongs_to_many :developers_required_by_default, class_name: "Developer"
+ ensure
+ ActiveRecord::Base.belongs_to_required_by_default = previous_value
+ end
+
attr_accessor :developers_log
after_initialize :set_developers_log