-
Notifications
You must be signed in to change notification settings - Fork 680
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
Add support for Rails 7.1 #686
Conversation
@@ -49,7 +49,11 @@ class Audit < ::ActiveRecord::Base | |||
cattr_accessor :audited_class_names | |||
self.audited_class_names = Set.new | |||
|
|||
serialize :audited_changes, YAMLIfTextColumnType | |||
if Rails.version >= "7.1" | |||
serialize :audited_changes, coder: YAMLIfTextColumnType |
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.
This addresses the deprecation warning below:
DEPRECATION WARNING: Passing the coder as positional argument is deprecated and will be removed in Rails 7.2.
Please pass the coder as a keyword argument:
serialize :audited_changes, coder: Audited::YAMLIfTextColumnType
(called from <class:Audit> at ~/lib/audited/audit.rb:55)
@@ -22,7 +22,8 @@ def audit_class | |||
|
|||
# remove audit_model in next major version it was only shortly present in 5.1.0 | |||
alias_method :audit_model, :audit_class | |||
deprecate audit_model: "use Audited.audit_class instead of Audited.audit_model. This method will be removed." | |||
deprecate audit_model: "use Audited.audit_class instead of Audited.audit_model. This method will be removed.", | |||
deprecator: ActiveSupport::Deprecation.new('6.0.0', 'Audited') |
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.
This addresses:
DEPRECATION WARNING: Module.deprecate without a deprecator is deprecated (called from singleton class at ~/lib/audited.rb:25)
config.active_record.yaml_column_permitted_classes = | ||
%w[String Symbol Integer NilClass Float Time Date FalseClass Hash Array DateTime TrueClass BigDecimal | ||
ActiveSupport::TimeWithZone ActiveSupport::TimeZone ActiveSupport::HashWithIndifferentAccess] | ||
end | ||
|
||
if Rails.version >= "7.1" | ||
config.active_support.cache_format_version = 7.1 |
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.
This addresses:
DEPRECATION WARNING: Support for `config.active_support.cache_format_version = 6.1` has been deprecated and will be removed in Rails 7.2.
Check the Rails upgrade guide at https://guides.rubyonrails.org/upgrading_ruby_on_rails.html#new-activesupport-cache-serialization-format
for more information on how to upgrade.
(called from <top (required)> at ~/spec/rails_app/config/environment.rb:5)
serialize :phone_numbers, Array | ||
|
||
if Rails.version >= "7.1" | ||
serialize :phone_numbers, type: Array |
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.
This addresses:
DEPRECATION WARNING: Passing the class as positional argument is deprecated and will be removed in Rails 7.2.
Please pass the class as a keyword argument:
serialize :phone_numbers, type: Array
(called from <class:User> at ~/spec/support/active_record/models.rb:15)
ActiveSupport::TimeWithZone, | ||
ActiveSupport::TimeZone, | ||
ActiveSupport::HashWithIndifferentAccess | ||
] |
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.
Apparently the elements of permitted classes need to be actual class objects rather than strings. Otherwise there would be a nuch of failing tests with the error message below:
19) Audited::Auditor revisions should be able to get time for first revision
Failure/Error: ActiveRecord::Coders::YAMLColumn.new(Object).dump(obj)
Psych::DisallowedClass:
Tried to dump unspecified class: ActiveSupport::TimeWithZone
# ./lib/audited/audit.rb:30:in `dump'
# ./lib/audited/auditor.rb:363:in `block in write_audit'
# ./lib/audited/auditor.rb:362:in `write_audit'
# ./lib/audited/auditor.rb:331:in `audit_create'
# ./spec/audited/auditor_spec.rb:820:in `block (3 levels) in <top (required)>'
I have taken a look at Psych's code, and it does seem like that this has always been class objects rather than strings. Not sure where the original setting has derived, but either way, this should fix the test for Rails 7.1.
This is great. Thanks! |
Just in time for 7.1 in a few days' time. Thank you @yuki24 and @danielmorrison for the release. 👏 |
@@ -49,7 +49,11 @@ class Audit < ::ActiveRecord::Base | |||
cattr_accessor :audited_class_names | |||
self.audited_class_names = Set.new | |||
|
|||
serialize :audited_changes, YAMLIfTextColumnType | |||
if Rails.version >= "7.1" |
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.
Might be better to use
Gem::Version.new(Rails.version) >= Gem::Version.new("7.1")
see
[8] pry(main)> Rails.version > "10.2.3"
=> true
[9] pry(main)> Gem::Version.new(Rails.version) >= Gem::Version.new("10.2.3")
=> false
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.
String version comparison is bad, agreed.
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.
Thank you for pointing this out!
See proposal for its resolution: #689
Fast on the heels of 7.0 here comes the latest and greatest Rails version! # What it does Gets us on Rails 7.1. # Why it is important Latest is greatest. And specifically this gets us access to background preprocessing of variants for finishing #1150 # Implementation notes * This gets us off the fork of `audited` we were using. The [change we switched for was upstreamed](collectiveidea/audited#609) and we need the [more recent work to make it compatible with Rails 7.1](collectiveidea/audited#686). Just a couple of code changes were needed and tests seem to be passing okay. * Updates us to [Devise 4.9.3](https://github.com/heartcombo/devise/blob/main/CHANGELOG.md#493---2023-10-11) which added Rails 7.1 support. - Note Devise 4.9.0 [added Hotwire + Turbo support](https://github.com/heartcombo/devise/blob/main/CHANGELOG.md#490---2023-02-17), something we might want to take a look at in either #1184 or a follow on task. * Includes a bump to Postgres 15 for the Docker and CI setups to match production. * The new Rails defaults in 7.1 raise in controllers when you mention an action that is not defined. This caught a couple of `before_action` typos. * Running `rake app:update` yielded diffs on many of the config files. I took all the changes to `bin` scripts whole hog and merged the rest. A second set of eyes across those diffs would be helpful though! 👀 * 💥 The upgrade caused an issue with threaded background work in tests whose fix is at the bottom of `config/environments/test.rb` with a note explaining. * 💡 I had neglected to update the Yarn dependencies for Rails in the 7 upgrade, so catching those up here. * 🚧 Asset compilation now runs on every execution of `bin/rails test` which made the SCSS deprecation warnings get pretty annoying. Pulling in a workaround from picturepan2/spectre#694 * Zeitwork (the new code autoloader) did not like `lib/rails_solargraph.rb`, so following a [comment on the referenced gist](https://gist.github.com/castwide/28b349566a223dfb439a337aea29713e?permalink_comment_id=4346127#gistcomment-4346127) I switch us to the solargraph-rails gem.
This PR adds:
I will leave comments to each change to provide more context. Addresses #685