rails--rails/activejob/test/cases/queuing_test.rb

45 lines
980 B
Ruby
Raw Normal View History

2014-05-18 09:44:28 +00:00
require 'helper'
2014-05-18 10:32:22 +00:00
require 'jobs/hello_job'
require 'active_support/core_ext/numeric/time'
2014-05-18 10:32:22 +00:00
2014-05-18 09:44:28 +00:00
class QueuingTest < ActiveSupport::TestCase
2014-05-18 10:32:22 +00:00
setup do
$BUFFER = []
end
test 'run queued job' do
HelloJob.enqueue
assert_equal "David says hello", $BUFFER.pop
end
test 'run queued job with arguments' do
2014-05-18 10:32:22 +00:00
HelloJob.enqueue "Jamie"
assert_equal "Jamie says hello", $BUFFER.pop
2014-05-18 09:44:28 +00:00
end
test 'run queued job later' do
begin
result = HelloJob.enqueue_at 1.second.ago, "Jamie"
2014-05-20 16:05:16 +00:00
assert result
rescue NotImplementedError
skip
end
end
test 'job returned by enqueue has the arguments available' do
job = HelloJob.enqueue "Jamie"
assert_equal [ "Jamie" ], job.arguments
end
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 09:44:28 +00:00
end