railties 7.0.8 → 7.1.0.rc1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (165) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +617 -209
  3. data/MIT-LICENSE +1 -1
  4. data/RDOC_MAIN.md +99 -0
  5. data/README.rdoc +4 -4
  6. data/lib/minitest/rails_plugin.rb +63 -0
  7. data/lib/rails/api/task.rb +35 -4
  8. data/lib/rails/app_updater.rb +1 -1
  9. data/lib/rails/application/bootstrap.rb +12 -3
  10. data/lib/rails/application/configuration.rb +179 -67
  11. data/lib/rails/application/default_middleware_stack.rb +8 -2
  12. data/lib/rails/application/dummy_config.rb +19 -0
  13. data/lib/rails/application/finisher.rb +40 -33
  14. data/lib/rails/application.rb +112 -24
  15. data/lib/rails/backtrace_cleaner.rb +1 -1
  16. data/lib/rails/cli.rb +5 -2
  17. data/lib/rails/command/actions.rb +10 -12
  18. data/lib/rails/command/base.rb +55 -53
  19. data/lib/rails/command/environment_argument.rb +32 -16
  20. data/lib/rails/command/helpers/editor.rb +17 -12
  21. data/lib/rails/command.rb +84 -33
  22. data/lib/rails/commands/about/about_command.rb +14 -0
  23. data/lib/rails/commands/application/application_command.rb +2 -0
  24. data/lib/rails/commands/console/console_command.rb +14 -14
  25. data/lib/rails/commands/credentials/USAGE +53 -55
  26. data/lib/rails/commands/credentials/credentials_command/diffing.rb +5 -3
  27. data/lib/rails/commands/credentials/credentials_command.rb +64 -70
  28. data/lib/rails/commands/db/system/change/change_command.rb +2 -1
  29. data/lib/rails/commands/dbconsole/dbconsole_command.rb +25 -115
  30. data/lib/rails/commands/destroy/destroy_command.rb +3 -2
  31. data/lib/rails/commands/dev/dev_command.rb +1 -6
  32. data/lib/rails/commands/encrypted/USAGE +15 -20
  33. data/lib/rails/commands/encrypted/encrypted_command.rb +46 -35
  34. data/lib/rails/commands/gem_help/USAGE +16 -0
  35. data/lib/rails/commands/gem_help/gem_help_command.rb +13 -0
  36. data/lib/rails/commands/generate/generate_command.rb +2 -2
  37. data/lib/rails/commands/help/USAGE +13 -13
  38. data/lib/rails/commands/help/help_command.rb +21 -2
  39. data/lib/rails/commands/initializers/initializers_command.rb +1 -4
  40. data/lib/rails/commands/middleware/middleware_command.rb +17 -0
  41. data/lib/rails/commands/new/new_command.rb +2 -0
  42. data/lib/rails/commands/notes/notes_command.rb +2 -1
  43. data/lib/rails/commands/plugin/plugin_command.rb +2 -0
  44. data/lib/rails/commands/rake/rake_command.rb +25 -22
  45. data/lib/rails/commands/restart/restart_command.rb +14 -0
  46. data/lib/rails/commands/routes/routes_command.rb +13 -1
  47. data/lib/rails/commands/runner/USAGE +14 -12
  48. data/lib/rails/commands/runner/runner_command.rb +32 -20
  49. data/lib/rails/commands/secret/secret_command.rb +13 -0
  50. data/lib/rails/commands/secrets/USAGE +44 -49
  51. data/lib/rails/commands/secrets/secrets_command.rb +19 -38
  52. data/lib/rails/commands/server/server_command.rb +33 -32
  53. data/lib/rails/commands/test/USAGE +14 -0
  54. data/lib/rails/commands/test/test_command.rb +56 -14
  55. data/lib/rails/commands/unused_routes/unused_routes_command.rb +75 -0
  56. data/lib/rails/commands/version/version_command.rb +1 -0
  57. data/lib/rails/configuration.rb +5 -5
  58. data/lib/rails/console/app.rb +1 -4
  59. data/lib/rails/deprecator.rb +7 -0
  60. data/lib/rails/engine/configuration.rb +5 -0
  61. data/lib/rails/engine.rb +32 -11
  62. data/lib/rails/gem_version.rb +4 -4
  63. data/lib/rails/generators/actions.rb +6 -15
  64. data/lib/rails/generators/active_model.rb +2 -2
  65. data/lib/rails/generators/app_base.rb +354 -83
  66. data/lib/rails/generators/app_name.rb +3 -14
  67. data/lib/rails/generators/base.rb +12 -4
  68. data/lib/rails/generators/database.rb +39 -1
  69. data/lib/rails/generators/erb/mailer/templates/layout.html.erb.tt +1 -1
  70. data/lib/rails/generators/generated_attribute.rb +12 -0
  71. data/lib/rails/generators/migration.rb +1 -2
  72. data/lib/rails/generators/model_helpers.rb +2 -1
  73. data/lib/rails/generators/rails/app/USAGE +22 -6
  74. data/lib/rails/generators/rails/app/app_generator.rb +84 -60
  75. data/lib/rails/generators/rails/app/templates/Dockerfile.tt +103 -0
  76. data/lib/rails/generators/rails/app/templates/Gemfile.tt +9 -11
  77. data/lib/rails/generators/rails/app/templates/app/views/layouts/mailer.html.erb.tt +1 -1
  78. data/lib/rails/generators/rails/app/templates/bin/setup.tt +10 -1
  79. data/lib/rails/generators/rails/app/templates/config/application.rb.tt +6 -17
  80. data/lib/rails/generators/rails/app/templates/config/databases/jdbcsqlite3.yml.tt +3 -3
  81. data/lib/rails/generators/rails/app/templates/config/databases/postgresql.yml.tt +0 -2
  82. data/lib/rails/generators/rails/app/templates/config/databases/sqlite3.yml.tt +3 -3
  83. data/lib/rails/generators/rails/app/templates/config/databases/trilogy.yml.tt +59 -0
  84. data/lib/rails/generators/rails/app/templates/config/environments/development.rb.tt +10 -2
  85. data/lib/rails/generators/rails/app/templates/config/environments/production.rb.tt +28 -24
  86. data/lib/rails/generators/rails/app/templates/config/environments/test.rb.tt +11 -7
  87. data/lib/rails/generators/rails/app/templates/config/initializers/assets.rb.tt +2 -0
  88. data/lib/rails/generators/rails/app/templates/config/initializers/content_security_policy.rb.tt +2 -2
  89. data/lib/rails/generators/rails/app/templates/config/initializers/cors.rb.tt +1 -1
  90. data/lib/rails/generators/rails/app/templates/config/initializers/filter_parameter_logging.rb.tt +3 -3
  91. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_7_1.rb.tt +223 -0
  92. data/lib/rails/generators/rails/app/templates/config/initializers/permissions_policy.rb.tt +11 -9
  93. data/lib/rails/generators/rails/app/templates/config/locales/en.yml +11 -13
  94. data/lib/rails/generators/rails/app/templates/config/puma.rb.tt +11 -19
  95. data/lib/rails/generators/rails/app/templates/config/routes.rb.tt +5 -1
  96. data/lib/rails/generators/rails/app/templates/db/seeds.rb.tt +6 -4
  97. data/lib/rails/generators/rails/app/templates/docker-entrypoint.tt +10 -0
  98. data/lib/rails/generators/rails/app/templates/dockerignore.tt +43 -0
  99. data/lib/rails/generators/rails/app/templates/gitignore.tt +4 -8
  100. data/lib/rails/generators/rails/app/templates/node-version.tt +1 -0
  101. data/lib/rails/generators/rails/app/templates/test/channels/application_cable/connection_test.rb.tt +10 -8
  102. data/lib/rails/generators/rails/app/templates/test/test_helper.rb.tt +9 -7
  103. data/lib/rails/generators/rails/application_record/application_record_generator.rb +4 -0
  104. data/lib/rails/generators/rails/benchmark/benchmark_generator.rb +2 -1
  105. data/lib/rails/generators/rails/controller/USAGE +12 -4
  106. data/lib/rails/generators/rails/controller/controller_generator.rb +5 -0
  107. data/lib/rails/generators/rails/controller/templates/controller.rb.tt +1 -1
  108. data/lib/rails/generators/rails/credentials/credentials_generator.rb +29 -24
  109. data/lib/rails/generators/rails/credentials/templates/credentials.yml.tt +8 -0
  110. data/lib/rails/generators/rails/db/system/change/change_generator.rb +27 -0
  111. data/lib/rails/generators/rails/encryption_key_file/encryption_key_file_generator.rb +1 -2
  112. data/lib/rails/generators/rails/migration/USAGE +21 -11
  113. data/lib/rails/generators/rails/model/model_generator.rb +4 -0
  114. data/lib/rails/generators/rails/plugin/USAGE +17 -6
  115. data/lib/rails/generators/rails/plugin/plugin_generator.rb +5 -15
  116. data/lib/rails/generators/rails/plugin/templates/Gemfile.tt +2 -2
  117. data/lib/rails/generators/rails/plugin/templates/MIT-LICENSE.tt +1 -1
  118. data/lib/rails/generators/rails/plugin/templates/bin/rails.tt +1 -17
  119. data/lib/rails/generators/rails/plugin/templates/gitignore.tt +0 -2
  120. data/lib/rails/generators/rails/plugin/templates/test/test_helper.rb.tt +4 -4
  121. data/lib/rails/generators/rails/resource/resource_generator.rb +6 -0
  122. data/lib/rails/generators/rails/scaffold/scaffold_generator.rb +2 -1
  123. data/lib/rails/generators/rails/scaffold_controller/scaffold_controller_generator.rb +1 -1
  124. data/lib/rails/generators/test_case.rb +2 -2
  125. data/lib/rails/generators/test_unit/scaffold/scaffold_generator.rb +1 -1
  126. data/lib/rails/generators/testing/{behaviour.rb → behavior.rb} +4 -1
  127. data/lib/rails/generators.rb +5 -13
  128. data/lib/rails/health_controller.rb +55 -0
  129. data/lib/rails/info.rb +1 -1
  130. data/lib/rails/info_controller.rb +31 -11
  131. data/lib/rails/mailers_controller.rb +15 -5
  132. data/lib/rails/paths.rb +13 -10
  133. data/lib/rails/rack/logger.rb +15 -12
  134. data/lib/rails/rackup/server.rb +15 -0
  135. data/lib/rails/railtie/configuration.rb +14 -1
  136. data/lib/rails/railtie.rb +18 -18
  137. data/lib/rails/ruby_version_check.rb +2 -0
  138. data/lib/rails/source_annotation_extractor.rb +67 -18
  139. data/lib/rails/tasks/engine.rake +8 -8
  140. data/lib/rails/tasks/framework.rake +4 -10
  141. data/lib/rails/tasks/log.rake +1 -1
  142. data/lib/rails/tasks/misc.rake +3 -14
  143. data/lib/rails/tasks/statistics.rake +5 -4
  144. data/lib/rails/tasks/tmp.rake +5 -5
  145. data/lib/rails/tasks/zeitwerk.rake +1 -1
  146. data/lib/rails/tasks.rb +0 -2
  147. data/lib/rails/templates/rails/mailers/email.html.erb +25 -0
  148. data/lib/rails/templates/rails/mailers/index.html.erb +14 -7
  149. data/lib/rails/templates/rails/mailers/mailer.html.erb +11 -5
  150. data/lib/rails/templates/rails/welcome/index.html.erb +1 -0
  151. data/lib/rails/test_help.rb +7 -7
  152. data/lib/rails/test_unit/line_filtering.rb +1 -1
  153. data/lib/rails/test_unit/reporter.rb +6 -2
  154. data/lib/rails/test_unit/runner.rb +36 -18
  155. data/lib/rails/test_unit/test_parser.rb +88 -0
  156. data/lib/rails/test_unit/testing.rake +13 -33
  157. data/lib/rails/version.rb +1 -1
  158. data/lib/rails.rb +15 -15
  159. metadata +65 -30
  160. data/RDOC_MAIN.rdoc +0 -97
  161. data/lib/rails/application/dummy_erb_compiler.rb +0 -18
  162. data/lib/rails/generators/rails/app/templates/config/initializers/new_framework_defaults_7_0.rb.tt +0 -143
  163. data/lib/rails/generators/rails/model/USAGE +0 -113
  164. data/lib/rails/tasks/middleware.rake +0 -9
  165. data/lib/rails/tasks/restart.rake +0 -9
@@ -3,6 +3,7 @@
3
3
  module Rails
4
4
  module Command
5
5
  class VersionCommand < Base # :nodoc:
6
+ desc "version", "Show the Rails version"
6
7
  def perform
7
8
  Rails::Command.invoke :application, [ "--version" ]
8
9
  end
@@ -7,17 +7,17 @@ require "rails/rack"
7
7
 
8
8
  module Rails
9
9
  module Configuration
10
- # MiddlewareStackProxy is a proxy for the Rails middleware stack that allows
10
+ # MiddlewareStackProxy is a proxy for the \Rails middleware stack that allows
11
11
  # you to configure middlewares in your application. It works basically as a
12
12
  # command recorder, saving each command to be applied after initialization
13
13
  # over the default middleware stack, so you can add, swap, or remove any
14
- # middleware in Rails.
14
+ # middleware in \Rails.
15
15
  #
16
16
  # You can add your own middlewares by using the +config.middleware.use+ method:
17
17
  #
18
18
  # config.middleware.use Magical::Unicorns
19
19
  #
20
- # This will put the <tt>Magical::Unicorns</tt> middleware on the end of the stack.
20
+ # This will put the +Magical::Unicorns+ middleware on the end of the stack.
21
21
  # You can use +insert_before+ if you wish to add a middleware before another:
22
22
  #
23
23
  # config.middleware.insert_before Rack::Head, Magical::Unicorns
@@ -34,8 +34,8 @@ module Rails
34
34
  #
35
35
  # config.middleware.move_before ActionDispatch::Flash, Magical::Unicorns
36
36
  #
37
- # This will move the <tt>Magical::Unicorns</tt> middleware before the
38
- # <tt>ActionDispatch::Flash</tt>. You can also move it after:
37
+ # This will move the +Magical::Unicorns+ middleware before the
38
+ # +ActionDispatch::Flash+. You can also move it after:
39
39
  #
40
40
  # config.middleware.move_after ActionDispatch::Flash, Magical::Unicorns
41
41
  #
@@ -9,9 +9,7 @@ module Rails
9
9
  # instance, pass a non-false value as the parameter.
10
10
  def app(create = false)
11
11
  @app_integration_instance = nil if create
12
- @app_integration_instance ||= new_session do |sess|
13
- sess.host! "www.example.com"
14
- end
12
+ @app_integration_instance ||= new_session
15
13
  end
16
14
 
17
15
  # create a new session. If a block is given, the new session will be yielded
@@ -19,7 +17,6 @@ module Rails
19
17
  def new_session
20
18
  app = Rails.application
21
19
  session = ActionDispatch::Integration::Session.new(app)
22
- yield session if block_given?
23
20
 
24
21
  # This makes app.url_for and app.foo_path available in the console
25
22
  session.extend(app.routes.url_helpers)
@@ -0,0 +1,7 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Rails
4
+ def self.deprecator # :nodoc:
5
+ @deprecator ||= ActiveSupport::Deprecation.new
6
+ end
7
+ end
@@ -50,6 +50,9 @@ module Rails
50
50
  paths.add "app/mailers", eager_load: true
51
51
  paths.add "app/views"
52
52
 
53
+ # If you add more lib subdirectories here that should not be managed
54
+ # by the main autoloader, please update the config.autoload_lib call
55
+ # in the template that generates config/application.rb accordingly.
53
56
  paths.add "lib", load_path: true
54
57
  paths.add "lib/assets", glob: "*"
55
58
  paths.add "lib/tasks", glob: "**/*.rake"
@@ -68,6 +71,8 @@ module Rails
68
71
  paths.add "vendor", load_path: true
69
72
  paths.add "vendor/assets", glob: "*"
70
73
 
74
+ paths.add "test/mailers/previews", autoload: true
75
+
71
76
  paths
72
77
  end
73
78
  end
data/lib/rails/engine.rb CHANGED
@@ -9,12 +9,12 @@ require "pathname"
9
9
  require "thread"
10
10
 
11
11
  module Rails
12
- # <tt>Rails::Engine</tt> allows you to wrap a specific Rails application or subset of
12
+ # +Rails::Engine+ allows you to wrap a specific \Rails application or subset of
13
13
  # functionality and share it with other applications or within a larger packaged application.
14
14
  # Every Rails::Application is just an engine, which allows for simple
15
15
  # feature and application sharing.
16
16
  #
17
- # Any <tt>Rails::Engine</tt> is also a Rails::Railtie, so the same
17
+ # Any +Rails::Engine+ is also a Rails::Railtie, so the same
18
18
  # methods (like <tt>rake_tasks</tt> and +generators+) and configuration
19
19
  # options that are available in railties can also be used in engines.
20
20
  #
@@ -181,7 +181,7 @@ module Rails
181
181
  # it's used as default <tt>:as</tt> option
182
182
  # * rake task for installing migrations <tt>my_engine:install:migrations</tt>
183
183
  #
184
- # Engine name is set by default based on class name. For <tt>MyEngine::Engine</tt> it will be
184
+ # Engine name is set by default based on class name. For +MyEngine::Engine+ it will be
185
185
  # <tt>my_engine_engine</tt>. You can change it manually using the <tt>engine_name</tt> method:
186
186
  #
187
187
  # module MyEngine
@@ -231,14 +231,14 @@ module Rails
231
231
  # end
232
232
  #
233
233
  # If +MyEngine+ is isolated, the routes above will point to
234
- # <tt>MyEngine::ArticlesController</tt>. You also don't need to use longer
234
+ # +MyEngine::ArticlesController+. You also don't need to use longer
235
235
  # URL helpers like +my_engine_articles_path+. Instead, you should simply use
236
236
  # +articles_path+, like you would do with your main application.
237
237
  #
238
238
  # To make this behavior consistent with other parts of the framework,
239
239
  # isolated engines also have an effect on ActiveModel::Naming. In a
240
- # normal Rails app, when you use a namespaced model such as
241
- # <tt>Namespace::Article</tt>, ActiveModel::Naming will generate
240
+ # normal \Rails app, when you use a namespaced model such as
241
+ # +Namespace::Article+, ActiveModel::Naming will generate
242
242
  # names with the prefix "namespace". In an isolated engine, the prefix will
243
243
  # be omitted in URL helpers and form fields, for convenience.
244
244
  #
@@ -252,7 +252,7 @@ module Rails
252
252
  # Additionally, an isolated engine will set its own name according to its
253
253
  # namespace, so <tt>MyEngine::Engine.engine_name</tt> will return
254
254
  # "my_engine". It will also set +MyEngine.table_name_prefix+ to "my_engine_",
255
- # meaning for example that <tt>MyEngine::Article</tt> will use the
255
+ # meaning for example that +MyEngine::Article+ will use the
256
256
  # +my_engine_articles+ database table by default.
257
257
  #
258
258
  # == Using Engine's routes outside Engine
@@ -450,7 +450,7 @@ module Rails
450
450
  self
451
451
  end
452
452
 
453
- # Load Rails runner and invoke the registered hooks.
453
+ # Load \Rails runner and invoke the registered hooks.
454
454
  # Check Rails::Railtie.runner for more info.
455
455
  def load_runner(app = self)
456
456
  run_runner_blocks(app)
@@ -465,7 +465,7 @@ module Rails
465
465
  self
466
466
  end
467
467
 
468
- # Load Rails generators and invoke the registered hooks.
468
+ # Load \Rails generators and invoke the registered hooks.
469
469
  # Check Rails::Railtie.generators for more info.
470
470
  def load_generators(app = self)
471
471
  require "rails/generators"
@@ -494,8 +494,7 @@ module Rails
494
494
  def helpers
495
495
  @helpers ||= begin
496
496
  helpers = Module.new
497
- all = ActionController::Base.all_helpers_from_path(helpers_paths)
498
- ActionController::Base.modules_for_helpers(all).each do |mod|
497
+ AbstractController::Helpers.helper_modules_from_paths(helpers_paths).each do |mod|
499
498
  helpers.include(mod)
500
499
  end
501
500
  helpers
@@ -587,6 +586,7 @@ module Rails
587
586
  routing_paths = paths["config/routes.rb"].existent
588
587
  external_paths = self.paths["config/routes"].paths
589
588
  routes.draw_paths.concat(external_paths)
589
+ app.routes.draw_paths.concat(external_paths)
590
590
 
591
591
  if routes? || routing_paths.any?
592
592
  app.routes_reloader.paths.unshift(*routing_paths)
@@ -609,6 +609,22 @@ module Rails
609
609
  end
610
610
  end
611
611
 
612
+ initializer :add_mailer_preview_paths do
613
+ previews = paths["test/mailers/previews"].existent
614
+ unless previews.empty?
615
+ ActiveSupport.on_load(:action_mailer) { self.preview_paths |= previews }
616
+ end
617
+ end
618
+
619
+ initializer :add_fixture_paths do
620
+ next if is_a?(Rails::Application)
621
+
622
+ fixtures = config.root.join("test", "fixtures")
623
+ if fixtures_in_root_and_not_in_vendor?(fixtures)
624
+ ActiveSupport.on_load(:active_record_fixtures) { self.fixture_paths |= ["#{fixtures}/"] }
625
+ end
626
+ end
627
+
612
628
  initializer :prepend_helpers_path do |app|
613
629
  if !isolated? || (app == self)
614
630
  app.config.helpers_paths.unshift(*paths["app/helpers"].existent)
@@ -712,6 +728,11 @@ module Rails
712
728
  end
713
729
  end
714
730
 
731
+ def fixtures_in_root_and_not_in_vendor?(fixtures)
732
+ fixtures.exist? && fixtures.to_s.start_with?(Rails.root.to_s) &&
733
+ !fixtures.to_s.start_with?(Rails.root.join("vendor").to_s)
734
+ end
735
+
715
736
  def build_request(env)
716
737
  env.merge!(env_config)
717
738
  req = ActionDispatch::Request.new env
@@ -1,16 +1,16 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Rails
4
- # Returns the currently loaded version of Rails as a <tt>Gem::Version</tt>.
4
+ # Returns the currently loaded version of \Rails as a +Gem::Version+.
5
5
  def self.gem_version
6
6
  Gem::Version.new VERSION::STRING
7
7
  end
8
8
 
9
9
  module VERSION
10
10
  MAJOR = 7
11
- MINOR = 0
12
- TINY = 8
13
- PRE = nil
11
+ MINOR = 1
12
+ TINY = 0
13
+ PRE = "rc1"
14
14
 
15
15
  STRING = [MAJOR, MINOR, TINY, PRE].compact.join(".")
16
16
  end
@@ -162,7 +162,7 @@ module Rails
162
162
  end
163
163
  end
164
164
 
165
- # Adds configuration code to a Rails runtime environment.
165
+ # Adds configuration code to a \Rails runtime environment.
166
166
  #
167
167
  # By default, adds code inside the +Application+ class in
168
168
  # +config/application.rb+ so that it applies to all environments.
@@ -349,7 +349,7 @@ module Rails
349
349
  # ==== Options
350
350
  #
351
351
  # [+:env+]
352
- # The Rails environment in which to run the task. Defaults to
352
+ # The \Rails environment in which to run the task. Defaults to
353
353
  # <tt>ENV["RAILS_ENV"] || "development"</tt>.
354
354
  #
355
355
  # [+:abort_on_failure+]
@@ -365,7 +365,7 @@ module Rails
365
365
  execute_command :rake, command, options
366
366
  end
367
367
 
368
- # Runs the specified Rails command.
368
+ # Runs the specified \Rails command.
369
369
  #
370
370
  # rails_command "db:migrate"
371
371
  # rails_command "db:migrate", env: "production"
@@ -376,7 +376,7 @@ module Rails
376
376
  # ==== Options
377
377
  #
378
378
  # [+:env+]
379
- # The Rails environment in which to run the command. Defaults to
379
+ # The \Rails environment in which to run the command. Defaults to
380
380
  # <tt>ENV["RAILS_ENV"] || "development"</tt>.
381
381
  #
382
382
  # [+:abort_on_failure+]
@@ -402,7 +402,7 @@ module Rails
402
402
  end
403
403
  end
404
404
 
405
- # Make an entry in Rails routing file <tt>config/routes.rb</tt>
405
+ # Make an entry in \Rails routing file <tt>config/routes.rb</tt>
406
406
  #
407
407
  # route "root 'welcome#index'"
408
408
  # route "root 'admin#index'", namespace: :admin
@@ -468,16 +468,7 @@ module Rails
468
468
  abort_on_failure: options[:abort_on_failure],
469
469
  }
470
470
 
471
- in_root { run("#{sudo}#{extify(executor)} #{command}", config) }
472
- end
473
-
474
- # Add an extension to the given name based on the platform.
475
- def extify(name) # :doc:
476
- if Gem.win_platform?
477
- "#{name}.bat"
478
- else
479
- name
480
- end
471
+ in_root { run("#{sudo}#{Shellwords.escape Gem.ruby} bin/#{executor} #{command}", config) }
481
472
  end
482
473
 
483
474
  # Always returns value in double quotes.
@@ -2,7 +2,7 @@
2
2
 
3
3
  module Rails
4
4
  module Generators
5
- # ActiveModel is a class to be implemented by each ORM to allow Rails to
5
+ # ActiveModel is a class to be implemented by each ORM to allow \Rails to
6
6
  # generate customized controller code.
7
7
  #
8
8
  # The API has the same methods as ActiveRecord, but each method returns a
@@ -73,7 +73,7 @@ module Rails
73
73
 
74
74
  # DELETE destroy
75
75
  def destroy
76
- "#{name}.destroy"
76
+ "#{name}.destroy!"
77
77
  end
78
78
  end
79
79
  end