-
Notifications
You must be signed in to change notification settings - Fork 133
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Generate *_changed? and *_previously_changed? sigs for belongs_to relations #1955
Conversation
Models with a belongs_to relation now have a `_changed?` and `_previously_changed?` method since rails/rails#42751. This shipped in Rails 7, see https://github.com/rails/rails/blob/b84fa1083ca7e6422356fdf80cb33751d0a23eff/activerecord/CHANGELOG.md#rails-700alpha1-september-15-2021.
@@ -206,6 +206,16 @@ def populate_single_assoc_getter_setter(klass, association_name, reflection) | |||
"reset_#{association_name}", | |||
return_type: "void", | |||
) | |||
if reflection.is_a?(ActiveRecord::Reflection::BelongsToReflection) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a good way of checking the version of Rails being targeted? We could avoid generating these signatures for pre-Rails 7 if so.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure if it's recommended but it looks like you could do this
if reflection.is_a?(ActiveRecord::Reflection::BelongsToReflection) | |
if reflection.is_a?(ActiveRecord::Reflection::BelongsToReflection) && Rails::VERSION::MAJOR >= 7 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ooh, thanks! I'll look around the repo, see if there are other such checks like this and, if so, I'll add this one.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can use RubyGems API
if ::Gem::Requirement.new(">= 7.0").satisfied_by?(::ActiveJob.gem_version) |
And in tests you can use the template
and rails_version
helpers
<% if rails_version(">= 7.0") %> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That worked great, thank you!
I have signed the CLA! |
https: //github.com/Shopify/pull/1955#discussion_r1678141642 Co-Authored-By: Ufuk Kayserilioglu <224488+paracycle@users.noreply.github.com>
https: //github.com/Shopify/pull/1955#discussion_r1678141696 Co-Authored-By: Ufuk Kayserilioglu <224488+paracycle@users.noreply.github.com>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the changes, this looks great!
HI Respected ma'am I am having a problem in getting my profile approved for the GitHub sponsorship and for that I was searching on the community discussion page for the answer and then I found one question or problem similar to me and you solved it then I check your profile and then I know that you are the staff of the GitHub so please view my profile and repository and please approve my profile for GitHub sponsorship please it will mean a lit for me |
Motivation
Models with a
belongs_to
relation now have a_changed?
and_previously_changed?
method since rails/rails#42751. This shipped in Rails 7, see https://github.com/rails/rails/blob/b84fa1083ca7e6422356fdf80cb33751d0a23eff/activerecord/CHANGELOG.md#rails-700alpha1-september-15-2021.I noticed in my project Sorbet was giving me an error about my model not having a
foo_changed?
method when I had abelongs_to :foo
, even though arespond_to?(:foo_changed?)
returned true.Implementation
I referenced existing
_changed?
method generation for regular columns on a model:tapioca/lib/tapioca/dsl/compilers/active_record_columns.rb
Lines 296 to 305 in df5079f
While @erinnachen pointed out https://github.com/Shopify/tapioca/blob/main/lib/tapioca/dsl/compilers/active_record_associations.rb looked to be the compiler for methods coming from
belongs_to
relations, so I added the new method generation there.I verified in the Rails implementation in https://github.com/rails/rails/pull/42751/files#diff-084ec489ba3b9f2e388734a99876f0d94776111278acfe4901235dca570040c5 that the new methods take no parameters.
Tests
I updated existing tests to expect the new method signatures to be present.