2024-09-09 23:14:39 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
RSpec.describe ::Migrations::Converters::Base::SerialJob do
|
|
|
|
subject(:job) { described_class.new(step) }
|
|
|
|
|
|
|
|
let(:step) { instance_double(::Migrations::Converters::Base::ProgressStep) }
|
|
|
|
let(:item) { "Item" }
|
2024-11-20 06:54:37 +08:00
|
|
|
let(:tracker) { instance_double(::Migrations::Converters::Base::StepTracker) }
|
|
|
|
let(:stats) { ::Migrations::Converters::Base::StepStats.new }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(step).to receive(:tracker).and_return(tracker)
|
2024-09-09 23:14:39 +08:00
|
|
|
|
2024-11-20 06:54:37 +08:00
|
|
|
allow(tracker).to receive(:reset_stats!)
|
|
|
|
allow(tracker).to receive(:log_error)
|
|
|
|
allow(tracker).to receive(:stats).and_return(stats)
|
|
|
|
end
|
2024-09-09 23:14:39 +08:00
|
|
|
|
|
|
|
describe "#run" do
|
|
|
|
it "resets stats and processes item" do
|
|
|
|
allow(step).to receive(:process_item).and_return(stats)
|
|
|
|
|
2024-11-20 06:54:37 +08:00
|
|
|
result = job.run(item)
|
|
|
|
expect(result).to eq(stats)
|
2024-09-09 23:14:39 +08:00
|
|
|
|
2024-11-20 06:54:37 +08:00
|
|
|
expect(tracker).to have_received(:reset_stats!)
|
|
|
|
expect(step).to have_received(:process_item).with(item)
|
2024-09-09 23:14:39 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
it "logs error if processing item raises an exception" do
|
|
|
|
allow(step).to receive(:process_item).and_raise(StandardError)
|
|
|
|
|
|
|
|
job.run(item)
|
|
|
|
|
2024-11-20 06:54:37 +08:00
|
|
|
expect(tracker).to have_received(:log_error).with(
|
2024-09-09 23:14:39 +08:00
|
|
|
"Failed to process item",
|
|
|
|
exception: an_instance_of(StandardError),
|
|
|
|
details: item,
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "#cleanup" do
|
|
|
|
it "can be called without errors" do
|
|
|
|
expect { job.cleanup }.not_to raise_error
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|