2014-05-18 05:44:28 -04:00
|
|
|
require 'helper'
|
2014-05-18 06:32:22 -04:00
|
|
|
require 'jobs/hello_job'
|
2014-05-19 18:27:28 -04:00
|
|
|
require 'active_support/core_ext/numeric/time'
|
2014-05-18 06:32:22 -04:00
|
|
|
|
2014-05-18 05:44:28 -04:00
|
|
|
|
|
|
|
class QueuingTest < ActiveSupport::TestCase
|
2014-05-18 06:32:22 -04:00
|
|
|
setup do
|
2014-08-17 09:23:24 -04:00
|
|
|
JobBuffer.clear
|
2014-05-18 06:32:22 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
test 'run queued job' do
|
|
|
|
HelloJob.enqueue
|
2014-08-17 09:23:24 -04:00
|
|
|
assert_equal "David says hello", JobBuffer.last_value
|
2014-05-18 06:32:22 -04:00
|
|
|
end
|
|
|
|
|
2014-05-22 13:35:45 -04:00
|
|
|
test 'run queued job with arguments' do
|
2014-05-18 06:32:22 -04:00
|
|
|
HelloJob.enqueue "Jamie"
|
2014-08-17 09:23:24 -04:00
|
|
|
assert_equal "Jamie says hello", JobBuffer.last_value
|
2014-05-18 05:44:28 -04:00
|
|
|
end
|
2014-05-19 18:27:28 -04:00
|
|
|
|
|
|
|
test 'run queued job later' do
|
|
|
|
begin
|
|
|
|
result = HelloJob.enqueue_at 1.second.ago, "Jamie"
|
2014-05-20 12:05:16 -04:00
|
|
|
assert result
|
2014-05-19 18:27:28 -04:00
|
|
|
rescue NotImplementedError
|
2014-05-20 13:19:14 -04:00
|
|
|
skip
|
2014-05-19 18:27:28 -04:00
|
|
|
end
|
|
|
|
end
|
2014-08-15 17:02:06 -04:00
|
|
|
|
2014-05-22 13:33:23 -04:00
|
|
|
test 'job returned by enqueue has the arguments available' do
|
|
|
|
job = HelloJob.enqueue "Jamie"
|
|
|
|
assert_equal [ "Jamie" ], job.arguments
|
|
|
|
end
|
|
|
|
|
2014-08-15 17:02:06 -04:00
|
|
|
|
2014-05-22 13:33:23 -04:00
|
|
|
test 'job returned by enqueue_at has the timestamp available' do
|
|
|
|
begin
|
|
|
|
job = HelloJob.enqueue_at Time.utc(2014, 1, 1)
|
|
|
|
assert_equal Time.utc(2014, 1, 1), job.enqueued_at
|
|
|
|
rescue NotImplementedError
|
|
|
|
skip
|
|
|
|
end
|
|
|
|
end
|
2014-05-18 05:44:28 -04:00
|
|
|
end
|