From 9ae56ba413b9159c826285f31e45fe5002af253a Mon Sep 17 00:00:00 2001 From: "Bryan Hanks, PMP" Date: Tue, 2 Mar 2021 08:33:02 -0600 Subject: [PATCH] BigDecimal required; test fixes for ruby 3 (#408) --- Appraisals | 1 + gemfiles/mongoid_5.0.gemfile | 1 + spec/ext/active_record_spec.rb | 30 ++++++++++++++++++++++++------ 3 files changed, 26 insertions(+), 6 deletions(-) diff --git a/Appraisals b/Appraisals index 2933392f..79bf8262 100644 --- a/Appraisals +++ b/Appraisals @@ -29,6 +29,7 @@ end appraise 'mongoid-5.0' do gem 'mongoid', '~> 5.0.0' + gem 'bigdecimal', '~> 1.3.5' end appraise 'mongoid-6.0' do diff --git a/gemfiles/mongoid_5.0.gemfile b/gemfiles/mongoid_5.0.gemfile index 4404aeb5..c011fc4f 100644 --- a/gemfiles/mongoid_5.0.gemfile +++ b/gemfiles/mongoid_5.0.gemfile @@ -3,5 +3,6 @@ source "https://rubygems.org" gem "mongoid", "~> 5.0.0" +gem "bigdecimal", "~> 1.3.5" gemspec path: "../" diff --git a/spec/ext/active_record_spec.rb b/spec/ext/active_record_spec.rb index 603632ab..32ef3f30 100644 --- a/spec/ext/active_record_spec.rb +++ b/spec/ext/active_record_spec.rb @@ -218,25 +218,43 @@ class SubUser < User { # spec 1 out = @ap.awesome(User.methods.grep(/first/)) - if ActiveRecord::VERSION::STRING >= '3.2' - expect(out).to match(/\sfirst\(\*arg.*?\)\s+User/) + if RUBY_VERSION >= '3.0.0' + expect(out).to match(/\sfirst\(\*\*,\s&&\)/) + elsif RUBY_VERSION >= '2.7.0' + if ActiveRecord::VERSION::STRING >= '3.2' + expect(out).to match(/\sfirst\(\*\*,\s&&\)\s+User/) + else + expect(out).to match(/\sfirst\(\*\*,\s&&\)\s+User \(ActiveRecord::Base\)/) + end else - expect(out).to match(/\sfirst\(\*arg.*?\)\s+User \(ActiveRecord::Base\)/) + if ActiveRecord::VERSION::STRING >= '3.2' + expect(out).to match(/\sfirst\(\*arg.*?\)\s+User/) + else + expect(out).to match(/\sfirst\(\*arg.*?\)\s+User \(ActiveRecord::Base\)/) + end end # spec 2 out = @ap.awesome(User.methods.grep(/primary_key/)) - expect(out).to match(/\sprimary_key\(.*?\)\s+User/) + if RUBY_VERSION >= '3.0.0' + expect(out).to match(/\sprimary_key\(.*?\)/) + else + expect(out).to match(/\sprimary_key\(.*?\)\s+User/) + end # spec 3 out = @ap.awesome(User.methods.grep(/validate/)) - if ActiveRecord::VERSION::MAJOR < 3 expect(out).to match(/\svalidate\(\*arg.*?\)\s+User \(ActiveRecord::Base\)/) else - expect(out).to match(/\svalidate\(\*arg.*?\)\s+User/) + if RUBY_VERSION >= '3.0.0' + expect(out).to match(/\svalidate\(\*arg.*?\)/) + else + expect(out).to match(/\svalidate\(\*arg.*?\)\s+User/) + end end end end end +