mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
c81af6ae72
We sometimes say "✂️ newline after `private`" in a code review (e.g. https://github.com/rails/rails/pull/18546#discussion_r23188776, https://github.com/rails/rails/pull/34832#discussion_r244847195). Now `Layout/EmptyLinesAroundAccessModifier` cop have new enforced style `EnforcedStyle: only_before` (https://github.com/rubocop-hq/rubocop/pull/7059). That cop and enforced style will reduce the our code review cost.
66 lines
1.2 KiB
Ruby
66 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "support/integration/jobs_manager"
|
|
|
|
module TestCaseHelpers
|
|
extend ActiveSupport::Concern
|
|
|
|
included do
|
|
self.use_transactional_tests = false
|
|
|
|
setup do
|
|
clear_jobs
|
|
@id = "AJ-#{SecureRandom.uuid}"
|
|
end
|
|
|
|
teardown do
|
|
clear_jobs
|
|
end
|
|
end
|
|
|
|
private
|
|
def jobs_manager
|
|
JobsManager.current_manager
|
|
end
|
|
|
|
def clear_jobs
|
|
jobs_manager.clear_jobs
|
|
end
|
|
|
|
def adapter_is?(*adapter_class_symbols)
|
|
adapter_class_symbols.map(&:to_s).include? ActiveJob::Base.queue_adapter_name
|
|
end
|
|
|
|
def wait_for_jobs_to_finish_for(seconds = 60)
|
|
Timeout.timeout(seconds) do
|
|
while !job_executed do
|
|
sleep 0.25
|
|
end
|
|
end
|
|
rescue Timeout::Error
|
|
end
|
|
|
|
def job_file(id)
|
|
Dummy::Application.root.join("tmp/#{id}")
|
|
end
|
|
|
|
def job_executed(id = @id)
|
|
job_file(id).exist?
|
|
end
|
|
|
|
def job_data(id)
|
|
Marshal.load(File.binread(job_file(id)))
|
|
end
|
|
|
|
def job_executed_at(id = @id)
|
|
job_data(id)["executed_at"]
|
|
end
|
|
|
|
def job_executed_in_locale(id = @id)
|
|
job_data(id)["locale"]
|
|
end
|
|
|
|
def job_executed_in_timezone(id = @id)
|
|
job_data(id)["timezone"]
|
|
end
|
|
end
|