diff options
author | Matthew Draper <matthew@trebex.net> | 2016-02-25 13:58:31 +1030 |
---|---|---|
committer | Matthew Draper <matthew@trebex.net> | 2016-02-25 13:58:31 +1030 |
commit | 50e4433b051829350984f0c5eb1271243f6d229d (patch) | |
tree | 49b981022945253872271314cfe77dcc9aea59a8 /actioncable/test | |
parent | 9e30869c9af4aa5a76d9c63cd9ac080aa3f1ac39 (diff) | |
parent | a536cc8f1e31e09526b6b43c07ec255d66cd2049 (diff) | |
download | rails-50e4433b051829350984f0c5eb1271243f6d229d.tar.gz rails-50e4433b051829350984f0c5eb1271243f6d229d.tar.bz2 rails-50e4433b051829350984f0c5eb1271243f6d229d.zip |
Merge pull request #23843 from maclover7/fix-23471
Only hijack Rack socket when first needed
Diffstat (limited to 'actioncable/test')
-rw-r--r-- | actioncable/test/connection/base_test.rb | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/actioncable/test/connection/base_test.rb b/actioncable/test/connection/base_test.rb index 3bef9e95a1..fb11f9be64 100644 --- a/actioncable/test/connection/base_test.rb +++ b/actioncable/test/connection/base_test.rb @@ -108,6 +108,26 @@ class ActionCable::Connection::BaseTest < ActionCable::TestCase end end + test "rejecting a connection causes a 404" do + run_in_eventmachine do + class CallMeMaybe + def call(*) + raise 'Do not call me!' + end + end + + env = Rack::MockRequest.env_for( + "/test", + { 'HTTP_CONNECTION' => 'upgrade', 'HTTP_UPGRADE' => 'websocket', + 'HTTP_ORIGIN' => 'http://rubyonrails.org', 'rack.hijack' => CallMeMaybe.new } + ) + + connection = ActionCable::Connection::Base.new(@server, env) + response = connection.process + assert_equal 404, response[0] + end + end + private def open_connection env = Rack::MockRequest.env_for "/test", 'HTTP_CONNECTION' => 'upgrade', 'HTTP_UPGRADE' => 'websocket', |