railties 4.2.11.3 → 5.0.0.beta1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/CHANGELOG.md +262 -206
- data/MIT-LICENSE +20 -0
- data/README.rdoc +1 -1
- data/{bin → exe}/rails +0 -0
- data/lib/rails.rb +19 -1
- data/lib/rails/all.rb +10 -9
- data/lib/rails/api/task.rb +7 -14
- data/lib/rails/{app_rails_loader.rb → app_loader.rb} +4 -3
- data/lib/rails/application.rb +31 -41
- data/lib/rails/application/bootstrap.rb +1 -14
- data/lib/rails/application/configuration.rb +94 -95
- data/lib/rails/application/default_middleware_stack.rb +30 -16
- data/lib/rails/application/finisher.rb +11 -2
- data/lib/rails/application/routes_reloader.rb +1 -3
- data/lib/rails/application_controller.rb +1 -1
- data/lib/rails/cli.rb +2 -2
- data/lib/rails/code_statistics.rb +6 -8
- data/lib/rails/code_statistics_calculator.rb +8 -1
- data/lib/rails/command.rb +70 -0
- data/lib/rails/commands.rb +5 -3
- data/lib/rails/commands/commands_tasks.rb +25 -14
- data/lib/rails/commands/console.rb +7 -52
- data/lib/rails/commands/console_helper.rb +34 -0
- data/lib/rails/commands/dbconsole.rb +59 -78
- data/lib/rails/commands/dev_cache.rb +21 -0
- data/lib/rails/commands/plugin.rb +1 -1
- data/lib/rails/commands/rake_proxy.rb +34 -0
- data/lib/rails/commands/runner.rb +0 -1
- data/lib/rails/commands/server.rb +29 -36
- data/lib/rails/commands/test.rb +9 -0
- data/lib/rails/configuration.rb +21 -5
- data/lib/rails/console/app.rb +5 -0
- data/lib/rails/console/helpers.rb +1 -1
- data/lib/rails/engine.rb +68 -58
- data/lib/rails/engine/commands.rb +4 -2
- data/lib/rails/engine/configuration.rb +4 -10
- data/lib/rails/gem_version.rb +4 -4
- data/lib/rails/generators.rb +30 -7
- data/lib/rails/generators/.named_base.rb.swp +0 -0
- data/lib/rails/generators/actions.rb +19 -5
- data/lib/rails/generators/app_base.rb +65 -45
- data/lib/rails/generators/base.rb +6 -6
- data/lib/rails/generators/erb/mailer/mailer_generator.rb +5 -8
- data/lib/rails/generators/erb/scaffold/templates/_form.html.erb +9 -7
- data/lib/rails/generators/erb/scaffold/templates/edit.html.erb +1 -1
- data/lib/rails/generators/erb/scaffold/templates/index.html.erb +2 -2
- data/lib/rails/generators/erb/scaffold/templates/new.html.erb +1 -1
- data/lib/rails/generators/generated_attribute.rb +5 -1
- data/lib/rails/generators/migration.rb +7 -7
- data/lib/rails/generators/named_base.rb +21 -5
- data/lib/rails/generators/rails/app/USAGE +0 -1
- data/lib/rails/generators/rails/app/app_generator.rb +75 -11
- data/lib/rails/generators/rails/app/templates/Gemfile +17 -13
- data/lib/rails/generators/rails/app/templates/{README.rdoc → README.md} +1 -5
- data/lib/rails/generators/rails/app/templates/app/assets/config/manifest.js.tt +7 -0
- data/lib/rails/generators/rails/app/templates/app/assets/javascripts/application.js.tt +1 -1
- data/lib/rails/generators/rails/app/templates/app/assets/javascripts/cable.coffee +11 -0
- data/lib/rails/generators/rails/app/templates/app/assets/stylesheets/application.css +3 -3
- data/lib/rails/generators/rails/app/templates/app/channels/application_cable/channel.rb +5 -0
- data/lib/rails/generators/rails/app/templates/app/channels/application_cable/connection.rb +5 -0
- data/lib/rails/generators/rails/app/templates/app/controllers/application_controller.rb.tt +3 -1
- data/lib/rails/generators/rails/app/templates/app/jobs/application_job.rb +2 -0
- data/lib/rails/generators/rails/app/templates/app/mailers/application_mailer.rb +4 -0
- data/lib/rails/generators/rails/app/templates/app/models/application_record.rb +3 -0
- data/lib/rails/generators/rails/app/templates/app/views/layouts/application.html.erb.tt +20 -17
- data/lib/rails/generators/rails/app/templates/app/views/layouts/mailer.html.erb.tt +13 -0
- data/lib/rails/generators/{erb/mailer/templates/layout.text.erb → rails/app/templates/app/views/layouts/mailer.text.erb.tt} +0 -0
- data/lib/rails/generators/rails/app/templates/bin/setup +17 -12
- data/lib/rails/generators/rails/app/templates/bin/update +28 -0
- data/lib/rails/generators/rails/app/templates/config.ru.tt +11 -0
- data/lib/rails/generators/rails/app/templates/config/application.rb +9 -14
- data/lib/rails/generators/rails/app/templates/config/databases/jdbcmysql.yml +1 -1
- data/lib/rails/generators/rails/app/templates/config/databases/mysql.yml +2 -2
- data/lib/rails/generators/rails/app/templates/config/environments/development.rb.tt +20 -3
- data/lib/rails/generators/rails/app/templates/config/environments/production.rb.tt +18 -11
- data/lib/rails/generators/rails/app/templates/config/environments/test.rb.tt +7 -3
- data/lib/rails/generators/rails/app/templates/config/initializers/active_record_belongs_to_required_by_default.rb +5 -0
- data/lib/rails/generators/rails/app/templates/config/initializers/application_controller_renderer.rb +6 -0
- data/lib/rails/generators/rails/app/templates/config/initializers/callback_terminator.rb +5 -0
- data/lib/rails/generators/rails/app/templates/config/initializers/cookies_serializer.rb +1 -0
- data/lib/rails/generators/rails/app/templates/config/initializers/cors.rb +16 -0
- data/lib/rails/generators/rails/app/templates/config/initializers/request_forgery_protection.rb +4 -0
- data/lib/rails/generators/rails/app/templates/config/initializers/wrap_parameters.rb.tt +2 -2
- data/lib/rails/generators/rails/app/templates/config/redis/cable.yml +9 -0
- data/lib/rails/generators/rails/app/templates/config/routes.rb +3 -53
- data/lib/rails/generators/rails/app/templates/db/seeds.rb.tt +3 -3
- data/lib/rails/generators/rails/app/templates/gitignore +7 -1
- data/lib/rails/generators/rails/controller/controller_generator.rb +6 -4
- data/lib/rails/generators/rails/migration/migration_generator.rb +1 -1
- data/lib/rails/generators/rails/model/USAGE +6 -1
- data/lib/rails/generators/rails/model/model_generator.rb +1 -1
- data/lib/rails/generators/rails/plugin/plugin_generator.rb +88 -35
- data/lib/rails/generators/rails/plugin/templates/%name%.gemspec +6 -9
- data/lib/rails/generators/rails/plugin/templates/Gemfile +3 -7
- data/lib/rails/generators/rails/plugin/templates/README.md +3 -0
- data/lib/rails/generators/rails/plugin/templates/Rakefile +2 -2
- data/lib/rails/generators/rails/plugin/templates/app/controllers/%namespaced_name%/application_controller.rb.tt +5 -0
- data/lib/rails/generators/rails/plugin/templates/app/helpers/%namespaced_name%/application_helper.rb.tt +5 -0
- data/lib/rails/generators/rails/plugin/templates/app/jobs/%namespaced_name%/application_job.rb.tt +5 -0
- data/lib/rails/generators/rails/plugin/templates/app/models/application_record.rb.tt +6 -0
- data/lib/rails/generators/rails/plugin/templates/app/views/layouts/%namespaced_name%/application.html.erb.tt +14 -0
- data/lib/rails/generators/rails/plugin/templates/bin/rails.tt +1 -1
- data/lib/rails/generators/rails/plugin/templates/bin/test.tt +8 -0
- data/lib/rails/generators/rails/plugin/templates/config/routes.rb +1 -1
- data/lib/rails/generators/rails/plugin/templates/gitignore +2 -3
- data/lib/rails/generators/rails/plugin/templates/lib/%namespaced_name%.rb +5 -0
- data/lib/rails/generators/rails/plugin/templates/lib/%namespaced_name%/engine.rb +7 -0
- data/lib/rails/generators/rails/plugin/templates/lib/%namespaced_name%/version.rb +1 -0
- data/lib/rails/generators/rails/plugin/templates/lib/tasks/{%name%_tasks.rake → %namespaced_name%_tasks.rake} +1 -1
- data/lib/rails/generators/rails/plugin/templates/rails/application.rb +3 -3
- data/lib/rails/generators/rails/plugin/templates/rails/dummy_manifest.js +11 -0
- data/lib/rails/generators/rails/plugin/templates/rails/engine_manifest.js +6 -0
- data/lib/rails/generators/rails/plugin/templates/rails/javascripts.js +1 -1
- data/lib/rails/generators/rails/plugin/templates/rails/routes.rb +1 -2
- data/lib/rails/generators/rails/plugin/templates/rails/stylesheets.css +3 -3
- data/lib/rails/generators/rails/plugin/templates/test/%namespaced_name%_test.rb +7 -0
- data/lib/rails/generators/rails/plugin/templates/test/test_helper.rb +4 -2
- data/lib/rails/generators/rails/resource/resource_generator.rb +0 -1
- data/lib/rails/generators/rails/resource_route/resource_route_generator.rb +0 -1
- data/lib/rails/generators/rails/scaffold/USAGE +1 -1
- data/lib/rails/generators/rails/scaffold/scaffold_generator.rb +2 -1
- data/lib/rails/generators/rails/scaffold/templates/scaffold.css +35 -7
- data/lib/rails/generators/rails/scaffold_controller/scaffold_controller_generator.rb +4 -1
- data/lib/rails/generators/rails/scaffold_controller/templates/api_controller.rb +61 -0
- data/lib/rails/generators/rails/scaffold_controller/templates/controller.rb +1 -1
- data/lib/rails/generators/resource_helpers.rb +3 -3
- data/lib/rails/generators/test_unit/controller/templates/.functional_test.rb.swp +0 -0
- data/lib/rails/generators/test_unit/controller/templates/functional_test.rb +3 -5
- data/lib/rails/generators/test_unit/mailer/mailer_generator.rb +8 -3
- data/lib/rails/generators/test_unit/mailer/templates/functional_test.rb +2 -2
- data/lib/rails/generators/test_unit/mailer/templates/preview.rb +4 -4
- data/lib/rails/generators/test_unit/model/model_generator.rb +1 -1
- data/lib/rails/generators/test_unit/model/templates/fixtures.yml +2 -0
- data/lib/rails/generators/test_unit/scaffold/scaffold_generator.rb +5 -1
- data/lib/rails/generators/test_unit/scaffold/templates/.api_functional_test.rb.swp +0 -0
- data/lib/rails/generators/test_unit/scaffold/templates/.functional_test.rb.swp +0 -0
- data/lib/rails/generators/test_unit/scaffold/templates/api_functional_test.rb +44 -0
- data/lib/rails/generators/test_unit/scaffold/templates/functional_test.rb +14 -14
- data/lib/rails/generators/testing/assertions.rb +0 -2
- data/lib/rails/generators/testing/behaviour.rb +4 -17
- data/lib/rails/info.rb +2 -2
- data/lib/rails/info_controller.rb +23 -2
- data/lib/rails/mailers_controller.rb +2 -2
- data/lib/rails/paths.rb +14 -6
- data/lib/rails/rack.rb +1 -3
- data/lib/rails/rack/debugger.rb +2 -23
- data/lib/rails/rack/logger.rb +4 -0
- data/lib/rails/ruby_version_check.rb +3 -3
- data/lib/rails/source_annotation_extractor.rb +1 -1
- data/lib/rails/tasks.rb +4 -1
- data/lib/rails/tasks/engine.rake +1 -1
- data/lib/rails/tasks/framework.rake +18 -16
- data/lib/rails/tasks/initializers.rake +6 -0
- data/lib/rails/tasks/restart.rake +5 -0
- data/lib/rails/tasks/statistics.rake +5 -6
- data/lib/rails/tasks/tmp.rake +4 -12
- data/lib/rails/templates/rails/mailers/email.html.erb +17 -3
- data/lib/rails/templates/rails/welcome/index.html.erb +10 -3
- data/lib/rails/test_help.rb +7 -8
- data/lib/rails/test_unit/minitest_plugin.rb +91 -0
- data/lib/rails/test_unit/reporter.rb +74 -0
- data/lib/rails/test_unit/test_requirer.rb +28 -0
- data/lib/rails/test_unit/testing.rake +18 -39
- metadata +80 -33
- data/lib/rails/deprecation.rb +0 -19
- data/lib/rails/generators/erb/mailer/templates/layout.html.erb +0 -5
- data/lib/rails/generators/rails/app/templates/config.ru +0 -4
- data/lib/rails/generators/rails/app/templates/config/initializers/to_time_preserves_timezone.rb +0 -10
- data/lib/rails/generators/rails/plugin/templates/README.rdoc +0 -3
- data/lib/rails/generators/rails/plugin/templates/app/controllers/%name%/application_controller.rb.tt +0 -5
- data/lib/rails/generators/rails/plugin/templates/app/helpers/%name%/application_helper.rb.tt +0 -4
- data/lib/rails/generators/rails/plugin/templates/app/views/layouts/%name%/application.html.erb.tt +0 -14
- data/lib/rails/generators/rails/plugin/templates/lib/%name%.rb +0 -6
- data/lib/rails/generators/rails/plugin/templates/lib/%name%/engine.rb +0 -7
- data/lib/rails/generators/rails/plugin/templates/lib/%name%/version.rb +0 -3
- data/lib/rails/generators/rails/plugin/templates/test/%name%_test.rb +0 -7
- data/lib/rails/rack/log_tailer.rb +0 -38
- data/lib/rails/tasks/documentation.rake +0 -70
- data/lib/rails/test_unit/sub_test_task.rb +0 -126
@@ -1,11 +1,11 @@
|
|
1
1
|
<% module_namespacing do -%>
|
2
|
-
# Preview all emails at http://localhost:3000/rails/mailers/<%= file_path %>
|
3
|
-
class <%= class_name %>
|
2
|
+
# Preview all emails at http://localhost:3000/rails/mailers/<%= file_path %>_mailer
|
3
|
+
class <%= class_name %>MailerPreview < ActionMailer::Preview
|
4
4
|
<% actions.each do |action| -%>
|
5
5
|
|
6
|
-
# Preview this email at http://localhost:3000/rails/mailers/<%= file_path
|
6
|
+
# Preview this email at http://localhost:3000/rails/mailers/<%= file_path %>_mailer/<%= action %>
|
7
7
|
def <%= action %>
|
8
|
-
<%= class_name
|
8
|
+
<%= class_name %>Mailer.<%= action %>
|
9
9
|
end
|
10
10
|
<% end -%>
|
11
11
|
|
@@ -19,7 +19,7 @@ module TestUnit # :nodoc:
|
|
19
19
|
|
20
20
|
def create_fixture_file
|
21
21
|
if options[:fixture] && options[:fixture_replacement].nil?
|
22
|
-
template 'fixtures.yml', File.join('test/fixtures', class_path, "#{
|
22
|
+
template 'fixtures.yml', File.join('test/fixtures', class_path, "#{fixture_file_name}.yml")
|
23
23
|
end
|
24
24
|
end
|
25
25
|
|
@@ -5,6 +5,8 @@
|
|
5
5
|
<% attributes.each do |attribute| -%>
|
6
6
|
<%- if attribute.password_digest? -%>
|
7
7
|
password_digest: <%%= BCrypt::Password.create('secret') %>
|
8
|
+
<%- elsif attribute.reference? -%>
|
9
|
+
<%= yaml_key_value(attribute.column_name.sub(/_id$/, ''), attribute.default) %>
|
8
10
|
<%- else -%>
|
9
11
|
<%= yaml_key_value(attribute.column_name, attribute.default) %>
|
10
12
|
<%- end -%>
|
@@ -8,10 +8,14 @@ module TestUnit # :nodoc:
|
|
8
8
|
|
9
9
|
check_class_collision suffix: "ControllerTest"
|
10
10
|
|
11
|
+
class_option :api, type: :boolean,
|
12
|
+
desc: "Generates API functional tests"
|
13
|
+
|
11
14
|
argument :attributes, type: :array, default: [], banner: "field:type field:type"
|
12
15
|
|
13
16
|
def create_test_files
|
14
|
-
|
17
|
+
template_file = options.api? ? "api_functional_test.rb" : "functional_test.rb"
|
18
|
+
template template_file,
|
15
19
|
File.join("test/controllers", controller_class_path, "#{controller_file_name}_controller_test.rb")
|
16
20
|
end
|
17
21
|
|
Binary file
|
@@ -0,0 +1,44 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
<% module_namespacing do -%>
|
4
|
+
class <%= controller_class_name %>ControllerTest < ActionDispatch::IntegrationTest
|
5
|
+
<%- if mountable_engine? -%>
|
6
|
+
include Engine.routes.url_helpers
|
7
|
+
|
8
|
+
<%- end -%>
|
9
|
+
setup do
|
10
|
+
@<%= singular_table_name %> = <%= fixture_name %>(:one)
|
11
|
+
end
|
12
|
+
|
13
|
+
test "should get index" do
|
14
|
+
get <%= index_helper %>_url
|
15
|
+
assert_response :success
|
16
|
+
end
|
17
|
+
|
18
|
+
test "should create <%= singular_table_name %>" do
|
19
|
+
assert_difference('<%= class_name %>.count') do
|
20
|
+
post <%= index_helper %>_url, params: { <%= "#{singular_table_name}: { #{attributes_hash} }" %> }
|
21
|
+
end
|
22
|
+
|
23
|
+
assert_response 201
|
24
|
+
end
|
25
|
+
|
26
|
+
test "should show <%= singular_table_name %>" do
|
27
|
+
get <%= show_helper %>
|
28
|
+
assert_response :success
|
29
|
+
end
|
30
|
+
|
31
|
+
test "should update <%= singular_table_name %>" do
|
32
|
+
patch <%= show_helper %>, params: { <%= "#{singular_table_name}: { #{attributes_hash} }" %> }
|
33
|
+
assert_response 200
|
34
|
+
end
|
35
|
+
|
36
|
+
test "should destroy <%= singular_table_name %>" do
|
37
|
+
assert_difference('<%= class_name %>.count', -1) do
|
38
|
+
delete <%= show_helper %>
|
39
|
+
end
|
40
|
+
|
41
|
+
assert_response 204
|
42
|
+
end
|
43
|
+
end
|
44
|
+
<% end -%>
|
@@ -1,51 +1,51 @@
|
|
1
1
|
require 'test_helper'
|
2
2
|
|
3
3
|
<% module_namespacing do -%>
|
4
|
-
class <%= controller_class_name %>ControllerTest <
|
4
|
+
class <%= controller_class_name %>ControllerTest < ActionDispatch::IntegrationTest
|
5
|
+
<%- if mountable_engine? -%>
|
6
|
+
include Engine.routes.url_helpers
|
7
|
+
|
8
|
+
<%- end -%>
|
5
9
|
setup do
|
6
10
|
@<%= singular_table_name %> = <%= fixture_name %>(:one)
|
7
|
-
<% if mountable_engine? -%>
|
8
|
-
@routes = Engine.routes
|
9
|
-
<% end -%>
|
10
11
|
end
|
11
12
|
|
12
13
|
test "should get index" do
|
13
|
-
get
|
14
|
+
get <%= index_helper %>_url
|
14
15
|
assert_response :success
|
15
|
-
assert_not_nil assigns(:<%= table_name %>)
|
16
16
|
end
|
17
17
|
|
18
18
|
test "should get new" do
|
19
|
-
get
|
19
|
+
get <%= new_helper %>
|
20
20
|
assert_response :success
|
21
21
|
end
|
22
22
|
|
23
23
|
test "should create <%= singular_table_name %>" do
|
24
24
|
assert_difference('<%= class_name %>.count') do
|
25
|
-
post
|
25
|
+
post <%= index_helper %>_url, params: { <%= "#{singular_table_name}: { #{attributes_hash} }" %> }
|
26
26
|
end
|
27
27
|
|
28
|
-
assert_redirected_to <%= singular_table_name %>_path(
|
28
|
+
assert_redirected_to <%= singular_table_name %>_path(<%= class_name %>.last)
|
29
29
|
end
|
30
30
|
|
31
31
|
test "should show <%= singular_table_name %>" do
|
32
|
-
get
|
32
|
+
get <%= show_helper %>
|
33
33
|
assert_response :success
|
34
34
|
end
|
35
35
|
|
36
36
|
test "should get edit" do
|
37
|
-
get
|
37
|
+
get <%= edit_helper %>
|
38
38
|
assert_response :success
|
39
39
|
end
|
40
40
|
|
41
41
|
test "should update <%= singular_table_name %>" do
|
42
|
-
patch
|
43
|
-
assert_redirected_to <%= singular_table_name %>_path(
|
42
|
+
patch <%= show_helper %>, params: { <%= "#{singular_table_name}: { #{attributes_hash} }" %> }
|
43
|
+
assert_redirected_to <%= singular_table_name %>_path(<%= "@#{singular_table_name}" %>)
|
44
44
|
end
|
45
45
|
|
46
46
|
test "should destroy <%= singular_table_name %>" do
|
47
47
|
assert_difference('<%= class_name %>.count', -1) do
|
48
|
-
delete
|
48
|
+
delete <%= show_helper %>
|
49
49
|
end
|
50
50
|
|
51
51
|
assert_redirected_to <%= index_helper %>_path
|
@@ -2,6 +2,7 @@ require 'active_support/core_ext/class/attribute'
|
|
2
2
|
require 'active_support/core_ext/module/delegation'
|
3
3
|
require 'active_support/core_ext/hash/reverse_merge'
|
4
4
|
require 'active_support/core_ext/kernel/reporting'
|
5
|
+
require 'active_support/testing/stream'
|
5
6
|
require 'active_support/concern'
|
6
7
|
require 'rails/generators'
|
7
8
|
|
@@ -10,6 +11,7 @@ module Rails
|
|
10
11
|
module Testing
|
11
12
|
module Behaviour
|
12
13
|
extend ActiveSupport::Concern
|
14
|
+
include ActiveSupport::Testing::Stream
|
13
15
|
|
14
16
|
included do
|
15
17
|
class_attribute :destination_root, :current_path, :generator_class, :default_arguments
|
@@ -90,7 +92,8 @@ module Rails
|
|
90
92
|
cd current_path
|
91
93
|
end
|
92
94
|
|
93
|
-
|
95
|
+
# Clears all files and directories in destination.
|
96
|
+
def prepare_destination
|
94
97
|
rm_rf(destination_root)
|
95
98
|
mkdir_p(destination_root)
|
96
99
|
end
|
@@ -101,22 +104,6 @@ module Rails
|
|
101
104
|
Dir.glob("#{dirname}/[0-9]*_*.rb").grep(/\d+_#{file_name}.rb$/).first
|
102
105
|
end
|
103
106
|
|
104
|
-
def capture(stream)
|
105
|
-
stream = stream.to_s
|
106
|
-
captured_stream = Tempfile.new(stream)
|
107
|
-
stream_io = eval("$#{stream}")
|
108
|
-
origin_stream = stream_io.dup
|
109
|
-
stream_io.reopen(captured_stream)
|
110
|
-
|
111
|
-
yield
|
112
|
-
|
113
|
-
stream_io.rewind
|
114
|
-
return captured_stream.read
|
115
|
-
ensure
|
116
|
-
captured_stream.close
|
117
|
-
captured_stream.unlink
|
118
|
-
stream_io.reopen(origin_stream)
|
119
|
-
end
|
120
107
|
end
|
121
108
|
end
|
122
109
|
end
|
data/lib/rails/info.rb
CHANGED
@@ -8,7 +8,7 @@ module Rails
|
|
8
8
|
mattr_accessor :properties
|
9
9
|
class << (@@properties = [])
|
10
10
|
def names
|
11
|
-
map
|
11
|
+
map(&:first)
|
12
12
|
end
|
13
13
|
|
14
14
|
def value_for(property_name)
|
@@ -26,7 +26,7 @@ module Rails
|
|
26
26
|
end
|
27
27
|
|
28
28
|
def to_s
|
29
|
-
column_width = properties.names.map
|
29
|
+
column_width = properties.names.map(&:length).max
|
30
30
|
info = properties.map do |name, value|
|
31
31
|
value = value.join(", ") if value.is_a?(Array)
|
32
32
|
"%-#{column_width}s %s" % [name, value]
|
@@ -17,7 +17,28 @@ class Rails::InfoController < Rails::ApplicationController # :nodoc:
|
|
17
17
|
end
|
18
18
|
|
19
19
|
def routes
|
20
|
-
|
21
|
-
|
20
|
+
if path = params[:path]
|
21
|
+
path = URI.parser.escape path
|
22
|
+
normalized_path = with_leading_slash path
|
23
|
+
render json: {
|
24
|
+
exact: match_route {|it| it.match normalized_path },
|
25
|
+
fuzzy: match_route {|it| it.spec.to_s.match path }
|
26
|
+
}
|
27
|
+
else
|
28
|
+
@routes_inspector = ActionDispatch::Routing::RoutesInspector.new(_routes.routes)
|
29
|
+
@page_title = 'Routes'
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
private
|
34
|
+
|
35
|
+
def match_route
|
36
|
+
_routes.routes.select {|route|
|
37
|
+
yield route.path
|
38
|
+
}.map {|route| route.path.spec.to_s }
|
39
|
+
end
|
40
|
+
|
41
|
+
def with_leading_slash(path)
|
42
|
+
('/' + path).squeeze('/')
|
22
43
|
end
|
23
44
|
end
|
@@ -26,12 +26,12 @@ class Rails::MailersController < Rails::ApplicationController # :nodoc:
|
|
26
26
|
|
27
27
|
if part = find_part(part_type)
|
28
28
|
response.content_type = part_type
|
29
|
-
render
|
29
|
+
render plain: part.respond_to?(:decoded) ? part.decoded : part
|
30
30
|
else
|
31
31
|
raise AbstractController::ActionNotFound, "Email part '#{part_type}' not found in #{@preview.name}##{@email_action}"
|
32
32
|
end
|
33
33
|
else
|
34
|
-
@part = find_preferred_part(request.format, Mime
|
34
|
+
@part = find_preferred_part(request.format, Mime[:html], Mime[:text])
|
35
35
|
render action: 'email', layout: false, formats: %w[html]
|
36
36
|
end
|
37
37
|
else
|
data/lib/rails/paths.rb
CHANGED
@@ -7,7 +7,7 @@ module Rails
|
|
7
7
|
# root = Root.new "/rails"
|
8
8
|
# root.add "app/controllers", eager_load: true
|
9
9
|
#
|
10
|
-
# The command above creates a new root object and
|
10
|
+
# The command above creates a new root object and adds "app/controllers" as a path.
|
11
11
|
# This means we can get a <tt>Rails::Paths::Path</tt> object back like below:
|
12
12
|
#
|
13
13
|
# path = root["app/controllers"]
|
@@ -77,23 +77,23 @@ module Rails
|
|
77
77
|
end
|
78
78
|
|
79
79
|
def all_paths
|
80
|
-
values.tap
|
80
|
+
values.tap(&:uniq!)
|
81
81
|
end
|
82
82
|
|
83
83
|
def autoload_once
|
84
|
-
filter_by
|
84
|
+
filter_by(&:autoload_once?)
|
85
85
|
end
|
86
86
|
|
87
87
|
def eager_load
|
88
|
-
filter_by
|
88
|
+
filter_by(&:eager_load?)
|
89
89
|
end
|
90
90
|
|
91
91
|
def autoload_paths
|
92
|
-
filter_by
|
92
|
+
filter_by(&:autoload?)
|
93
93
|
end
|
94
94
|
|
95
95
|
def load_paths
|
96
|
-
filter_by
|
96
|
+
filter_by(&:load_path?)
|
97
97
|
end
|
98
98
|
|
99
99
|
private
|
@@ -123,6 +123,10 @@ module Rails
|
|
123
123
|
options[:load_path] ? load_path! : skip_load_path!
|
124
124
|
end
|
125
125
|
|
126
|
+
def absolute_current # :nodoc:
|
127
|
+
File.expand_path(@current, @root.path)
|
128
|
+
end
|
129
|
+
|
126
130
|
def children
|
127
131
|
keys = @root.keys.find_all { |k|
|
128
132
|
k.start_with?(@current) && k != @current
|
@@ -175,6 +179,10 @@ module Rails
|
|
175
179
|
@paths
|
176
180
|
end
|
177
181
|
|
182
|
+
def extensions # :nodoc:
|
183
|
+
$1.split(',') if @glob =~ /\{([\S]+)\}/
|
184
|
+
end
|
185
|
+
|
178
186
|
# Expands all paths against the root and return all unique values.
|
179
187
|
def expanded
|
180
188
|
raise "You need to set a path root" unless @root.path
|
data/lib/rails/rack.rb
CHANGED
data/lib/rails/rack/debugger.rb
CHANGED
@@ -1,24 +1,3 @@
|
|
1
|
-
|
2
|
-
module Rack
|
3
|
-
class Debugger
|
4
|
-
def initialize(app)
|
5
|
-
@app = app
|
1
|
+
require 'active_support/deprecation'
|
6
2
|
|
7
|
-
|
8
|
-
|
9
|
-
require 'debugger'
|
10
|
-
|
11
|
-
::Debugger.start
|
12
|
-
::Debugger.settings[:autoeval] = true if ::Debugger.respond_to?(:settings)
|
13
|
-
puts "=> Debugger enabled"
|
14
|
-
rescue LoadError
|
15
|
-
puts "You're missing the 'debugger' gem. Add it to your Gemfile, bundle it and try again."
|
16
|
-
exit(1)
|
17
|
-
end
|
18
|
-
|
19
|
-
def call(env)
|
20
|
-
@app.call(env)
|
21
|
-
end
|
22
|
-
end
|
23
|
-
end
|
24
|
-
end
|
3
|
+
ActiveSupport::Deprecation.warn("This file is deprecated and will be removed in Rails 5.1 with no replacement.")
|
data/lib/rails/rack/logger.rb
CHANGED
@@ -7,6 +7,10 @@ require 'rack/body_proxy'
|
|
7
7
|
module Rails
|
8
8
|
module Rack
|
9
9
|
# Sets log tags, logs the request, calls the app, and flushes the logs.
|
10
|
+
#
|
11
|
+
# Log tags (+taggers+) can be an Array containing: methods that the +request+
|
12
|
+
# object responds to, objects that respond to +to_s+ or Proc objects that accept
|
13
|
+
# an instance of the +request+ object.
|
10
14
|
class Logger < ActiveSupport::LogSubscriber
|
11
15
|
def initialize(app, taggers = nil)
|
12
16
|
@app = app
|
@@ -1,13 +1,13 @@
|
|
1
|
-
if RUBY_VERSION < '
|
1
|
+
if RUBY_VERSION < '2.2.2' && RUBY_ENGINE == 'ruby'
|
2
2
|
desc = defined?(RUBY_DESCRIPTION) ? RUBY_DESCRIPTION : "ruby #{RUBY_VERSION} (#{RUBY_RELEASE_DATE})"
|
3
3
|
abort <<-end_message
|
4
4
|
|
5
|
-
Rails
|
5
|
+
Rails 5 requires Ruby 2.2.2 or newer.
|
6
6
|
|
7
7
|
You're running
|
8
8
|
#{desc}
|
9
9
|
|
10
|
-
Please upgrade to Ruby
|
10
|
+
Please upgrade to Ruby 2.2.2 or newer to continue.
|
11
11
|
|
12
12
|
end_message
|
13
13
|
end
|
@@ -3,7 +3,7 @@
|
|
3
3
|
# rake notes
|
4
4
|
# rake notes:optimize
|
5
5
|
#
|
6
|
-
# and friends. See <tt>rake -T notes</tt> and <tt>railties/lib/tasks/annotations.rake</tt>.
|
6
|
+
# and friends. See <tt>rake -T notes</tt> and <tt>railties/lib/rails/tasks/annotations.rake</tt>.
|
7
7
|
#
|
8
8
|
# Annotation objects are triplets <tt>:line</tt>, <tt>:tag</tt>, <tt>:text</tt> that
|
9
9
|
# represent the line where the annotation lives, its tag, and its text. Note
|
data/lib/rails/tasks.rb
CHANGED
data/lib/rails/tasks/engine.rake
CHANGED
@@ -40,7 +40,7 @@ namespace :db do
|
|
40
40
|
desc "Rolls the schema back to the previous version (specify steps w/ STEP=n)."
|
41
41
|
app_task "rollback"
|
42
42
|
|
43
|
-
desc "Create a db/schema.rb file that can be portably used against any DB supported by
|
43
|
+
desc "Create a db/schema.rb file that can be portably used against any DB supported by Active Record"
|
44
44
|
app_task "schema:dump"
|
45
45
|
|
46
46
|
desc "Load a schema.rb file into the database"
|