diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 77965ddc..1842dce3 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -8,17 +8,21 @@ jobs: strategy: matrix: ruby_version: ['2.7', '3.0', '3.1', '3.2'] - rails_gemfile: ['6.0', '6.1', '7.0', '7.1'] + rails_gemfile: ['6.0', '6.1', '7.0', '7.1', '7.2'] postgres_version: ['14'] include: # Postgres versions - - { ruby_version: '3.2', rails_gemfile: '7.1', postgres_version: '9' } - - { ruby_version: '3.2', rails_gemfile: '7.1', postgres_version: '10' } - - { ruby_version: '3.2', rails_gemfile: '7.1', postgres_version: '11' } - - { ruby_version: '3.2', rails_gemfile: '7.1', postgres_version: '12' } - - { ruby_version: '3.2', rails_gemfile: '7.1', postgres_version: '13' } - - { ruby_version: '3.2', rails_gemfile: '7.1', postgres_version: '14' } - exclude: [] + - { ruby_version: '3.2', rails_gemfile: '7.2', postgres_version: '9' } + - { ruby_version: '3.2', rails_gemfile: '7.2', postgres_version: '10' } + - { ruby_version: '3.2', rails_gemfile: '7.2', postgres_version: '11' } + - { ruby_version: '3.2', rails_gemfile: '7.2', postgres_version: '12' } + - { ruby_version: '3.2', rails_gemfile: '7.2', postgres_version: '13' } + - { ruby_version: '3.2', rails_gemfile: '7.2', postgres_version: '14' } + exclude: # Rails 7.2 is not compatible with Ruby < 3.1 + - ruby_version: '2.7' + rails_gemfile: '7.2' + - ruby_version: '3.0' + rails_gemfile: '7.2' name: "Test: Ruby ${{ matrix.ruby_version }}, Rails ${{ matrix.rails_gemfile }}, PostgreSQL ${{ matrix.postgres_version }}" services: db: diff --git a/Gemfile b/Gemfile index 7b048d5f..eeec1ae1 100644 --- a/Gemfile +++ b/Gemfile @@ -6,8 +6,8 @@ source 'https://rubygems.org' group :development, :test do gem 'rake' - gem 'activerecord', '~> 7.1.0', require: nil - gem 'activejob', '~> 7.1.0', require: nil + gem 'activerecord', '~> 7.2.0', require: nil + gem 'activejob', '~> 7.2.0', require: nil gem 'sequel', require: nil gem 'connection_pool', require: nil gem 'pond', require: nil diff --git a/lib/que/active_record/connection.rb b/lib/que/active_record/connection.rb index aafeb878..9ecefd35 100644 --- a/lib/que/active_record/connection.rb +++ b/lib/que/active_record/connection.rb @@ -42,7 +42,12 @@ def call(job) # feature to unknowingly leak connections to other databases. So, # take the additional step of telling ActiveRecord to check in all # of the current thread's connections after each job is run. - ::ActiveRecord::Base.clear_active_connections! unless job.class.resolve_que_setting(:run_synchronously) + return if job.class.resolve_que_setting(:run_synchronously) + if ::ActiveRecord.version >= Gem::Version.new('7.1') + ::ActiveRecord::Base.connection_handler.clear_active_connections!(:all) + else + ::ActiveRecord::Base.clear_active_connections! + end end end end diff --git a/spec/gemfiles/Gemfile-rails-7.2 b/spec/gemfiles/Gemfile-rails-7.2 new file mode 100644 index 00000000..1caa4180 --- /dev/null +++ b/spec/gemfiles/Gemfile-rails-7.2 @@ -0,0 +1,23 @@ +source 'https://rubygems.org' + +gem 'que', path: '../..' + +group :development, :test do + gem 'rake' + + gem 'activerecord', '~> 7.2.0', require: nil + gem 'activejob', '~> 7.2.0', require: nil + gem 'sequel', require: nil + gem 'connection_pool', require: nil + gem 'pond', require: nil + gem 'pg', require: nil, platform: :ruby + gem 'pg_jruby', require: nil, platform: :jruby +end + +group :test do + gem 'minitest', '~> 5.10.1' + gem 'minitest-profile', '0.0.2' + gem 'minitest-hooks', '1.4.0' + gem 'pry' + gem 'pg_examiner', '~> 0.5.2' +end diff --git a/spec/que/active_record/connection_spec.rb b/spec/que/active_record/connection_spec.rb index 21458d92..60a2d57b 100644 --- a/spec/que/active_record/connection_spec.rb +++ b/spec/que/active_record/connection_spec.rb @@ -39,7 +39,11 @@ class SecondDatabaseModel < ActiveRecord::Base establish_connection(QUE_URL) end - SecondDatabaseModel.clear_active_connections! + if ::ActiveRecord.version >= Gem::Version.new('7.1') + SecondDatabaseModel.connection_handler.clear_active_connections!(:all) + else + SecondDatabaseModel.clear_active_connections! + end refute SecondDatabaseModel.connection_handler.active_connections? class SecondDatabaseModelJob < Que::Job