mirror of
https://github.com/discourse/discourse.git
synced 2025-01-21 08:26:14 +08:00
7c3a29c9d6
* Updates GitHub Actions * Switches from `bundler/inline` to an optional group in the `Gemfile` because the previous solution didn't work well with rspec * Adds the converter framework and tests * Allows loading private converters (see README) * Switches from multiple CLI tools to a single CLI * Makes DB connections reusable and adds a new abstraction for the `IntermediateDB` * `IntermediateDB` acts as an interface for IPC calls when a converter steps runs in parallel (forks). Only the main process writes to the DB. * Includes a simple example implementation of a converter for now.
84 lines
2.5 KiB
Ruby
84 lines
2.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
RSpec.describe ::Migrations::Converters::Base::ParallelJob do
|
|
subject(:job) { described_class.new(step) }
|
|
|
|
let(:step) { instance_double(::Migrations::Converters::Base::ProgressStep) }
|
|
let(:item) { { key: "value" } }
|
|
let(:stats) { instance_double(::Migrations::Converters::Base::ProgressStats) }
|
|
let(:intermediate_db) { class_double(::Migrations::Database::IntermediateDB).as_stubbed_const }
|
|
|
|
before do
|
|
allow(::Migrations::Converters::Base::ProgressStats).to receive(:new).and_return(stats)
|
|
|
|
allow(stats).to receive(:reset!)
|
|
allow(stats).to receive(:log_error)
|
|
allow(intermediate_db).to receive(:setup)
|
|
allow(intermediate_db).to receive(:close)
|
|
end
|
|
|
|
after do
|
|
::Migrations::Database::IntermediateDB.setup(nil)
|
|
::Migrations::ForkManager.clear!
|
|
end
|
|
|
|
describe "#initialize" do
|
|
it "sets up `OfflineConnection` as `IntermediateDB` connection" do
|
|
described_class.new(step)
|
|
|
|
::Migrations::ForkManager.fork do
|
|
expect(intermediate_db).to have_received(:setup).with(
|
|
an_instance_of(::Migrations::Database::OfflineConnection),
|
|
)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe "#run" do
|
|
let(:offline_connection) { instance_double(::Migrations::Database::OfflineConnection) }
|
|
|
|
before do
|
|
allow(::Migrations::Database::OfflineConnection).to receive(:new).and_return(
|
|
offline_connection,
|
|
)
|
|
allow(offline_connection).to receive(:clear!)
|
|
|
|
allow(step).to receive(:process_item)
|
|
allow(offline_connection).to receive(:parametrized_insert_statements).and_return(
|
|
[["SQL", [1, 2]], ["SQL", [2, 3]]],
|
|
)
|
|
end
|
|
|
|
it "resets stats and clears the offline connection" do
|
|
job.run(item)
|
|
|
|
expect(stats).to have_received(:reset!)
|
|
expect(offline_connection).to have_received(:clear!)
|
|
end
|
|
|
|
it "processes an item and logs errors if exceptions occur" do
|
|
allow(step).to receive(:process_item).and_raise(StandardError.new("error"))
|
|
|
|
job.run(item)
|
|
|
|
expect(stats).to have_received(:log_error).with(
|
|
"Failed to process item",
|
|
exception: an_instance_of(StandardError),
|
|
details: item,
|
|
)
|
|
end
|
|
|
|
it "returns the parametrized insert statements and stats" do
|
|
result = job.run(item)
|
|
|
|
expect(result).to eq([[["SQL", [1, 2]], ["SQL", [2, 3]]], stats])
|
|
end
|
|
end
|
|
|
|
describe "#cleanup" do
|
|
it "can be called without errors" do
|
|
expect { job.cleanup }.not_to raise_error
|
|
end
|
|
end
|
|
end
|