From a18e5060a5ffa9b15b2c8497258bb7dbf313ece0 Mon Sep 17 00:00:00 2001 From: masayuki oguni Date: Fri, 19 Jan 2024 18:11:00 +0900 Subject: [PATCH] Upgraded to ruby 3.3.0 rails 7.0 fastly-ruby 3.0.0 Add github workflows test --- .github/workflows/ruby.yml | 12 +++++------ .gitignore | 4 ++++ .travis.yml | 3 +-- Appraisals | 18 +++++----------- README.md | 8 +++---- Rakefile | 7 +++--- fastly-rails.gemspec | 7 +++--- gemfiles/rails_3.gemfile | 8 ------- gemfiles/rails_4.gemfile | 7 ------ gemfiles/rails_41.gemfile | 7 ------ gemfiles/{rails_5.gemfile => rails_7.gemfile} | 4 ++-- gemfiles/rails_7_1.gemfile | 8 +++++++ .../dummy/app/controllers/books_controller.rb | 4 ++-- test/dummy/config/boot.rb | 2 +- test/dummy/db/test.sqlite3-shm | Bin 0 -> 32768 bytes test/dummy/db/test.sqlite3-wal | Bin 0 -> 280192 bytes .../test/controllers/books_controller_test.rb | 7 +++--- test/dummy/test/factories/books.rb | 6 +++--- .../test/integration/fastly_headers_test.rb | 5 ++--- .../test/lib/remove_set_cookie_header_test.rb | 4 ++-- test/dummy/test/models/book_test.rb | 5 +++-- test/test_helper.rb | 20 ++++++------------ 22 files changed, 60 insertions(+), 86 deletions(-) delete mode 100644 gemfiles/rails_3.gemfile delete mode 100644 gemfiles/rails_4.gemfile delete mode 100644 gemfiles/rails_41.gemfile rename gemfiles/{rails_5.gemfile => rails_7.gemfile} (69%) create mode 100644 gemfiles/rails_7_1.gemfile create mode 100644 test/dummy/db/test.sqlite3-shm create mode 100644 test/dummy/db/test.sqlite3-wal diff --git a/.github/workflows/ruby.yml b/.github/workflows/ruby.yml index 20dafd3..a660de7 100644 --- a/.github/workflows/ruby.yml +++ b/.github/workflows/ruby.yml @@ -9,28 +9,28 @@ name: Ruby on: push: - branches: [ "master" ] pull_request: - branches: [ "master" ] + types: + - opened + - synchronize + - reopened permissions: contents: read jobs: test: - runs-on: ubuntu-latest strategy: matrix: - ruby-version: ['2.6', '2.7', '3.0'] + ruby-version: ['3.2', '3.3'] steps: - uses: actions/checkout@v3 - name: Set up Ruby # To automatically get bug fixes and new Ruby versions for ruby/setup-ruby, # change this to (see https://github.com/ruby/setup-ruby#versioning): - # uses: ruby/setup-ruby@v1 - uses: ruby/setup-ruby@55283cc23133118229fd3f97f9336ee23a179fcf # v1.146.0 + uses: ruby/setup-ruby@v1 with: ruby-version: ${{ matrix.ruby-version }} bundler-cache: true # runs 'bundle install' and caches installed gems automatically diff --git a/.gitignore b/.gitignore index 316a815..10b94d3 100644 --- a/.gitignore +++ b/.gitignore @@ -3,8 +3,12 @@ log/*.log pkg/ test/dummy/db/*.sqlite3 test/dummy/db/*.sqlite3-journal +test/dummy/db/test.sqlite3-shm +test/dummy/db/test.sqlite3-wal test/dummy/log/*.log test/dummy/tmp/ test/dummy/.sass-cache gemfiles/*.lock Gemfile.lock +gemfiles/vendor/ +vendor diff --git a/.travis.yml b/.travis.yml index 5458bea..68d7601 100644 --- a/.travis.yml +++ b/.travis.yml @@ -3,5 +3,4 @@ before_script: 'bundle exec rake test:setup' script: 'bundle exec rake test:all' cache: bundler rvm: - - 2.3.3 - - 2.2.2 + - 3.3.0 diff --git a/Appraisals b/Appraisals index dc4de30..e04d285 100644 --- a/Appraisals +++ b/Appraisals @@ -1,17 +1,9 @@ -appraise 'rails-3' do - gem 'rails', '~> 3.2.18' - gem 'test-unit', '~> 3.0' -end - -appraise 'rails-4' do - gem 'rails', '~> 4.0.5' -end - -appraise 'rails-41' do - gem 'rails', '~> 4.1.1' +appraise 'rails-7' do + gem 'rails', '~> 7.0.0' + gem 'rails-controller-testing' end -appraise 'rails-5' do - gem 'rails', '~> 5.0' +appraise 'rails-7_1' do + gem 'rails', '~> 7.1.0' gem 'rails-controller-testing' end diff --git a/README.md b/README.md index 70506ce..6d49497 100644 --- a/README.md +++ b/README.md @@ -74,7 +74,7 @@ end ### Headers -This plugin adds a `set_cache_control_headers` method to ActionController. You'll need to add this in a `before_filter` or `after_filter` [see note on cookies below](https://github.com/fastly/fastly-rails#sessions-cookies-and-private-data) to any controller action that you wish to edge cache (see example below). The method sets Cache-Control and Surrogate-Control HTTP Headers with a default of 30 days (remember you can configure this, see the initializer setup above). +This plugin adds a `set_cache_control_headers` method to ActionController. You'll need to add this in a `before_action` or `after_filter` [see note on cookies below](https://github.com/fastly/fastly-rails#sessions-cookies-and-private-data) to any controller action that you wish to edge cache (see example below). The method sets Cache-Control and Surrogate-Control HTTP Headers with a default of 30 days (remember you can configure this, see the initializer setup above). It's up to you to set Surrogate-Key headers for objects that you want to be able to purge. @@ -82,10 +82,10 @@ To do this use the `set_surrogate_key_header` method on GET actions. ````ruby class BooksController < ApplicationController - # include this before_filter in controller endpoints that you wish to edge cache - before_filter :set_cache_control_headers, only: [:index, :show] + # include this before_action in controller endpoints that you wish to edge cache + before_action :set_cache_control_headers, only: [:index, :show] # This can be used with any customer actions. Set these headers for GETs that you want to cache - # e.g. before_filter :set_cache_control_headers, only: [:index, :show, :my_custom_action] + # e.g. before_action :set_cache_control_headers, only: [:index, :show, :my_custom_action] def index @books = Book.all diff --git a/Rakefile b/Rakefile index d032fe9..d04190d 100644 --- a/Rakefile +++ b/Rakefile @@ -22,13 +22,13 @@ Bundler::GemHelper.install_tasks namespace :test do desc 'Install dependencies for all tests with appraisal' task :setup do - sh 'bin/rails db:environment:set RAILS_ENV=test 2>&1 >/dev/null || exit 0' - sh 'appraisal install' + sh 'bundle exec appraisal install' end desc 'Run all tests with appraisal' task :all do - sh 'appraisal rake test' + sh 'bundle exec appraisal install' + sh 'bundle exec appraisal rake test' end end @@ -41,5 +41,4 @@ Rake::TestTask.new(:test) do |t| t.verbose = false end - task default: :test diff --git a/fastly-rails.gemspec b/fastly-rails.gemspec index 47c8bb8..e2f4e66 100644 --- a/fastly-rails.gemspec +++ b/fastly-rails.gemspec @@ -15,14 +15,13 @@ Gem::Specification.new do |s| s.test_files = Dir["test/**/*"] s.add_dependency "railties", '> 2', '< 8' - s.add_dependency 'fastly', '~> 1.6' + s.add_dependency 'fastly', '~> 3.0.0' s.add_development_dependency "sqlite3" - s.add_development_dependency "database_cleaner" - s.add_development_dependency "factory_girl_rails" + s.add_development_dependency "database_cleaner-active_record" + s.add_development_dependency "factory_bot" s.add_development_dependency "ffaker" s.add_development_dependency "minitest-spec-rails" s.add_development_dependency "appraisal" s.add_development_dependency 'webmock', ((RUBY_VERSION <= '1.9.3') ? '2.2.0' : '>= 2.3.0') - s.add_development_dependency 'rails' end diff --git a/gemfiles/rails_3.gemfile b/gemfiles/rails_3.gemfile deleted file mode 100644 index bbd9aa2..0000000 --- a/gemfiles/rails_3.gemfile +++ /dev/null @@ -1,8 +0,0 @@ -# This file was generated by Appraisal - -source "https://rubygems.org" - -gem "rails", "~> 3.2.18" -gem "test-unit", "~> 3.0" - -gemspec :path => "../" diff --git a/gemfiles/rails_4.gemfile b/gemfiles/rails_4.gemfile deleted file mode 100644 index 39a1bd6..0000000 --- a/gemfiles/rails_4.gemfile +++ /dev/null @@ -1,7 +0,0 @@ -# This file was generated by Appraisal - -source "https://rubygems.org" - -gem "rails", "~> 4.0.5" - -gemspec :path => "../" diff --git a/gemfiles/rails_41.gemfile b/gemfiles/rails_41.gemfile deleted file mode 100644 index 8dfe1fe..0000000 --- a/gemfiles/rails_41.gemfile +++ /dev/null @@ -1,7 +0,0 @@ -# This file was generated by Appraisal - -source "https://rubygems.org" - -gem "rails", "~> 4.1.1" - -gemspec :path => "../" diff --git a/gemfiles/rails_5.gemfile b/gemfiles/rails_7.gemfile similarity index 69% rename from gemfiles/rails_5.gemfile rename to gemfiles/rails_7.gemfile index 265a9a1..2be2eae 100644 --- a/gemfiles/rails_5.gemfile +++ b/gemfiles/rails_7.gemfile @@ -2,7 +2,7 @@ source "https://rubygems.org" -gem "rails", "~> 5.0" +gem "rails", "~> 7.0.0" gem "rails-controller-testing" -gemspec :path => "../" +gemspec path: "../" diff --git a/gemfiles/rails_7_1.gemfile b/gemfiles/rails_7_1.gemfile new file mode 100644 index 0000000..45820b6 --- /dev/null +++ b/gemfiles/rails_7_1.gemfile @@ -0,0 +1,8 @@ +# This file was generated by Appraisal + +source "https://rubygems.org" + +gem "rails", "~> 7.1.0" +gem "rails-controller-testing" + +gemspec path: "../" diff --git a/test/dummy/app/controllers/books_controller.rb b/test/dummy/app/controllers/books_controller.rb index 91aea7f..b527103 100644 --- a/test/dummy/app/controllers/books_controller.rb +++ b/test/dummy/app/controllers/books_controller.rb @@ -1,6 +1,6 @@ class BooksController < ApplicationController - before_filter :set_cache_control_headers, only: [:index, :show] - before_filter :find_book, :only => [:show, :edit, :update, :destroy] + before_action :set_cache_control_headers, only: [:index, :show] + before_action :find_book, :only => [:show, :edit, :update, :destroy] def index @books = Book.all diff --git a/test/dummy/config/boot.rb b/test/dummy/config/boot.rb index ef36047..6266cfc 100644 --- a/test/dummy/config/boot.rb +++ b/test/dummy/config/boot.rb @@ -1,5 +1,5 @@ # Set up gems listed in the Gemfile. ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../../../Gemfile', __FILE__) -require 'bundler/setup' if File.exists?(ENV['BUNDLE_GEMFILE']) +require 'bundler/setup' if File.exist?(ENV['BUNDLE_GEMFILE']) $LOAD_PATH.unshift File.expand_path('../../../../lib', __FILE__) diff --git a/test/dummy/db/test.sqlite3-shm b/test/dummy/db/test.sqlite3-shm new file mode 100644 index 0000000000000000000000000000000000000000..630d3a491d3af9a9844f288ccd71f7ace24b855b GIT binary patch literal 32768 zcmeI)NlrpR5P;zyaaQy>KXFD;9B`g+!U3W;aqSsAkq0oIzzeu!;~m`Sdx<235Th$1 z`77ykccoLQ{ti%KB~LXH5R{@zSG3+9U(%I_@@w#XpS#NzQn$s@Q|7(=5&rRgwRT+h zvnFcu@wu(RN`B{lyEm%QtXzH1aUb=$pYG9fLjeU8P(T3%6i`3`1r$&~0RSRfHiT}jeTM>O%JhdxpaGQ=<=j55YJ6NF5XW{PQMm}QQ67Ra#35?Pj6 zA;&6ftg}I$O}5x(hh6sA=a6FxoN`W)D{fj?(Xahaflj*VrJn%;4mje3GcLH~ns`=` zp@0GkD4>7>3Mim}0tzUgfC36Apnw7jD4>7>3Mim}0tzUgfC36Apnw7jD4>7>3Mim} W0tzUgfC36Apnw7jD4;+y1-<}{Xf7Q9 literal 0 HcmV?d00001 diff --git a/test/dummy/db/test.sqlite3-wal b/test/dummy/db/test.sqlite3-wal new file mode 100644 index 0000000000000000000000000000000000000000..5339666e28181bfd3af2c2015ce5d11faac05456 GIT binary patch literal 280192 zcmeI*du)~U83*t~xo;x4fG`};qI3{eJUyou+h`bB*{WN(B&cj*XpxI@vD5+^5#^>) z5VDnJ=r)ZUqk>WPMwPU=9Es2oxrsw7TG&DKq zyzSfP_xU}4ee-)CO6Rs)kSI9VBa!HmX#DE3eNz9*er26b4cl?;&g$)rALcZCw?F&& zy#EY5vak1o{7(P-;Y6bIrp6b(2oNAZfB*pk1PBlyK!5;&>=5``t9FS2Lxyy#t)4a^ zcU*P#l-zr(rcFpCQ$+>I!h%#PH(63%TvDD)4k{{5l@ym<_)1mn_=yc`IxiQPQE=kL zxl4b4R4$MmyR8ZW1PBlyK!5-N0t5&UAaK4wxVgaEQNwSm*}QkBT;P0l?+6eeK!5-N z0t5&UAV7dXb_j%<3)Hun{N{nDk9Uv@WXEo+f&c*m1PBlyK!5-N0t5)0FAz#D5X>F8 z`o+4Ho8H**>&9H5Rl{%r^99b=_l^Jo0t5&UAV7cs0RjXFw5-4<%>~kfk|oK~8;Y9F z7dU(6|MLY}H>@X^JNW*}!Q%$c9`p4xxj=oQbA8LM)?X(;fB*pk1PBlyK!5-N0t7NG z(4kf9?j0Lv7S=Z0`MkMJb*&r8iULX^j<{ktH5FkK+009C72oNAZAd3W=oEHe@3nU-Ps~UQE&_?qG zvS_=MLVy4P0t5&UAV7cs0RjX9fr~jWP*|3}ztXfu?FcAwYlt0RjXF5FkK+009CmFK{vE1yW_j=~OaRRFEtzNTqU z<;nD*WJ%+d=H?3={rQ3)%zt9T9P9+>b>-RTWME?~aE zCGC=5B0zuu0RjXF5FkK+009EoD{$fS0{`4P`KonyK0hPK1)LYi-fdJF0RjXF5FkK+ z009C72*gkzzt+Pe?^V|stNKnz>Uk_iwXK!5-N0t5&UAV44j0^#NY ze_Zh9*79%czd|k$fmTo=0RjXF5FkK+009C72*gkz++5(UZzhUI-d%O4Tp)(6Wyu5x z5FkK+009C72oN9;0fBIHfhjqUhNSuz0v1PBlyK!5-N0t5&|Kp^B?U~=!9-@bmz9JxRQT0w~f2oNAZ zfB*pk1PBly5JQ1*bAhRoXSThjW=|KnKnz>Uk_iwXK!5-N0t5&UAV44j0^#NY{eF6X zVaH{|M#%*t&r2`mJ1Q55Kr1Mb009C72oNAZfB*pk1Y#%T5FkK+009C72oQ*XK)AWU@~+eG$@y~k zF>-+jw1N@|5FkK+009C72oNAZAcg|r<^rdF^!Tbyqid(j1!CA*mP~*E0RjXF5FkK+ z009CK5C}IHm_4w=$oKazDv}FCpcRxzfB*pk1PBlyK!5-N0x=W_Hy8NL(x(cZJhA(T zTp)(6Wyu5x5FkK+009C72oN9;0fBIHfzPzR_FvDQu6s!?5P?=uA^`#f2oNAZfB*pk z1PH`XAlzJF!1pK2{P&g1a^(UsY%NPBK!5-N0t5&UAV7csfd~kMoC`cXw5s;?x!1`B zBG3v-BtU=w0RjXF5FkK+0D%|^gqsWe_5K+TY@FDqhg=|rt!2ps2oNAZfB*pk1PBly z5CMU3bAdJ={&>-zeVuQV3q+t5lt_R80RjXF5FkK+009Cq6bLsL=yk_$hhE?DTYr!X z#IUt2nE(L-1PBlyK!5-N0t6x;5NT5FkK+009C72oQ*XK)AWU@_Uk>?OQ*1om?OS zt)N5#1PBlyK!5-N0t5&Uh@n8Zxj?r&Zs~U9=C1SP0x@hYOC~^o009C72oNAZfB=CA z2!xvphN zSuz0v1PBlyK!5-N0t5&|Kp@;)V8gHauUXu7@8{$K5oiS^5+Fc;009C72oNAZfItid z!p#NN_nCLN`v;?wa)B7OmL(G)K!5-N0t5&UAV7dX1O&p(1^TR8UiZ|Noa1tV2(*F{ z2@oJafB*pk1PBlyKp=(!;pPHM7GFJW-HqK=%LQWCT9!KvKEG|x`lBuGCWMM%nm76Rn zFD@xhrU#w5QdK*CV#BgpH+;80n+uGX^7bviyZzQLoXG|16P@d`X5k7UK!5-N0t5&U zAV7cs0RjXvBG92#>+T)LRaZ}`ZMa=d!*`Gi)O>o8 zyg)EtV8!rh-#dO)%~JCPvS+tcLVy4P0t5&UAV7cs0RjZh30%y1fplSMar5&98m}}r zU*N63EjrmVy=$TQ0_ViNB0zuu0RjXF5FkK+009D*mq3&A0`0qOpVYsyUs#c?W0RjXF5FkK+009C7A}$c_d4V=-wm&iUwcUvz7cgHS;{Bq0 z0t5&UAV7cs0RjXF5FqezfhOk#g82fwRwo`ATzPDO`2rs|^PT_!0t5&UAV7cs0RjXF zWP`xPoEIocCsWPO7ihfF+j}5XJ_$CjkNk2oNAZfB*pk1PBngM1gS63-o+`;r^G0 l)*K9S0rLeeai9De0RjXF5FkK+009C72oT6tfpg~t{tK9A*_Z$T literal 0 HcmV?d00001 diff --git a/test/dummy/test/controllers/books_controller_test.rb b/test/dummy/test/controllers/books_controller_test.rb index 2374830..b6d0903 100644 --- a/test/dummy/test/controllers/books_controller_test.rb +++ b/test/dummy/test/controllers/books_controller_test.rb @@ -9,7 +9,8 @@ def setup :body => "{}" ) @no_of_books = 5 - create_list :book, @no_of_books + + FactoryBot.create_list(:book, @no_of_books) end test "index" do @@ -27,7 +28,7 @@ def setup test "show" do expected_id = 1 - get :show, {:id => expected_id} + get :show, params: { id: expected_id} assert_response :success, 'it should return successfully' assert_not_nil assigns(:book), '@book should not be nil' assert_instance_of Book, assigns(:book), 'it should be an instance of a book' @@ -38,7 +39,7 @@ def setup test "create" do expected_name = 'newly-created-book' assert_difference('Book.count') do - post :create, :book => {'name' => expected_name} + post :create, params: { book: { name: expected_name}} end end end diff --git a/test/dummy/test/factories/books.rb b/test/dummy/test/factories/books.rb index a64efcc..2d1f9e6 100644 --- a/test/dummy/test/factories/books.rb +++ b/test/dummy/test/factories/books.rb @@ -1,8 +1,8 @@ # Read about factories at https://github.com/thoughtbot/factory_girl -FactoryGirl.define do +FactoryBot.define do factory :book do - name 'some book name' - service_id 'asdf' + name { 'some book name' } + service_id { 'asdf' } end end diff --git a/test/dummy/test/integration/fastly_headers_test.rb b/test/dummy/test/integration/fastly_headers_test.rb index 61a5bac..73631e5 100644 --- a/test/dummy/test/integration/fastly_headers_test.rb +++ b/test/dummy/test/integration/fastly_headers_test.rb @@ -39,9 +39,8 @@ class FastlyHeadersTest < ActionDispatch::IntegrationTest end test 'POST /books should not have fastly headers/ fastly header values' do - assert_difference('Book.count') do - post '/books', 'book' => { 'name' => 'some new book' } + post '/books', params: { book: { name: 'some new book'}} end assert_nil request.session_options[:skip] @@ -57,7 +56,7 @@ class FastlyHeadersTest < ActionDispatch::IntegrationTest create :book, :id => 1, :name => 'some new book' - put '/books/1', 'id' => 1, 'book' => { 'name' => 'changed book' } + put '/books/1', params: { book: { id: 1, name: 'changed book'}} assert_equal 'changed book', Book.find(1).name diff --git a/test/dummy/test/lib/remove_set_cookie_header_test.rb b/test/dummy/test/lib/remove_set_cookie_header_test.rb index bf8bf19..a007b46 100644 --- a/test/dummy/test/lib/remove_set_cookie_header_test.rb +++ b/test/dummy/test/lib/remove_set_cookie_header_test.rb @@ -28,7 +28,7 @@ end it "keeps 'set-cookie' if no 'surrogate-control' or 'surrogate-key'" do - headers = { "Set-Cookie" => "yes!!" } + headers = { "Set-Cookie" => "yes=!!" } app = Rack::Builder.new do use FastlyRails::Rack::RemoveSetCookieHeader @@ -38,6 +38,6 @@ env = Rack::MockRequest.env_for('/') response = Rack::MockResponse.new(*app.call(env)) - assert_equal response.headers['Set-Cookie'], "yes!!" + assert_equal response.headers['Set-Cookie'], "yes=!!" end end diff --git a/test/dummy/test/models/book_test.rb b/test/dummy/test/models/book_test.rb index 400385c..f929913 100644 --- a/test/dummy/test/models/book_test.rb +++ b/test/dummy/test/models/book_test.rb @@ -8,10 +8,11 @@ describe Book do - let (:book) { create :book, id: 1 } + let (:book) { + FactoryBot.create(:book, id: 1) + } it "should have Fastly::SurrogateKey instance methods" do - [:record_key, :table_key, :purge, :purge_all, :soft_purge, :soft_purge_all].each do |method| assert_respond_to book, method end diff --git a/test/test_helper.rb b/test/test_helper.rb index 3fc4ec0..28bc729 100644 --- a/test/test_helper.rb +++ b/test/test_helper.rb @@ -3,17 +3,13 @@ require File.expand_path("../dummy/config/environment.rb", __FILE__) require "rails/test_help" +require "minitest/unit" require "minitest/autorun" -require 'database_cleaner' +require 'database_cleaner/active_record' require 'ffaker' -require 'factory_girl_rails' +require 'factory_bot' require 'webmock/minitest' -begin - require 'rails-controller-testing' -rescue LoadError -end - Rails.backtrace_cleaner.remove_silencers! #include factories @@ -27,10 +23,8 @@ # ActiveSupport::TestCase.fixtures :all # end -ActiveRecord::Migrator.migrate File.expand_path('../dummy/db/migrate/', __FILE__) - class Minitest::Spec - include FactoryGirl::Syntax::Methods + include FactoryBot::Syntax::Methods before :each do stub_request(:any, "https://api.fastly.com/login"). @@ -44,7 +38,7 @@ class Minitest::Spec ) WebMock.disable_net_connect! - + DatabaseCleaner.strategy = :truncation DatabaseCleaner.start end @@ -55,12 +49,12 @@ class Minitest::Spec end class ActionController::TestCase - include FactoryGirl::Syntax::Methods + include FactoryBot::Syntax::Methods end class ActionDispatch::IntegrationTest include WebMock::API - include FactoryGirl::Syntax::Methods + include FactoryBot::Syntax::Methods def setup stub_request(:any, /.*/).