railties 6.1.7.2 → 7.0.0.alpha1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (151) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +89 -433
  3. data/MIT-LICENSE +1 -1
  4. data/RDOC_MAIN.rdoc +16 -16
  5. data/README.rdoc +0 -1
  6. data/lib/rails/app_updater.rb +2 -4
  7. data/lib/rails/application/bootstrap.rb +17 -5
  8. data/lib/rails/application/configuration.rb +52 -31
  9. data/lib/rails/application/default_middleware_stack.rb +6 -3
  10. data/lib/rails/application/finisher.rb +43 -85
  11. data/lib/rails/application/routes_reloader.rb +8 -0
  12. data/lib/rails/application.rb +24 -50
  13. data/lib/rails/application_controller.rb +2 -2
  14. data/lib/rails/autoloaders/inflector.rb +21 -0
  15. data/lib/rails/autoloaders.rb +12 -16
  16. data/lib/rails/code_statistics.rb +2 -2
  17. data/lib/rails/code_statistics_calculator.rb +10 -1
  18. data/lib/rails/command/base.rb +26 -12
  19. data/lib/rails/command/behavior.rb +1 -1
  20. data/lib/rails/command/environment_argument.rb +1 -1
  21. data/lib/rails/command.rb +8 -5
  22. data/lib/rails/commands/credentials/USAGE +4 -2
  23. data/lib/rails/commands/credentials/credentials_command/diffing.rb +26 -16
  24. data/lib/rails/commands/credentials/credentials_command.rb +6 -2
  25. data/lib/rails/commands/dbconsole/dbconsole_command.rb +16 -15
  26. data/lib/rails/commands/help/USAGE +3 -2
  27. data/lib/rails/commands/runner/runner_command.rb +3 -2
  28. data/lib/rails/commands/server/server_command.rb +2 -5
  29. data/lib/rails/configuration.rb +18 -23
  30. data/lib/rails/engine/configuration.rb +2 -2
  31. data/lib/rails/engine.rb +23 -27
  32. data/lib/rails/gem_version.rb +4 -4
  33. data/lib/rails/generators/actions/create_migration.rb +2 -4
  34. data/lib/rails/generators/actions.rb +35 -13
  35. data/lib/rails/generators/app_base.rb +66 -102
  36. data/lib/rails/generators/app_name.rb +1 -1
  37. data/lib/rails/generators/base.rb +9 -13
  38. data/lib/rails/generators/erb/scaffold/scaffold_generator.rb +2 -0
  39. data/lib/rails/generators/erb/scaffold/templates/edit.html.erb.tt +8 -4
  40. data/lib/rails/generators/erb/scaffold/templates/index.html.erb.tt +5 -27
  41. data/lib/rails/generators/erb/scaffold/templates/new.html.erb.tt +7 -3
  42. data/lib/rails/generators/erb/scaffold/templates/partial.html.erb.tt +20 -0
  43. data/lib/rails/generators/erb/scaffold/templates/show.html.erb.tt +7 -16
  44. data/lib/rails/generators/erb.rb +1 -1
  45. data/lib/rails/generators/generated_attribute.rb +40 -4
  46. data/lib/rails/generators/migration.rb +2 -6
  47. data/lib/rails/generators/model_helpers.rb +1 -1
  48. data/lib/rails/generators/named_base.rb +1 -1
  49. data/lib/rails/generators/rails/app/app_generator.rb +44 -88
  50. data/lib/rails/generators/rails/app/templates/Gemfile.tt +41 -52
  51. data/lib/rails/generators/rails/app/templates/app/assets/stylesheets/application.css.tt +2 -2
  52. data/lib/rails/generators/rails/app/templates/app/mailers/application_mailer.rb.tt +2 -2
  53. data/lib/rails/generators/rails/app/templates/app/models/application_record.rb.tt +1 -1
  54. data/lib/rails/generators/rails/app/templates/app/views/layouts/application.html.erb.tt +3 -10
  55. data/lib/rails/generators/rails/app/templates/bin/rails.tt +1 -4
  56. data/lib/rails/generators/rails/app/templates/bin/rake.tt +0 -3
  57. data/lib/rails/generators/rails/app/templates/bin/setup.tt +9 -14
  58. data/lib/rails/generators/rails/app/templates/config/boot.rb.tt +1 -1
  59. data/lib/rails/generators/rails/app/templates/config/databases/jdbc.yml.tt +2 -2
  60. data/lib/rails/generators/rails/app/templates/config/databases/jdbcmysql.yml.tt +3 -3
  61. data/lib/rails/generators/rails/app/templates/config/databases/jdbcpostgresql.yml.tt +3 -3
  62. data/lib/rails/generators/rails/app/templates/config/databases/jdbcsqlite3.yml.tt +2 -2
  63. data/lib/rails/generators/rails/app/templates/config/databases/mysql.yml.tt +3 -3
  64. data/lib/rails/generators/rails/app/templates/config/databases/oracle.yml.tt +2 -2
  65. data/lib/rails/generators/rails/app/templates/config/databases/postgresql.yml.tt +3 -3
  66. data/lib/rails/generators/rails/app/templates/config/databases/sqlite3.yml.tt +1 -1
  67. data/lib/rails/generators/rails/app/templates/config/databases/sqlserver.yml.tt +5 -5
  68. data/lib/rails/generators/rails/app/templates/config/environments/development.rb.tt +2 -11
  69. data/lib/rails/generators/rails/app/templates/config/environments/production.rb.tt +9 -15
  70. data/lib/rails/generators/rails/app/templates/config/environments/test.rb.tt +2 -7
  71. data/lib/rails/generators/rails/app/templates/config/initializers/assets.rb.tt +1 -5
  72. data/lib/rails/generators/rails/app/templates/config/initializers/content_security_policy.rb.tt +0 -5
  73. data/lib/rails/generators/rails/app/templates/config/initializers/cors.rb.tt +2 -2
  74. data/lib/rails/generators/rails/app/templates/config/initializers/inflections.rb.tt +4 -4
  75. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_7_0.rb.tt +85 -0
  76. data/lib/rails/generators/rails/app/templates/config/locales/en.yml +3 -3
  77. data/lib/rails/generators/rails/app/templates/config/puma.rb.tt +1 -1
  78. data/lib/rails/generators/rails/app/templates/config/routes.rb.tt +3 -0
  79. data/lib/rails/generators/rails/app/templates/config/storage.yml.tt +5 -5
  80. data/lib/rails/generators/rails/app/templates/db/seeds.rb.tt +2 -2
  81. data/lib/rails/generators/rails/app/templates/gitattributes.tt +0 -5
  82. data/lib/rails/generators/rails/app/templates/gitignore.tt +0 -1
  83. data/lib/rails/generators/rails/app/templates/test/test_helper.rb.tt +1 -1
  84. data/lib/rails/generators/rails/controller/controller_generator.rb +1 -2
  85. data/lib/rails/generators/rails/controller/templates/controller.rb.tt +0 -4
  86. data/lib/rails/generators/rails/db/system/change/change_generator.rb +1 -1
  87. data/lib/rails/generators/rails/generator/templates/%file_name%_generator.rb.tt +1 -1
  88. data/lib/rails/generators/rails/plugin/plugin_generator.rb +40 -15
  89. data/lib/rails/generators/rails/plugin/templates/%name%.gemspec.tt +4 -2
  90. data/lib/rails/generators/rails/plugin/templates/Gemfile.tt +9 -9
  91. data/lib/rails/generators/rails/plugin/templates/README.md.tt +1 -1
  92. data/lib/rails/generators/rails/plugin/templates/app/mailers/%namespaced_name%/application_mailer.rb.tt +2 -2
  93. data/lib/rails/generators/rails/plugin/templates/app/models/%namespaced_name%/application_record.rb.tt +1 -1
  94. data/lib/rails/generators/rails/plugin/templates/app/views/layouts/%namespaced_name%/application.html.erb.tt +0 -3
  95. data/lib/rails/generators/rails/plugin/templates/bin/rails.tt +4 -4
  96. data/lib/rails/generators/rails/plugin/templates/gitignore.tt +0 -5
  97. data/lib/rails/generators/rails/plugin/templates/lib/%namespaced_name%/engine.rb.tt +2 -2
  98. data/lib/rails/generators/rails/plugin/templates/lib/%namespaced_name%/version.rb.tt +1 -1
  99. data/lib/rails/generators/rails/plugin/templates/rails/boot.rb.tt +2 -2
  100. data/lib/rails/generators/rails/plugin/templates/test/test_helper.rb.tt +3 -3
  101. data/lib/rails/generators/rails/scaffold/scaffold_generator.rb +0 -19
  102. data/lib/rails/generators/rails/scaffold_controller/templates/api_controller.rb.tt +1 -5
  103. data/lib/rails/generators/rails/scaffold_controller/templates/controller.rb.tt +6 -10
  104. data/lib/rails/generators/resource_helpers.rb +2 -2
  105. data/lib/rails/generators/test_unit/generator/templates/generator_test.rb.tt +1 -1
  106. data/lib/rails/generators/test_unit/model/templates/fixtures.yml.tt +2 -2
  107. data/lib/rails/generators/test_unit/scaffold/scaffold_generator.rb +3 -3
  108. data/lib/rails/generators/test_unit/scaffold/templates/api_functional_test.rb.tt +5 -5
  109. data/lib/rails/generators/test_unit/scaffold/templates/functional_test.rb.tt +2 -2
  110. data/lib/rails/generators/test_unit/scaffold/templates/system_test.rb.tt +3 -3
  111. data/lib/rails/generators/testing/behaviour.rb +1 -2
  112. data/lib/rails/generators.rb +9 -22
  113. data/lib/rails/info.rb +1 -1
  114. data/lib/rails/info_controller.rb +1 -3
  115. data/lib/rails/initializable.rb +1 -1
  116. data/lib/rails/mailers_controller.rb +2 -4
  117. data/lib/rails/rack/logger.rb +0 -1
  118. data/lib/rails/railtie/configuration.rb +1 -2
  119. data/lib/rails/railtie.rb +9 -9
  120. data/lib/rails/ruby_version_check.rb +3 -3
  121. data/lib/rails/tasks/framework.rake +2 -8
  122. data/lib/rails/tasks/statistics.rake +3 -1
  123. data/lib/rails/tasks/tmp.rake +8 -1
  124. data/lib/rails/tasks/yarn.rake +5 -1
  125. data/lib/rails/tasks/zeitwerk.rake +2 -10
  126. data/lib/rails/templates/layouts/application.html.erb +15 -0
  127. data/lib/rails/templates/rails/mailers/email.html.erb +12 -10
  128. data/lib/rails/templates/rails/welcome/index.html.erb +3 -0
  129. data/lib/rails/test_unit/railtie.rb +0 -4
  130. data/lib/rails/test_unit/runner.rb +7 -5
  131. data/lib/rails/test_unit/testing.rake +4 -9
  132. data/lib/rails.rb +1 -0
  133. metadata +37 -39
  134. data/lib/rails/command/spellchecker.rb +0 -57
  135. data/lib/rails/generators/css/assets/assets_generator.rb +0 -15
  136. data/lib/rails/generators/css/assets/templates/stylesheet.css +0 -4
  137. data/lib/rails/generators/css/scaffold/scaffold_generator.rb +0 -18
  138. data/lib/rails/generators/rails/app/templates/app/javascript/channels/consumer.js +0 -6
  139. data/lib/rails/generators/rails/app/templates/app/javascript/channels/index.js +0 -5
  140. data/lib/rails/generators/rails/app/templates/app/javascript/packs/application.js.tt +0 -23
  141. data/lib/rails/generators/rails/app/templates/bin/spring.tt +0 -13
  142. data/lib/rails/generators/rails/app/templates/bin/yarn.tt +0 -16
  143. data/lib/rails/generators/rails/app/templates/config/initializers/application_controller_renderer.rb.tt +0 -8
  144. data/lib/rails/generators/rails/app/templates/config/initializers/cookies_serializer.rb.tt +0 -5
  145. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_6_1.rb.tt +0 -67
  146. data/lib/rails/generators/rails/app/templates/config/spring.rb.tt +0 -6
  147. data/lib/rails/generators/rails/app/templates/package.json.tt +0 -11
  148. data/lib/rails/generators/rails/assets/USAGE +0 -16
  149. data/lib/rails/generators/rails/assets/assets_generator.rb +0 -26
  150. data/lib/rails/generators/rails/assets/templates/stylesheet.css +0 -4
  151. data/lib/rails/generators/rails/scaffold/templates/scaffold.css +0 -80
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: f0196a31ae994e96500308c5264325cfe0061a6de262b86b7fa6da17a1da4c8d
4
- data.tar.gz: 75f1e98818dd844d27137bdb52d751bcab7f0d97c8718b2ba270860c10009ff9
3
+ metadata.gz: 809add07149bc6a8fc6bd9e1848b4237e6a39642319d686c0e5e7c1ff005a0fe
4
+ data.tar.gz: 3676fc831492d4e660fe82b657b25630373e1176d5dfc0d6375857aa0de0d0cd
5
5
  SHA512:
6
- metadata.gz: d32b17a1759631c52b9ecfb9e9958546d36a81ea6440ddcf07ba31bc205511c325e3db453b55cad78840ad2901c768717081ce4dae1fa4f502bb53888317ef95
7
- data.tar.gz: 83e39f653d92073c7ea8763f82aba8e161f116135bd8792b66648c23e2dda7ebc7051fb59f8ff5126ea251da3085fc59a32fa8ad7040fe7d784a859c0ebd11af
6
+ metadata.gz: 136de74c284cec25a993107e665b70f0732116b770c0ca3081b2b9f6a2366046d318d0153da438b557485aadb18ab0850c7135c20ef662154418e1690a0f8788
7
+ data.tar.gz: a6ad192510bd25f054e931fcbb7ef7fa3c34cbc90a9445d7b8ca173c9c2f58b5ffd40e33b10ddb27d7cdf5cf026ebb5e2a9cd7e6637804d291e922310fc795c8
data/CHANGELOG.md CHANGED
@@ -1,86 +1,101 @@
1
- ## Rails 6.1.7.2 (January 24, 2023) ##
1
+ ## Rails 7.0.0.alpha1 (September 15, 2021) ##
2
2
 
3
- * No changes.
3
+ * New and upgraded Rails apps no longer generate `config/initializers/application_controller_renderer.rb`
4
+ or `config/initializers/cookies_serializer.rb`
4
5
 
6
+ The default value for `cookies_serializer` (`:json`) has been moved to `config.load_defaults("7.0")`.
7
+ The new framework defaults file sets the serializer to `:marshal`.
5
8
 
6
- ## Rails 6.1.7.1 (January 17, 2023) ##
7
-
8
- * No changes.
9
-
10
-
11
- ## Rails 6.1.7 (September 09, 2022) ##
12
-
13
- * No changes.
14
-
15
-
16
- ## Rails 6.1.6.1 (July 12, 2022) ##
17
-
18
- * No changes.
19
-
9
+ *Alex Ghiculescu*
20
10
 
21
- ## Rails 6.1.6 (May 09, 2022) ##
11
+ * New applications get a dependency on the new `debug` gem, replacing `byebug`.
22
12
 
23
- * No changes.
13
+ *Xavier Noria*
24
14
 
15
+ * Add SSL support for postgresql in `bin/rails dbconsole`.
25
16
 
26
- ## Rails 6.1.5.1 (April 26, 2022) ##
17
+ Fixes #43114.
27
18
 
28
- * No changes.
19
+ *Michael Bayucot*
29
20
 
21
+ * Add support for comments above gem declaration in Rails application templates, e.g. `gem("nokogiri", comment: "For XML")`.
30
22
 
31
- ## Rails 6.1.5 (March 09, 2022) ##
23
+ *Linas Juškevičius*
32
24
 
33
- * In `zeitwerk` mode, setup the `once` autoloader first, and the `main` autoloader after it.
34
- This order plays better with shared namespaces.
25
+ * The setter `config.autoloader=` has been deleted. `zeitwerk` is the only
26
+ available autoloading mode.
35
27
 
36
28
  *Xavier Noria*
37
29
 
38
- * Handle paths with spaces when editing credentials.
30
+ * `config.autoload_once_paths` can be configured in the body of the
31
+ application class defined in `config/application.rb` or in the configuration
32
+ for environments in `config/environments/*`.
39
33
 
40
- *Alex Ghiculescu*
34
+ Similarly, engines can configure that collection in the class body of the
35
+ engine class or in the configuration for environments.
41
36
 
42
- * Support Psych 4 when loading secrets.
37
+ After that, the collection is frozen, and you can autoload from those paths.
38
+ They are managed by the `Rails.autoloaders.once` autoloader, which does not
39
+ reload, only autoloads/eager loads.
43
40
 
44
- *Nat Morcos*
41
+ *Xavier Noria*
45
42
 
43
+ * During initialization, you cannot autoload reloadable classes or modules
44
+ like application models, unless they are wrapped in a `to_prepare` block.
45
+ For example, from `config/initializers/*`, or in application, engines, or
46
+ railties initializers.
46
47
 
47
- ## Rails 6.1.4.7 (March 08, 2022) ##
48
+ Please check the [autoloading
49
+ guide](https://guides.rubyonrails.org/v7.0/autoloading_and_reloading_constants.html#autoloading-when-the-application-boots)
50
+ for details.
48
51
 
49
- * No changes.
52
+ *Xavier Noria*
50
53
 
54
+ * While they are allowed to have elements in common, it is no longer required
55
+ that `config.autoload_once_paths` is a subset of `config.autoload_paths`.
56
+ The former are managed by the `once` autoloader. The `main` autoloader
57
+ manages the latter minus the former.
51
58
 
52
- ## Rails 6.1.4.6 (February 11, 2022) ##
59
+ *Xavier Noria*
53
60
 
54
- * No changes.
61
+ * Show Rake task description if command is run with `-h`.
55
62
 
63
+ Adding `-h` (or `--help`) to a Rails command that's a Rake task now outputs
64
+ the task description instead of the general Rake help.
56
65
 
57
- ## Rails 6.1.4.5 (February 11, 2022) ##
66
+ *Petrik de Heus*
58
67
 
59
- * No changes.
68
+ * Add missing `plugin new` command to help.
60
69
 
70
+ *Petrik de Heus
61
71
 
62
- ## Rails 6.1.4.4 (December 15, 2021) ##
72
+ * Fix `config_for` error when there's only a shared root array.
63
73
 
64
- * No changes.
74
+ *Loïc Delmaire*
65
75
 
76
+ * Raise an error in generators if an index type is invalid.
66
77
 
67
- ## Rails 6.1.4.3 (December 14, 2021) ##
78
+ *Petrik de Heus*
68
79
 
69
- * Allow localhost with a port by default in development
80
+ * `package.json` now uses a strict version constraint for Rails JavaScript packages on new Rails apps.
70
81
 
71
- [Fixes: #43864]
82
+ *Zachary Scott*, *Alex Ghiculescu*
72
83
 
73
- ## Rails 6.1.4.2 (December 14, 2021) ##
84
+ * Modified scaffold generator template so that running
85
+ `rails g scaffold Author` no longer generates tests called "creating
86
+ a Author", "updating a Author", and "destroying a Author".
74
87
 
75
- * No changes.
88
+ Fixes #40744.
76
89
 
90
+ *Michael Duchemin*
77
91
 
78
- ## Rails 6.1.4.1 (August 19, 2021) ##
92
+ * Raise an error in generators if a field type is invalid.
79
93
 
80
- * No changes.
94
+ *Petrik de Heus*
81
95
 
96
+ * `bin/rails tmp:clear` deletes also files and directories in `tmp/storage`.
82
97
 
83
- ## Rails 6.1.4 (June 24, 2021) ##
98
+ *George Claghorn*
84
99
 
85
100
  * Fix compatibility with `psych >= 4`.
86
101
 
@@ -89,421 +104,62 @@
89
104
 
90
105
  *Jean Boussier*
91
106
 
92
- * Ensure `Rails.application.config_for` always cast hashes to `ActiveSupport::OrderedOptions`.
93
-
94
- *Jean Boussier*
95
-
96
- * Fix create migration generator with `--pretend` option.
97
-
98
- *euxx*
99
-
107
+ * Allow loading nested locales in engines.
100
108
 
101
- ## Rails 6.1.3.2 (May 05, 2021) ##
109
+ *Gannon McGibbon*
102
110
 
103
- * No changes.
104
-
105
-
106
- ## Rails 6.1.3.1 (March 26, 2021) ##
107
-
108
- * No changes.
109
-
110
-
111
- ## Rails 6.1.3 (February 17, 2021) ##
112
-
113
- * No changes.
114
-
115
-
116
- ## Rails 6.1.2.1 (February 10, 2021) ##
117
-
118
- * No changes.
111
+ * Ensure `Rails.application.config_for` always cast hashes to `ActiveSupport::OrderedOptions`.
119
112
 
113
+ *Jean Boussier*
120
114
 
121
- ## Rails 6.1.2 (February 09, 2021) ##
115
+ * Remove `Rack::Runtime` from the default middleware stack and deprecate
116
+ referencing it in middleware operations without adding it back.
122
117
 
123
- * No changes.
118
+ *Hartley McGuire*
124
119
 
120
+ * Allow adding additional authorized hosts in development via `ENV['RAILS_DEVELOPMENT_HOSTS']`.
125
121
 
126
- ## Rails 6.1.1 (January 07, 2021) ##
122
+ *Josh Abernathy*, *Debbie Milburn*
127
123
 
128
- * Allow spaces in path to Yarn binstub and only run on precompile if needed.
124
+ * Add app concern and test keepfiles to generated engine plugins.
129
125
 
130
- *Markus Doits*
126
+ *Gannon McGibbon*
131
127
 
132
- * Populate ARGV for app template.
128
+ * Stop generating a license for in-app plugins.
133
129
 
134
- Fixes #40945.
130
+ *Gannon McGibbon*
135
131
 
136
- *Jonathan Hefner*
132
+ * `rails app:update` no longer prompts you to overwrite files that are generally modified in the
133
+ course of developing a Rails app. See [#41083](https://github.com/rails/rails/pull/41083) for
134
+ the full list of changes.
137
135
 
136
+ *Alex Ghiculescu*
138
137
 
139
- ## Rails 6.1.0 (December 09, 2020) ##
138
+ * Change default branch for new Rails projects and plugins to `main`.
140
139
 
141
- * Added `Railtie#server` hook called when Rails starts a server.
142
- This is useful in case your application or a library needs to run
143
- another process next to the Rails server. This is quite common in development
144
- for instance to run the Webpack or the React server.
140
+ *Prateek Choudhary*
145
141
 
146
- It can be used like this:
142
+ * The new method `Rails.benchmark` gives you a quick way to measure and log the execution time taken by a block:
147
143
 
148
- ```ruby
149
- class MyRailtie < Rails::Railtie
150
- server do
151
- WebpackServer.run
144
+ def test_expensive_stuff
145
+ Rails.benchmark("test_expensive_stuff") { ... }
152
146
  end
153
- end
154
- ```
155
-
156
- *Edouard Chin*
157
-
158
- * Remove deprecated `rake dev:cache` tasks.
159
-
160
- *Rafael Mendonça França*
161
-
162
- * Remove deprecated `rake routes` tasks.
163
-
164
- *Rafael Mendonça França*
165
-
166
- * Remove deprecated `rake initializers` tasks.
167
-
168
- *Rafael Mendonça França*
169
-
170
- * Remove deprecated support for using the `HOST` environment variable to specify the server IP.
171
-
172
- *Rafael Mendonça França*
173
-
174
- * Remove deprecated `server` argument from the rails server command.
175
-
176
- *Rafael Mendonça França*
177
-
178
- * Remove deprecated `SOURCE_ANNOTATION_DIRECTORIES` environment variable support from `rails notes`.
179
-
180
- *Rafael Mendonça França*
181
-
182
- * Remove deprecated `connection` option in the `rails dbconsole` command.
183
-
184
- *Rafael Mendonça França*
185
-
186
- * Remove depreated `rake notes` tasks.
187
-
188
- *Rafael Mendonça França*
189
-
190
- * Return a 405 Method Not Allowed response when a request uses an unknown HTTP method.
191
-
192
- Fixes #38998.
193
-
194
- *Loren Norman*
195
-
196
- * Make railsrc file location xdg-specification compliant
197
-
198
- `rails new` will now look for the default `railsrc` file at
199
- `$XDG_CONFIG_HOME/rails/railsrc` (or `~/.config/rails/railsrc` if
200
- `XDG_CONFIG_HOME` is not set). If this file does not exist, `rails new`
201
- will fall back to `~/.railsrc`.
202
-
203
- The fallback behaviour means this does not cause any breaking changes.
204
-
205
- *Nick Wolf*
206
-
207
- * Change the default logging level from :debug to :info to avoid inadvertent exposure of personally
208
- identifiable information (PII) in production environments.
209
-
210
- *Eric M. Payne*
211
-
212
- * Automatically generate abstract class when using multiple databases.
213
-
214
- When generating a scaffold for a multiple database application, Rails will now automatically generate the abstract class for the database when the database argument is passed. This abstract class will include the connection information for the writing configuration and any models generated for that database will automatically inherit from the abstract class.
215
-
216
- Usage:
217
-
218
- ```bash
219
- $ bin/rails generate scaffold Pet name:string --database=animals
220
- ```
221
-
222
- Will create an abstract class for the animals connection.
223
-
224
- ```ruby
225
- class AnimalsRecord < ApplicationRecord
226
- self.abstract_class = true
227
-
228
- connects_to database: { writing: :animals }
229
- end
230
- ```
231
-
232
- And generate a `Pet` model that inherits from the new `AnimalsRecord`:
233
-
234
- ```ruby
235
- class Pet < AnimalsRecord
236
- end
237
- ```
238
-
239
- If you already have an abstract class and it follows a different pattern than Rails defaults, you can pass a parent class with the database argument.
240
-
241
- ```bash
242
- $ bin/rails generate scaffold Pet name:string --database=animals --parent=SecondaryBase
243
- ```
244
-
245
- This will ensure the model inherits from the `SecondaryBase` parent instead of `AnimalsRecord`
246
-
247
- ```ruby
248
- class Pet < SecondaryBase
249
- end
250
- ```
251
-
252
- *Eileen M. Uchitelle*, *John Crepezzi*
253
-
254
- * Accept params from url to prepopulate the Inbound Emails form in Rails conductor.
255
-
256
- *Chris Oliver*
257
-
258
- * Create a new rails app using a minimal stack.
259
-
260
- `rails new cool_app --minimal`
261
-
262
- All the following are excluded from your minimal stack:
263
-
264
- - action_cable
265
- - action_mailbox
266
- - action_mailer
267
- - action_text
268
- - active_job
269
- - active_storage
270
- - bootsnap
271
- - jbuilder
272
- - spring
273
- - system_tests
274
- - turbolinks
275
- - webpack
276
-
277
- *Haroon Ahmed*, *DHH*
278
147
 
279
- * Add default ENV variable option with BACKTRACE to turn off backtrace cleaning when debugging framework code in the
280
- generated config/initializers/backtrace_silencers.rb.
148
+ This functionality was available in some contexts only before.
281
149
 
282
- `BACKTRACE=1 ./bin/rails runner "MyClass.perform"`
150
+ *Simon Perepelitsa*
283
151
 
284
- *DHH*
152
+ * Applications generated with `--skip-sprockets` no longer get `app/assets/config/manifest.js` and `app/assets/stylesheets/application.css`.
285
153
 
286
- * The autoloading guide for Zeitwerk mode documents how to autoload classes
287
- during application boot in a safe way.
288
-
289
- *Haroon Ahmed*, *Xavier Noria*
290
-
291
- * The `classic` autoloader starts its deprecation cycle.
292
-
293
- New Rails projects are strongly discouraged from using `classic`, and we recommend that existing projects running on `classic` switch to `zeitwerk` mode when upgrading. Please check the [_Upgrading Ruby on Rails_](https://guides.rubyonrails.org/upgrading_ruby_on_rails.html) guide for tips.
294
-
295
- *Xavier Noria*
296
-
297
- * Adds `rails test:all` for running all tests in the test directory.
298
-
299
- This runs all test files in the test directory, including system tests.
300
-
301
- *Niklas Häusele*
302
-
303
- * Add `config.generators.after_generate` for processing to generated files.
304
-
305
- Register a callback that will get called right after generators has finished.
306
-
307
- *Yuji Yaginuma*
308
-
309
- * Make test file patterns configurable via Environment variables
310
-
311
- This makes test file patterns configurable via two environment variables:
312
- `DEFAULT_TEST`, to configure files to test, and `DEFAULT_TEST_EXCLUDE`,
313
- to configure files to exclude from testing.
314
-
315
- These values were hardcoded before, which made it difficult to add
316
- new categories of tests that should not be executed by default (e.g:
317
- smoke tests).
318
-
319
- *Jorge Manrubia*
320
-
321
- * No longer include `rake rdoc` task when generating plugins.
322
-
323
- To generate docs, use the `rdoc lib` command instead.
324
-
325
- *Jonathan Hefner*
326
-
327
- * Allow relative paths with trailing slashes to be passed to `rails test`.
328
-
329
- *Eugene Kenny*
330
-
331
- * Add `rack-mini-profiler` gem to the default `Gemfile`.
332
-
333
- `rack-mini-profiler` displays performance information such as SQL time and flame graphs.
334
- It's enabled by default in development environment, but can be enabled in production as well.
335
- See the gem [README](https://github.com/MiniProfiler/rack-mini-profiler/blob/master/README.md) for information on how to enable it in production.
336
-
337
- *Osama Sayegh*
338
-
339
- * `rails stats` will now count TypeScript files toward JavaScript stats.
340
-
341
- *Joshua Cody*
342
-
343
- * Run `git init` when generating plugins.
344
-
345
- Opt out with `--skip-git`.
346
-
347
- *OKURA Masafumi*
348
-
349
- * Add benchmark generator.
350
-
351
- Introduce benchmark generator to benchmark Rails applications.
352
-
353
- `rails generate benchmark opt_compare`
354
-
355
- This creates a benchmark file that uses [`benchmark-ips`](https://github.com/evanphx/benchmark-ips).
356
- By default, two code blocks can be benchmarked using the `before` and `after` reports.
357
-
358
- You can run the generated benchmark file using:
359
- `ruby script/benchmarks/opt_compare.rb`
360
-
361
- *Kevin Jalbert*, *Gannon McGibbon*
362
-
363
- * Cache compiled view templates when running tests by default.
364
-
365
- When generating a new app without `--skip-spring`, caching classes is
366
- disabled in `environments/test.rb`. This implicitly disables caching
367
- view templates too. This change will enable view template caching by
368
- adding this to the generated `environments/test.rb`:
369
-
370
- ```ruby
371
- config.action_view.cache_template_loading = true
372
- ```
373
-
374
- *Jorge Manrubia*
375
-
376
- * Introduce middleware move operations.
377
-
378
- With this change, you no longer need to delete and reinsert a middleware to
379
- move it from one place to another in the stack:
380
-
381
- ```ruby
382
- config.middleware.move_before ActionDispatch::Flash, Magical::Unicorns
383
- ```
384
-
385
- This will move the `Magical::Unicorns` middleware before
386
- `ActionDispatch::Flash`. You can also move it after with:
387
-
388
- ```ruby
389
- config.middleware.move_after ActionDispatch::Flash, Magical::Unicorns
390
- ```
391
-
392
- *Genadi Samokovarov*
393
-
394
- * Generators that inherit from NamedBase respect `--force` option.
395
-
396
- *Josh Brody*
397
-
398
- * Allow configuration of eager_load behaviour for rake environment:
399
-
400
- config.rake_eager_load
401
-
402
- Defaults to `false` as per previous behaviour.
403
-
404
- *Thierry Joyal*
405
-
406
- * Ensure Rails migration generator respects system-wide primary key config.
407
-
408
- When rails is configured to use a specific primary key type:
409
-
410
- ```ruby
411
- config.generators do |g|
412
- g.orm :active_record, primary_key_type: :uuid
413
- end
414
- ```
415
-
416
- Previously:
417
-
418
- ```bash
419
- $ bin/rails g migration add_location_to_users location:references
420
- ```
421
-
422
- The references line in the migration would not have `type: :uuid`.
423
- This change causes the type to be applied appropriately.
424
-
425
- *Louis-Michel Couture*, *Dermot Haughey*
426
-
427
- * Deprecate `Rails::DBConsole#config`.
428
-
429
- `Rails::DBConsole#config` is deprecated without replacement. Use `Rails::DBConsole.db_config.configuration_hash` instead.
430
-
431
- *Eileen M. Uchitelle*, *John Crepezzi*
432
-
433
- * `Rails.application.config_for` merges shared configuration deeply.
434
-
435
- ```yaml
436
- # config/example.yml
437
- shared:
438
- foo:
439
- bar:
440
- baz: 1
441
- development:
442
- foo:
443
- bar:
444
- qux: 2
445
- ```
446
-
447
- ```ruby
448
- # Previously
449
- Rails.application.config_for(:example)[:foo][:bar] #=> { qux: 2 }
450
-
451
- # Now
452
- Rails.application.config_for(:example)[:foo][:bar] #=> { baz: 1, qux: 2 }
453
- ```
454
-
455
- *Yuhei Kiriyama*
456
-
457
- * Remove access to values in nested hashes returned by `Rails.application.config_for` via String keys.
458
-
459
- ```yaml
460
- # config/example.yml
461
- development:
462
- options:
463
- key: value
464
- ```
465
-
466
- ```ruby
467
- Rails.application.config_for(:example).options
468
- ```
469
-
470
- This used to return a Hash on which you could access values with String keys. This was deprecated in 6.0, and now doesn't work anymore.
471
-
472
- *Étienne Barrié*
473
-
474
- * Configuration files for environments (`config/environments/*.rb`) are
475
- now able to modify `autoload_paths`, `autoload_once_paths`, and
476
- `eager_load_paths`.
477
-
478
- As a consequence, applications cannot autoload within those files. Before, they technically could, but changes in autoloaded classes or modules had no effect anyway in the configuration because reloading does not reboot.
479
-
480
- Ways to use application code in these files:
481
-
482
- * Define early in the boot process a class that is not reloadable, from which the application takes configuration values that get passed to the framework.
483
-
484
- ```ruby
485
- # In config/application.rb, for example.
486
- require "#{Rails.root}/lib/my_app/config"
487
-
488
- # In config/environments/development.rb, for example.
489
- config.foo = MyApp::Config.foo
490
- ```
491
-
492
- * If the class has to be reloadable, then wrap the configuration code in a `to_prepare` block:
493
-
494
- ```ruby
495
- config.to_prepare do
496
- config.foo = MyModel.foo
497
- end
498
- ```
154
+ *Cindy Gao*
499
155
 
500
- That assigns the latest `MyModel.foo` to `config.foo` when the application boots, and each time there is a reload. But whether that has an effect or not depends on the configuration point, since it is not uncommon for engines to read the application configuration during initialization and set their own state from them. That process happens only on boot, not on reloads, and if that is how `config.foo` worked, resetting it would have no effect in the state of the engine.
156
+ * Add support for stylesheets and ERB views to `rails stats`.
501
157
 
502
- *Allen Hsu* & *Xavier Noria*
158
+ *Joel Hawksley*
503
159
 
504
- * Support using environment variable to set pidfile.
160
+ * Allow appended root routes to take precedence over internal welcome controller.
505
161
 
506
- *Ben Thorner*
162
+ *Gannon McGibbon*
507
163
 
508
164
 
509
- Please check [6-0-stable](https://github.com/rails/rails/blob/6-0-stable/railties/CHANGELOG.md) for previous changes.
165
+ Please check [6-1-stable](https://github.com/rails/rails/blob/6-1-stable/railties/CHANGELOG.md) for previous changes.
data/MIT-LICENSE CHANGED
@@ -1,4 +1,4 @@
1
- Copyright (c) 2004-2022 David Heinemeier Hansson
1
+ Copyright (c) 2004-2021 David Heinemeier Hansson
2
2
 
3
3
  Permission is hereby granted, free of charge, to any person obtaining
4
4
  a copy of this software and associated documentation files (the
data/RDOC_MAIN.rdoc CHANGED
@@ -15,21 +15,21 @@ application into three layers: Model, View, and Controller, each with a specific
15
15
  The <em><b>Model layer</b></em> represents the domain model (such as Account, Product,
16
16
  Person, Post, etc.) and encapsulates the business logic specific to
17
17
  your application. In \Rails, database-backed model classes are derived from
18
- <tt>ActiveRecord::Base</tt>. {Active Record}[link:files/activerecord/README_rdoc.html] allows you to present the data from
18
+ <tt>ActiveRecord::Base</tt>. {Active Record}[link:/files/activerecord/README_rdoc.html] allows you to present the data from
19
19
  database rows as objects and embellish these data objects with business logic
20
20
  methods. Although most \Rails models are backed by a database, models can also be ordinary
21
21
  Ruby classes, or Ruby classes that implement a set of interfaces as provided by
22
- the {Active Model}[link:files/activemodel/README_rdoc.html] module.
22
+ the {Active Model}[link:/files/activemodel/README_rdoc.html] module.
23
23
 
24
24
  == Controller layer
25
25
 
26
26
  The <em><b>Controller layer</b></em> is responsible for handling incoming HTTP requests and
27
- providing a suitable response. Usually this means returning \HTML, but \Rails controllers
27
+ providing a suitable response. Usually, this means returning \HTML, but \Rails controllers
28
28
  can also generate XML, JSON, PDFs, mobile-specific views, and more. Controllers load and
29
- manipulate models, and render view templates in order to generate the appropriate HTTP response.
29
+ manipulate models and render view templates in order to generate the appropriate HTTP response.
30
30
  In \Rails, incoming requests are routed by Action Dispatch to an appropriate controller, and
31
31
  controller classes are derived from <tt>ActionController::Base</tt>. Action Dispatch and Action Controller
32
- are bundled together in {Action Pack}[link:files/actionpack/README_rdoc.html].
32
+ are bundled together in {Action Pack}[link:/files/actionpack/README_rdoc.html].
33
33
 
34
34
  == View layer
35
35
 
@@ -37,19 +37,19 @@ The <em><b>View layer</b></em> is composed of "templates" that are responsible f
37
37
  appropriate representations of your application's resources. Templates can
38
38
  come in a variety of formats, but most view templates are \HTML with embedded
39
39
  Ruby code (ERB files). Views are typically rendered to generate a controller response,
40
- or to generate the body of an email. In \Rails, View generation is handled by {Action View}[link:files/actionview/README_rdoc.html].
40
+ or to generate the body of an email. In \Rails, View generation is handled by {Action View}[link:/files/actionview/README_rdoc.html].
41
41
 
42
42
  == Frameworks and libraries
43
43
 
44
- {Active Record}[link:files/activerecord/README_rdoc.html], {Active Model}[link:files/activemodel/README_rdoc.html],
45
- {Action Pack}[link:files/actionpack/README_rdoc.html], and {Action View}[link:files/actionview/README_rdoc.html] can each be used independently outside \Rails.
46
- In addition to that, \Rails also comes with {Action Mailer}[link:files/actionmailer/README_rdoc.html], a library
47
- to generate and send emails; {Action Mailbox}[link:files/actionmailbox/README_md.html], a library to receive emails within a Rails application;
48
- {Active Job}[link:files/activejob/README_md.html], a framework for declaring jobs and making them run on a variety of queueing
49
- backends; {Action Cable}[link:files/actioncable/README_md.html], a framework to
50
- integrate WebSockets with a \Rails application; {Active Storage}[link:files/activestorage/README_md.html],
51
- a library to attach cloud and local files to \Rails applications; {Action Text}[link:files/actiontext/README_md.html], a library to handle rich text content;
52
- and {Active Support}[link:files/activesupport/README_rdoc.html], a collection
44
+ {Active Record}[link:/files/activerecord/README_rdoc.html], {Active Model}[link:/files/activemodel/README_rdoc.html],
45
+ {Action Pack}[link:/files/actionpack/README_rdoc.html], and {Action View}[link:/files/actionview/README_rdoc.html] can each be used independently outside \Rails.
46
+ In addition to that, \Rails also comes with {Action Mailer}[link:/files/actionmailer/README_rdoc.html], a library
47
+ to generate and send emails; {Action Mailbox}[link:/files/actionmailbox/README_md.html], a library to receive emails within a Rails application;
48
+ {Active Job}[link:/files/activejob/README_md.html], a framework for declaring jobs and making them run on a variety of queueing
49
+ backends; {Action Cable}[link:/files/actioncable/README_md.html], a framework to
50
+ integrate WebSockets with a \Rails application; {Active Storage}[link:/files/activestorage/README_md.html],
51
+ a library to attach cloud and local files to \Rails applications; {Action Text}[link:/files/actiontext/README_md.html], a library to handle rich text content;
52
+ and {Active Support}[link:/files/activesupport/README_rdoc.html], a collection
53
53
  of utility classes and standard library extensions that are useful for \Rails,
54
54
  and may also be used independently outside \Rails.
55
55
 
@@ -72,7 +72,7 @@ and may also be used independently outside \Rails.
72
72
 
73
73
  Run with <tt>--help</tt> or <tt>-h</tt> for options.
74
74
 
75
- 4. Go to <tt>http://localhost:3000</tt> and you'll see: "Yay! You’re on \Rails!"
75
+ 4. Go to <tt>http://localhost:3000</tt>, and you'll see: "Yay! You’re on \Rails!"
76
76
 
77
77
  5. Follow the guidelines to start developing your application. You may find the following resources handy:
78
78