Skip to content

Commit b38b4e6

Browse files
cbeercorylown
authored andcommitted
Update to Rails 7.1
1 parent d3b5b75 commit b38b4e6

File tree

10 files changed

+446
-127
lines changed

10 files changed

+446
-127
lines changed

Gemfile

+2-2
Original file line numberDiff line numberDiff line change
@@ -2,7 +2,7 @@ source 'https://rubygems.org'
22
git_source(:github) { |repo| "https://github.com/#{repo}.git" }
33

44
# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
5-
gem 'rails', '~> 7.0.0'
5+
gem 'rails', '~> 7.1.3'
66

77
# The original asset pipeline for Rails [https://github.com/rails/sprockets-rails]
88
gem "sprockets-rails"
@@ -12,7 +12,7 @@ gem 'sqlite3', '~> 1.4'
1212
gem 'pg'
1313

1414
# Use Puma as the app server
15-
gem 'puma', '~> 5.0'
15+
gem 'puma', '>= 5.0'
1616

1717
# Turbolinks makes navigating your web application faster. Read more: https://github.com/turbolinks/turbolinks
1818
gem 'turbolinks', '~> 5'

Gemfile.lock

+87-77
Original file line numberDiff line numberDiff line change
@@ -1,73 +1,82 @@
11
GEM
22
remote: https://rubygems.org/
33
specs:
4-
actioncable (7.0.8.4)
5-
actionpack (= 7.0.8.4)
6-
activesupport (= 7.0.8.4)
4+
actioncable (7.1.3.4)
5+
actionpack (= 7.1.3.4)
6+
activesupport (= 7.1.3.4)
77
nio4r (~> 2.0)
88
websocket-driver (>= 0.6.1)
9-
actionmailbox (7.0.8.4)
10-
actionpack (= 7.0.8.4)
11-
activejob (= 7.0.8.4)
12-
activerecord (= 7.0.8.4)
13-
activestorage (= 7.0.8.4)
14-
activesupport (= 7.0.8.4)
9+
zeitwerk (~> 2.6)
10+
actionmailbox (7.1.3.4)
11+
actionpack (= 7.1.3.4)
12+
activejob (= 7.1.3.4)
13+
activerecord (= 7.1.3.4)
14+
activestorage (= 7.1.3.4)
15+
activesupport (= 7.1.3.4)
1516
mail (>= 2.7.1)
1617
net-imap
1718
net-pop
1819
net-smtp
19-
actionmailer (7.0.8.4)
20-
actionpack (= 7.0.8.4)
21-
actionview (= 7.0.8.4)
22-
activejob (= 7.0.8.4)
23-
activesupport (= 7.0.8.4)
20+
actionmailer (7.1.3.4)
21+
actionpack (= 7.1.3.4)
22+
actionview (= 7.1.3.4)
23+
activejob (= 7.1.3.4)
24+
activesupport (= 7.1.3.4)
2425
mail (~> 2.5, >= 2.5.4)
2526
net-imap
2627
net-pop
2728
net-smtp
28-
rails-dom-testing (~> 2.0)
29-
actionpack (7.0.8.4)
30-
actionview (= 7.0.8.4)
31-
activesupport (= 7.0.8.4)
32-
rack (~> 2.0, >= 2.2.4)
29+
rails-dom-testing (~> 2.2)
30+
actionpack (7.1.3.4)
31+
actionview (= 7.1.3.4)
32+
activesupport (= 7.1.3.4)
33+
nokogiri (>= 1.8.5)
34+
racc
35+
rack (>= 2.2.4)
36+
rack-session (>= 1.0.1)
3337
rack-test (>= 0.6.3)
34-
rails-dom-testing (~> 2.0)
35-
rails-html-sanitizer (~> 1.0, >= 1.2.0)
36-
actiontext (7.0.8.4)
37-
actionpack (= 7.0.8.4)
38-
activerecord (= 7.0.8.4)
39-
activestorage (= 7.0.8.4)
40-
activesupport (= 7.0.8.4)
38+
rails-dom-testing (~> 2.2)
39+
rails-html-sanitizer (~> 1.6)
40+
actiontext (7.1.3.4)
41+
actionpack (= 7.1.3.4)
42+
activerecord (= 7.1.3.4)
43+
activestorage (= 7.1.3.4)
44+
activesupport (= 7.1.3.4)
4145
globalid (>= 0.6.0)
4246
nokogiri (>= 1.8.5)
43-
actionview (7.0.8.4)
44-
activesupport (= 7.0.8.4)
47+
actionview (7.1.3.4)
48+
activesupport (= 7.1.3.4)
4549
builder (~> 3.1)
46-
erubi (~> 1.4)
47-
rails-dom-testing (~> 2.0)
48-
rails-html-sanitizer (~> 1.1, >= 1.2.0)
49-
activejob (7.0.8.4)
50-
activesupport (= 7.0.8.4)
50+
erubi (~> 1.11)
51+
rails-dom-testing (~> 2.2)
52+
rails-html-sanitizer (~> 1.6)
53+
activejob (7.1.3.4)
54+
activesupport (= 7.1.3.4)
5155
globalid (>= 0.3.6)
5256
activejob-status (1.0.2)
5357
activejob (>= 6.0)
5458
activesupport (>= 6.0)
55-
activemodel (7.0.8.4)
56-
activesupport (= 7.0.8.4)
57-
activerecord (7.0.8.4)
58-
activemodel (= 7.0.8.4)
59-
activesupport (= 7.0.8.4)
60-
activestorage (7.0.8.4)
61-
actionpack (= 7.0.8.4)
62-
activejob (= 7.0.8.4)
63-
activerecord (= 7.0.8.4)
64-
activesupport (= 7.0.8.4)
59+
activemodel (7.1.3.4)
60+
activesupport (= 7.1.3.4)
61+
activerecord (7.1.3.4)
62+
activemodel (= 7.1.3.4)
63+
activesupport (= 7.1.3.4)
64+
timeout (>= 0.4.0)
65+
activestorage (7.1.3.4)
66+
actionpack (= 7.1.3.4)
67+
activejob (= 7.1.3.4)
68+
activerecord (= 7.1.3.4)
69+
activesupport (= 7.1.3.4)
6570
marcel (~> 1.0)
66-
mini_mime (>= 1.1.0)
67-
activesupport (7.0.8.4)
71+
activesupport (7.1.3.4)
72+
base64
73+
bigdecimal
6874
concurrent-ruby (~> 1.0, >= 1.0.2)
75+
connection_pool (>= 2.2.5)
76+
drb
6977
i18n (>= 1.6, < 2)
7078
minitest (>= 5.1)
79+
mutex_m
7180
tzinfo (~> 2.0)
7281
addressable (2.8.7)
7382
public_suffix (>= 2.0.2, < 7.0)
@@ -82,7 +91,6 @@ GEM
8291
bcrypt (3.1.20)
8392
bcrypt_pbkdf (1.1.1)
8493
bcrypt_pbkdf (1.1.1-arm64-darwin)
85-
bcrypt_pbkdf (1.1.1-x86_64-darwin)
8694
bigdecimal (3.1.8)
8795
bindex (0.8.1)
8896
bootstrap_form (5.4.0)
@@ -158,6 +166,7 @@ GEM
158166
ed25519
159167
docile (1.4.1)
160168
domain_name (0.6.20240107)
169+
drb (2.2.1)
161170
ed25519 (1.3.0)
162171
erubi (1.13.0)
163172
factory_bot (6.2.1)
@@ -166,7 +175,6 @@ GEM
166175
factory_bot (~> 6.2.0)
167176
railties (>= 5.0.0)
168177
ffi (1.17.0-arm64-darwin)
169-
ffi (1.17.0-x86_64-darwin)
170178
ffi (1.17.0-x86_64-linux-gnu)
171179
ffi-compiler (1.3.2)
172180
ffi (>= 1.15.5)
@@ -251,9 +259,9 @@ GEM
251259
unf
252260
marcel (1.0.4)
253261
matrix (0.4.2)
254-
method_source (1.1.0)
255262
mini_mime (1.1.5)
256-
minitest (5.24.1)
263+
minitest (5.25.0)
264+
mutex_m (0.2.0)
257265
net-imap (0.4.14)
258266
date
259267
net-protocol
@@ -271,8 +279,6 @@ GEM
271279
nio4r (2.7.3)
272280
nokogiri (1.16.7-arm64-darwin)
273281
racc (~> 1.4)
274-
nokogiri (1.16.7-x86_64-darwin)
275-
racc (~> 1.4)
276282
nokogiri (1.16.7-x86_64-linux)
277283
racc (~> 1.4)
278284
okcomputer (1.18.5)
@@ -288,28 +294,33 @@ GEM
288294
psych (5.1.2)
289295
stringio
290296
public_suffix (6.0.1)
291-
puma (5.6.8)
297+
puma (6.4.2)
292298
nio4r (~> 2.0)
293299
racc (1.8.1)
294-
rack (2.2.9)
300+
rack (3.1.7)
295301
rack-attack (6.7.0)
296302
rack (>= 1.0, < 4)
303+
rack-session (2.0.0)
304+
rack (>= 3.0.0)
297305
rack-test (2.1.0)
298306
rack (>= 1.3)
299-
rails (7.0.8.4)
300-
actioncable (= 7.0.8.4)
301-
actionmailbox (= 7.0.8.4)
302-
actionmailer (= 7.0.8.4)
303-
actionpack (= 7.0.8.4)
304-
actiontext (= 7.0.8.4)
305-
actionview (= 7.0.8.4)
306-
activejob (= 7.0.8.4)
307-
activemodel (= 7.0.8.4)
308-
activerecord (= 7.0.8.4)
309-
activestorage (= 7.0.8.4)
310-
activesupport (= 7.0.8.4)
307+
rackup (2.1.0)
308+
rack (>= 3)
309+
webrick (~> 1.8)
310+
rails (7.1.3.4)
311+
actioncable (= 7.1.3.4)
312+
actionmailbox (= 7.1.3.4)
313+
actionmailer (= 7.1.3.4)
314+
actionpack (= 7.1.3.4)
315+
actiontext (= 7.1.3.4)
316+
actionview (= 7.1.3.4)
317+
activejob (= 7.1.3.4)
318+
activemodel (= 7.1.3.4)
319+
activerecord (= 7.1.3.4)
320+
activestorage (= 7.1.3.4)
321+
activesupport (= 7.1.3.4)
311322
bundler (>= 1.15.0)
312-
railties (= 7.0.8.4)
323+
railties (= 7.1.3.4)
313324
rails-controller-testing (1.0.5)
314325
actionpack (>= 5.0.1.rc1)
315326
actionview (>= 5.0.1.rc1)
@@ -324,13 +335,14 @@ GEM
324335
rails-i18n (7.0.9)
325336
i18n (>= 0.7, < 2)
326337
railties (>= 6.0.0, < 8)
327-
railties (7.0.8.4)
328-
actionpack (= 7.0.8.4)
329-
activesupport (= 7.0.8.4)
330-
method_source
338+
railties (7.1.3.4)
339+
actionpack (= 7.1.3.4)
340+
activesupport (= 7.1.3.4)
341+
irb
342+
rackup (>= 1.0.0)
331343
rake (>= 12.2)
332-
thor (~> 1.0)
333-
zeitwerk (~> 2.5)
344+
thor (~> 1.0, >= 1.2.2)
345+
zeitwerk (~> 2.6)
334346
rainbow (3.1.1)
335347
rake (13.2.1)
336348
rdoc (6.7.0)
@@ -427,7 +439,6 @@ GEM
427439
activesupport (>= 6.1)
428440
sprockets (>= 3.0.0)
429441
sqlite3 (1.7.3-arm64-darwin)
430-
sqlite3 (1.7.3-x86_64-darwin)
431442
sqlite3 (1.7.3-x86_64-linux)
432443
sshkit (1.23.0)
433444
base64
@@ -465,6 +476,7 @@ GEM
465476
addressable (>= 2.8.0)
466477
crack (>= 0.3.2)
467478
hashdiff (>= 0.4.0, < 2.0.0)
479+
webrick (1.8.1)
468480
websocket (1.2.11)
469481
websocket-driver (0.7.6)
470482
websocket-extensions (>= 0.1.0)
@@ -477,8 +489,6 @@ GEM
477489

478490
PLATFORMS
479491
arm64-darwin-23
480-
x86_64-darwin-19
481-
x86_64-darwin-22
482492
x86_64-linux
483493

484494
DEPENDENCIES
@@ -516,9 +526,9 @@ DEPENDENCIES
516526
okcomputer
517527
paper_trail
518528
pg
519-
puma (~> 5.0)
529+
puma (>= 5.0)
520530
rack-attack
521-
rails (~> 7.0.0)
531+
rails (~> 7.1.3)
522532
rails-controller-testing
523533
redis (~> 5.0)
524534
rexml

app/models/upload.rb

+8-4
Original file line numberDiff line numberDiff line change
@@ -18,13 +18,13 @@ class Upload < ApplicationRecord
1818

1919
after_create :attach_file_from_url
2020

21-
after_save_commit :perform_extract_marc_record_metadata_job, if: :active?
22-
after_save_commit :perform_extract_files_job, if: :active?
23-
24-
# This should be after any callbacks that interact with the attached upload
21+
# This should be _before_ any callbacks that interact with the attached upload
2522
# See https://github.com/rails/rails/issues/37304
2623
has_many_attached :files
2724

25+
after_save_commit :perform_extract_marc_record_metadata_job, if: :active?
26+
after_save_commit :perform_extract_files_job, if: :active?
27+
2828
def active?
2929
status == 'active'
3030
end
@@ -73,10 +73,14 @@ def url_presence_if_no_uploaded_files
7373
end
7474

7575
def perform_extract_marc_record_metadata_job
76+
return unless files.any?(&:saved_changes?)
77+
7678
ExtractMarcRecordMetadataJob.perform_later(self)
7779
end
7880

7981
def perform_extract_files_job
82+
return unless files.any?(&:saved_changes?)
83+
8084
ExtractFilesJob.perform_later(self)
8185
end
8286

bin/setup

+1-1
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ require "fileutils"
55
APP_ROOT = File.expand_path('..', __dir__)
66

77
def system!(*args)
8-
system(*args) || abort("\n== Command #{args} failed ==")
8+
system(*args, exception: true)
99
end
1010

1111
FileUtils.chdir APP_ROOT do

config/application.rb

+5
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,11 @@ class Application < Rails::Application
1111
# Initialize configuration defaults for originally generated Rails version.
1212
config.load_defaults 6.1
1313

14+
# Please, add to the `ignore` list any other `lib` subdirectories that do
15+
# not contain `.rb` files, or that should not be reloaded or eager loaded.
16+
# Common ones are `templates`, `generators`, or `middleware`, for example.
17+
config.autoload_lib(ignore: %w(assets tasks))
18+
1419
# Configuration for the application, engines, and railties goes here.
1520
#
1621
# These settings can be overridden in specific environments using the files

config/environments/development.rb

+7-1
Original file line numberDiff line numberDiff line change
@@ -6,7 +6,7 @@
66
# In the development environment your application's code is reloaded any time
77
# it changes. This slows down response time but is perfect for development
88
# since you don't have to restart the web server when you make code changes.
9-
config.cache_classes = false
9+
config.enable_reloading = true
1010

1111
# Do not eager load code on boot.
1212
config.eager_load = false
@@ -59,6 +59,9 @@
5959
# Highlight code that triggered database queries in logs.
6060
config.active_record.verbose_query_logs = true
6161

62+
# Highlight code that enqueued background job in logs.
63+
config.active_job.verbose_enqueue_logs = true
64+
6265
# Suppress logger output for asset requests.
6366
config.assets.quiet = true
6467

@@ -70,4 +73,7 @@
7073

7174
# Uncomment if you wish to allow Action Cable access from any origin.
7275
# config.action_cable.disable_request_forgery_protection = true
76+
77+
# Raise error when a before_action's only/except options reference missing actions
78+
config.action_controller.raise_on_missing_callback_actions = true
7379
end

0 commit comments

Comments
 (0)