|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| | This will fix the failures fixed by
41488adbb89a09fa96188486f8414842ff28c848
and keep this new option that is semi-private
outside of the generated configurations | 
| | 
| 
| 
| 
| | Railties tests didn't know about the new config option added in 80b416f so
it needed to be added to the railties generators for configs. | 
| | 
| 
| 
| 
| 
| | - As assets are removed for API only apps anyways, so we don't need any
  conditional upfront.
- assets are removed for API apps here - https://github.com/rails/rails/blob/94ef224aa61ace3fa643eab161ff9056b7d90a62/railties/lib/rails/generators/rails/app/app_generator.rb#L266-L273. | 
| | 
| 
| 
| 
| | This option is used in a initializer hook that runs before the
config/initializers files so it will not work if it is set there. | 
| |\  
| | 
| | 
| | 
| | | y-yagi/generate_mailer_layout_files_if_it_does_not_already_exist
generate mailer layout files if it does not already exist | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | Currently, if `ApplicationMailer` does not exist, it is generated when
run the mailer generator, but layouts files does not generate.
However, because it uses the layouts in `ApplicationMailer`,
layouts are required.
Follow up to #24161 | 
| | | |  | 
| |\ \  
| | | 
| | | | Fix API controller tests by assigning them the encoding type | 
| | | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | | - Fixes #25183.
- The `as: :json` feature was added in
  https://github.com/rails/rails/pull/21671 and recommended to use for
  JSON endpoints so let's use it by default for API controller tests. | 
| |/ /  
| |   
| |   
| |   
| |   
| |   
| |   
| |   
| | | Since Ruby 2.4 isn't out yet, the fact that it will make `to_time` preserve the
time zone should be toggled with a update flag.
Second, remove the flipping on what version had what defaults. It's called new
framework defaults, so it's from the future looking. Thus keep the line that
mentions past versions. | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | 
| | | about old apps and how you can upgrade to new defaults.
[Kasper Timm Hansen, Prathamesh Sonpatki] | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | request_forgery_protection configs
- Earlier per_form_csrf_tokens and request_forgery_protection config
  files were generated for old apps upgraded to Rails 5.
- But when we collapsed all initializers into one file, the entire file
  does not get created for old apps.
- This commit fixes it and also changes values for all new defaults for
  old apps so that they will not break.
- Also added a test for `rails app:update`. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | | - Move real new default options to the top of the file.
- After that club together all the options which were added to keep
  backward compatibility. So all of them will get only one header.
- Based on https://github.com/rails/rails/pull/25231#issuecomment-222945173. | 
| | | |  | 
| |\ \  
| | | 
| | | | Collapse all new default initializers into a single file | 
| | | | 
| | | 
| | | 
| | | 
| | | 
| | | | - Adjusted tests also for this new behavior.
- Based on the discussion in
  https://github.com/rails/rails/pull/25184#issuecomment-222454583. | 
| |/ / |  | 
| | | 
| | 
| | 
| | 
| | 
| | | - These initializers are new defaults for Rails 5 and newly generated
  apps do not need to change them.
- Fixes #25181 | 
| |\ \  
| | | 
| | | | Remove public/ files for API apps | 
| | | | 
| | | 
| | | 
| | | | - Fixes #25180 | 
| | | | |  | 
| | | | 
| | | 
| | | 
| | | | second is now irrelevant with the dedicated API mode | 
| |/ / |  | 
| |\ \  
| | | 
| | | | Use RAILS_MAX_THREADS as pool size on all adapters | 
| | | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | 
| | | | When RAILS_MAX_THREADS is set, the postgresql adapter uses it as the
connection pool size, so that there are always enough connections
available to serve Action Cable requests.
The same logic applies when using any other adapter. | 
| | | | |  | 
| |\ \ \  
| | | | 
| | | | | Un-hide helper and assets options for controller generator | 
| | | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | 
| | | | | These options were hidden via 9b36cf0fa4cbdcb2e2072ef1b8179a98b13efce3,
but these options have tests written for them, and I believe that they
are supposed to be public API.
Fixes #24168. | 
| | | | | 
| | | | 
| | | | 
| | | | | environments | 
| | |/ /  
|/| |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | |   
| | | | javascript engine of the application
- Now we will detect what javascript engine user is using and based on
  that we will generate either `.js` or `.coffee` version of the channel
  file.
- This also needs a change in coffee-rails to override the `js_template`
  method. Related PR https://github.com/rails/coffee-rails/pull/72.
- Currently coffee-rails gem sets
  `config.app_generators.javascript_engine` to `:coffee` and using this
  information we override the `js_template` to set the extension as
  `.coffee` in coffee-rails gem.
- Using this approach, we can keep the `channel.js` and `channel.coffee`
  files in the Rails repository itself.
- Additionally the `js_template` method can act as public interface for
  coffee-rails gem to hook into and change the extension to `.coffee`
  without maintaining the actual asset files.
[Prathamesh Sonpatki, Matthew Draper] | 
| | |/  
|/|   
| |   
| | | Conventionally envs are ordered development -> test -> production. | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | In Ruby 2.4 the `to_time` method for both `DateTime` and `Time` will
preserve the timezone of the receiver when converting to an instance
of `Time`. Since Rails 5.0 will support Ruby 2.2, 2.3 and later we
need to introduce a compatibility layer so that apps that upgrade do
not break. New apps will have a config initializer file that defaults
to match the new Ruby 2.4 behavior going forward.
For information about the changes to Ruby see:
https://bugs.ruby-lang.org/issues/12189
https://bugs.ruby-lang.org/issues/12271
Fixes #24617. | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | `bundler` provides wrapper file to add rask tasks.
https://github.com/bundler/bundler/blob/master/lib/bundler/gem_tasks.rb
Instead of directly call method, by which require this file,
it can be used without updating of Rakefile if task has been added. | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | 
| | | With the exception of what is loaded in active_support/rails,
each file is responsible for its own dependencies. You cannot
rely on runtime order of execution. | 
| | | 
| | 
| | 
| | 
| | 
| | | * Updated syntax
* Updated tests to match syntax | 
| | | |  | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | When generating a plugin without ActiveRecord (-O),
ActionCable wasn't include, which causes problems with the
require action_cable statement in cable.js
add active_job require statement
also updated order of require statements to match with all.rb | 
| | | |  | 
| | | |  | 
| |/  
|   
|   
|   
|   
| | The logger interface to get all Rails features is not obvious. This change adds documentation on how to assign a logger that will use all Rails features.
We are also matching the stdout logging interface to the default logger in bootstrap https://github.com/rails/rails/blob/f5a5988352b165143f0f9d622707c351c1470882/railties/lib/rails/application/bootstrap.rb#L42-L45. | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | This commit comes from the comments made by @matthewd at https://github.com/rails/rails/pull/23795/files#r54469637
and by @rafaelfranca at https://github.com/rails/rails/pull/23795/files#r54609364
The idea is that if you type (for example) "rake db:migrate" in an AppGenerator,
then this should actually invoke `rake db:migrate` on the command line, whereas
if you type "rails_command db:migrate", this should invoke `rails db:migrate`. | 
| |\  
| | 
| | | Remove redundant regexp escapes in generators | 
| | | |  | 
| | | 
| | 
| | 
| | 
| | 
| | 
| | 
| | 
| | | In the latest version of Web Console, you can call `console` anywhere in
your application and get a console with that binding in it. I think this
is worth advertising, as it may be useful to do outside of controllers
and views.
[ci skip] | 
| |/  
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
|   
| | Between major versions 2 and 3, we hit a bug. It's fixed in version 3,
however, the explicit 2.x requirement of `~> '2.0'` will prevent people
from getting the fix with `bundle update` and they would have to
explicitly set the constraint to `~> '3.0'`.
For more information see: rails/web-console#178.
I propose we drop the explicit version constraints in the Gemfile. Web
Console has been relatively stable for the past couple of years, and I
don't anticipate any major alterations, like we saw between major
versions 1 and 2. |