aboutsummaryrefslogtreecommitdiffstats
path: root/actioncable/test
diff options
context:
space:
mode:
authorIlia Kasianenko <i.kasianenko@gmail.com>2018-12-12 15:42:34 +0200
committerIlia Kasianenko <i.kasianenko@gmail.com>2018-12-12 15:48:55 +0200
commit87f407db3ebac3dfaf53e19590e8707bd0183496 (patch)
treefcca452ddccfef3fa040936d138c9609f6709163 /actioncable/test
parentc4f37cc8c5a3b1de5746146a0f65b22d418cfef4 (diff)
downloadrails-87f407db3ebac3dfaf53e19590e8707bd0183496.tar.gz
rails-87f407db3ebac3dfaf53e19590e8707bd0183496.tar.bz2
rails-87f407db3ebac3dfaf53e19590e8707bd0183496.zip
Add Missing ActiveSupport::Rescuable to ActionCable::Channel
[timthez, Ilia Kasianenko]
Diffstat (limited to 'actioncable/test')
-rw-r--r--actioncable/test/channel/base_test.rb18
1 files changed, 17 insertions, 1 deletions
diff --git a/actioncable/test/channel/base_test.rb b/actioncable/test/channel/base_test.rb
index eb0e1673b0..c2968226c7 100644
--- a/actioncable/test/channel/base_test.rb
+++ b/actioncable/test/channel/base_test.rb
@@ -26,6 +26,9 @@ class ActionCable::Channel::BaseTest < ActionCable::TestCase
after_subscribe :toggle_subscribed
after_unsubscribe :toggle_subscribed
+ class SomeCustomError < StandardError; end
+ rescue_from SomeCustomError, with: :error_handler
+
def initialize(*)
@subscribed = false
super
@@ -68,10 +71,18 @@ class ActionCable::Channel::BaseTest < ActionCable::TestCase
@last_action = [ :receive ]
end
+ def error_action
+ raise SomeCustomError
+ end
+
private
def rm_rf
@last_action = [ :rm_rf ]
end
+
+ def error_handler
+ @last_action = [ :error_action ]
+ end
end
setup do
@@ -168,7 +179,7 @@ class ActionCable::Channel::BaseTest < ActionCable::TestCase
end
test "actions available on Channel" do
- available_actions = %w(room last_action subscribed unsubscribed toggle_subscribed leave speak subscribed? get_latest receive chatters topic).to_set
+ available_actions = %w(room last_action subscribed unsubscribed toggle_subscribed leave speak subscribed? get_latest receive chatters topic error_action).to_set
assert_equal available_actions, ChatChannel.action_methods
end
@@ -256,6 +267,11 @@ class ActionCable::Channel::BaseTest < ActionCable::TestCase
end
end
+ test "behaves like rescuable" do
+ @channel.perform_action "action" => :error_action
+ assert_equal [ :error_action ], @channel.last_action
+ end
+
private
def assert_logged(message)
old_logger = @connection.logger