diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 14ec6ec67..fd6f78aa9 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -14,6 +14,7 @@ jobs: - '3.0' - 3.1 - 3.2 + - 3.3 gemfile: - gemfiles/rails_4_2.gemfile - gemfiles/rails_5_0.gemfile @@ -21,6 +22,9 @@ jobs: - gemfiles/rails_5_2.gemfile - gemfiles/rails_6_0.gemfile - gemfiles/rails_7_0.gemfile + - gemfiles/rails_7_1.gemfile + - gemfiles/rails_7_2.gemfile + - gemfiles/rails_8_0.gemfile db: - sqlite - mysql @@ -51,6 +55,7 @@ jobs: - ruby: 3.2 gemfile: gemfiles/rails_7_0_mongoid_7.gemfile devise-token-auth-orm: mongoid + # TODO: add mongoid for rails 7.2 exclude: - ruby: 2.7 gemfile: gemfiles/rails_4_2.gemfile @@ -60,6 +65,10 @@ jobs: gemfile: gemfiles/rails_5_1.gemfile - ruby: 2.7 gemfile: gemfiles/rails_5_2.gemfile + - ruby: 2.7 + gemfile: gemfiles/rails_7_2.gemfile + - ruby: 2.7 + gemfile: gemfiles/rails_8_0.gemfile - ruby: '3.0' gemfile: gemfiles/rails_4_2.gemfile - ruby: '3.0' @@ -70,6 +79,12 @@ jobs: gemfile: gemfiles/rails_5_2.gemfile - ruby: '3.0' gemfile: gemfiles/rails_6_0.gemfile + - ruby: '3.0' + gemfile: gemfiles/rails_7_2.gemfile + - ruby: '3.0' + gemfile: gemfiles/rails_8_0.gemfile + - ruby: '3.0' + gemfile: gemfiles/rails_7_1.gemfile - ruby: 3.1 gemfile: gemfiles/rails_4_2.gemfile - ruby: 3.1 @@ -90,6 +105,17 @@ jobs: gemfile: gemfiles/rails_5_2.gemfile - ruby: 3.2 gemfile: gemfiles/rails_6_0.gemfile + - ruby: 3.3 + gemfile: gemfiles/rails_4_2.gemfile + - ruby: 3.3 + gemfile: gemfiles/rails_5_0.gemfile + - ruby: 3.3 + gemfile: gemfiles/rails_5_1.gemfile + - ruby: 3.3 + gemfile: gemfiles/rails_5_2.gemfile + - ruby: 3.3 + gemfile: gemfiles/rails_6_0.gemfile + services: mysql: diff --git a/gemfiles/rails_7_1.gemfile b/gemfiles/rails_7_1.gemfile new file mode 100644 index 000000000..3ab6904dc --- /dev/null +++ b/gemfiles/rails_7_1.gemfile @@ -0,0 +1,47 @@ +# This file was generated by Appraisal + +source "https://rubygems.org" + +gem "omniauth", "~> 2.0" +gem "omniauth-rails_csrf_protection" +gem 'rails', '~> 7.1.5' +gem "sqlite3", "~> 1.4.1" +gem "mysql2" +gem "pg" + +group :development, :test do + gem "attr_encrypted" + gem "figaro", "~> 1.2" + gem "omniauth-facebook" + gem "omniauth-github" + gem "omniauth-google-oauth2" + gem 'omniauth-apple' + gem "rack-cors" + gem "thor", "~> 1.2" + gem "database_cleaner" + gem "factory_bot_rails" + gem "faker", "~> 2.16" + gem "fuzz_ball" + gem "guard" + gem "guard-minitest" + gem "minitest" + gem "minitest-focus" + gem "minitest-rails", "~> 7" + gem "minitest-reporters" + gem "mocha", ">= 1.5" + gem "pry" + gem "pry-byebug" + gem "pry-remote" + gem "rubocop", require: false +end + +group :test do + gem "rails-controller-testing" + gem "simplecov", require: false +end + +group :development do + gem "github_changelog_generator" +end + +gemspec path: "../" diff --git a/gemfiles/rails_7_2.gemfile b/gemfiles/rails_7_2.gemfile new file mode 100644 index 000000000..629802a5c --- /dev/null +++ b/gemfiles/rails_7_2.gemfile @@ -0,0 +1,47 @@ +# This file was generated by Appraisal + +source "https://rubygems.org" + +gem "omniauth", "~> 2.0" +gem "omniauth-rails_csrf_protection" +gem 'rails', '~> 7.2.1.2' +gem "sqlite3", "~> 1.4.1" +gem "mysql2" +gem "pg" + +group :development, :test do + gem "attr_encrypted" + gem "figaro", "~> 1.2" + gem "omniauth-facebook" + gem "omniauth-github" + gem "omniauth-google-oauth2" + gem 'omniauth-apple' + gem "rack-cors" + gem "thor", "~> 1.2" + gem "database_cleaner" + gem "factory_bot_rails" + gem "faker", "~> 2.16" + gem "fuzz_ball" + gem "guard" + gem "guard-minitest" + gem "minitest" + gem "minitest-focus" + gem "minitest-rails", "~> 7" + gem "minitest-reporters" + gem "mocha", ">= 1.5" + gem "pry" + gem "pry-byebug" + gem "pry-remote" + gem "rubocop", require: false +end + +group :test do + gem "rails-controller-testing" + gem "simplecov", require: false +end + +group :development do + gem "github_changelog_generator" +end + +gemspec path: "../" diff --git a/gemfiles/rails_8_0.gemfile b/gemfiles/rails_8_0.gemfile new file mode 100644 index 000000000..16ff0c256 --- /dev/null +++ b/gemfiles/rails_8_0.gemfile @@ -0,0 +1,48 @@ +# This file was generated by Appraisal + +source "https://rubygems.org" + +gem "omniauth", "~> 2.0" +gem "omniauth-rails_csrf_protection" +gem "rails", "~> 8.0.0.rc1" +gem "sqlite3", "~> 1.4.1" +gem "mysql2" +gem "pg" +gem "mongoid", git: "https://github.com/comandeo-mongo/mongoid/5818-rails-8" + +group :development, :test do + gem "attr_encrypted" + gem "figaro", "~> 1.2" + gem "omniauth-facebook" + gem "omniauth-github" + gem "omniauth-google-oauth2" + gem 'omniauth-apple' + gem "rack-cors" + gem "thor", "~> 1.2" + gem "database_cleaner" + gem "factory_bot_rails" + gem "faker", "~> 2.16" + gem "fuzz_ball" + gem "guard" + gem "guard-minitest" + gem "minitest" + gem "minitest-focus" + gem "minitest-rails", "~> 7" + gem "minitest-reporters" + gem "mocha", ">= 1.5" + gem "pry" + gem "pry-byebug" + gem "pry-remote" + gem "rubocop", require: false +end + +group :test do + gem "rails-controller-testing" + gem "simplecov", require: false +end + +group :development do + gem "github_changelog_generator" +end + +gemspec path: "../" diff --git a/test/dummy/config/environments/test.rb b/test/dummy/config/environments/test.rb index 0a31ff05c..a2ee5f826 100644 --- a/test/dummy/config/environments/test.rb +++ b/test/dummy/config/environments/test.rb @@ -32,7 +32,11 @@ config.action_controller.perform_caching = false # Raise exceptions instead of rendering exception templates. - config.action_dispatch.show_exceptions = false + if Rails::VERSION::MAJOR >= 7 && Rails::VERSION::MINOR > 0 + config.action_dispatch.show_exceptions = :none + else + config.action_dispatch.show_exceptions = true + end # Disable request forgery protection in test environment. config.action_controller.allow_forgery_protection = false diff --git a/test/test_helper.rb b/test/test_helper.rb index ef019e2fa..1acf4028c 100644 --- a/test/test_helper.rb +++ b/test/test_helper.rb @@ -38,7 +38,7 @@ def follow_all_redirects! class ActiveSupport::TestCase include FactoryBot::Syntax::Methods - ActiveRecord::Migration.check_pending! if DEVISE_TOKEN_AUTH_ORM == :active_record + # ActiveRecord::Migration.check_pending! if DEVISE_TOKEN_AUTH_ORM == :active_record strategies = { active_record: :transaction, mongoid: :deletion }