railties 7.1.6 → 7.2.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 (121) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +174 -811
  3. data/lib/minitest/rails_plugin.rb +5 -2
  4. data/lib/rails/all.rb +1 -3
  5. data/lib/rails/api/task.rb +3 -2
  6. data/lib/rails/application/bootstrap.rb +5 -6
  7. data/lib/rails/application/configuration.rb +31 -36
  8. data/lib/rails/application/dummy_config.rb +2 -2
  9. data/lib/rails/application/finisher.rb +7 -0
  10. data/lib/rails/application.rb +13 -57
  11. data/lib/rails/backtrace_cleaner.rb +14 -1
  12. data/lib/rails/cli.rb +0 -1
  13. data/lib/rails/command.rb +1 -1
  14. data/lib/rails/commands/app/update_command.rb +86 -0
  15. data/lib/rails/commands/console/console_command.rb +2 -21
  16. data/lib/rails/commands/console/irb_console.rb +137 -0
  17. data/lib/rails/commands/credentials/credentials_command.rb +2 -2
  18. data/lib/rails/commands/dbconsole/dbconsole_command.rb +21 -30
  19. data/lib/rails/commands/devcontainer/devcontainer_command.rb +34 -0
  20. data/lib/rails/commands/rake/rake_command.rb +1 -1
  21. data/lib/rails/commands/runner/runner_command.rb +14 -3
  22. data/lib/rails/commands/server/server_command.rb +5 -3
  23. data/lib/rails/commands/test/test_command.rb +2 -0
  24. data/lib/rails/configuration.rb +10 -1
  25. data/lib/rails/console/app.rb +5 -32
  26. data/lib/rails/console/helpers.rb +5 -16
  27. data/lib/rails/console/methods.rb +23 -0
  28. data/lib/rails/engine.rb +5 -5
  29. data/lib/rails/gem_version.rb +3 -3
  30. data/lib/rails/generators/app_base.rb +70 -49
  31. data/lib/rails/generators/base.rb +5 -1
  32. data/lib/rails/generators/database.rb +227 -69
  33. data/lib/rails/generators/erb/scaffold/templates/edit.html.erb.tt +2 -0
  34. data/lib/rails/generators/erb/scaffold/templates/index.html.erb.tt +2 -0
  35. data/lib/rails/generators/erb/scaffold/templates/new.html.erb.tt +2 -0
  36. data/lib/rails/generators/generated_attribute.rb +26 -1
  37. data/lib/rails/generators/rails/app/app_generator.rb +52 -23
  38. data/lib/rails/generators/rails/app/templates/Dockerfile.tt +23 -14
  39. data/lib/rails/generators/rails/app/templates/Gemfile.tt +16 -16
  40. data/lib/rails/generators/rails/app/templates/app/controllers/application_controller.rb.tt +4 -0
  41. data/lib/rails/generators/rails/app/templates/app/views/layouts/application.html.erb.tt +8 -1
  42. data/lib/rails/generators/rails/app/templates/app/views/pwa/manifest.json.erb.tt +22 -0
  43. data/lib/rails/generators/rails/app/templates/app/views/pwa/service-worker.js +26 -0
  44. data/lib/rails/generators/rails/app/templates/bin/brakeman.tt +6 -0
  45. data/lib/rails/generators/rails/app/templates/bin/rubocop.tt +7 -0
  46. data/lib/rails/generators/rails/app/templates/bin/setup.tt +6 -2
  47. data/lib/rails/generators/rails/app/templates/config/application.rb.tt +1 -1
  48. data/lib/rails/generators/rails/app/templates/config/databases/mysql.yml.tt +3 -3
  49. data/lib/rails/generators/rails/app/templates/config/databases/postgresql.yml.tt +7 -0
  50. data/lib/rails/generators/rails/app/templates/config/databases/sqlite3.yml.tt +8 -1
  51. data/lib/rails/generators/rails/app/templates/config/databases/trilogy.yml.tt +3 -3
  52. data/lib/rails/generators/rails/app/templates/config/environments/development.rb.tt +11 -6
  53. data/lib/rails/generators/rails/app/templates/config/environments/production.rb.tt +2 -0
  54. data/lib/rails/generators/rails/app/templates/config/environments/test.rb.tt +6 -5
  55. data/lib/rails/generators/rails/app/templates/config/initializers/filter_parameter_logging.rb.tt +1 -1
  56. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_7_2.rb.tt +70 -0
  57. data/lib/rails/generators/rails/app/templates/config/puma.rb.tt +39 -29
  58. data/lib/rails/generators/rails/app/templates/config/routes.rb.tt +4 -0
  59. data/lib/rails/generators/rails/app/templates/docker-entrypoint.tt +5 -0
  60. data/lib/rails/generators/rails/app/templates/dockerignore.tt +13 -0
  61. data/lib/rails/generators/rails/app/templates/github/ci.yml.tt +138 -0
  62. data/lib/rails/generators/rails/app/templates/github/dependabot.yml +12 -0
  63. data/lib/rails/generators/rails/app/templates/gitignore.tt +3 -3
  64. data/lib/rails/generators/rails/app/templates/public/406-unsupported-browser.html +66 -0
  65. data/lib/rails/generators/rails/app/templates/public/icon.png +0 -0
  66. data/lib/rails/generators/rails/app/templates/public/icon.svg +3 -0
  67. data/lib/rails/generators/rails/app/templates/rubocop.yml.tt +8 -0
  68. data/lib/rails/generators/rails/app/templates/test/application_system_test_case.rb.tt +1 -1
  69. data/lib/rails/generators/rails/controller/controller_generator.rb +1 -1
  70. data/lib/rails/generators/rails/db/system/change/change_generator.rb +131 -20
  71. data/lib/rails/generators/rails/devcontainer/devcontainer_generator.rb +166 -0
  72. data/lib/rails/generators/rails/migration/migration_generator.rb +4 -0
  73. data/lib/rails/generators/rails/plugin/plugin_generator.rb +38 -7
  74. data/lib/rails/generators/rails/plugin/templates/%name%.gemspec.tt +2 -2
  75. data/lib/rails/generators/rails/plugin/templates/Gemfile.tt +5 -1
  76. data/lib/rails/generators/rails/plugin/templates/bin/rubocop.tt +7 -0
  77. data/lib/rails/generators/rails/plugin/templates/github/ci.yml.tt +103 -0
  78. data/lib/rails/generators/rails/plugin/templates/github/dependabot.yml +12 -0
  79. data/lib/rails/generators/rails/plugin/templates/rubocop.yml.tt +8 -0
  80. data/lib/rails/generators/rails/plugin/templates/test/application_system_test_case.rb.tt +1 -1
  81. data/lib/rails/generators/test_unit/scaffold/scaffold_generator.rb +10 -0
  82. data/lib/rails/generators/test_unit/scaffold/templates/system_test.rb.tt +2 -0
  83. data/lib/rails/generators/test_unit/system/templates/application_system_test_case.rb.tt +1 -1
  84. data/lib/rails/generators/testing/assertions.rb +20 -0
  85. data/lib/rails/generators/testing/behavior.rb +7 -6
  86. data/lib/rails/generators.rb +2 -2
  87. data/lib/rails/health_controller.rb +1 -1
  88. data/lib/rails/info.rb +2 -2
  89. data/lib/rails/info_controller.rb +2 -4
  90. data/lib/rails/mailers_controller.rb +14 -1
  91. data/lib/rails/paths.rb +2 -2
  92. data/lib/rails/pwa_controller.rb +15 -0
  93. data/lib/rails/rack/logger.rb +15 -7
  94. data/lib/rails/railtie/configurable.rb +2 -2
  95. data/lib/rails/railtie.rb +15 -16
  96. data/lib/rails/tasks/framework.rake +0 -26
  97. data/lib/rails/tasks/tmp.rake +1 -1
  98. data/lib/rails/templates/layouts/application.html.erb +1 -1
  99. data/lib/rails/templates/rails/mailers/email.html.erb +12 -8
  100. data/lib/rails/templates/rails/welcome/index.html.erb +3 -2
  101. data/lib/rails/test_help.rb +2 -4
  102. data/lib/rails/test_unit/reporter.rb +8 -2
  103. data/lib/rails/test_unit/runner.rb +21 -2
  104. data/lib/rails/test_unit/test_parser.rb +45 -0
  105. data/lib/rails.rb +6 -3
  106. metadata +41 -60
  107. data/lib/rails/app_updater.rb +0 -52
  108. data/lib/rails/commands/secrets/USAGE +0 -61
  109. data/lib/rails/commands/secrets/secrets_command.rb +0 -47
  110. data/lib/rails/generators/rails/app/templates/config/databases/jdbc.yml.tt +0 -68
  111. data/lib/rails/generators/rails/app/templates/config/databases/jdbcmysql.yml.tt +0 -54
  112. data/lib/rails/generators/rails/app/templates/config/databases/jdbcpostgresql.yml.tt +0 -70
  113. data/lib/rails/generators/rails/app/templates/config/databases/jdbcsqlite3.yml.tt +0 -24
  114. data/lib/rails/generators/rails/app/templates/config/databases/oracle.yml.tt +0 -62
  115. data/lib/rails/generators/rails/app/templates/config/databases/sqlserver.yml.tt +0 -53
  116. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_7_1.rb.tt +0 -280
  117. data/lib/rails/generators/rails/app/templates/public/apple-touch-icon-precomposed.png +0 -0
  118. data/lib/rails/generators/rails/app/templates/public/apple-touch-icon.png +0 -0
  119. data/lib/rails/generators/rails/app/templates/public/favicon.ico +0 -0
  120. data/lib/rails/ruby_version_check.rb +0 -17
  121. data/lib/rails/secrets.rb +0 -110
data/CHANGELOG.md CHANGED
@@ -1,961 +1,324 @@
1
- ## Rails 7.1.6 (October 28, 2025) ##
1
+ ## Rails 7.2.0.beta1 (May 29, 2024) ##
2
2
 
3
- * No changes.
3
+ * Create a Dev Container Generator that generates a Dev Container setup based on the current configuration
4
+ of the application. Usage:
4
5
 
6
+ `bin/rails devcontainer`
5
7
 
6
- ## Rails 7.1.5.2 (August 13, 2025) ##
8
+ *Andrew Novoselac*
7
9
 
8
- * No changes.
10
+ * Add Rubocop and GitHub Actions to plugin generator.
11
+ This can be skipped using --skip-rubocop and --skip-ci.
9
12
 
13
+ *Chris Oliver*
10
14
 
11
- ## Rails 7.1.5.1 (December 10, 2024) ##
15
+ * Remove support for `oracle`, `sqlserver` and JRuby specific database adapters from the
16
+ `rails new` and `rails db:system:change` commands.
12
17
 
13
- * No changes.
18
+ The supported options are `sqlite3`, `mysql`, `postgresql` and `trilogy`.
14
19
 
20
+ *Andrew Novoselac*
15
21
 
16
- ## Rails 7.1.5 (October 30, 2024) ##
22
+ * Add options to `bin/rails app:update`.
17
23
 
18
- * No changes.
24
+ `bin/rails app:update` now supports the same generic options that generators do:
19
25
 
26
+ * `--force`: Accept all changes to existing files
27
+ * `--skip`: Refuse all changes to existing files
28
+ * `--pretend`: Don't make any changes
29
+ * `--quiet`: Don't output all changes made
20
30
 
21
- ## Rails 7.1.4.2 (October 23, 2024) ##
22
-
23
- * No changes.
24
-
25
-
26
- ## Rails 7.1.4.1 (October 15, 2024) ##
27
-
28
- * No changes.
29
-
30
-
31
- ## Rails 7.1.4 (August 22, 2024) ##
32
-
33
- * Preserve `--asset-pipeline propshaft` when running `app:update`.
34
-
35
- *Zacharias Knudsen*
36
-
37
- * Allow string keys for SQLCommenter.
38
-
39
- *Ngan Pham*
40
-
41
- * Fix derived foreign key to return correctly when association id is part of query constraints.
42
-
43
- *Varun Sharma*
44
-
45
- * Show warning for `secret_key_base` in development too.
46
-
47
- *fatkodima*
48
-
49
- * Fix sanitizer vendor configuration in 7.1 defaults.
50
-
51
- In apps where `rails-html-sanitizer` was not eagerly loaded, the sanitizer default could end up
52
- being Rails::HTML4::Sanitizer when it should be set to `Rails::HTML5::Sanitizer`.
53
-
54
- *Mike Dalessio*, *Rafael Mendonça França*
55
-
56
- * Revert the use of `Concurrent.physical_processor_count` in default Puma config
57
-
58
- While for many people this saves one config to set, for many others using
59
- a shared hosting solution, this cause the default configuration to spawn
60
- way more workers than reasonable.
61
-
62
- There is unfortunately no reliable way to detect how many cores an application
63
- can realistically use, and even then, assuming the application should use
64
- all the machine resources is often wrong.
65
-
66
- *Jean Boussier*
67
-
68
-
69
- ## Rails 7.1.3.4 (June 04, 2024) ##
70
-
71
- * No changes.
72
-
73
-
74
- ## Rails 7.1.3.3 (May 16, 2024) ##
75
-
76
- * No changes.
77
-
78
-
79
- ## Rails 7.1.3.2 (February 21, 2024) ##
80
-
81
- * No changes.
82
-
31
+ *Étienne Barrié*
83
32
 
84
- ## Rails 7.1.3.1 (February 21, 2024) ##
33
+ * Implement Rails console commands and helpers with IRB v1.13's extension APIs.
85
34
 
86
- * No changes.
35
+ Rails console users will now see `helper`, `controller`, `new_session`, and `app` under
36
+ IRB help message's `Helper methods` category. And `reload!` command will be displayed under
37
+ the new `Rails console` commands category.
87
38
 
39
+ Prior to this change, Rails console's commands and helper methods are added through IRB's
40
+ private components and don't show up in its help message, which led to poor discoverability.
88
41
 
89
- ## Rails 7.1.3 (January 16, 2024) ##
42
+ *Stan Lo*
90
43
 
91
- * Make sure `config.after_routes_loaded` hook runs on boot.
44
+ * Remove deprecated `Rails::Generators::Testing::Behaviour`.
92
45
 
93
46
  *Rafael Mendonça França*
94
47
 
95
- * Fix `config.log_level` not being respected when using a `BroadcastLogger`
96
-
97
- *Édouard Chin*
98
-
99
- * Fix isolated engines to take `ActiveRecord::Base.table_name_prefix` into consideration.
100
- This will allow for engine defined models, such as inside Active Storage, to respect
101
- Active Record table name prefix configuration.
102
-
103
- *Chedli Bourguiba*
104
-
105
- * The `bin/rails app:template` command will no longer add potentially unwanted
106
- gem platforms via `bundle lock --add-platform=...` commands.
107
-
108
- *Jonathan Hefner*
109
-
110
-
111
- ## Rails 7.1.2 (November 10, 2023) ##
112
-
113
- * Fix running `db:system:change` when app has no Dockerfile.
114
-
115
- *Hartley McGuire*
116
-
117
- * If you accessed `config.eager_load_paths` and friends, later changes to
118
- `config.paths` were not reflected in the expected auto/eager load paths.
119
- Now, they are.
120
-
121
- This bug has been latent since Rails 3.
122
-
123
- Fixes #49629.
124
-
125
- *Xavier Noria*
126
-
127
- ## Rails 7.1.1 (October 11, 2023) ##
128
-
129
- * Ensures the Rails generated Dockerfile uses correct ruby version and matches Gemfile.
130
-
131
- *Abhay Nikam*
132
-
133
-
134
- ## Rails 7.1.0 (October 05, 2023) ##
135
-
136
- * No changes.
137
-
138
-
139
- ## Rails 7.1.0.rc2 (October 01, 2023) ##
140
-
141
- * Always set the Rails logger to be an instance of `ActiveSupport::BroadcastLogger`.
142
-
143
- *Edouard Chin*
144
-
145
-
146
- ## Rails 7.1.0.rc1 (September 27, 2023) ##
147
-
148
- * Require `concurrent-ruby` in `config/puma.rb` so that Puma can boot in
149
- production when `WEB_CONCURRENCY` is not explicitly specified.
150
-
151
- Fixes #49323.
152
-
153
- *Matt Brictson*
154
-
155
- * Raise error when generating attribute with dangerous name.
156
-
157
- The following will now raise an error as `save` and `hash` are already
158
- defined by Active Record.
159
-
160
- ```bash
161
- $ bin/rails generate model Post save
162
- $ bin/rails generate model Post hash
163
- ```
164
-
165
- *Petrik de Heus*
48
+ * Remove deprecated `find_cmd_and_exec` console helper.
166
49
 
50
+ *Rafael Mendonça França*
167
51
 
168
- ## Rails 7.1.0.beta1 (September 13, 2023) ##
169
-
170
- * Add ability to show slow tests to the test runner
171
-
172
- ```bash
173
- $ bin/test --profile # additionally prints 10 (default) slowest tests
174
- # or
175
- $ bin/test --profile 20 # prints 20 slowest tests
176
- ```
177
-
178
- *fatkodima*
179
-
180
- * `rails new --javascript` generator now supports Bun
181
-
182
- ```bash
183
- $ rails new my_new_app --javascript=bun
184
- ```
185
-
186
- *Jason Meller*
187
-
188
- * bin/setup uses `bun` instead of `yarn` when generated an app with bun
189
-
190
- Use `bun install` on `bin/setup` when using `bun`.
191
-
192
- *Cadu Ribeiro*
193
-
194
- * `config/application.rb` now includes
195
-
196
- ```ruby
197
- config.autoload_lib(ignore: %w(assets tasks))
198
- ```
199
-
200
- In practice, this means that new 7.1 applications autoload from `lib` out of the box.
201
-
202
- *Xavier Noria*
203
-
204
- * Add an option to start rails console in sandbox mode by default
205
-
206
- `sandbox_by_default` option is added to start rails console in sandbox
207
- mode by default. With this option turned on, `--no-sandbox` must be
208
- specified to start rails in non-sandbox mode.
209
-
210
- Note that this option is ignored when rails environment is development
211
- or test.
212
-
213
- *Shouichi Kamiya*
214
-
215
- * Omit `webdrivers` gem dependency from `Gemfile` template
216
-
217
- *Sean Doyle*
218
-
219
- * Support filtering tests by line ranges
220
-
221
- The new syntax allows you to filter tests by line ranges. For example, the
222
- following command runs tests from line 10 to 20.
223
-
224
- ```bash
225
- $ rails test test/models/user_test.rb:10-20
226
- ```
227
-
228
- *Shouichi Kamiya*, *Seonggi Yang*, *oljfte*, *Ryohei UEDA*
229
-
230
- * Update default scaffold templates to set 303 (See Other) as status code
231
- on redirect for the update action for XHR requests other than GET or POST
232
- to avoid issues (e.g browsers trying to follow the redirect using the
233
- original request method resulting in double PATCH/PUT)
234
-
235
- *Guillermo Iguaran*
52
+ * Remove deprecated `Rails.config.enable_dependency_loading`.
236
53
 
237
- * The new `config.autoload_lib_once` is similar to `config.autoload_lib`,
238
- except that it adds `lib` to `config.autoload_once_paths` instead.
54
+ *Rafael Mendonça França*
239
55
 
240
- By calling `config.autoload_lib_once`, classes and modules in `lib` can be
241
- autoloaded, even from application initializers, but won't be reloaded.
56
+ * Remove deprecated `Rails.application.secrets`.
242
57
 
243
- Please, see further details in the [autoloading
244
- guide](https://guides.rubyonrails.org/v7.1/autoloading_and_reloading_constants.html).
58
+ *Rafael Mendonça França*
245
59
 
246
- *Xavier Noria*
60
+ * Generated Gemfile will include `require: "debug/prelude"` for the `debug` gem.
247
61
 
248
- * Add `config.action_dispatch.debug_exception_log_level` to configure the log
249
- level used by `ActionDispatch::DebugExceptions`.
62
+ Requiring `debug` gem directly automatically activates it, which could introduce
63
+ additional overhead and memory usage even without entering a debugging session.
250
64
 
251
- The default is `:fatal`, but with `load_defaults "7.1"` the default will be
252
- `:error`.
65
+ By making Bundler require `debug/prelude` instead, developers can keep their access
66
+ to breakpoint methods like `debugger` or `binding.break`, but the debugger won't be
67
+ activated until a breakpoint is hit.
253
68
 
254
- *Hartley McGuire*
69
+ *Stan Lo*
255
70
 
256
- * Add `DATABASE` option to `railties:install:migrations`
71
+ * Skip generating a `test` job in ci.yml when a new application is generated with the
72
+ `--skip-test` option.
257
73
 
258
- This allows you to specify which database the migrations should be copied to
259
- when running `rails railties:install:migrations`.
74
+ *Steve Polito*
260
75
 
261
- ```bash
262
- $ rails railties:install:migrations DATABASE=animals
263
- ```
76
+ * Update the `.node-version` file conditionally generated for new applications to 20.11.1
264
77
 
265
- *Matthew Hirst*
78
+ *Steve Polito*
266
79
 
267
- * The new method `config.autoload_lib(ignore:)` provides a simple way to
268
- autoload from `lib`:
80
+ * Fix sanitizer vendor configuration in 7.1 defaults.
269
81
 
270
- ```ruby
271
- # config/application.rb
272
- config.autoload_lib(ignore: %w(assets tasks))
273
- ```
82
+ In apps where rails-html-sanitizer was not eagerly loaded, the sanitizer default could end up
83
+ being Rails::HTML4::Sanitizer when it should be set to Rails::HTML5::Sanitizer.
274
84
 
275
- Please, see further details in the [autoloading
276
- guide](https://guides.rubyonrails.org/v7.1/autoloading_and_reloading_constants.html).
85
+ *Mike Dalessio*, *Rafael Mendonça França*
277
86
 
278
- *Xavier Noria*
87
+ * Set `action_mailer.default_url_options` values in `development` and `test`.
279
88
 
280
- * Don't show secret_key_base for `Rails.application.config#inspect`.
89
+ Prior to this commit, new Rails applications would raise `ActionView::Template::Error`
90
+ if a mailer included a url built with a `*_path` helper.
281
91
 
282
- Before:
92
+ *Steve Polito*
283
93
 
284
- ```ruby
285
- Rails.application.config.inspect
286
- "#<Rails::Application::Configuration:0x00000001132b02a0 @root=... @secret_key_base=\"b3c631c314c0bbca50c1b2843150fe33\" ... >"
287
- ```
94
+ * Introduce `Rails::Generators::Testing::Assertions#assert_initializer`.
288
95
 
289
- After:
96
+ Compliments the existing `initializer` generator action.
290
97
 
291
- ```ruby
292
- Rails.application.config.inspect
293
- "#<Rails::Application::Configuration:0x00000001132b02a0>"
98
+ ```rb
99
+ assert_initializer "mail_interceptors.rb"
294
100
  ```
295
101
 
296
- *Petrik de Heus*
297
-
298
- * Deprecate calling `Rails.application.secrets`.
299
-
300
- Rails `secrets` have been deprecated in favor of `credentials`.
301
- Calling `Rails.application.secrets` should show a deprecation warning.
302
-
303
- *Petrik de Heus*
304
-
305
- * Store `secret_key_base` in `Rails.config` for local environments.
306
-
307
- Rails `secrets` have been deprecated in favor of `credentials`.
308
- For the local environments the `secret_key_base` is now stored in
309
- `Rails.config.secret_key_base` instead of the soft deprecated
310
- `Rails.application.secrets.secret_key_base`.
311
-
312
- *Petrik de Heus*
313
-
314
- * Enable force_ssl=true in production by default: Force all access to the app over SSL,
315
- use Strict-Transport-Security, and use secure cookies
316
-
317
- *Justin Searls*, *Aaron Patterson*, *Guillermo Iguaran*, *Vinícius Bispo*
318
-
319
- * Add engine's draw paths to application route set, so that the application
320
- can draw route files defined in engine paths.
321
-
322
- *Gannon McGibbon*
323
-
324
- * Support `VISUAL` environment variable for commands which open an editor,
325
- and prefer it over `EDITOR`.
326
-
327
- *Summer ☀️*
102
+ *Steve Polito*
328
103
 
329
- * Add engine's `test/fixtures` path to `fixture_paths` in `on_load` hook if
330
- path exists and is under the Rails application root.
104
+ * Generate a .devcontainer folder and its contents when creating a new app.
331
105
 
332
- *Chris Salzberg*
106
+ The .devcontainer folder includes everything needed to boot the app and do development in a remote container.
333
107
 
334
- * `bin/rails app:template` now runs `bundle install` and any `after_bundle`
335
- blocks after the template is executed.
108
+ The container setup includes:
109
+ - A redis container for Kredis, ActionCable etc.
110
+ - A database (SQLite, Postgres, MySQL or MariaDB)
111
+ - A Headless chrome container for system tests
112
+ - Active Storage configured to use the local disk and with preview features working
336
113
 
337
- *Jonathan Hefner* and *Gerry Caulfield*
114
+ If any of these options are skipped in the app setup they will not be included in the container configuration.
338
115
 
339
- * Enable passing column size to migration generator
116
+ These files can be skipped using the `--skip-devcontainer` option.
340
117
 
341
- Previously you could pass a limit to the migration generator:
118
+ *Andrew Novoselac & Rafael Mendonça França*
342
119
 
343
- `rails generate migration CreateAuthor name:text{65535}`
120
+ * Introduce `SystemTestCase#served_by` for configuring the System Test application server.
344
121
 
345
- Now, a size attribute can be passed to the migration generator:
346
-
347
- `rails generate migration CreateAuthor name:text{medium}`
348
-
349
- This generates a migration which includes the size attribute:
122
+ By default this is localhost. This method allows the host and port to be specified manually.
350
123
 
351
124
  ```ruby
352
- class CreateAuthor < ActiveRecord::Migration[7.1]
353
- def change
354
- create_table :authors do |t|
355
- t.text :name, size: :medium
356
- end
357
- end
125
+ class ApplicationSystemTestCase < ActionDispatch::SystemTestCase
126
+ served_by host: "testserver", port: 45678
358
127
  end
359
128
  ```
360
129
 
361
- *Josh Broughton*, *Hartley McGuire*
362
-
363
- * Trying to set a config key with the same name of a method now raises:
364
-
365
- ```ruby
366
- config.load_defaults = 7.0
367
- # NoMethodError: Cannot assign to `load_defaults`, it is a configuration method
368
- ```
369
-
370
- *Xavier Noria*
371
-
372
- * Deprecate `secrets:edit/show` and remove `secrets:setup`
373
-
374
- `bin/rails secrets:setup` has been deprecated since Rails 5.2 in favor of
375
- credentials. This command has been removed.
130
+ *Andrew Novoselac & Rafael Mendonça França*
376
131
 
377
- `bin/rails secrets:show` and `bin/rails secrets:edit` have been deprecated
378
- in favor of credentials.
132
+ * `bin/rails test` will no longer load files named `*_test.rb` if they are located in the `fixtures` folder.
379
133
 
380
- Run `bin/rails credentials:help` for more information
381
-
382
- *Petrik de Heus*
134
+ *Edouard Chin*
383
135
 
384
- * `bin/rails --help` will now list only framework and plugin commands. Rake
385
- tasks defined in `lib/tasks/*.rake` files will no longer be included. For a
386
- list of those tasks, use `rake -T`.
136
+ * Ensure logger tags configured with `config.log_tags` are still active in `request.action_dispatch` handlers.
387
137
 
388
- *Jonathan Hefner*
138
+ *KJ Tsanaktsidis*
389
139
 
390
- * Allow calling `bin/rails restart` outside of app directory.
140
+ * Setup jemalloc in the default Dockerfile for memory optimization.
391
141
 
392
- The following would previously fail with a "No Rakefile found" error.
142
+ *Matt Almeida*, *Jean Boussier*
393
143
 
394
- ```bash
395
- $ blog/bin/rails restart
396
- ```
144
+ * Commented out lines in .railsrc file should not be treated as arguments when using
145
+ rails new generator command. Update ARGVScrubber to ignore text after `#` symbols.
397
146
 
398
- *Petrik de Heus*
147
+ *Willian Tenfen*
399
148
 
400
- * Support prerelease rubies in Gemfile template if RubyGems version is 3.3.13 or higher.
149
+ * Skip CSS when generating APIs.
401
150
 
402
- *Yasuo Honda*, *David Rodríguez*
151
+ *Ruy Rocha*
403
152
 
404
- * Autoloading setup honors root directories manually set by the user.
153
+ * Rails console now indicates application name and the current Rails environment:
405
154
 
406
- This is relevant for custom namespaces. For example, if you'd like classes
407
- and modules under `app/services` to be defined in the `Services` namespace
408
- without an extra `app/services/services` directory, this is now enough:
409
-
410
- ```ruby
411
- # config/initializers/autoloading.rb
412
-
413
- # The namespace has to exist.
414
- #
415
- # In this example we define the module on the spot. Could also be created
416
- # elsewhere and its definition loaded here with an ordinary `require`. In
417
- # any case, `push_dir` expects a class or module object.
418
- module Services; end
419
-
420
- Rails.autoloaders.main.push_dir("#{Rails.root}/app/services", namespace: Services)
155
+ ```txt
156
+ my-app(dev)> # for RAILS_ENV=development
157
+ my-app(test)> # for RAILS_ENV=test
158
+ my-app(prod)> # for RAILS_ENV=production
159
+ my-app(my_env)> # for RAILS_ENV=my_env
421
160
  ```
422
161
 
423
- Check the autoloading guide for further details.
162
+ The application name is derived from the application's module name from `config/application.rb`.
163
+ For example, `MyApp` will displayed as `my-app` in the prompt.
424
164
 
425
- *Xavier Noria*
426
-
427
- * Railties now requires the irb gem as a dependency, which means when you install Rails, irb will also
428
- be installed as a gem. Rails will then use the installed version of irb for its console instead of
429
- relying on Ruby's built-in version.
430
- This ensures that Rails has access to the most up-to-date and reliable version of irb for its console.
165
+ Additionally, the environment name will be colorized when the environment is
166
+ `development` (blue), `test` (blue), or `production` (red), if your
167
+ terminal supports it.
431
168
 
432
169
  *Stan Lo*
433
170
 
434
- * Use infinitive form for all rails command descriptions verbs.
435
-
436
- *Petrik de Heus*
171
+ * Ensure `autoload_paths`, `autoload_once_paths`, `eager_load_paths`, and
172
+ `load_paths` only have directories when initialized from engine defaults.
437
173
 
438
- * Credentials commands (e.g. `bin/rails credentials:edit`) now respect
439
- `config.credentials.content_path` and `config.credentials.key_path` when set
440
- in `config/application.rb` or `config/environments/#{Rails.env}.rb`.
174
+ Previously, files under the `app` directory could end up there too.
441
175
 
442
- Before:
176
+ *Takumasa Ochi*
443
177
 
444
- * `bin/rails credentials:edit` ignored `RAILS_ENV`, and would always edit
445
- `config/credentials.yml.enc`.
178
+ * Prevent unnecessary application reloads in development.
446
179
 
447
- * `bin/rails credentials:edit --environment foo` would create and edit
448
- `config/credentials/foo.yml.enc`.
180
+ Previously, some files outside autoload paths triggered unnecessary reloads.
181
+ With this fix, application reloads according to `Rails.autoloaders.main.dirs`,
182
+ thereby preventing unnecessary reloads.
449
183
 
450
- * If `config.credentials.content_path` or `config.credentials.key_path`
451
- was set, `bin/rails credentials:edit` could not be used to edit the
452
- credentials. Editing credentials required using `bin/rails
453
- encrypted:edit path/to/credentials --key path/to/key`.
184
+ *Takumasa Ochi*
454
185
 
455
- After:
186
+ * Use `oven-sh/setup-bun` in GitHub CI when generating an app with Bun.
456
187
 
457
- * `bin/rails credentials:edit` will edit the credentials file that the app
458
- would load for the current `RAILS_ENV`.
188
+ *TangRufus*
459
189
 
460
- * `bin/rails credentials:edit` respects `config.credentials.content_path`
461
- and `config.credentials.key_path` when set in `config/application.rb`
462
- or `config/environments/#{Rails.env}.rb`.
190
+ * Disable `pidfile` generation in the `production` environment.
463
191
 
464
- * `bin/rails credentials:edit --environment foo` will create and edit
465
- `config/credentials/foo.yml.enc` _if_ `config.credentials.content_path`
466
- has not been set for the `foo` environment. Ultimately, it will edit
467
- the credentials file that the app would load for the `foo` environment.
192
+ *Hans Schnedlitz*
468
193
 
469
- *Jonathan Hefner*
194
+ * Set `config.action_view.annotate_rendered_view_with_filenames` to `true` in
195
+ the `development` environment.
470
196
 
471
- * Add descriptions for non-Rake commands when running `rails -h`.
197
+ *Adrian Marin*
472
198
 
473
- *Petrik de Heus*
199
+ * Support the `BACKTRACE` environment variable to turn off backtrace cleaning.
474
200
 
475
- * Show relevant commands when calling help
201
+ Useful for debugging framework code:
476
202
 
477
- When running `rails -h` or just `rails` outside a Rails application,
478
- Rails outputs all options for running the `rails new` command. This can be
479
- confusing to users when they probably want to see the common Rails commands.
480
-
481
- Instead, we should always show the common commands when running `rails -h`
482
- inside or outside a Rails application.
483
-
484
- As the relevant commands inside a Rails application differ from the
485
- commands outside an application, the help USAGE file has been split to
486
- show the most relevant commands for the context.
487
-
488
- *Petrik de Heus*
489
-
490
- * Add Rails::HealthController#show and map it to /up for newly generated applications.
491
- Load balancers and uptime monitors all need a basic endpoint to tell whether the app is up.
492
- This is a good starting point that'll work in many situations.
493
-
494
- *DHH*
203
+ ```sh
204
+ BACKTRACE=1 bin/rails server
205
+ ```
495
206
 
496
- * Only use HostAuthorization middleware if `config.hosts` is not empty
207
+ *Alex Ghiculescu*
497
208
 
498
- *Hartley McGuire*
499
-
500
- * Raise an exception when a `before_action`'s "only" or "except" filter
501
- options reference an action that doesn't exist. This will be enabled by
502
- default but can be overridden via config.
209
+ * Raise `ArgumentError` when reading `config.x.something` with arguments:
503
210
 
504
211
  ```ruby
505
- # config/environments/production.rb
506
- config.action_controller.raise_on_missing_callback_actions = false
212
+ config.x.this_works.this_raises true # raises ArgumentError
507
213
  ```
508
214
 
509
- *Jess Bees*
215
+ *Sean Doyle*
510
216
 
511
- * Use physical processor count as the default Puma worker count in production.
512
- This can be overridden by setting `ENV["WEB_CONCURRENCY"]` or editing the
513
- generated "config/puma.rb" directly.
217
+ * 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.
514
218
 
515
219
  *DHH*
516
220
 
517
- * Add Docker files by default to new apps: Dockerfile, .dockerignore, bin/docker-entrypoint.
518
- These files can be skipped with `--skip-docker`. They're intended as a starting point for
519
- a production deploy of the application. Not intended for development (see Docked Rails for that).
520
-
521
- Example:
522
-
523
- ```bash
524
- $ docker build -t app .
525
- $ docker volume create app-storage
526
- $ docker run --rm -it -v app-storage:/rails/storage -p 3000:3000 --env RAILS_MASTER_KEY=<see config/master.key> app
527
- ```
528
-
529
- You can also start a console or a runner from this image:
530
-
531
- ```bash
532
- $ docker run --rm -it -v app-storage:/rails/storage --env RAILS_MASTER_KEY=<see config/master.key> app console
533
- ```
534
-
535
- To create a multi-platform image on Apple Silicon to deploy on AMD or Intel and push to Docker Hub for user/app:
536
-
537
- ```bash
538
- $ docker login -u <user>
539
- $ docker buildx create --use
540
- $ docker buildx build --push --platform=linux/amd64,linux/arm64 -t <user/image> .
541
- ```
542
-
543
- *DHH, Sam Ruby*
544
-
545
- * Add ENV["SECRET_KEY_BASE_DUMMY"] for starting production environment with a generated secret base key,
546
- which can be used to run tasks like `assets:precompile` without making the RAILS_MASTER_KEY available
547
- to the build process.
548
-
549
- Dockerfile layer example:
550
-
551
- ```
552
- RUN SECRET_KEY_BASE_DUMMY=1 bundle exec rails assets:precompile
553
- ```
221
+ * Updated system tests to now use headless Chrome by default for the new applications.
554
222
 
555
223
  *DHH*
556
224
 
557
- * Show descriptions for all commands in Rails help
558
-
559
- When calling `rails help` most commands missed their description. We now
560
- show the same descriptions as shown in `rails -T`.
561
-
562
- *Petrik de Heus*
563
-
564
- * Always generate the storage/ directory with rails new to ensure there's a stable place to
565
- put permanent files, and a single mount point for containers to map. Then default sqlite3 databases
566
- to live there instead of db/, which is only meant for configuration, not data.
225
+ * Add GitHub CI files for Dependabot, Brakeman, RuboCop, and running tests by default. Can be skipped with `--skip-ci`.
567
226
 
568
227
  *DHH*
569
228
 
570
- * Rails console now disables `IRB`'s autocompletion feature in production by default.
571
-
572
- Setting `IRB_USE_AUTOCOMPLETE=true` can override this default.
573
-
574
- *Stan Lo*
575
-
576
- * Add `config.precompile_filter_parameters`, which enables precompilation of
577
- `config.filter_parameters` using `ActiveSupport::ParameterFilter.precompile_filters`.
578
- Precompilation can improve filtering performance, depending on the quantity
579
- and types of filters.
580
-
581
- `config.precompile_filter_parameters` defaults to `true` for
582
- `config.load_defaults 7.1` and above.
583
-
584
- *Jonathan Hefner*
585
-
586
- * Add `after_routes_loaded` hook to `Rails::Railtie::Configuration` for
587
- engines to add a hook to be called after application routes have been
588
- loaded.
589
-
590
- ```ruby
591
- MyEngine.config.after_routes_loaded do
592
- # code that must happen after routes have been loaded
593
- end
594
- ```
595
-
596
- *Chris Salzberg*
597
-
598
- * Send 303 See Other status code back for the destroy action on newly generated
599
- scaffold controllers.
600
-
601
- *Tony Drake*
602
-
603
- * Add `Rails.application.deprecators` as a central point to manage deprecators
604
- for an application.
605
-
606
- Individual deprecators can be added and retrieved from the collection:
607
-
608
- ```ruby
609
- Rails.application.deprecators[:my_gem] = ActiveSupport::Deprecation.new("2.0", "MyGem")
610
- Rails.application.deprecators[:other_gem] = ActiveSupport::Deprecation.new("3.0", "OtherGem")
611
- ```
612
-
613
- And the collection's configuration methods affect all deprecators in the
614
- collection:
615
-
616
- ```ruby
617
- Rails.application.deprecators.debug = true
618
-
619
- Rails.application.deprecators[:my_gem].debug
620
- # => true
621
- Rails.application.deprecators[:other_gem].debug
622
- # => true
623
- ```
624
-
625
- Additionally, all deprecators in the collection can be silenced for the
626
- duration of a given block:
627
-
628
- ```ruby
629
- Rails.application.deprecators.silence do
630
- Rails.application.deprecators[:my_gem].warn # => silenced (no warning)
631
- Rails.application.deprecators[:other_gem].warn # => silenced (no warning)
632
- end
633
- ```
634
-
635
- *Jonathan Hefner*
636
-
637
- * Move dbconsole logic to Active Record connection adapter.
638
-
639
- Instead of hosting the connection logic in the command object, the
640
- database adapter should be responsible for connecting to a console session.
641
- This patch moves #find_cmd_and_exec to the adapter and exposes a new API to
642
- lookup the adapter class without instantiating it.
643
-
644
- *Gannon McGibbon*, *Paarth Madan*
645
-
646
- * Add `Rails.application.message_verifiers` as a central point to configure
647
- and create message verifiers for an application.
648
-
649
- This allows applications to, for example, rotate old `secret_key_base`
650
- values:
651
-
652
- ```ruby
653
- config.before_initialize do |app|
654
- app.message_verifiers.rotate(secret_key_base: "old secret_key_base")
655
- end
656
- ```
657
-
658
- And for libraries to create preconfigured message verifiers:
659
-
660
- ```ruby
661
- ActiveStorage.verifier = Rails.application.message_verifiers["ActiveStorage"]
662
- ```
663
-
664
- *Jonathan Hefner*
665
-
666
- * Support MySQL's ssl-mode option for the dbconsole command.
667
-
668
- Verifying the identity of the database server requires setting the ssl-mode
669
- option to VERIFY_CA or VERIFY_IDENTITY. This option was previously ignored
670
- for the dbconsole command.
671
-
672
- *Petrik de Heus*
229
+ * Add Brakeman by default for static analysis of security vulnerabilities. Allow skipping with `--skip-brakeman option`.
673
230
 
674
- * Delegate application record generator description to orm hooked generator.
231
+ *vipulnsward*
675
232
 
676
- *Gannon McGibbon*
233
+ * Add RuboCop with rules from `rubocop-rails-omakase` by default. Skip with `--skip-rubocop`.
677
234
 
678
- * Show BCC recipients when present in Action Mailer previews.
235
+ *DHH* and *zzak*
679
236
 
680
- *Akshay Birajdar*
237
+ * Use `bin/rails runner --skip-executor` to not wrap the runner script with an
238
+ Executor.
681
239
 
682
- * Extend `routes --grep` to also filter routes by matching against path.
240
+ *Ben Sheldon*
683
241
 
684
- Example:
685
-
686
- ```bash
687
- $ bin/rails routes --grep /cats/1
688
- Prefix Verb URI Pattern Controller#Action
689
- cat GET /cats/:id(.:format) cats#show
690
- PATCH /cats/:id(.:format) cats#update
691
- PUT /cats/:id(.:format) cats#update
692
- DELETE /cats/:id(.:format) cats#destroy
693
- ```
694
-
695
- *Orhan Toy*
696
-
697
- * Improve `rails runner` output when given a file path that doesn't exist.
698
-
699
- *Tekin Suleyman*
700
-
701
- * `config.allow_concurrency = false` now use a `Monitor` instead of a `Mutex`
702
-
703
- This allows to enable `config.active_support.executor_around_test_case` even
704
- when `config.allow_concurrency` is disabled.
705
-
706
- *Jean Boussier*
707
-
708
- * Add `routes --unused` option to detect extraneous routes.
709
-
710
- Example:
711
-
712
- ```bash
713
- $ bin/rails routes --unused
714
-
715
- Found 2 unused routes:
716
-
717
- Prefix Verb URI Pattern Controller#Action
718
- one GET /one(.:format) action#one
719
- two GET /two(.:format) action#two
720
- ```
721
-
722
- *Gannon McGibbon*
723
-
724
- * Add `--parent` option to controller generator to specify parent class of job.
725
-
726
- Example:
242
+ * Fix isolated engines to take `ActiveRecord::Base.table_name_prefix` into consideration.
727
243
 
728
- `bin/rails g controller admin/users --parent=admin_controller` generates:
244
+ This will allow for engine defined models, such as inside Active Storage, to respect
245
+ Active Record table name prefix configuration.
729
246
 
730
- ```ruby
731
- class Admin::UsersController < AdminController
732
- # ...
733
- end
734
- ```
247
+ *Chedli Bourguiba*
735
248
 
736
- *Gannon McGibbon*
737
-
738
- * In-app custom credentials templates are now supported. When a credentials
739
- file does not exist, `rails credentials:edit` will now try to use
740
- `lib/templates/rails/credentials/credentials.yml.tt` to generate the
741
- credentials file, before falling back to the default template.
742
-
743
- This allows e.g. an open-source Rails app (which would not include encrypted
744
- credentials files in its repo) to include a credentials template, so that
745
- users who install the app will get a custom pre-filled credentials file when
746
- they run `rails credentials:edit`.
747
-
748
- *Jonathan Hefner*
749
-
750
- * Except for `dev` and `test` environments, newly generated per-environment
751
- credentials files (e.g. `config/credentials/production.yml.enc`) now include
752
- a `secret_key_base` for convenience, just as `config/credentials.yml.enc`
753
- does.
754
-
755
- *Jonathan Hefner*
756
-
757
- * `--no-*` options now work with the app generator's `--minimal` option, and
758
- are both comprehensive and precise. For example:
759
-
760
- ```bash
761
- $ rails new my_cool_app --minimal
762
- Based on the specified options, the following options will also be activated:
763
-
764
- --skip-active-job [due to --minimal]
765
- --skip-action-mailer [due to --skip-active-job, --minimal]
766
- --skip-active-storage [due to --skip-active-job, --minimal]
767
- --skip-action-mailbox [due to --skip-active-storage, --minimal]
768
- --skip-action-text [due to --skip-active-storage, --minimal]
769
- --skip-javascript [due to --minimal]
770
- --skip-hotwire [due to --skip-javascript, --minimal]
771
- --skip-action-cable [due to --minimal]
772
- --skip-bootsnap [due to --minimal]
773
- --skip-dev-gems [due to --minimal]
774
- --skip-system-test [due to --minimal]
775
-
776
- ...
777
-
778
- $ rails new my_cool_app --minimal --no-skip-active-storage
779
- Based on the specified options, the following options will also be activated:
780
-
781
- --skip-action-mailer [due to --minimal]
782
- --skip-action-mailbox [due to --minimal]
783
- --skip-action-text [due to --minimal]
784
- --skip-javascript [due to --minimal]
785
- --skip-hotwire [due to --skip-javascript, --minimal]
786
- --skip-action-cable [due to --minimal]
787
- --skip-bootsnap [due to --minimal]
788
- --skip-dev-gems [due to --minimal]
789
- --skip-system-test [due to --minimal]
790
-
791
- ...
792
- ```
249
+ * Fix running `db:system:change` when the app has no Dockerfile.
793
250
 
794
- *Brad Trick* and *Jonathan Hefner*
251
+ *Hartley McGuire*
795
252
 
796
- * Add `--skip-dev-gems` option to app generator to skip adding development
797
- gems (like `web-console`) to the Gemfile.
253
+ * In Action Mailer previews, list inline attachments separately from normal
254
+ attachments.
798
255
 
799
- *Brad Trick*
256
+ For example, attachments that were previously listed like
800
257
 
801
- * Skip Active Storage and Action Mailer if Active Job is skipped.
258
+ > Attachments: logo.png file1.pdf file2.pdf
802
259
 
803
- *Étienne Barrié*
260
+ will now be listed like
804
261
 
805
- * Correctly check if frameworks are disabled when running app:update.
262
+ > Attachments: file1.pdf file2.pdf (Inline: logo.png)
806
263
 
807
- *Étienne Barrié* and *Paulo Barros*
264
+ *Christian Schmidt* and *Jonathan Hefner*
808
265
 
809
- * Delegate model generator description to orm hooked generator.
266
+ * In mailer preview, only show SMTP-To if it differs from the union of To, Cc and Bcc.
810
267
 
811
- *Gannon McGibbon*
268
+ *Christian Schmidt*
812
269
 
813
- * Execute `rails runner` scripts inside the executor.
270
+ * Enable YJIT by default on new applications running Ruby 3.3+.
814
271
 
815
- Enables error reporting, query cache, etc.
272
+ Adds a `config/initializers/enable_yjit.rb` initializer that enables YJIT
273
+ when running on Ruby 3.3+.
816
274
 
817
275
  *Jean Boussier*
818
276
 
819
- * Avoid booting in development then test for test tasks.
820
-
821
- Running one of the rails test subtasks (e.g. test:system, test:models) would
822
- go through Rake and cause the app to be booted twice. Now all the test:*
823
- subtasks are defined as Thor tasks and directly load the test environment.
824
-
825
- *Étienne Barrié*
826
-
827
- * Deprecate `Rails::Generators::Testing::Behaviour` in favor of `Rails::Generators::Testing::Behavior`.
828
-
829
- *Gannon McGibbon*
830
-
831
- * Allow configuration of logger size for local and test environments
832
-
833
- `config.log_file_size`
834
-
835
- Defaults to `100` megabytes.
836
-
837
- *Bernie Chiu*
277
+ * In Action Mailer previews, show date from message `Date` header if present.
838
278
 
839
- * Enroll new apps in decrypted diffs of credentials by default. This behavior
840
- can be opted out of with the app generator's `--skip-decrypted-diffs` flag.
279
+ *Sampat Badhe*
841
280
 
842
- *Jonathan Hefner*
281
+ * Exit with non-zero status when the migration generator fails.
843
282
 
844
- * Support declarative-style test name filters with `bin/rails test`.
283
+ *Katsuhiko YOSHIDA*
845
284
 
846
- This makes it possible to run a declarative-style test such as:
285
+ * Use numeric UID and GID in Dockerfile template.
847
286
 
848
- ```ruby
849
- class MyTest < ActiveSupport::TestCase
850
- test "does something" do
851
- # ...
852
- end
853
- end
854
- ```
287
+ The Dockerfile generated by `rails new` sets the default user and group
288
+ by name instead of UID:GID. This can cause the following error in Kubernetes:
855
289
 
856
- Using its declared name:
857
-
858
- ```bash
859
- $ bin/rails test test/my_test.rb -n "does something"
860
290
  ```
861
-
862
- Instead of having to specify its expanded method name:
863
-
864
- ```bash
865
- $ bin/rails test test/my_test.rb -n test_does_something
291
+ container has runAsNonRoot and image has non-numeric user (rails), cannot verify user is non-root
866
292
  ```
867
293
 
868
- *Jonathan Hefner*
869
-
870
- * Add `--js` and `--skip-javascript` options to `rails new`
871
-
872
- `--js` alias to `rails new --javascript ...`
873
-
874
- Same as `-j`, e.g. `rails new --js esbuild ...`
875
-
876
- `--skip-js` alias to `rails new --skip-javascript ...`
294
+ This change sets default user and group by their numeric values.
877
295
 
878
- Same as `-J`, e.g. `rails new --skip-js ...`
296
+ *Ivan Fedotov*
879
297
 
880
- *Dorian Marié*
298
+ * Disallow invalid values for rails new options.
881
299
 
882
- * Allow relative paths with leading dot slash to be passed to `rails test`.
300
+ The `--database`, `--asset-pipeline`, `--css`, and `--javascript` options
301
+ for `rails new` take different arguments. This change validates them.
883
302
 
884
- Fix `rails test ./test/model/post_test.rb` to run a single test file.
303
+ *Tony Drake*, *Akhil G Krishnan*, *Petrik de Heus*
885
304
 
886
- *Shouichi Kamiya* and *oljfte*
305
+ * Conditionally print `$stdout` when invoking `run_generator`.
887
306
 
888
- * Deprecate `config.enable_dependency_loading`. This flag addressed a limitation of the `classic` autoloader and has no effect nowadays. To fix this deprecation, please just delete the reference.
307
+ In an effort to improve the developer experience when debugging
308
+ generator tests, we add the ability to conditionally print `$stdout`
309
+ instead of capturing it.
889
310
 
890
- *Xavier Noria*
311
+ This allows for calls to `binding.irb` and `puts` work as expected.
891
312
 
892
- * Define `config.enable_reloading` to be `!config.cache_classes` for a more intuitive name. While `config.enable_reloading` and `config.reloading_enabled?` are preferred from now on, `config.cache_classes` is supported for backwards compatibility.
893
-
894
- *Xavier Noria*
895
-
896
- * Add JavaScript dependencies installation on bin/setup
897
-
898
- Add `yarn install` to bin/setup when using esbuild, webpack, or rollout.
899
-
900
- *Carlos Ribeiro*
901
-
902
- * Use `controller_class_path` in `Rails::Generators::NamedBase#route_url`
903
-
904
- The `route_url` method now returns the correct path when generating
905
- a namespaced controller with a top-level model using `--model-name`.
906
-
907
- Previously, when running this command:
908
-
909
- ```bash
910
- $ bin/rails generate scaffold_controller Admin/Post --model-name Post
313
+ ```sh
314
+ RAILS_LOG_TO_STDOUT=true ./bin/test test/generators/actions_test.rb
911
315
  ```
912
316
 
913
- the comments above the controller action would look like:
914
-
915
- ``` ruby
916
- # GET /posts
917
- def index
918
- @posts = Post.all
919
- end
920
- ```
921
-
922
- afterwards, they now look like this:
923
-
924
- ``` ruby
925
- # GET /admin/posts
926
- def index
927
- @posts = Post.all
928
- end
929
- ```
930
-
931
- Fixes #44662.
932
-
933
- *Andrew White*
934
-
935
- * No longer add autoloaded paths to `$LOAD_PATH`.
936
-
937
- This means it won't be possible to load them with a manual `require` call, the class or module can be referenced instead.
938
-
939
- Reducing the size of `$LOAD_PATH` speed-up `require` calls for apps not using `bootsnap`, and reduce the
940
- size of the `bootsnap` cache for the others.
941
-
942
- *Jean Boussier*
943
-
944
- * Remove default `X-Download-Options` header
945
-
946
- This header is currently only used by Internet Explorer which
947
- will be discontinued in 2022 and since Rails 7 does not fully
948
- support Internet Explorer this header should not be a default one.
949
-
950
- *Harun Sabljaković*
951
-
952
- * Add .node-version files for Rails apps that use Node.js
953
-
954
- Node version managers that make use of this file:
955
- https://github.com/shadowspawn/node-version-usage#node-version-file-usage
317
+ *Steve Polito*
956
318
 
957
- The generated Dockerfile will use the same node version.
319
+ * Remove the option `config.public_file_server.enabled` from the generators
320
+ for all environments, as the value is the same in all environments.
958
321
 
959
- *Sam Ruby*
322
+ *Adrian Hirt*
960
323
 
961
- Please check [7-0-stable](https://github.com/rails/rails/blob/7-0-stable/railties/CHANGELOG.md) for previous changes.
324
+ Please check [7-1-stable](https://github.com/rails/rails/blob/7-1-stable/railties/CHANGELOG.md) for previous changes.