1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/actioncable/test/test_helper.rb
Jeremy Daer 3ba0eec20c
Cable: Extract stream handler construction
* Use separate stream handler builders for easy override and testing.
* Fix worker pool execution that was silently failing since it only
  expected connection receivers.

Sparked by code in #24162.
2016-04-18 23:29:51 -07:00

73 lines
1.5 KiB
Ruby

require 'action_cable'
require 'active_support/testing/autorun'
require 'puma'
require 'mocha/setup'
require 'rack/mock'
begin
require 'byebug'
rescue LoadError
end
# Require all the stubs and models
Dir[File.dirname(__FILE__) + '/stubs/*.rb'].each {|file| require file }
if ENV['FAYE'].present?
require 'faye/websocket'
class << Faye::WebSocket
remove_method :ensure_reactor_running
# We don't want Faye to start the EM reactor in tests because it makes testing much harder.
# We want to be able to start and stop EM loop in tests to make things simpler.
def ensure_reactor_running
# no-op
end
end
end
module EventMachineConcurrencyHelpers
def wait_for_async
EM.run_deferred_callbacks
end
def run_in_eventmachine
failure = nil
EM.run do
begin
yield
rescue => ex
failure = ex
ensure
wait_for_async
EM.stop if EM.reactor_running?
end
end
raise failure if failure
end
end
module ConcurrentRubyConcurrencyHelpers
def wait_for_async
wait_for_executor Concurrent.global_io_executor
end
def run_in_eventmachine
yield
wait_for_async
end
end
class ActionCable::TestCase < ActiveSupport::TestCase
if ENV['FAYE'].present?
include EventMachineConcurrencyHelpers
else
include ConcurrentRubyConcurrencyHelpers
end
def wait_for_executor(executor)
until executor.completed_task_count == executor.scheduled_task_count
sleep 0.1
end
end
end