aboutsummaryrefslogtreecommitdiffstats
path: root/actioncable/test
diff options
context:
space:
mode:
authorMatthew Draper <matthew@trebex.net>2016-02-25 13:58:31 +1030
committerMatthew Draper <matthew@trebex.net>2016-02-25 13:58:31 +1030
commit50e4433b051829350984f0c5eb1271243f6d229d (patch)
tree49b981022945253872271314cfe77dcc9aea59a8 /actioncable/test
parent9e30869c9af4aa5a76d9c63cd9ac080aa3f1ac39 (diff)
parenta536cc8f1e31e09526b6b43c07ec255d66cd2049 (diff)
downloadrails-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.rb20
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',