diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 00000000..b2b8f0c9 --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,42 @@ +name: Tests + +on: + pull_request: + branches: + - '*' + push: + branches: + - master + +jobs: + tests: + runs-on: ubuntu-latest + strategy: + matrix: + ruby: ['3.1', '3.2', '3.3'] + gemfile: + - rails_6_1 + - rails_7 + - rails_7_1 + + env: + BUNDLE_GEMFILE: ${{ github.workspace }}/gemfiles/${{ matrix.gemfile }}.gemfile + BUNDLE_PATH_RELATIVE_TO_CWD: true + + steps: + - uses: actions/checkout@v4 + + - name: Set up Ruby + uses: ruby/setup-ruby@v1 + with: + ruby-version: ${{ matrix.ruby }} + bundler: default + bundler-cache: true + rubygems: latest + + - name: Run tests + env: + RAILS_ENV: test + run: | + bundle exec rake setup + bundle exec rake test diff --git a/.travis.yml b/.travis.yml deleted file mode 100644 index b6d1a86b..00000000 --- a/.travis.yml +++ /dev/null @@ -1,19 +0,0 @@ -language: ruby -sudo: false -cache: bundler - -rvm: - - 2.5 - - 2.6 - - 2.7 - - 3.0 - -env: - - RAILS_VERSION=5.2 - - RAILS_VERSION=6.0 - - RAILS_VERSION=6.1 - -matrix: - exclude: - - env: RAILS_VERSION=5.2 - rvm: 3.0 diff --git a/Appraisals b/Appraisals new file mode 100644 index 00000000..86d5b266 --- /dev/null +++ b/Appraisals @@ -0,0 +1,11 @@ +appraise 'rails_6_1' do + gem 'rails', '~> 6.1' +end + +appraise 'rails_7' do + gem 'rails', '~> 7.0' +end + +appraise 'rails_7_1' do + gem 'rails', '~> 7.1' +end diff --git a/Gemfile b/Gemfile index 426942d7..f78ed552 100644 --- a/Gemfile +++ b/Gemfile @@ -2,7 +2,12 @@ source 'https://rubygems.org' gemspec -gem 'rails', "~> #{ENV.fetch('RAILS_VERSION', 6.0)}" +# Ruby 3.4? +# gem 'base64' +# gem 'mutex_m' +# gem 'observer' + +gem "rails" group :development, :test do gem 'sqlite3', '~> 1.4' diff --git a/NEWS.md b/NEWS.md index 96354173..30c45cef 100644 --- a/NEWS.md +++ b/NEWS.md @@ -2,6 +2,13 @@ User-visible changes worth mentioning. +## 5.0.0 (unreleased) + +- Drop end-of-life'd versions of rails: 5.2 and 6.0, and ruby 3.0 +- Test with current versions of Rails: 6.1, 7.0, 7.1 +- Convert project to GitHub Actions +- Mark 3 tests as pending to the open bug on deleted models + ## 4.0.3 - Add webrick as a development dependency diff --git a/README.md b/README.md index cb59a299..fd27d364 100644 --- a/README.md +++ b/README.md @@ -3,7 +3,6 @@ Merit adds reputation behavior to Rails apps in the form of Badges, Points, and Rankings. -[![Build Status](https://app.travis-ci.com/merit-gem/merit.svg?branch=master)](https://app.travis-ci.com/github/merit-gem/merit) [![Coverage Status](https://coveralls.io/repos/github/merit-gem/merit/badge.svg?branch=master)](https://coveralls.io/github/merit-gem/merit?branch=master) [![Code Climate](https://codeclimate.com/github/tute/merit/badges/gpa.svg)](https://codeclimate.com/github/tute/merit) diff --git a/Rakefile b/Rakefile index ad802757..df554508 100644 --- a/Rakefile +++ b/Rakefile @@ -1,4 +1,3 @@ -# encoding: UTF-8 begin require 'bundler/setup' rescue LoadError @@ -7,8 +6,10 @@ end require 'rake/testtask' -desc 'Default: run tests for all ORMs.' -task default: [:setup, :test, :api_test] +desc 'Default: run tests for all rails\' versions.' +if !ENV["APPRAISAL_INITIALIZED"] + task default: [:setup, :appraisal] +end task :setup do system "cd test/dummy && rake db:migrate && rake db:test:prepare" diff --git a/gemfiles/rails_6_1.gemfile b/gemfiles/rails_6_1.gemfile new file mode 100644 index 00000000..44bfbcbc --- /dev/null +++ b/gemfiles/rails_6_1.gemfile @@ -0,0 +1,12 @@ +# This file was generated by Appraisal + +source "https://rubygems.org" + +gem "rails", "~> 6.1" +gem "coveralls", "~> 0.8.23", require: false + +group :development, :test do + gem "sqlite3", "~> 1.4" +end + +gemspec path: "../" diff --git a/gemfiles/rails_6_1.gemfile.lock b/gemfiles/rails_6_1.gemfile.lock new file mode 100644 index 00000000..96da6d68 --- /dev/null +++ b/gemfiles/rails_6_1.gemfile.lock @@ -0,0 +1,253 @@ +PATH + remote: .. + specs: + merit (4.0.3) + ambry (~> 1.0.0) + zeitwerk + +GEM + remote: https://rubygems.org/ + specs: + actioncable (6.1.7.8) + actionpack (= 6.1.7.8) + activesupport (= 6.1.7.8) + nio4r (~> 2.0) + websocket-driver (>= 0.6.1) + actionmailbox (6.1.7.8) + actionpack (= 6.1.7.8) + activejob (= 6.1.7.8) + activerecord (= 6.1.7.8) + activestorage (= 6.1.7.8) + activesupport (= 6.1.7.8) + mail (>= 2.7.1) + actionmailer (6.1.7.8) + actionpack (= 6.1.7.8) + actionview (= 6.1.7.8) + activejob (= 6.1.7.8) + activesupport (= 6.1.7.8) + mail (~> 2.5, >= 2.5.4) + rails-dom-testing (~> 2.0) + actionpack (6.1.7.8) + actionview (= 6.1.7.8) + activesupport (= 6.1.7.8) + rack (~> 2.0, >= 2.0.9) + rack-test (>= 0.6.3) + rails-dom-testing (~> 2.0) + rails-html-sanitizer (~> 1.0, >= 1.2.0) + actiontext (6.1.7.8) + actionpack (= 6.1.7.8) + activerecord (= 6.1.7.8) + activestorage (= 6.1.7.8) + activesupport (= 6.1.7.8) + nokogiri (>= 1.8.5) + actionview (6.1.7.8) + activesupport (= 6.1.7.8) + builder (~> 3.1) + erubi (~> 1.4) + rails-dom-testing (~> 2.0) + rails-html-sanitizer (~> 1.1, >= 1.2.0) + activejob (6.1.7.8) + activesupport (= 6.1.7.8) + globalid (>= 0.3.6) + activemodel (6.1.7.8) + activesupport (= 6.1.7.8) + activerecord (6.1.7.8) + activemodel (= 6.1.7.8) + activesupport (= 6.1.7.8) + activestorage (6.1.7.8) + actionpack (= 6.1.7.8) + activejob (= 6.1.7.8) + activerecord (= 6.1.7.8) + activesupport (= 6.1.7.8) + marcel (~> 1.0) + mini_mime (>= 1.1.0) + activesupport (6.1.7.8) + concurrent-ruby (~> 1.0, >= 1.0.2) + i18n (>= 1.6, < 2) + minitest (>= 5.1) + tzinfo (~> 2.0) + zeitwerk (~> 2.3) + addressable (2.8.7) + public_suffix (>= 2.0.2, < 7.0) + ambry (1.0.0) + appraisal (2.5.0) + bundler + rake + thor (>= 0.14.0) + ast (2.4.2) + bigdecimal (3.1.8) + builder (3.3.0) + capybara (3.40.0) + addressable + matrix + mini_mime (>= 0.1.3) + nokogiri (~> 1.11) + rack (>= 1.6.0) + rack-test (>= 0.6.3) + regexp_parser (>= 1.5, < 3.0) + xpath (~> 3.2) + concurrent-ruby (1.3.3) + coveralls (0.8.23) + json (>= 1.8, < 3) + simplecov (~> 0.16.1) + term-ansicolor (~> 1.3) + thor (>= 0.19.4, < 2.0) + tins (~> 1.6) + crass (1.0.6) + date (3.3.4) + docile (1.4.0) + erubi (1.13.0) + globalid (1.2.1) + activesupport (>= 6.1) + i18n (1.14.5) + concurrent-ruby (~> 1.0) + json (2.7.2) + language_server-protocol (3.17.0.3) + loofah (2.22.0) + crass (~> 1.0.2) + nokogiri (>= 1.12.0) + mail (2.8.1) + mini_mime (>= 0.1.1) + net-imap + net-pop + net-smtp + marcel (1.0.4) + matrix (0.4.2) + method_source (1.1.0) + mini_mime (1.1.5) + minitest (5.24.1) + minitest-rails (6.1.1) + minitest (~> 5.10) + railties (~> 6.1.0) + mize (0.4.1) + protocol (~> 2.0) + mocha (2.4.0) + ruby2_keywords (>= 0.0.5) + net-imap (0.4.14) + date + net-protocol + net-pop (0.1.2) + net-protocol + net-protocol (0.2.2) + timeout + net-smtp (0.5.0) + net-protocol + nio4r (2.7.3) + nokogiri (1.16.6-arm64-darwin) + racc (~> 1.4) + parallel (1.25.1) + parser (3.3.3.0) + ast (~> 2.4.1) + racc + protocol (2.0.0) + ruby_parser (~> 3.0) + public_suffix (6.0.0) + racc (1.8.0) + rack (2.2.9) + rack-test (2.1.0) + rack (>= 1.3) + rails (6.1.7.8) + actioncable (= 6.1.7.8) + actionmailbox (= 6.1.7.8) + actionmailer (= 6.1.7.8) + actionpack (= 6.1.7.8) + actiontext (= 6.1.7.8) + actionview (= 6.1.7.8) + activejob (= 6.1.7.8) + activemodel (= 6.1.7.8) + activerecord (= 6.1.7.8) + activestorage (= 6.1.7.8) + activesupport (= 6.1.7.8) + bundler (>= 1.15.0) + railties (= 6.1.7.8) + sprockets-rails (>= 2.0.0) + rails-dom-testing (2.2.0) + activesupport (>= 5.0.0) + minitest + nokogiri (>= 1.6) + rails-html-sanitizer (1.6.0) + loofah (~> 2.21) + nokogiri (~> 1.14) + railties (6.1.7.8) + actionpack (= 6.1.7.8) + activesupport (= 6.1.7.8) + method_source + rake (>= 12.2) + thor (~> 1.0) + rainbow (3.1.1) + rake (13.2.1) + regexp_parser (2.9.2) + rexml (3.3.1) + strscan + rubocop (1.64.1) + json (~> 2.3) + language_server-protocol (>= 3.17.0) + parallel (~> 1.10) + parser (>= 3.3.0.2) + rainbow (>= 2.2.2, < 4.0) + regexp_parser (>= 1.8, < 3.0) + rexml (>= 3.2.5, < 4.0) + rubocop-ast (>= 1.31.1, < 2.0) + ruby-progressbar (~> 1.7) + unicode-display_width (>= 2.4.0, < 3.0) + rubocop-ast (1.31.3) + parser (>= 3.3.1.0) + ruby-progressbar (1.13.0) + ruby2_keywords (0.0.5) + ruby_parser (3.21.0) + racc (~> 1.5) + sexp_processor (~> 4.16) + sexp_processor (4.17.1) + simplecov (0.16.1) + docile (~> 1.1) + json (>= 1.8, < 3) + simplecov-html (~> 0.10.0) + simplecov-html (0.10.2) + sprockets (4.2.1) + concurrent-ruby (~> 1.0) + rack (>= 2.2.4, < 4) + sprockets-rails (3.5.1) + actionpack (>= 6.1) + activesupport (>= 6.1) + sprockets (>= 3.0.0) + sqlite3 (1.7.3-arm64-darwin) + strscan (3.1.0) + sync (0.5.0) + term-ansicolor (1.10.2) + mize + tins (~> 1.0) + thor (1.3.1) + timeout (0.4.1) + tins (1.33.0) + bigdecimal + sync + tzinfo (2.0.6) + concurrent-ruby (~> 1.0) + unicode-display_width (2.5.0) + webrick (1.8.1) + websocket-driver (0.7.6) + websocket-extensions (>= 0.1.0) + websocket-extensions (0.1.5) + xpath (3.2.0) + nokogiri (~> 1.8) + zeitwerk (2.6.16) + +PLATFORMS + arm64-darwin + x86_64-linux + +DEPENDENCIES + appraisal + capybara + coveralls (~> 0.8.23) + merit! + minitest-rails + mocha + rails (~> 6.1) + rubocop + simplecov + sqlite3 (~> 1.4) + webrick + +BUNDLED WITH + 2.5.14 diff --git a/gemfiles/rails_7.gemfile b/gemfiles/rails_7.gemfile new file mode 100644 index 00000000..e5c58a76 --- /dev/null +++ b/gemfiles/rails_7.gemfile @@ -0,0 +1,12 @@ +# This file was generated by Appraisal + +source "https://rubygems.org" + +gem "rails", "~> 7.0" +gem "coveralls", "~> 0.8.23", require: false + +group :development, :test do + gem "sqlite3", "~> 1.4" +end + +gemspec path: "../" diff --git a/gemfiles/rails_7.gemfile.lock b/gemfiles/rails_7.gemfile.lock new file mode 100644 index 00000000..435c3bbc --- /dev/null +++ b/gemfiles/rails_7.gemfile.lock @@ -0,0 +1,281 @@ +PATH + remote: .. + specs: + merit (4.0.3) + ambry (~> 1.0.0) + zeitwerk + +GEM + remote: https://rubygems.org/ + specs: + actioncable (7.1.3.4) + actionpack (= 7.1.3.4) + activesupport (= 7.1.3.4) + nio4r (~> 2.0) + websocket-driver (>= 0.6.1) + zeitwerk (~> 2.6) + actionmailbox (7.1.3.4) + actionpack (= 7.1.3.4) + activejob (= 7.1.3.4) + activerecord (= 7.1.3.4) + activestorage (= 7.1.3.4) + activesupport (= 7.1.3.4) + mail (>= 2.7.1) + net-imap + net-pop + net-smtp + actionmailer (7.1.3.4) + actionpack (= 7.1.3.4) + actionview (= 7.1.3.4) + activejob (= 7.1.3.4) + activesupport (= 7.1.3.4) + mail (~> 2.5, >= 2.5.4) + net-imap + net-pop + net-smtp + rails-dom-testing (~> 2.2) + actionpack (7.1.3.4) + actionview (= 7.1.3.4) + activesupport (= 7.1.3.4) + nokogiri (>= 1.8.5) + racc + rack (>= 2.2.4) + rack-session (>= 1.0.1) + rack-test (>= 0.6.3) + rails-dom-testing (~> 2.2) + rails-html-sanitizer (~> 1.6) + actiontext (7.1.3.4) + actionpack (= 7.1.3.4) + activerecord (= 7.1.3.4) + activestorage (= 7.1.3.4) + activesupport (= 7.1.3.4) + globalid (>= 0.6.0) + nokogiri (>= 1.8.5) + actionview (7.1.3.4) + activesupport (= 7.1.3.4) + builder (~> 3.1) + erubi (~> 1.11) + rails-dom-testing (~> 2.2) + rails-html-sanitizer (~> 1.6) + activejob (7.1.3.4) + activesupport (= 7.1.3.4) + globalid (>= 0.3.6) + activemodel (7.1.3.4) + activesupport (= 7.1.3.4) + activerecord (7.1.3.4) + activemodel (= 7.1.3.4) + activesupport (= 7.1.3.4) + timeout (>= 0.4.0) + activestorage (7.1.3.4) + actionpack (= 7.1.3.4) + activejob (= 7.1.3.4) + activerecord (= 7.1.3.4) + activesupport (= 7.1.3.4) + marcel (~> 1.0) + activesupport (7.1.3.4) + base64 + bigdecimal + concurrent-ruby (~> 1.0, >= 1.0.2) + connection_pool (>= 2.2.5) + drb + i18n (>= 1.6, < 2) + minitest (>= 5.1) + mutex_m + tzinfo (~> 2.0) + addressable (2.8.7) + public_suffix (>= 2.0.2, < 7.0) + ambry (1.0.0) + appraisal (2.5.0) + bundler + rake + thor (>= 0.14.0) + ast (2.4.2) + base64 (0.2.0) + bigdecimal (3.1.8) + builder (3.3.0) + capybara (3.40.0) + addressable + matrix + mini_mime (>= 0.1.3) + nokogiri (~> 1.11) + rack (>= 1.6.0) + rack-test (>= 0.6.3) + regexp_parser (>= 1.5, < 3.0) + xpath (~> 3.2) + concurrent-ruby (1.3.3) + connection_pool (2.4.1) + coveralls (0.8.23) + json (>= 1.8, < 3) + simplecov (~> 0.16.1) + term-ansicolor (~> 1.3) + thor (>= 0.19.4, < 2.0) + tins (~> 1.6) + crass (1.0.6) + date (3.3.4) + docile (1.4.0) + drb (2.2.1) + erubi (1.13.0) + globalid (1.2.1) + activesupport (>= 6.1) + i18n (1.14.5) + concurrent-ruby (~> 1.0) + io-console (0.7.2) + irb (1.14.0) + rdoc (>= 4.0.0) + reline (>= 0.4.2) + json (2.7.2) + language_server-protocol (3.17.0.3) + loofah (2.22.0) + crass (~> 1.0.2) + nokogiri (>= 1.12.0) + mail (2.8.1) + mini_mime (>= 0.1.1) + net-imap + net-pop + net-smtp + marcel (1.0.4) + matrix (0.4.2) + mini_mime (1.1.5) + minitest (5.24.1) + minitest-rails (7.1.1) + minitest (~> 5.20) + railties (>= 7.1.0, < 8.0.0) + mize (0.4.1) + protocol (~> 2.0) + mocha (2.4.0) + ruby2_keywords (>= 0.0.5) + mutex_m (0.2.0) + net-imap (0.4.14) + date + net-protocol + net-pop (0.1.2) + net-protocol + net-protocol (0.2.2) + timeout + net-smtp (0.5.0) + net-protocol + nio4r (2.7.3) + nokogiri (1.16.6-arm64-darwin) + racc (~> 1.4) + parallel (1.25.1) + parser (3.3.3.0) + ast (~> 2.4.1) + racc + protocol (2.0.0) + ruby_parser (~> 3.0) + psych (5.1.2) + stringio + public_suffix (6.0.0) + racc (1.8.0) + rack (3.1.6) + rack-session (2.0.0) + rack (>= 3.0.0) + rack-test (2.1.0) + rack (>= 1.3) + rackup (2.1.0) + rack (>= 3) + webrick (~> 1.8) + rails (7.1.3.4) + actioncable (= 7.1.3.4) + actionmailbox (= 7.1.3.4) + actionmailer (= 7.1.3.4) + actionpack (= 7.1.3.4) + actiontext (= 7.1.3.4) + actionview (= 7.1.3.4) + activejob (= 7.1.3.4) + activemodel (= 7.1.3.4) + activerecord (= 7.1.3.4) + activestorage (= 7.1.3.4) + activesupport (= 7.1.3.4) + bundler (>= 1.15.0) + railties (= 7.1.3.4) + rails-dom-testing (2.2.0) + activesupport (>= 5.0.0) + minitest + nokogiri (>= 1.6) + rails-html-sanitizer (1.6.0) + loofah (~> 2.21) + nokogiri (~> 1.14) + railties (7.1.3.4) + actionpack (= 7.1.3.4) + activesupport (= 7.1.3.4) + irb + rackup (>= 1.0.0) + rake (>= 12.2) + thor (~> 1.0, >= 1.2.2) + zeitwerk (~> 2.6) + rainbow (3.1.1) + rake (13.2.1) + rdoc (6.7.0) + psych (>= 4.0.0) + regexp_parser (2.9.2) + reline (0.5.9) + io-console (~> 0.5) + rexml (3.3.1) + strscan + rubocop (1.64.1) + json (~> 2.3) + language_server-protocol (>= 3.17.0) + parallel (~> 1.10) + parser (>= 3.3.0.2) + rainbow (>= 2.2.2, < 4.0) + regexp_parser (>= 1.8, < 3.0) + rexml (>= 3.2.5, < 4.0) + rubocop-ast (>= 1.31.1, < 2.0) + ruby-progressbar (~> 1.7) + unicode-display_width (>= 2.4.0, < 3.0) + rubocop-ast (1.31.3) + parser (>= 3.3.1.0) + ruby-progressbar (1.13.0) + ruby2_keywords (0.0.5) + ruby_parser (3.21.0) + racc (~> 1.5) + sexp_processor (~> 4.16) + sexp_processor (4.17.1) + simplecov (0.16.1) + docile (~> 1.1) + json (>= 1.8, < 3) + simplecov-html (~> 0.10.0) + simplecov-html (0.10.2) + sqlite3 (1.7.3-arm64-darwin) + stringio (3.1.1) + strscan (3.1.0) + sync (0.5.0) + term-ansicolor (1.10.2) + mize + tins (~> 1.0) + thor (1.3.1) + timeout (0.4.1) + tins (1.33.0) + bigdecimal + sync + tzinfo (2.0.6) + concurrent-ruby (~> 1.0) + unicode-display_width (2.5.0) + webrick (1.8.1) + websocket-driver (0.7.6) + websocket-extensions (>= 0.1.0) + websocket-extensions (0.1.5) + xpath (3.2.0) + nokogiri (~> 1.8) + zeitwerk (2.6.16) + +PLATFORMS + arm64-darwin + x86_64-linux + +DEPENDENCIES + appraisal + capybara + coveralls (~> 0.8.23) + merit! + minitest-rails + mocha + rails (~> 7.0) + rubocop + simplecov + sqlite3 (~> 1.4) + webrick + +BUNDLED WITH + 2.5.14 diff --git a/gemfiles/rails_7_1.gemfile b/gemfiles/rails_7_1.gemfile new file mode 100644 index 00000000..bf236e45 --- /dev/null +++ b/gemfiles/rails_7_1.gemfile @@ -0,0 +1,12 @@ +# This file was generated by Appraisal + +source "https://rubygems.org" + +gem "rails", "~> 7.1" +gem "coveralls", "~> 0.8.23", require: false + +group :development, :test do + gem "sqlite3", "~> 1.4" +end + +gemspec path: "../" diff --git a/gemfiles/rails_7_1.gemfile.lock b/gemfiles/rails_7_1.gemfile.lock new file mode 100644 index 00000000..e4ddd9d2 --- /dev/null +++ b/gemfiles/rails_7_1.gemfile.lock @@ -0,0 +1,281 @@ +PATH + remote: .. + specs: + merit (4.0.3) + ambry (~> 1.0.0) + zeitwerk + +GEM + remote: https://rubygems.org/ + specs: + actioncable (7.1.3.4) + actionpack (= 7.1.3.4) + activesupport (= 7.1.3.4) + nio4r (~> 2.0) + websocket-driver (>= 0.6.1) + zeitwerk (~> 2.6) + actionmailbox (7.1.3.4) + actionpack (= 7.1.3.4) + activejob (= 7.1.3.4) + activerecord (= 7.1.3.4) + activestorage (= 7.1.3.4) + activesupport (= 7.1.3.4) + mail (>= 2.7.1) + net-imap + net-pop + net-smtp + actionmailer (7.1.3.4) + actionpack (= 7.1.3.4) + actionview (= 7.1.3.4) + activejob (= 7.1.3.4) + activesupport (= 7.1.3.4) + mail (~> 2.5, >= 2.5.4) + net-imap + net-pop + net-smtp + rails-dom-testing (~> 2.2) + actionpack (7.1.3.4) + actionview (= 7.1.3.4) + activesupport (= 7.1.3.4) + nokogiri (>= 1.8.5) + racc + rack (>= 2.2.4) + rack-session (>= 1.0.1) + rack-test (>= 0.6.3) + rails-dom-testing (~> 2.2) + rails-html-sanitizer (~> 1.6) + actiontext (7.1.3.4) + actionpack (= 7.1.3.4) + activerecord (= 7.1.3.4) + activestorage (= 7.1.3.4) + activesupport (= 7.1.3.4) + globalid (>= 0.6.0) + nokogiri (>= 1.8.5) + actionview (7.1.3.4) + activesupport (= 7.1.3.4) + builder (~> 3.1) + erubi (~> 1.11) + rails-dom-testing (~> 2.2) + rails-html-sanitizer (~> 1.6) + activejob (7.1.3.4) + activesupport (= 7.1.3.4) + globalid (>= 0.3.6) + activemodel (7.1.3.4) + activesupport (= 7.1.3.4) + activerecord (7.1.3.4) + activemodel (= 7.1.3.4) + activesupport (= 7.1.3.4) + timeout (>= 0.4.0) + activestorage (7.1.3.4) + actionpack (= 7.1.3.4) + activejob (= 7.1.3.4) + activerecord (= 7.1.3.4) + activesupport (= 7.1.3.4) + marcel (~> 1.0) + activesupport (7.1.3.4) + base64 + bigdecimal + concurrent-ruby (~> 1.0, >= 1.0.2) + connection_pool (>= 2.2.5) + drb + i18n (>= 1.6, < 2) + minitest (>= 5.1) + mutex_m + tzinfo (~> 2.0) + addressable (2.8.7) + public_suffix (>= 2.0.2, < 7.0) + ambry (1.0.0) + appraisal (2.5.0) + bundler + rake + thor (>= 0.14.0) + ast (2.4.2) + base64 (0.2.0) + bigdecimal (3.1.8) + builder (3.3.0) + capybara (3.40.0) + addressable + matrix + mini_mime (>= 0.1.3) + nokogiri (~> 1.11) + rack (>= 1.6.0) + rack-test (>= 0.6.3) + regexp_parser (>= 1.5, < 3.0) + xpath (~> 3.2) + concurrent-ruby (1.3.3) + connection_pool (2.4.1) + coveralls (0.8.23) + json (>= 1.8, < 3) + simplecov (~> 0.16.1) + term-ansicolor (~> 1.3) + thor (>= 0.19.4, < 2.0) + tins (~> 1.6) + crass (1.0.6) + date (3.3.4) + docile (1.4.0) + drb (2.2.1) + erubi (1.13.0) + globalid (1.2.1) + activesupport (>= 6.1) + i18n (1.14.5) + concurrent-ruby (~> 1.0) + io-console (0.7.2) + irb (1.14.0) + rdoc (>= 4.0.0) + reline (>= 0.4.2) + json (2.7.2) + language_server-protocol (3.17.0.3) + loofah (2.22.0) + crass (~> 1.0.2) + nokogiri (>= 1.12.0) + mail (2.8.1) + mini_mime (>= 0.1.1) + net-imap + net-pop + net-smtp + marcel (1.0.4) + matrix (0.4.2) + mini_mime (1.1.5) + minitest (5.24.1) + minitest-rails (7.1.1) + minitest (~> 5.20) + railties (>= 7.1.0, < 8.0.0) + mize (0.4.1) + protocol (~> 2.0) + mocha (2.4.0) + ruby2_keywords (>= 0.0.5) + mutex_m (0.2.0) + net-imap (0.4.14) + date + net-protocol + net-pop (0.1.2) + net-protocol + net-protocol (0.2.2) + timeout + net-smtp (0.5.0) + net-protocol + nio4r (2.7.3) + nokogiri (1.16.6-arm64-darwin) + racc (~> 1.4) + parallel (1.25.1) + parser (3.3.3.0) + ast (~> 2.4.1) + racc + protocol (2.0.0) + ruby_parser (~> 3.0) + psych (5.1.2) + stringio + public_suffix (6.0.0) + racc (1.8.0) + rack (3.1.6) + rack-session (2.0.0) + rack (>= 3.0.0) + rack-test (2.1.0) + rack (>= 1.3) + rackup (2.1.0) + rack (>= 3) + webrick (~> 1.8) + rails (7.1.3.4) + actioncable (= 7.1.3.4) + actionmailbox (= 7.1.3.4) + actionmailer (= 7.1.3.4) + actionpack (= 7.1.3.4) + actiontext (= 7.1.3.4) + actionview (= 7.1.3.4) + activejob (= 7.1.3.4) + activemodel (= 7.1.3.4) + activerecord (= 7.1.3.4) + activestorage (= 7.1.3.4) + activesupport (= 7.1.3.4) + bundler (>= 1.15.0) + railties (= 7.1.3.4) + rails-dom-testing (2.2.0) + activesupport (>= 5.0.0) + minitest + nokogiri (>= 1.6) + rails-html-sanitizer (1.6.0) + loofah (~> 2.21) + nokogiri (~> 1.14) + railties (7.1.3.4) + actionpack (= 7.1.3.4) + activesupport (= 7.1.3.4) + irb + rackup (>= 1.0.0) + rake (>= 12.2) + thor (~> 1.0, >= 1.2.2) + zeitwerk (~> 2.6) + rainbow (3.1.1) + rake (13.2.1) + rdoc (6.7.0) + psych (>= 4.0.0) + regexp_parser (2.9.2) + reline (0.5.9) + io-console (~> 0.5) + rexml (3.3.1) + strscan + rubocop (1.64.1) + json (~> 2.3) + language_server-protocol (>= 3.17.0) + parallel (~> 1.10) + parser (>= 3.3.0.2) + rainbow (>= 2.2.2, < 4.0) + regexp_parser (>= 1.8, < 3.0) + rexml (>= 3.2.5, < 4.0) + rubocop-ast (>= 1.31.1, < 2.0) + ruby-progressbar (~> 1.7) + unicode-display_width (>= 2.4.0, < 3.0) + rubocop-ast (1.31.3) + parser (>= 3.3.1.0) + ruby-progressbar (1.13.0) + ruby2_keywords (0.0.5) + ruby_parser (3.21.0) + racc (~> 1.5) + sexp_processor (~> 4.16) + sexp_processor (4.17.1) + simplecov (0.16.1) + docile (~> 1.1) + json (>= 1.8, < 3) + simplecov-html (~> 0.10.0) + simplecov-html (0.10.2) + sqlite3 (1.7.3-arm64-darwin) + stringio (3.1.1) + strscan (3.1.0) + sync (0.5.0) + term-ansicolor (1.10.2) + mize + tins (~> 1.0) + thor (1.3.1) + timeout (0.4.1) + tins (1.33.0) + bigdecimal + sync + tzinfo (2.0.6) + concurrent-ruby (~> 1.0) + unicode-display_width (2.5.0) + webrick (1.8.1) + websocket-driver (0.7.6) + websocket-extensions (>= 0.1.0) + websocket-extensions (0.1.5) + xpath (3.2.0) + nokogiri (~> 1.8) + zeitwerk (2.6.16) + +PLATFORMS + arm64-darwin + x86_64-linux + +DEPENDENCIES + appraisal + capybara + coveralls (~> 0.8.23) + merit! + minitest-rails + mocha + rails (~> 7.1) + rubocop + simplecov + sqlite3 (~> 1.4) + webrick + +BUNDLED WITH + 2.5.14 diff --git a/merit.gemspec b/merit.gemspec index 4ff4e571..581877d0 100644 --- a/merit.gemspec +++ b/merit.gemspec @@ -15,7 +15,7 @@ Gem::Specification.new do |s| s.add_runtime_dependency 'ambry', '~> 1.0.0' s.add_runtime_dependency 'zeitwerk' - s.add_development_dependency 'rails', '>= 5.1.6' + s.add_development_dependency 'appraisal' s.add_development_dependency 'capybara' s.add_development_dependency 'simplecov' s.add_development_dependency 'rubocop' diff --git a/test/dummy/config/application.rb b/test/dummy/config/application.rb index bb91f643..de886a0c 100644 --- a/test/dummy/config/application.rb +++ b/test/dummy/config/application.rb @@ -11,14 +11,7 @@ module Dummy class Application < ::Rails::Application - if Rails.version.match? "5.2.+" - config.active_record.sqlite3.represent_boolean_as_integer = true - end - - if Rails.version.match? "6.0.+" - config.load_defaults "6.0" - end - + config.load_defaults Rails.version[0..2] config.i18n.enforce_available_locales = true config.encoding = "utf-8" config.filter_parameters += [:password] diff --git a/test/dummy/config/application_api_only.rb b/test/dummy/config/application_api_only.rb index 0889051f..b3570fc4 100644 --- a/test/dummy/config/application_api_only.rb +++ b/test/dummy/config/application_api_only.rb @@ -20,7 +20,7 @@ module Dummy class Application < ::Rails::Application - config.load_defaults 5.2 if ENV["RAILS_VERSION"] =~ /^5.2/ + config.load_defaults Rails.version[0..2] config.api_only = true config.i18n.enforce_available_locales = true config.encoding = "utf-8" diff --git a/test/dummy/config/initializers/merit.rb b/test/dummy/config/initializers/merit.rb index 1a327b19..5f543019 100644 --- a/test/dummy/config/initializers/merit.rb +++ b/test/dummy/config/initializers/merit.rb @@ -7,41 +7,43 @@ end # Create application badges (uses https://github.com/norman/ambry) -badge_id = 0 -[{ - id: (badge_id = badge_id+1), - name: 'commenter', - description: 'You\'ve participated good in our boards! (level 10)', - level: 10 -}, { - id: (badge_id = badge_id+1), - name: 'commenter', - description: 'You\'ve participated great in our boards!' -}, { - id: (badge_id = badge_id+1), - name: 'visited_admin', - description: 'You sneaked in!' -}, { - id: (badge_id = badge_id+1), - name: 'has_commenter_friend', - description: 'Testing badge granting in more than one rule per action, with different targets' -}, { - id: (badge_id = badge_id+1), - name: 'relevant-commenter', - description: 'You\'ve received 5 votes on a comment.' -}, { - id: (badge_id = badge_id+1), - name: 'autobiographer', - description: 'You\'ve edited your name and it\'s above 4 characters! (?)' -}, { - id: (badge_id = badge_id+1), - name: 'just-registered' -}, { - id: (badge_id = badge_id+1), - name: 'wildcard_badge' -}, { - id: (badge_id = badge_id+1), - name: 'gossip' -}].each do |badge| - Merit::Badge.create! badge +Rails.application.reloader.to_prepare do + badge_id = 0 + [{ + id: (badge_id = badge_id+1), + name: 'commenter', + description: 'You\'ve participated good in our boards! (level 10)', + level: 10 + }, { + id: (badge_id = badge_id+1), + name: 'commenter', + description: 'You\'ve participated great in our boards!' + }, { + id: (badge_id = badge_id+1), + name: 'visited_admin', + description: 'You sneaked in!' + }, { + id: (badge_id = badge_id+1), + name: 'has_commenter_friend', + description: 'Testing badge granting in more than one rule per action, with different targets' + }, { + id: (badge_id = badge_id+1), + name: 'relevant-commenter', + description: 'You\'ve received 5 votes on a comment.' + }, { + id: (badge_id = badge_id+1), + name: 'autobiographer', + description: 'You\'ve edited your name and it\'s above 4 characters! (?)' + }, { + id: (badge_id = badge_id+1), + name: 'just-registered' + }, { + id: (badge_id = badge_id+1), + name: 'wildcard_badge' + }, { + id: (badge_id = badge_id+1), + name: 'gossip' + }].each do |badge| + Merit::Badge.create! badge + end end diff --git a/test/dummy/db/schema.rb b/test/dummy/db/schema.rb index a73cdf1b..477401c6 100644 --- a/test/dummy/db/schema.rb +++ b/test/dummy/db/schema.rb @@ -10,8 +10,7 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema.define(version: 2014_08_19_133931) do - +ActiveRecord::Schema[7.1].define(version: 2014_08_19_133931) do create_table "addresses", force: :cascade do |t| t.integer "user_id" t.index ["user_id"], name: "index_addresses_on_user_id" @@ -21,7 +20,7 @@ t.integer "badge_id" t.integer "sash_id" t.boolean "notified_user", default: false - t.datetime "created_at" + t.datetime "created_at", precision: nil t.index ["badge_id", "sash_id"], name: "index_badges_sashes_on_badge_id_and_sash_id" t.index ["badge_id"], name: "index_badges_sashes_on_badge_id" t.index ["sash_id"], name: "index_badges_sashes_on_sash_id" @@ -32,8 +31,8 @@ t.text "comment" t.integer "user_id" t.integer "votes", default: 0 - t.datetime "created_at", null: false - t.datetime "updated_at", null: false + t.datetime "created_at", precision: nil, null: false + t.datetime "updated_at", precision: nil, null: false t.integer "sash_id" t.integer "level", default: 0 end @@ -46,8 +45,8 @@ t.string "target_model" t.integer "target_id" t.boolean "processed", default: false - t.datetime "created_at", null: false - t.datetime "updated_at", null: false + t.datetime "created_at", precision: nil, null: false + t.datetime "updated_at", precision: nil, null: false t.text "target_data" t.index ["processed"], name: "index_merit_actions_on_processed" end @@ -57,14 +56,14 @@ t.string "related_change_type" t.integer "related_change_id" t.string "description" - t.datetime "created_at" + t.datetime "created_at", precision: nil end create_table "merit_score_points", force: :cascade do |t| t.integer "score_id" t.integer "num_points", default: 0 t.string "log" - t.datetime "created_at" + t.datetime "created_at", precision: nil t.index ["score_id"], name: "index_merit_score_points_on_score_id" end @@ -75,14 +74,14 @@ end create_table "sashes", force: :cascade do |t| - t.datetime "created_at", null: false - t.datetime "updated_at", null: false + t.datetime "created_at", precision: nil, null: false + t.datetime "updated_at", precision: nil, null: false end create_table "users", force: :cascade do |t| t.string "name" - t.datetime "created_at", null: false - t.datetime "updated_at", null: false + t.datetime "created_at", precision: nil, null: false + t.datetime "updated_at", precision: nil, null: false t.integer "sash_id" t.integer "level", default: 0 end diff --git a/test/integration/navigation_test.rb b/test/integration/navigation_test.rb index 6a848943..579bb23c 100644 --- a/test/integration/navigation_test.rb +++ b/test/integration/navigation_test.rb @@ -231,6 +231,7 @@ def teardown # Destroying a comment should remove points from the comment creator. comment_to_destroy = user.comments.last visit '/comments' + skip "see bug https://github.com/merit-gem/merit/issues/365" assert_difference lambda { user.reload.points }, -5 do within("tr#c_#{comment_to_destroy.id}") do click_link 'Destroy' diff --git a/test/unit/action_test.rb b/test/unit/action_test.rb index 75a31f7a..93782c65 100644 --- a/test/unit/action_test.rb +++ b/test/unit/action_test.rb @@ -2,6 +2,7 @@ describe Merit::Action do it 'saves correctly with a serialised model' do + skip "see bug https://github.com/merit-gem/merit/issues/365" comment = Comment.new(name: 'the comment name') action = Merit::Action.create(target_model: 'comment', target_id: 2, diff --git a/test/unit/base_target_finder_test.rb b/test/unit/base_target_finder_test.rb index d662f8d8..e423ef34 100644 --- a/test/unit/base_target_finder_test.rb +++ b/test/unit/base_target_finder_test.rb @@ -47,6 +47,7 @@ describe 'target was destroyed' do it 'gets the object from the JSON data in the merit_actions table' do + skip "see bug https://github.com/merit-gem/merit/issues/365" comment = Comment.new(name: 'the comment name') rule = Merit::Rule.new