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

45 lines
1 KiB
Ruby
Raw Normal View History

2014-05-18 05:44:28 -04:00
require 'helper'
2014-05-18 06:32:22 -04:00
require 'jobs/hello_job'
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
2014-08-25 10:34:50 -04:00
HelloJob.perform_later
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
test 'run queued job with arguments' do
2014-08-25 10:34:50 -04:00
HelloJob.perform_later "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
test 'run queued job later' do
begin
2014-08-25 10:34:50 -04:00
result = HelloJob.set(wait_until: 1.second.ago).perform_later "Jamie"
2014-05-20 12:05:16 -04:00
assert result
rescue NotImplementedError
skip
end
end
test 'job returned by enqueue has the arguments available' do
2014-08-25 10:34:50 -04:00
job = HelloJob.perform_later "Jamie"
assert_equal [ "Jamie" ], job.arguments
end
2014-08-25 10:34:50 -04:00
test 'job returned by perform_at has the timestamp available' do
begin
2014-08-25 10:34:50 -04:00
job = HelloJob.set(wait_until: Time.utc(2014, 1, 1)).perform_later
assert_equal Time.utc(2014, 1, 1).to_f, job.scheduled_at
rescue NotImplementedError
skip
end
end
2014-05-18 05:44:28 -04:00
end