From aacd52b8250680ab22beaeca618ba9c32c6b9666 Mon Sep 17 00:00:00 2001 From: Samuel Giddins Date: Mon, 9 Oct 2023 18:31:39 -0700 Subject: [PATCH] Test against rails 7.1 --- .github/workflows/tests.yml | 1 + Appraisals | 10 +++++++--- gemfiles/rails_6.0.gemfile | 2 +- gemfiles/rails_6.1.gemfile | 2 +- gemfiles/rails_7.0.gemfile | 2 +- gemfiles/rails_7.1.gemfile | 21 ++++++++++++++++++++ lib/clearance/authentication.rb | 8 +++++++- lib/clearance/testing/deny_access_matcher.rb | 2 +- spec/support/request_with_remember_token.rb | 7 +------ 9 files changed, 41 insertions(+), 14 deletions(-) create mode 100644 gemfiles/rails_7.1.gemfile diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 80380bd7..0f4c5e14 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -19,6 +19,7 @@ jobs: - "6.0" - "6.1" - "7.0" + - "7.1" ruby: - "2.7.6" - "3.0.4" diff --git a/Appraisals b/Appraisals index 69947f18..466faf4f 100644 --- a/Appraisals +++ b/Appraisals @@ -1,14 +1,18 @@ appraise "rails_6.0" do - gem "railties", "~> 6.0" + gem "railties", "~> 6.0.0" gem "net-smtp", require: false # not bundled in ruby 3.1 gem "psych", "< 4" # psych 4 switched from unsafe load to safe load end appraise "rails_6.1" do - gem "railties", "~> 6.1" + gem "railties", "~> 6.1.0" gem "net-smtp", require: false # not bundled in ruby 3.1 end appraise "rails_7.0" do - gem "railties", "~> 7.0" + gem "railties", "~> 7.0.0" +end + +appraise "rails_7.1" do + gem "railties", "~> 7.1.0" end diff --git a/gemfiles/rails_6.0.gemfile b/gemfiles/rails_6.0.gemfile index e7b10b92..8896d145 100644 --- a/gemfiles/rails_6.0.gemfile +++ b/gemfiles/rails_6.0.gemfile @@ -16,7 +16,7 @@ gem "rspec-rails" gem "shoulda-matchers" gem "sqlite3" gem "timecop" -gem "railties", "~> 6.0" +gem "railties", "~> 6.0.0" gem "net-smtp", require: false gem "psych", "< 4" diff --git a/gemfiles/rails_6.1.gemfile b/gemfiles/rails_6.1.gemfile index c6ddb455..1db7a9f3 100644 --- a/gemfiles/rails_6.1.gemfile +++ b/gemfiles/rails_6.1.gemfile @@ -16,7 +16,7 @@ gem "rspec-rails" gem "shoulda-matchers" gem "sqlite3" gem "timecop" -gem "railties", "~> 6.1" +gem "railties", "~> 6.1.0" gem "net-smtp", require: false gemspec path: "../" diff --git a/gemfiles/rails_7.0.gemfile b/gemfiles/rails_7.0.gemfile index 0d33ed33..349636f7 100644 --- a/gemfiles/rails_7.0.gemfile +++ b/gemfiles/rails_7.0.gemfile @@ -16,6 +16,6 @@ gem "rspec-rails" gem "shoulda-matchers" gem "sqlite3" gem "timecop" -gem "railties", "~> 7.0" +gem "railties", "~> 7.0.0" gemspec path: "../" diff --git a/gemfiles/rails_7.1.gemfile b/gemfiles/rails_7.1.gemfile new file mode 100644 index 00000000..8726d560 --- /dev/null +++ b/gemfiles/rails_7.1.gemfile @@ -0,0 +1,21 @@ +# This file was generated by Appraisal + +source "https://rubygems.org" + +gem "addressable" +gem "ammeter" +gem "appraisal" +gem "capybara" +gem "database_cleaner" +gem "erb_lint", require: false +gem "factory_bot_rails" +gem "nokogiri" +gem "pry", require: false +gem "rails-controller-testing" +gem "rspec-rails" +gem "shoulda-matchers" +gem "sqlite3" +gem "timecop" +gem "railties", "~> 7.1.0" + +gemspec path: "../" diff --git a/lib/clearance/authentication.rb b/lib/clearance/authentication.rb index a582cd8e..733e005c 100644 --- a/lib/clearance/authentication.rb +++ b/lib/clearance/authentication.rb @@ -66,7 +66,13 @@ def sign_in(user, &block) clearance_session.sign_in(user, &block) if signed_in? && Clearance.configuration.rotate_csrf_on_sign_in? - session.delete(:_csrf_token) + if request.respond_to?(:controller_instance) && \ + request.controller_instance.respond_to?(:reset_csrf_token) + # Rails 7.1+ + request.controller_instance.reset_csrf_token(request) + else + request.session.try(:delete, :_csrf_token) + end form_authenticity_token end end diff --git a/lib/clearance/testing/deny_access_matcher.rb b/lib/clearance/testing/deny_access_matcher.rb index 470daa3c..dfa9cc26 100644 --- a/lib/clearance/testing/deny_access_matcher.rb +++ b/lib/clearance/testing/deny_access_matcher.rb @@ -90,7 +90,7 @@ def redirects_to_url? @failure_message_when_negated << "Didn't expect to redirect to #{@url}." true - rescue Minitest::Assertion, ::Test::Unit::AssertionFailedError + rescue ::Minitest::Assertion, ::Test::Unit::AssertionFailedError @failure_message << "Expected to redirect to #{@url} but did not." false end diff --git a/spec/support/request_with_remember_token.rb b/spec/support/request_with_remember_token.rb index 39cf6ba4..a5da41e0 100644 --- a/spec/support/request_with_remember_token.rb +++ b/spec/support/request_with_remember_token.rb @@ -16,12 +16,7 @@ def request_without_remember_token end def remember_token_cookies - cookies = headers["Set-Cookie"] || headers["set-cookie"] - if cookies.is_a?(String) - cookie_lines = cookies.lines.map(&:chomp) - else - cookie_lines = cookies - end + cookie_lines = Array(headers["Set-Cookie"]).join("\n").lines.map(&:chomp) cookie_lines.select { |name| name =~ /^remember_token/ } end end