1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/railties/test/queueing/test_queue_test.rb

68 lines
1.1 KiB
Ruby
Raw Normal View History

2012-04-27 00:43:12 -04:00
require 'abstract_unit'
require 'rails/queueing'
class TestQueueTest < ActiveSupport::TestCase
class Job
2012-04-27 17:26:26 -04:00
def initialize(&block)
2012-04-27 00:43:12 -04:00
@block = block
end
def run
@block.call if @block
end
end
def setup
@queue = Rails::Queueing::TestQueue.new
end
def test_drain_raises
@queue.push Job.new { raise }
assert_raises(RuntimeError) { @queue.drain }
end
def test_jobs
@queue.push 1
@queue.push 2
assert_equal [1,2], @queue.jobs
end
2012-04-27 00:43:12 -04:00
def test_contents
2012-04-27 17:26:26 -04:00
assert @queue.empty?
job = Job.new
2012-04-27 00:43:12 -04:00
@queue.push job
2012-04-27 17:26:26 -04:00
refute @queue.empty?
assert_equal job, @queue.pop
2012-04-27 00:43:12 -04:00
end
def test_order
2012-04-27 16:51:54 -04:00
processed = []
2012-04-27 16:21:51 -04:00
2012-04-27 17:26:26 -04:00
job1 = Job.new { processed << 1 }
job2 = Job.new { processed << 2 }
2012-04-27 16:21:51 -04:00
@queue.push job1
@queue.push job2
@queue.drain
2012-04-27 16:21:51 -04:00
2012-04-27 16:51:54 -04:00
assert_equal [1,2], processed
end
2012-04-27 00:43:12 -04:00
def test_drain
t = nil
ran = false
2012-04-27 17:26:26 -04:00
job = Job.new do
2012-04-27 00:43:12 -04:00
ran = true
t = Thread.current
end
@queue.push job
@queue.drain
2012-04-27 17:26:26 -04:00
assert @queue.empty?
2012-04-27 00:43:12 -04:00
assert ran, "The job runs synchronously when the queue is drained"
assert_not_equal t, Thread.current
end
end