railties 7.2.3.1 → 8.0.0.beta1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (110) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +111 -329
  3. data/README.rdoc +1 -1
  4. data/lib/minitest/rails_plugin.rb +2 -2
  5. data/lib/rails/application/bootstrap.rb +3 -1
  6. data/lib/rails/application/configuration.rb +22 -7
  7. data/lib/rails/application/default_middleware_stack.rb +4 -0
  8. data/lib/rails/application/finisher.rb +2 -2
  9. data/lib/rails/application/routes_reloader.rb +11 -1
  10. data/lib/rails/application.rb +14 -12
  11. data/lib/rails/backtrace_cleaner.rb +1 -1
  12. data/lib/rails/code_statistics.rb +128 -86
  13. data/lib/rails/code_statistics_calculator.rb +78 -76
  14. data/lib/rails/command/helpers/editor.rb +1 -1
  15. data/lib/rails/commands/app/update_command.rb +1 -9
  16. data/lib/rails/commands/console/irb_console.rb +6 -3
  17. data/lib/rails/commands/credentials/USAGE +4 -4
  18. data/lib/rails/commands/credentials/credentials_command.rb +5 -1
  19. data/lib/rails/commands/dev/dev_command.rb +1 -1
  20. data/lib/rails/commands/devcontainer/devcontainer_command.rb +1 -1
  21. data/lib/rails/commands/stats/stats_command.rb +19 -0
  22. data/lib/rails/commands/test/test_command.rb +2 -0
  23. data/lib/rails/dev_caching.rb +2 -2
  24. data/lib/rails/engine/configuration.rb +3 -1
  25. data/lib/rails/engine/lazy_route_set.rb +109 -0
  26. data/lib/rails/engine.rb +8 -3
  27. data/lib/rails/gem_version.rb +4 -4
  28. data/lib/rails/generators/actions.rb +5 -9
  29. data/lib/rails/generators/app_base.rb +49 -31
  30. data/lib/rails/generators/database.rb +101 -67
  31. data/lib/rails/generators/erb/authentication/authentication_generator.rb +15 -0
  32. data/lib/rails/generators/erb/authentication/templates/views/passwords/edit.html.erb +9 -0
  33. data/lib/rails/generators/erb/authentication/templates/views/passwords/new.html.erb +8 -0
  34. data/lib/rails/generators/erb/authentication/templates/views/sessions/new.html.erb +11 -0
  35. data/lib/rails/generators/generated_attribute.rb +16 -11
  36. data/lib/rails/generators/rails/app/app_generator.rb +19 -28
  37. data/lib/rails/generators/rails/app/templates/Dockerfile.tt +12 -3
  38. data/lib/rails/generators/rails/app/templates/Gemfile.tt +23 -8
  39. data/lib/rails/generators/rails/app/templates/app/assets/stylesheets/application.css.tt +6 -11
  40. data/lib/rails/generators/rails/app/templates/app/views/layouts/application.html.erb.tt +10 -3
  41. data/lib/rails/generators/rails/app/templates/bin/dev.tt +1 -0
  42. data/lib/rails/generators/rails/app/templates/bin/setup.tt +5 -7
  43. data/lib/rails/generators/rails/app/templates/bin/thrust.tt +4 -0
  44. data/lib/rails/generators/rails/app/templates/config/databases/mysql.yml.tt +23 -0
  45. data/lib/rails/generators/rails/app/templates/config/databases/postgresql.yml.tt +23 -0
  46. data/lib/rails/generators/rails/app/templates/config/databases/sqlite3.yml.tt +40 -0
  47. data/lib/rails/generators/rails/app/templates/config/databases/trilogy.yml.tt +23 -0
  48. data/lib/rails/generators/rails/app/templates/config/deploy.yml.tt +124 -0
  49. data/lib/rails/generators/rails/app/templates/config/environments/development.rb.tt +12 -23
  50. data/lib/rails/generators/rails/app/templates/config/environments/production.rb.tt +31 -51
  51. data/lib/rails/generators/rails/app/templates/config/environments/test.rb.tt +5 -19
  52. data/lib/rails/generators/rails/app/templates/config/initializers/assets.rb.tt +0 -7
  53. data/lib/rails/generators/rails/app/templates/config/initializers/filter_parameter_logging.rb.tt +1 -1
  54. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_8_0.rb.tt +25 -0
  55. data/lib/rails/generators/rails/app/templates/config/puma.rb.tt +11 -2
  56. data/lib/rails/generators/rails/app/templates/config/routes.rb.tt +3 -3
  57. data/lib/rails/generators/rails/app/templates/docker-entrypoint.tt +4 -3
  58. data/lib/rails/generators/rails/app/templates/dockerignore.tt +1 -2
  59. data/lib/rails/generators/rails/app/templates/github/ci.yml.tt +1 -3
  60. data/lib/rails/generators/rails/app/templates/gitignore.tt +1 -2
  61. data/lib/rails/generators/rails/app/templates/kamal-secrets.tt +17 -0
  62. data/lib/rails/generators/rails/app/templates/public/400.html +114 -0
  63. data/lib/rails/generators/rails/app/templates/public/404.html +113 -66
  64. data/lib/rails/generators/rails/app/templates/public/406-unsupported-browser.html +113 -65
  65. data/lib/rails/generators/rails/app/templates/public/422.html +113 -66
  66. data/lib/rails/generators/rails/app/templates/public/500.html +113 -65
  67. data/lib/rails/generators/rails/app/templates/public/icon.png +0 -0
  68. data/lib/rails/generators/rails/app/templates/public/icon.svg +2 -2
  69. data/lib/rails/generators/rails/authentication/USAGE +6 -0
  70. data/lib/rails/generators/rails/authentication/authentication_generator.rb +54 -0
  71. data/lib/rails/generators/rails/authentication/templates/controllers/concerns/authentication.rb +55 -0
  72. data/lib/rails/generators/rails/authentication/templates/controllers/passwords_controller.rb +33 -0
  73. data/lib/rails/generators/rails/authentication/templates/controllers/sessions_controller.rb +21 -0
  74. data/lib/rails/generators/rails/authentication/templates/mailers/passwords_mailer.rb +6 -0
  75. data/lib/rails/generators/rails/authentication/templates/models/current.rb +4 -0
  76. data/lib/rails/generators/rails/authentication/templates/models/session.rb +3 -0
  77. data/lib/rails/generators/rails/authentication/templates/models/user.rb +6 -0
  78. data/lib/rails/generators/rails/authentication/templates/test/mailers/previews/passwords_mailer_preview.rb +7 -0
  79. data/lib/rails/generators/rails/authentication/templates/views/passwords_mailer/reset.html.erb +4 -0
  80. data/lib/rails/generators/rails/authentication/templates/views/passwords_mailer/reset.text.erb +2 -0
  81. data/lib/rails/generators/rails/credentials/templates/credentials.yml.tt +4 -0
  82. data/lib/rails/generators/rails/db/system/change/change_generator.rb +1 -1
  83. data/lib/rails/generators/rails/devcontainer/devcontainer_generator.rb +4 -2
  84. data/lib/rails/generators/rails/devcontainer/templates/devcontainer/devcontainer.json.tt +1 -1
  85. data/lib/rails/generators/rails/plugin/plugin_generator.rb +7 -9
  86. data/lib/rails/generators/rails/plugin/templates/github/ci.yml.tt +2 -3
  87. data/lib/rails/generators/rails/scaffold_controller/templates/api_controller.rb.tt +4 -4
  88. data/lib/rails/generators/rails/scaffold_controller/templates/controller.rb.tt +5 -5
  89. data/lib/rails/generators/rails/script/USAGE +18 -0
  90. data/lib/rails/generators/rails/script/script_generator.rb +18 -0
  91. data/lib/rails/generators/rails/script/templates/script.rb.tt +3 -0
  92. data/lib/rails/generators.rb +6 -5
  93. data/lib/rails/info_controller.rb +10 -4
  94. data/lib/rails/rack/silence_request.rb +33 -0
  95. data/lib/rails/rack.rb +1 -0
  96. data/lib/rails/source_annotation_extractor.rb +31 -14
  97. data/lib/rails/tasks/statistics.rake +13 -28
  98. data/lib/rails/templates/rails/info/notes.html.erb +65 -0
  99. data/lib/rails/test_unit/runner.rb +3 -7
  100. data/lib/rails/test_unit/test_parser.rb +15 -18
  101. metadata +45 -50
  102. data/lib/rails/generators/rails/app/templates/app/assets/config/manifest.js.tt +0 -2
  103. data/lib/rails/generators/rails/app/templates/app/channels/application_cable/channel.rb.tt +0 -4
  104. data/lib/rails/generators/rails/app/templates/app/channels/application_cable/connection.rb.tt +0 -4
  105. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_7_2.rb.tt +0 -70
  106. data/lib/rails/generators/rails/app/templates/config/initializers/permissions_policy.rb.tt +0 -13
  107. data/lib/rails/generators/rails/app/templates/test/channels/application_cable/connection_test.rb.tt +0 -13
  108. data/lib/rails/generators/rails/plugin/templates/rails/dummy_manifest.js.tt +0 -10
  109. data/lib/rails/generators/rails/plugin/templates/rails/engine_manifest.js.tt +0 -6
  110. data/lib/rails/generators/rails/plugin/templates/rails/javascripts.js.tt +0 -17
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 6901f0b92ef11f501dfc346db6917e4f8c5612cfe69dcf286b2fe34c7984d00d
4
- data.tar.gz: fc0584d1aa4d6a4900ccbaa846eef834deb35a96e253c0fb3abc47e9216f5ffe
3
+ metadata.gz: 8e33b7c8f20e79a1706cdcad58be19d009563111e20a59f96d8c387d4088883c
4
+ data.tar.gz: 4490c2625c393ab52a69d98a61caaa3a3b3f5093899e8203dad3d28a8a5dbc99
5
5
  SHA512:
6
- metadata.gz: 105b31ef811832df283f6b185b0e2a3277023e949ed32b45bfb64ff99733df720c74b60b83d38679411069a52671f0df1b46add11385219f610c13a9894e2446
7
- data.tar.gz: ef33b6491ada406372baa50d9e1f5ea70e0cae44abca697bea78748610109eca8e91fb68b077c1a5b55e5388f1d7108d78812b4d29da0b8f88143fd93da0f2e3
6
+ metadata.gz: 7fd02c87add0fdf9ac0b0a1b5ed6b79a278b258f8d40fc02c912e24d6995a4155bdea1a460b795c180e938a7b9f7af793f23a8ff3feec9cb15c4812101d22ce5
7
+ data.tar.gz: 4788fa68c076ebb9901afd5fc6e24112939de491353096659b1151d841a37872d17f45b21b659287a976916d1b02a1342f2de536a835108a46559cfbd7af3ba2
data/CHANGELOG.md CHANGED
@@ -1,403 +1,185 @@
1
- ## Rails 7.2.3.1 (March 23, 2026) ##
1
+ ## Rails 8.0.0.beta1 (September 26, 2024) ##
2
2
 
3
- * No changes.
3
+ * Exit `rails g` with code 1 if generator could not be found.
4
4
 
5
+ Previously `rails g` returned 0, which would make it harder to catch typos in scripts calling `rails g`.
5
6
 
6
- ## Rails 7.2.3 (October 28, 2025) ##
7
+ *Christopher Özbek*
7
8
 
8
- * Use `secret_key_base` from ENV or credentials when present locally.
9
+ * Remove `require_*` statements from application.css to align with the transition from Sprockets to Propshaft.
9
10
 
10
- When ENV["SECRET_KEY_BASE"] or
11
- `Rails.application.credentials.secret_key_base` is set for test or
12
- development, it is used for the `Rails.config.secret_key_base`,
13
- instead of generating a `tmp/local_secret.txt` file.
11
+ With Propshaft as the default asset pipeline in Rails 8, the require_tree and require_self clauses in application.css are no longer necessary, as they were specific to Sprockets. Additionally, the comment has been updated to clarify that CSS precedence now follows standard cascading order without automatic prioritization by the asset pipeline.
14
12
 
15
- *Petrik de Heus*
16
-
17
-
18
- ## Rails 7.2.2.2 (August 13, 2025) ##
19
-
20
- * No changes.
21
-
22
-
23
- ## Rails 7.2.2.1 (December 10, 2024) ##
24
-
25
- * No changes.
26
-
27
-
28
- ## Rails 7.2.2 (October 30, 2024) ##
29
-
30
- * No changes.
31
-
32
-
33
- ## Rails 7.2.1.2 (October 23, 2024) ##
34
-
35
- * No changes.
36
-
37
-
38
- ## Rails 7.2.1.1 (October 15, 2024) ##
39
-
40
- * No changes.
41
-
42
-
43
- ## Rails 7.2.1 (August 22, 2024) ##
13
+ *Eduardo Alencar*
44
14
 
45
- * Fix `rails console` for application with non default application constant.
15
+ * Do not include redis by default in generated Dev Containers.
46
16
 
47
- The wrongly assumed the Rails application would be named `AppNamespace::Application`,
48
- which is the default but not an obligation.
17
+ Now that applications use the Solid Queue and Solid Cache gems by default, we do not need to include redis
18
+ in the Dev Container. We will only include redis if `--skip-solid` is used when generating an app that uses
19
+ Active Job or Action Cable.
49
20
 
50
- *Jean Boussier*
51
-
52
- * Fix the default Dockerfile to include the full sqlite3 package.
53
-
54
- Prior to this it only included `libsqlite3`, so it wasn't enough to
55
- run `rails dbconsole`.
56
-
57
- *Jerome Dalbert*
58
-
59
- * Don't update public directory during `app:update` command for API-only Applications.
60
-
61
- *y-yagi*
62
-
63
- * Don't add bin/brakeman if brakeman is not in bundle when upgrading an application.
64
-
65
- *Etienne Barrié*
66
-
67
- * Remove PWA views and routes if its an API only project.
68
-
69
- *Jean Boussier*
70
-
71
- * Simplify generated Puma configuration
72
-
73
- *DHH*, *Rafael Mendonça França*
74
-
75
-
76
- ## Rails 7.2.0 (August 09, 2024) ##
77
-
78
- * The new `bin/rails boot` command boots the application and exits. Supports the
79
- standard `-e/--environment` options.
80
-
81
- *Xavier Noria*
82
-
83
- * Create a Dev Container Generator that generates a Dev Container setup based on the current configuration
84
- of the application. Usage:
85
-
86
- `bin/rails devcontainer`
21
+ When generating a Dev Container for an existing app, we will not include redis if either of the solid gems
22
+ are in use.
87
23
 
88
24
  *Andrew Novoselac*
89
25
 
90
- * Add Rubocop and GitHub Actions to plugin generator.
91
- This can be skipped using --skip-rubocop and --skip-ci.
92
-
93
- *Chris Oliver*
94
-
95
- * Remove support for `oracle`, `sqlserver` and JRuby specific database adapters from the
96
- `rails new` and `rails db:system:change` commands.
97
-
98
- The supported options are `sqlite3`, `mysql`, `postgresql` and `trilogy`.
99
-
100
- *Andrew Novoselac*
101
-
102
- * Add options to `bin/rails app:update`.
103
-
104
- `bin/rails app:update` now supports the same generic options that generators do:
105
-
106
- * `--force`: Accept all changes to existing files
107
- * `--skip`: Refuse all changes to existing files
108
- * `--pretend`: Don't make any changes
109
- * `--quiet`: Don't output all changes made
110
-
111
- *Étienne Barrié*
112
-
113
- * Implement Rails console commands and helpers with IRB v1.13's extension APIs.
114
-
115
- Rails console users will now see `helper`, `controller`, `new_session`, and `app` under
116
- IRB help message's `Helper methods` category. And `reload!` command will be displayed under
117
- the new `Rails console` commands category.
118
-
119
- Prior to this change, Rails console's commands and helper methods are added through IRB's
120
- private components and don't show up in its help message, which led to poor discoverability.
121
-
122
- *Stan Lo*
123
-
124
- * Remove deprecated `Rails::Generators::Testing::Behaviour`.
125
-
126
- *Rafael Mendonça França*
127
-
128
- * Remove deprecated `find_cmd_and_exec` console helper.
129
-
130
- *Rafael Mendonça França*
131
-
132
- * Remove deprecated `Rails.config.enable_dependency_loading`.
133
-
134
- *Rafael Mendonça França*
135
-
136
- * Remove deprecated `Rails.application.secrets`.
137
-
138
- *Rafael Mendonça França*
139
-
140
- * Generated Gemfile will include `require: "debug/prelude"` for the `debug` gem.
141
-
142
- Requiring `debug` gem directly automatically activates it, which could introduce
143
- additional overhead and memory usage even without entering a debugging session.
144
-
145
- By making Bundler require `debug/prelude` instead, developers can keep their access
146
- to breakpoint methods like `debugger` or `binding.break`, but the debugger won't be
147
- activated until a breakpoint is hit.
148
-
149
- *Stan Lo*
150
-
151
- * Skip generating a `test` job in ci.yml when a new application is generated with the
152
- `--skip-test` option.
153
-
154
- *Steve Polito*
155
-
156
- * Update the `.node-version` file conditionally generated for new applications to 20.11.1
157
-
158
- *Steve Polito*
159
-
160
- * Fix sanitizer vendor configuration in 7.1 defaults.
161
-
162
- In apps where rails-html-sanitizer was not eagerly loaded, the sanitizer default could end up
163
- being Rails::HTML4::Sanitizer when it should be set to Rails::HTML5::Sanitizer.
164
-
165
- *Mike Dalessio*, *Rafael Mendonça França*
166
-
167
- * Set `action_mailer.default_url_options` values in `development` and `test`.
26
+ * Use [Solid Cable](https://github.com/rails/solid_cable) as the default Action Cable adapter in production, configured as a separate queue database in config/database.yml. It keeps messages in a table and continuously polls for updates. This makes it possible to drop the common dependency on Redis, if it isn't needed for any other purpose. Despite polling, the performance of Solid Cable is comparable to Redis in most situations. And in all circumstances, it makes it easier to deploy Rails when Redis is no longer a required dependency for Action Cable functionality.
168
27
 
169
- Prior to this commit, new Rails applications would raise `ActionView::Template::Error`
170
- if a mailer included a url built with a `*_path` helper.
28
+ *DHH*
171
29
 
172
- *Steve Polito*
30
+ * Use [Solid Queue](https://github.com/rails/solid_queue) as the default Active Job backend in production, configured as a separate queue database in config/database.yml. In a single-server deployment, it'll run as a Puma plugin. This is configured in `config/deploy.yml` and can easily be changed to use a dedicated jobs machine.
173
31
 
174
- * Introduce `Rails::Generators::Testing::Assertions#assert_initializer`.
32
+ *DHH*
175
33
 
176
- Compliments the existing `initializer` generator action.
34
+ * Use [Solid Cache](https://github.com/rails/solid_cache) as the default Rails.cache backend in production, configured as a separate cache database in config/database.yml.
177
35
 
178
- ```rb
179
- assert_initializer "mail_interceptors.rb"
180
- ```
181
-
182
- *Steve Polito*
36
+ *DHH*
183
37
 
184
- * Generate a .devcontainer folder and its contents when creating a new app.
38
+ * Add Rails::Rack::SilenceRequest middleware and use it via `config.silence_healthcheck_path = path`
39
+ to silence requests to "/up". This prevents the Kamal-required health checks from clogging up
40
+ the production logs.
185
41
 
186
- The .devcontainer folder includes everything needed to boot the app and do development in a remote container.
42
+ *DHH*
187
43
 
188
- The container setup includes:
189
- - A redis container for Kredis, ActionCable etc.
190
- - A database (SQLite, Postgres, MySQL or MariaDB)
191
- - A Headless chrome container for system tests
192
- - Active Storage configured to use the local disk and with preview features working
44
+ * Introduce `mariadb-mysql` and `mariadb-trilogy` database options for `rails new`
193
45
 
194
- If any of these options are skipped in the app setup they will not be included in the container configuration.
46
+ When used with the `--devcontainer` flag, these options will use `mariadb` as the database for the
47
+ Dev Container. The original `mysql` and `trilogy` options will use `mysql`. Users who are not
48
+ generating a Dev Container do not need to use the new options.
195
49
 
196
- These files can be skipped using the `--skip-devcontainer` option.
50
+ *Andrew Novoselac*
197
51
 
198
- *Andrew Novoselac & Rafael Mendonça França*
52
+ * Deprecate `::STATS_DIRECTORIES`.
199
53
 
200
- * Introduce `SystemTestCase#served_by` for configuring the System Test application server.
54
+ The global constant `STATS_DIRECTORIES` has been deprecated in favor of
55
+ `Rails::CodeStatistics.register_directory`.
201
56
 
202
- By default this is localhost. This method allows the host and port to be specified manually.
57
+ Add extra directories with `Rails::CodeStatistics.register_directory(label, path)`:
203
58
 
204
59
  ```ruby
205
- class ApplicationSystemTestCase < ActionDispatch::SystemTestCase
206
- served_by host: "testserver", port: 45678
207
- end
60
+ require "rails/code_statistics"
61
+ Rails::CodeStatistics.register_directory('My Directory', 'path/to/dir')
208
62
  ```
209
63
 
210
- *Andrew Novoselac & Rafael Mendonça França*
64
+ *Petrik de Heus*
211
65
 
212
- * `bin/rails test` will no longer load files named `*_test.rb` if they are located in the `fixtures` folder.
66
+ * Enable query log tags by default on development env
213
67
 
214
- *Edouard Chin*
68
+ This can be used to trace troublesome SQL statements back to the application
69
+ code that generated these statements. It is also useful when using multiple
70
+ databases because the query logs can identify which database is being used.
215
71
 
216
- * Ensure logger tags configured with `config.log_tags` are still active in `request.action_dispatch` handlers.
72
+ *Matheus Richard*
217
73
 
218
- *KJ Tsanaktsidis*
74
+ * Defer route drawing to the first request, or when url_helpers are called
219
75
 
220
- * Setup jemalloc in the default Dockerfile for memory optimization.
76
+ Executes the first routes reload in middleware, or when a route set's
77
+ url_helpers receives a route call / asked if it responds to a route.
78
+ Previously, this was executed unconditionally on boot, which can
79
+ slow down boot time unnecessarily for larger apps with lots of routes.
221
80
 
222
- *Matt Almeida*, *Jean Boussier*
81
+ Environments like production that have `config.eager_load = true` will
82
+ continue to eagerly load routes on boot.
223
83
 
224
- * Commented out lines in .railsrc file should not be treated as arguments when using
225
- rails new generator command. Update ARGVScrubber to ignore text after `#` symbols.
84
+ *Gannon McGibbon*
226
85
 
227
- *Willian Tenfen*
86
+ * Generate form helpers to use `textarea*` methods instead of `text_area*` methods
228
87
 
229
- * Skip CSS when generating APIs.
88
+ *Sean Doyle*
230
89
 
231
- *Ruy Rocha*
90
+ * Add authentication generator to give a basic start to an authentication system using database-tracked sessions and password reset.
232
91
 
233
- * Rails console now indicates application name and the current Rails environment:
92
+ Generate with...
234
93
 
235
- ```txt
236
- my-app(dev)> # for RAILS_ENV=development
237
- my-app(test)> # for RAILS_ENV=test
238
- my-app(prod)> # for RAILS_ENV=production
239
- my-app(my_env)> # for RAILS_ENV=my_env
94
+ ```
95
+ bin/rails generate authentication
240
96
  ```
241
97
 
242
- The application name is derived from the application's module name from `config/application.rb`.
243
- For example, `MyApp` will displayed as `my-app` in the prompt.
244
-
245
- Additionally, the environment name will be colorized when the environment is
246
- `development` (blue), `test` (blue), or `production` (red), if your
247
- terminal supports it.
248
-
249
- *Stan Lo*
250
-
251
- * Ensure `autoload_paths`, `autoload_once_paths`, `eager_load_paths`, and
252
- `load_paths` only have directories when initialized from engine defaults.
253
-
254
- Previously, files under the `app` directory could end up there too.
255
-
256
- *Takumasa Ochi*
257
-
258
- * Prevent unnecessary application reloads in development.
259
-
260
- Previously, some files outside autoload paths triggered unnecessary reloads.
261
- With this fix, application reloads according to `Rails.autoloaders.main.dirs`,
262
- thereby preventing unnecessary reloads.
263
-
264
- *Takumasa Ochi*
265
-
266
- * Use `oven-sh/setup-bun` in GitHub CI when generating an app with Bun.
267
-
268
- *TangRufus*
269
-
270
- * Disable `pidfile` generation in the `production` environment.
98
+ Generated files:
271
99
 
272
- *Hans Schnedlitz*
100
+ ```
101
+ app/models/current.rb
102
+ app/models/user.rb
103
+ app/models/session.rb
104
+ app/controllers/sessions_controller.rb
105
+ app/controllers/passwords_controller.rb
106
+ app/mailers/passwords_mailer.rb
107
+ app/views/sessions/new.html.erb
108
+ app/views/passwords/new.html.erb
109
+ app/views/passwords/edit.html.erb
110
+ app/views/passwords_mailer/reset.html.erb
111
+ app/views/passwords_mailer/reset.text.erb
112
+ db/migrate/xxxxxxx_create_users.rb
113
+ db/migrate/xxxxxxx_create_sessions.rb
114
+ test/mailers/previews/passwords_mailer_preview.rb
115
+ ```
273
116
 
274
- * Set `config.action_view.annotate_rendered_view_with_filenames` to `true` in
275
- the `development` environment.
117
+ *DHH*
276
118
 
277
- *Adrian Marin*
278
119
 
279
- * Support the `BACKTRACE` environment variable to turn off backtrace cleaning.
120
+ * Add not-null type modifier to migration attributes.
280
121
 
281
- Useful for debugging framework code:
122
+ Generating with...
282
123
 
283
- ```sh
284
- BACKTRACE=1 bin/rails server
124
+ ```
125
+ bin/rails generate migration CreateUsers email_address:string!:uniq password_digest:string!
285
126
  ```
286
127
 
287
- *Alex Ghiculescu*
288
-
289
- * Raise `ArgumentError` when reading `config.x.something` with arguments:
128
+ Produces:
290
129
 
291
130
  ```ruby
292
- config.x.this_works.this_raises true # raises ArgumentError
131
+ class CreateUsers < ActiveRecord::Migration[8.0]
132
+ def change
133
+ create_table :users do |t|
134
+ t.string :email_address, null: false
135
+ t.string :password_digest, null: false
136
+
137
+ t.timestamps
138
+ end
139
+ add_index :users, :email_address, unique: true
140
+ end
141
+ end
293
142
  ```
294
143
 
295
- *Sean Doyle*
296
-
297
- * Add default PWA files for manifest and service-worker that are served from `app/views/pwa` and can be dynamically rendered through ERB. Mount these files explicitly at the root with default routes in the generated routes file.
298
-
299
- *DHH*
300
-
301
- * Updated system tests to now use headless Chrome by default for the new applications.
302
-
303
- *DHH*
304
-
305
- * Add GitHub CI files for Dependabot, Brakeman, RuboCop, and running tests by default. Can be skipped with `--skip-ci`.
306
-
307
144
  *DHH*
308
145
 
309
- * Add Brakeman by default for static analysis of security vulnerabilities. Allow skipping with `--skip-brakeman option`.
310
-
311
- *vipulnsward*
312
-
313
- * Add RuboCop with rules from `rubocop-rails-omakase` by default. Skip with `--skip-rubocop`.
314
-
315
- *DHH* and *zzak*
316
-
317
- * Use `bin/rails runner --skip-executor` to not wrap the runner script with an
318
- Executor.
319
-
320
- *Ben Sheldon*
321
-
322
- * Fix isolated engines to take `ActiveRecord::Base.table_name_prefix` into consideration.
323
-
324
- This will allow for engine defined models, such as inside Active Storage, to respect
325
- Active Record table name prefix configuration.
326
-
327
- *Chedli Bourguiba*
328
-
329
- * Fix running `db:system:change` when the app has no Dockerfile.
330
-
331
- *Hartley McGuire*
332
-
333
- * In Action Mailer previews, list inline attachments separately from normal
334
- attachments.
335
-
336
- For example, attachments that were previously listed like
337
-
338
- > Attachments: logo.png file1.pdf file2.pdf
339
-
340
- will now be listed like
341
-
342
- > Attachments: file1.pdf file2.pdf (Inline: logo.png)
343
-
344
- *Christian Schmidt* and *Jonathan Hefner*
146
+ * Add a `script` folder to applications, and a scripts generator.
345
147
 
346
- * In mailer preview, only show SMTP-To if it differs from the union of To, Cc and Bcc.
148
+ The new `script` folder is meant to hold one-off or general purpose scripts,
149
+ such as data migration scripts, cleanup scripts, etc.
347
150
 
348
- *Christian Schmidt*
349
-
350
- * Enable YJIT by default on new applications running Ruby 3.3+.
351
-
352
- This can be disabled by setting `Rails.application.config.yjit = false`
353
-
354
- *Jean Boussier*, *Rafael Mendonça França*
355
-
356
- * In Action Mailer previews, show date from message `Date` header if present.
357
-
358
- *Sampat Badhe*
359
-
360
- * Exit with non-zero status when the migration generator fails.
361
-
362
- *Katsuhiko YOSHIDA*
363
-
364
- * Use numeric UID and GID in Dockerfile template.
365
-
366
- The Dockerfile generated by `rails new` sets the default user and group
367
- by name instead of UID:GID. This can cause the following error in Kubernetes:
151
+ A new script generator allows you to create such scripts:
368
152
 
369
153
  ```
370
- container has runAsNonRoot and image has non-numeric user (rails), cannot verify user is non-root
154
+ bin/rails generate script my_script
155
+ bin/rails generate script data/backfill
371
156
  ```
372
157
 
373
- This change sets default user and group by their numeric values.
158
+ You can run the generated script using:
374
159
 
375
- *Ivan Fedotov*
376
-
377
- * Disallow invalid values for rails new options.
160
+ ```
161
+ bundle exec ruby script/my_script.rb
162
+ bundle exec ruby script/data/backfill.rb
163
+ ```
378
164
 
379
- The `--database`, `--asset-pipeline`, `--css`, and `--javascript` options
380
- for `rails new` take different arguments. This change validates them.
165
+ *Jerome Dalbert*, *Haroon Ahmed*
381
166
 
382
- *Tony Drake*, *Akhil G Krishnan*, *Petrik de Heus*
167
+ * Deprecate `bin/rake stats` in favor of `bin/rails stats`.
383
168
 
384
- * Conditionally print `$stdout` when invoking `run_generator`.
169
+ *Juan Vásquez*
385
170
 
386
- In an effort to improve the developer experience when debugging
387
- generator tests, we add the ability to conditionally print `$stdout`
388
- instead of capturing it.
171
+ * Add internal page `/rails/info/notes`, that displays the same information as `bin/rails notes`.
389
172
 
390
- This allows for calls to `binding.irb` and `puts` work as expected.
173
+ *Deepak Mahakale*
391
174
 
392
- ```sh
393
- RAILS_LOG_TO_STDOUT=true ./bin/test test/generators/actions_test.rb
394
- ```
175
+ * Add Rubocop and GitHub Actions to plugin generator.
176
+ This can be skipped using --skip-rubocop and --skip-ci.
395
177
 
396
- *Steve Polito*
178
+ *Chris Oliver*
397
179
 
398
- * Remove the option `config.public_file_server.enabled` from the generators
399
- for all environments, as the value is the same in all environments.
180
+ * Use Kamal for deployment by default, which includes generating a Rails-specific config/deploy.yml.
181
+ This can be skipped using --skip-kamal. See more: https://kamal-deploy.org/
400
182
 
401
- *Adrian Hirt*
183
+ *DHH*
402
184
 
403
- Please check [7-1-stable](https://github.com/rails/rails/blob/7-1-stable/railties/CHANGELOG.md) for previous changes.
185
+ Please check [7-2-stable](https://github.com/rails/rails/blob/7-2-stable/railties/CHANGELOG.md) for previous changes.
data/README.rdoc CHANGED
@@ -34,6 +34,6 @@ Bug reports can be filed for the Ruby on \Rails project here:
34
34
 
35
35
  * https://github.com/rails/rails/issues
36
36
 
37
- Feature requests should be discussed on the rubyonrails-core forum here:
37
+ Feature requests should be discussed on the rails-core mailing list here:
38
38
 
39
39
  * https://discuss.rubyonrails.org/c/rubyonrails-core
@@ -25,7 +25,7 @@ module Minitest
25
25
  end
26
26
  end
27
27
 
28
- class ProfileReporter < Reporter
28
+ class ProfileReporter < StatisticsReporter
29
29
  def initialize(io = $stdout, options = {})
30
30
  super
31
31
  @results = []
@@ -110,7 +110,7 @@ module Minitest
110
110
  # minitest-reporters, maxitest, and others.
111
111
  def self.plugin_rails_init(options)
112
112
  # Don't mess with Minitest unless RAILS_ENV is set
113
- return unless ENV["RAILS_ENV"]
113
+ return unless ENV["RAILS_ENV"] || ENV["RAILS_MINITEST_PLUGIN"]
114
114
 
115
115
  unless options[:full_backtrace]
116
116
  # Plugin can run without Rails loaded, check before filtering.
@@ -60,7 +60,9 @@ module Rails
60
60
  end
61
61
  else
62
62
  Rails.logger.level = ActiveSupport::Logger.const_get(config.log_level.to_s.upcase)
63
- Rails.logger = ActiveSupport::BroadcastLogger.new(Rails.logger)
63
+ broadcast_logger = ActiveSupport::BroadcastLogger.new(Rails.logger)
64
+ broadcast_logger.formatter = Rails.logger.formatter
65
+ Rails.logger = broadcast_logger
64
66
  end
65
67
  end
66
68
 
@@ -15,7 +15,7 @@ module Rails
15
15
  :cache_classes, :cache_store, :consider_all_requests_local, :console,
16
16
  :eager_load, :exceptions_app, :file_watcher, :filter_parameters, :precompile_filter_parameters,
17
17
  :force_ssl, :helpers_paths, :hosts, :host_authorization, :logger, :log_formatter,
18
- :log_tags, :railties_order, :relative_url_root,
18
+ :log_tags, :silence_healthcheck_path, :railties_order, :relative_url_root,
19
19
  :ssl_options, :public_file_server,
20
20
  :session_options, :time_zone, :reload_classes_only_on_change,
21
21
  :beginning_of_week, :filter_redirect, :x,
@@ -62,6 +62,7 @@ module Rails
62
62
  @exceptions_app = nil
63
63
  @autoflush_log = true
64
64
  @log_formatter = ActiveSupport::Logger::SimpleFormatter.new
65
+ @silence_healthcheck_path = nil
65
66
  @eager_load = nil
66
67
  @secret_key_base = nil
67
68
  @api_only = false
@@ -114,7 +115,9 @@ module Rails
114
115
  action_controller.forgery_protection_origin_check = true
115
116
  end
116
117
 
117
- ActiveSupport.to_time_preserves_timezone = true
118
+ if respond_to?(:active_support)
119
+ active_support.to_time_preserves_timezone = :offset
120
+ end
118
121
 
119
122
  if respond_to?(:active_record)
120
123
  active_record.belongs_to_required_by_default = true
@@ -335,6 +338,16 @@ module Rails
335
338
  active_record.postgresql_adapter_decode_dates = true
336
339
  active_record.validate_migration_timestamps = true
337
340
  end
341
+ when "8.0"
342
+ load_defaults "7.2"
343
+
344
+ if respond_to?(:active_support)
345
+ active_support.to_time_preserves_timezone = :zone
346
+ end
347
+
348
+ if respond_to?(:action_dispatch)
349
+ action_dispatch.strict_freshness = true
350
+ end
338
351
  else
339
352
  raise "Unknown version #{target_version.to_s.inspect}"
340
353
  end
@@ -500,18 +513,16 @@ module Rails
500
513
 
501
514
  def secret_key_base
502
515
  @secret_key_base || begin
503
- self.secret_key_base = if ENV["SECRET_KEY_BASE_DUMMY"]
516
+ self.secret_key_base = if generate_local_secret?
504
517
  generate_local_secret
505
518
  else
506
- ENV["SECRET_KEY_BASE"] ||
507
- Rails.application.credentials.secret_key_base ||
508
- (Rails.env.local? && generate_local_secret)
519
+ ENV["SECRET_KEY_BASE"] || Rails.application.credentials.secret_key_base
509
520
  end
510
521
  end
511
522
  end
512
523
 
513
524
  def secret_key_base=(new_secret_key_base)
514
- if new_secret_key_base.nil? && Rails.env.local?
525
+ if new_secret_key_base.nil? && generate_local_secret?
515
526
  @secret_key_base = generate_local_secret
516
527
  elsif new_secret_key_base.is_a?(String) && new_secret_key_base.present?
517
528
  @secret_key_base = new_secret_key_base
@@ -639,6 +650,10 @@ module Rails
639
650
 
640
651
  File.binread(key_file)
641
652
  end
653
+
654
+ def generate_local_secret?
655
+ Rails.env.local? || ENV["SECRET_KEY_BASE_DUMMY"]
656
+ end
642
657
  end
643
658
  end
644
659
  end
@@ -54,6 +54,10 @@ module Rails
54
54
  middleware.use ::ActionDispatch::RequestId, header: config.action_dispatch.request_id_header
55
55
  middleware.use ::ActionDispatch::RemoteIp, config.action_dispatch.ip_spoofing_check, config.action_dispatch.trusted_proxies
56
56
 
57
+ if path = config.silence_healthcheck_path
58
+ middleware.use ::Rails::Rack::SilenceRequest, path: path
59
+ end
60
+
57
61
  middleware.use ::Rails::Rack::Logger, config.log_tags
58
62
  middleware.use ::ActionDispatch::ShowExceptions, show_exceptions_app
59
63
  middleware.use ::ActionDispatch::DebugExceptions, app, config.debug_exception_response_format