2010-01-04 20:34:42 -05:00
|
|
|
require 'isolation/abstract_unit'
|
|
|
|
|
|
|
|
module ApplicationTests
|
2012-01-05 20:30:17 -05:00
|
|
|
class MiddlewareTest < ActiveSupport::TestCase
|
2010-01-04 20:34:42 -05:00
|
|
|
include ActiveSupport::Testing::Isolation
|
|
|
|
|
|
|
|
def setup
|
|
|
|
build_app
|
|
|
|
boot_rails
|
|
|
|
FileUtils.rm_rf "#{app_path}/config/environments"
|
|
|
|
end
|
|
|
|
|
2011-06-06 08:54:05 -04:00
|
|
|
def teardown
|
|
|
|
teardown_app
|
|
|
|
end
|
|
|
|
|
2010-04-26 03:04:04 -04:00
|
|
|
def app
|
|
|
|
@app ||= Rails.application
|
|
|
|
end
|
|
|
|
|
2010-01-04 20:34:42 -05:00
|
|
|
test "default middleware stack" do
|
2013-07-15 04:47:59 -04:00
|
|
|
add_to_config "config.active_record.migration_error = :page_load"
|
|
|
|
|
2010-01-04 20:34:42 -05:00
|
|
|
boot!
|
|
|
|
|
2010-09-15 15:58:49 -04:00
|
|
|
assert_equal [
|
2012-03-03 14:05:45 -05:00
|
|
|
"Rack::Sendfile",
|
2010-09-15 15:58:49 -04:00
|
|
|
"ActionDispatch::Static",
|
2016-02-21 20:25:52 -05:00
|
|
|
"ActionDispatch::Executor",
|
2015-10-02 17:45:31 -04:00
|
|
|
"ActiveSupport::Cache::Strategy::LocalCache",
|
2015-10-03 17:21:31 -04:00
|
|
|
"Rack::Runtime",
|
|
|
|
"Rack::MethodOverride",
|
2011-10-20 03:29:27 -04:00
|
|
|
"ActionDispatch::RequestId",
|
2011-05-07 04:19:01 -04:00
|
|
|
"Rails::Rack::Logger", # must come after Rack::MethodOverride to properly log overridden methods
|
2010-09-15 15:58:49 -04:00
|
|
|
"ActionDispatch::ShowExceptions",
|
2011-12-01 14:46:18 -05:00
|
|
|
"ActionDispatch::DebugExceptions",
|
2010-09-15 15:58:49 -04:00
|
|
|
"ActionDispatch::RemoteIp",
|
2010-11-23 21:04:05 -05:00
|
|
|
"ActionDispatch::Reloader",
|
2010-09-15 15:58:49 -04:00
|
|
|
"ActionDispatch::Callbacks",
|
2013-07-15 04:47:59 -04:00
|
|
|
"ActiveRecord::Migration::CheckPending",
|
2010-09-15 15:58:49 -04:00
|
|
|
"ActionDispatch::Cookies",
|
|
|
|
"ActionDispatch::Session::CookieStore",
|
|
|
|
"ActionDispatch::Flash",
|
2012-07-23 12:50:48 -04:00
|
|
|
"Rack::Head",
|
2010-09-22 15:40:14 -04:00
|
|
|
"Rack::ConditionalGet",
|
2013-01-28 12:14:28 -05:00
|
|
|
"Rack::ETag"
|
2010-09-15 15:58:49 -04:00
|
|
|
], middleware
|
|
|
|
end
|
|
|
|
|
2015-04-16 13:55:32 -04:00
|
|
|
test "api middleware stack" do
|
|
|
|
add_to_config "config.api_only = true"
|
|
|
|
|
|
|
|
boot!
|
|
|
|
|
|
|
|
assert_equal [
|
|
|
|
"Rack::Sendfile",
|
|
|
|
"ActionDispatch::Static",
|
2016-02-21 20:25:52 -05:00
|
|
|
"ActionDispatch::Executor",
|
2015-04-16 13:55:32 -04:00
|
|
|
"ActiveSupport::Cache::Strategy::LocalCache",
|
2015-10-03 17:21:31 -04:00
|
|
|
"Rack::Runtime",
|
2015-04-16 13:55:32 -04:00
|
|
|
"ActionDispatch::RequestId",
|
|
|
|
"Rails::Rack::Logger", # must come after Rack::MethodOverride to properly log overridden methods
|
|
|
|
"ActionDispatch::ShowExceptions",
|
|
|
|
"ActionDispatch::DebugExceptions",
|
|
|
|
"ActionDispatch::RemoteIp",
|
|
|
|
"ActionDispatch::Reloader",
|
|
|
|
"ActionDispatch::Callbacks",
|
|
|
|
"Rack::Head",
|
|
|
|
"Rack::ConditionalGet",
|
|
|
|
"Rack::ETag"
|
|
|
|
], middleware
|
|
|
|
end
|
|
|
|
|
2012-10-03 17:43:39 -04:00
|
|
|
test "Rack::Cache is not included by default" do
|
2010-09-15 15:58:49 -04:00
|
|
|
boot!
|
|
|
|
|
2012-10-03 17:43:39 -04:00
|
|
|
assert !middleware.include?("Rack::Cache"), "Rack::Cache is not included in the default stack unless you set config.action_dispatch.rack_cache"
|
|
|
|
end
|
|
|
|
|
2012-10-18 13:31:52 -04:00
|
|
|
test "Rack::Cache is present when action_dispatch.rack_cache is set" do
|
2012-10-03 17:43:39 -04:00
|
|
|
add_to_config "config.action_dispatch.rack_cache = true"
|
|
|
|
|
|
|
|
boot!
|
|
|
|
|
2013-09-25 20:06:20 -04:00
|
|
|
assert middleware.include?("Rack::Cache")
|
2010-01-04 20:34:42 -05:00
|
|
|
end
|
|
|
|
|
2013-06-08 15:10:15 -04:00
|
|
|
test "ActiveRecord::Migration::CheckPending is present when active_record.migration_error is set to :page_load" do
|
|
|
|
add_to_config "config.active_record.migration_error = :page_load"
|
|
|
|
|
|
|
|
boot!
|
|
|
|
|
|
|
|
assert middleware.include?("ActiveRecord::Migration::CheckPending")
|
|
|
|
end
|
|
|
|
|
2012-03-16 22:22:25 -04:00
|
|
|
test "ActionDispatch::SSL is present when force_ssl is set" do
|
2011-03-27 12:55:46 -04:00
|
|
|
add_to_config "config.force_ssl = true"
|
|
|
|
boot!
|
2012-03-16 22:22:25 -04:00
|
|
|
assert middleware.include?("ActionDispatch::SSL")
|
2011-03-27 12:55:46 -04:00
|
|
|
end
|
|
|
|
|
2012-03-16 22:22:25 -04:00
|
|
|
test "ActionDispatch::SSL is configured with options when given" do
|
2011-09-26 22:22:52 -04:00
|
|
|
add_to_config "config.force_ssl = true"
|
2012-10-14 06:03:39 -04:00
|
|
|
add_to_config "config.ssl_options = { host: 'example.com' }"
|
2011-09-26 22:22:52 -04:00
|
|
|
boot!
|
2011-12-20 14:17:17 -05:00
|
|
|
|
2014-08-26 11:53:19 -04:00
|
|
|
assert_equal [{host: 'example.com'}], Rails.application.middleware.first.args
|
2011-09-26 22:22:52 -04:00
|
|
|
end
|
|
|
|
|
2010-07-25 16:08:34 -04:00
|
|
|
test "removing Active Record omits its middleware" do
|
2010-01-04 20:34:42 -05:00
|
|
|
use_frameworks []
|
|
|
|
boot!
|
2013-07-15 04:47:59 -04:00
|
|
|
assert !middleware.include?("ActiveRecord::Migration::CheckPending")
|
2010-01-04 20:34:42 -05:00
|
|
|
end
|
|
|
|
|
2016-02-21 20:25:52 -05:00
|
|
|
test "includes executor" do
|
2014-09-29 12:02:42 -04:00
|
|
|
boot!
|
2016-02-21 20:25:52 -05:00
|
|
|
assert_includes middleware, "ActionDispatch::Executor"
|
2014-09-18 16:35:19 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
test "does not include lock if cache_classes is set and so is eager_load" do
|
|
|
|
add_to_config "config.cache_classes = true"
|
|
|
|
add_to_config "config.eager_load = true"
|
|
|
|
boot!
|
2014-09-29 12:02:42 -04:00
|
|
|
assert_not_includes middleware, "Rack::Lock"
|
2010-01-04 20:34:42 -05:00
|
|
|
end
|
|
|
|
|
2014-09-29 12:16:07 -04:00
|
|
|
test "does not include lock if allow_concurrency is set to :unsafe" do
|
|
|
|
add_to_config "config.allow_concurrency = :unsafe"
|
2013-03-03 15:20:44 -05:00
|
|
|
boot!
|
2014-09-29 12:02:42 -04:00
|
|
|
assert_not_includes middleware, "Rack::Lock"
|
|
|
|
end
|
|
|
|
|
|
|
|
test "includes lock if allow_concurrency is disabled" do
|
|
|
|
add_to_config "config.allow_concurrency = false"
|
|
|
|
boot!
|
|
|
|
assert_includes middleware, "Rack::Lock"
|
2013-03-03 15:20:44 -05:00
|
|
|
end
|
|
|
|
|
2015-11-04 16:31:16 -05:00
|
|
|
test "removes static asset server if public_file_server.enabled is disabled" do
|
|
|
|
add_to_config "config.public_file_server.enabled = false"
|
2010-01-04 20:34:42 -05:00
|
|
|
boot!
|
|
|
|
assert !middleware.include?("ActionDispatch::Static")
|
|
|
|
end
|
|
|
|
|
2010-06-07 17:17:23 -04:00
|
|
|
test "can delete a middleware from the stack" do
|
|
|
|
add_to_config "config.middleware.delete ActionDispatch::Static"
|
|
|
|
boot!
|
|
|
|
assert !middleware.include?("ActionDispatch::Static")
|
|
|
|
end
|
|
|
|
|
2015-02-18 13:35:51 -05:00
|
|
|
test "can delete a middleware from the stack even if insert_before is added after delete" do
|
2015-10-03 17:21:31 -04:00
|
|
|
add_to_config "config.middleware.delete Rack::Runtime"
|
|
|
|
add_to_config "config.middleware.insert_before(Rack::Runtime, Rack::Config)"
|
2015-02-18 13:35:51 -05:00
|
|
|
boot!
|
|
|
|
assert middleware.include?("Rack::Config")
|
2015-10-03 17:21:31 -04:00
|
|
|
assert_not middleware.include?("Rack::Runtime")
|
2015-02-18 13:35:51 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
test "can delete a middleware from the stack even if insert_after is added after delete" do
|
2015-10-03 17:21:31 -04:00
|
|
|
add_to_config "config.middleware.delete Rack::Runtime"
|
|
|
|
add_to_config "config.middleware.insert_after(Rack::Runtime, Rack::Config)"
|
2015-02-18 13:35:51 -05:00
|
|
|
boot!
|
|
|
|
assert middleware.include?("Rack::Config")
|
2015-10-03 17:21:31 -04:00
|
|
|
assert_not middleware.include?("Rack::Runtime")
|
2015-02-18 13:35:51 -05:00
|
|
|
end
|
|
|
|
|
2011-12-01 14:46:18 -05:00
|
|
|
test "includes exceptions middlewares even if action_dispatch.show_exceptions is disabled" do
|
2010-04-02 14:54:10 -04:00
|
|
|
add_to_config "config.action_dispatch.show_exceptions = false"
|
|
|
|
boot!
|
2011-02-22 15:02:39 -05:00
|
|
|
assert middleware.include?("ActionDispatch::ShowExceptions")
|
2011-12-01 14:46:18 -05:00
|
|
|
assert middleware.include?("ActionDispatch::DebugExceptions")
|
2010-04-02 14:54:10 -04:00
|
|
|
end
|
|
|
|
|
2010-11-23 21:04:05 -05:00
|
|
|
test "removes ActionDispatch::Reloader if cache_classes is true" do
|
|
|
|
add_to_config "config.cache_classes = true"
|
|
|
|
boot!
|
|
|
|
assert !middleware.include?("ActionDispatch::Reloader")
|
|
|
|
end
|
|
|
|
|
2010-01-04 20:34:42 -05:00
|
|
|
test "use middleware" do
|
|
|
|
use_frameworks []
|
|
|
|
add_to_config "config.middleware.use Rack::Config"
|
|
|
|
boot!
|
|
|
|
assert_equal "Rack::Config", middleware.last
|
|
|
|
end
|
|
|
|
|
2010-01-04 20:38:56 -05:00
|
|
|
test "insert middleware after" do
|
2013-07-15 01:33:09 -04:00
|
|
|
add_to_config "config.middleware.insert_after Rack::Sendfile, Rack::Config"
|
2010-01-04 20:38:56 -05:00
|
|
|
boot!
|
2010-09-15 15:58:49 -04:00
|
|
|
assert_equal "Rack::Config", middleware.second
|
2010-01-04 20:38:56 -05:00
|
|
|
end
|
|
|
|
|
2013-10-09 06:16:22 -04:00
|
|
|
test 'unshift middleware' do
|
|
|
|
add_to_config 'config.middleware.unshift Rack::Config'
|
|
|
|
boot!
|
|
|
|
assert_equal 'Rack::Config', middleware.first
|
|
|
|
end
|
|
|
|
|
2012-01-17 11:53:09 -05:00
|
|
|
test "Rails.cache does not respond to middleware" do
|
2010-06-24 12:42:09 -04:00
|
|
|
add_to_config "config.cache_store = :memory_store"
|
|
|
|
boot!
|
2015-10-03 17:21:31 -04:00
|
|
|
assert_equal "Rack::Runtime", middleware.fourth
|
2010-06-24 12:42:09 -04:00
|
|
|
end
|
|
|
|
|
2012-01-17 11:53:09 -05:00
|
|
|
test "Rails.cache does respond to middleware" do
|
2010-06-24 12:42:09 -04:00
|
|
|
boot!
|
2015-10-03 17:21:31 -04:00
|
|
|
assert_equal "Rack::Runtime", middleware.fifth
|
2010-06-24 12:42:09 -04:00
|
|
|
end
|
|
|
|
|
2010-01-04 20:38:56 -05:00
|
|
|
test "insert middleware before" do
|
2013-07-15 01:33:09 -04:00
|
|
|
add_to_config "config.middleware.insert_before Rack::Sendfile, Rack::Config"
|
2010-01-04 20:38:56 -05:00
|
|
|
boot!
|
2010-09-15 15:58:49 -04:00
|
|
|
assert_equal "Rack::Config", middleware.first
|
2010-01-04 20:38:56 -05:00
|
|
|
end
|
|
|
|
|
2012-04-20 15:17:03 -04:00
|
|
|
test "can't change middleware after it's built" do
|
|
|
|
boot!
|
|
|
|
assert_raise RuntimeError do
|
|
|
|
app.config.middleware.use Rack::Config
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2010-09-22 15:40:14 -04:00
|
|
|
# ConditionalGet + Etag
|
|
|
|
test "conditional get + etag middlewares handle http caching based on body" do
|
|
|
|
make_basic_app
|
|
|
|
|
|
|
|
class ::OmgController < ActionController::Base
|
|
|
|
def index
|
|
|
|
if params[:nothing]
|
2012-10-14 06:03:39 -04:00
|
|
|
render text: ""
|
2010-09-22 15:40:14 -04:00
|
|
|
else
|
2012-10-14 06:03:39 -04:00
|
|
|
render text: "OMG"
|
2010-09-22 15:40:14 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2016-05-06 17:30:42 -04:00
|
|
|
etag = "W/" + "c00862d1c6c1cf7c1b49388306e7b3c1".inspect
|
2010-09-22 15:40:14 -04:00
|
|
|
|
|
|
|
get "/"
|
|
|
|
assert_equal 200, last_response.status
|
|
|
|
assert_equal "OMG", last_response.body
|
|
|
|
assert_equal "text/html; charset=utf-8", last_response.headers["Content-Type"]
|
|
|
|
assert_equal "max-age=0, private, must-revalidate", last_response.headers["Cache-Control"]
|
|
|
|
assert_equal etag, last_response.headers["Etag"]
|
|
|
|
|
|
|
|
get "/", {}, "HTTP_IF_NONE_MATCH" => etag
|
|
|
|
assert_equal 304, last_response.status
|
|
|
|
assert_equal "", last_response.body
|
|
|
|
assert_equal nil, last_response.headers["Content-Type"]
|
|
|
|
assert_equal "max-age=0, private, must-revalidate", last_response.headers["Cache-Control"]
|
|
|
|
assert_equal etag, last_response.headers["Etag"]
|
|
|
|
|
|
|
|
get "/?nothing=true"
|
|
|
|
assert_equal 200, last_response.status
|
|
|
|
assert_equal "", last_response.body
|
|
|
|
assert_equal "text/html; charset=utf-8", last_response.headers["Content-Type"]
|
|
|
|
assert_equal "no-cache", last_response.headers["Cache-Control"]
|
|
|
|
assert_equal nil, last_response.headers["Etag"]
|
|
|
|
end
|
|
|
|
|
2011-12-20 14:17:17 -05:00
|
|
|
test "ORIGINAL_FULLPATH is passed to env" do
|
|
|
|
boot!
|
|
|
|
env = ::Rack::MockRequest.env_for("/foo/?something")
|
|
|
|
Rails.application.call(env)
|
|
|
|
|
|
|
|
assert_equal "/foo/?something", env["ORIGINAL_FULLPATH"]
|
|
|
|
end
|
|
|
|
|
2010-01-04 20:34:42 -05:00
|
|
|
private
|
2010-04-26 03:04:04 -04:00
|
|
|
|
2010-01-04 20:34:42 -05:00
|
|
|
def boot!
|
|
|
|
require "#{app_path}/config/environment"
|
|
|
|
end
|
|
|
|
|
|
|
|
def middleware
|
2013-06-09 22:47:07 -04:00
|
|
|
Rails.application.middleware.map(&:klass).map(&:name)
|
2010-01-04 20:34:42 -05:00
|
|
|
end
|
|
|
|
end
|
2011-06-06 08:54:05 -04:00
|
|
|
end
|