|
|
|
require "rails_helper"
|
|
|
|
|
|
|
|
RSpec.describe Imports::SchemeImportService do
|
|
|
|
subject(:scheme_service) { described_class.new(storage_service, logger) }
|
|
|
|
|
|
|
|
let(:storage_service) { instance_double(Storage::S3Service) }
|
|
|
|
let(:logger) { instance_double(ActiveSupport::Logger) }
|
|
|
|
|
|
|
|
let(:fixture_directory) { "spec/fixtures/imports/mgmtgroups" }
|
|
|
|
let(:scheme_id) { "6d6d7618b58affe2a150a5ef2e9f4765fa6cd05d" }
|
|
|
|
|
|
|
|
let!(:owning_org) { FactoryBot.create(:organisation, old_org_id: "7c5bd5fb549c09z2c55d9cb90d7ba84927e64618") }
|
|
|
|
let!(:managing_org) { FactoryBot.create(:organisation, old_visible_id: 456) }
|
|
|
|
|
|
|
|
def open_file(directory, filename)
|
|
|
|
File.open("#{directory}/#{filename}.xml")
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when importing schemes" do
|
|
|
|
let(:remote_folder) { "mgmtgroups" }
|
|
|
|
|
|
|
|
before do
|
|
|
|
# Stub the S3 file listing and download
|
|
|
|
allow(storage_service).to receive(:list_files)
|
|
|
|
.and_return(%W[#{remote_folder}/#{scheme_id}.xml])
|
|
|
|
allow(storage_service).to receive(:get_file_io)
|
|
|
|
.with("#{remote_folder}/#{scheme_id}.xml")
|
|
|
|
.and_return(open_file(fixture_directory, scheme_id))
|
|
|
|
end
|
|
|
|
|
|
|
|
it "successfully create all schemes" do
|
|
|
|
expect(logger).not_to receive(:error)
|
|
|
|
expect(logger).not_to receive(:warn)
|
|
|
|
expect(logger).not_to receive(:info)
|
|
|
|
expect { scheme_service.create_schemes(remote_folder) }
|
|
|
|
.to change(Scheme, :count).by(1)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when importing a specific scheme" do
|
|
|
|
let(:scheme_file) { open_file(fixture_directory, scheme_id) }
|
|
|
|
let(:scheme_xml) { Nokogiri::XML(scheme_file) }
|
|
|
|
|
|
|
|
it "matches expected values" do
|
|
|
|
scheme = scheme_service.create_scheme(scheme_xml)
|
|
|
|
expect(scheme.owning_organisation).to eq(owning_org)
|
|
|
|
expect(scheme.managing_organisation).to eq(managing_org)
|
|
|
|
expect(scheme.old_id).to eq("6d6d7618b58affe2a150a5ef2e9f4765fa6cd05d")
|
|
|
|
expect(scheme.old_visible_id).to eq(123)
|
|
|
|
expect(scheme.service_name).to eq("Management Group")
|
|
|
|
expect(scheme.arrangement_type).to eq("Another organisation")
|
|
|
|
end
|
|
|
|
|
|
|
|
context "and the scheme status is not approved" do
|
|
|
|
before { scheme_xml.at_xpath("//mgmtgroup:status").content = "Temporary" }
|
|
|
|
|
|
|
|
it "does not create the scheme" do
|
|
|
|
expect(logger).to receive(:warn).with("Scheme with legacy ID 6d6d7618b58affe2a150a5ef2e9f4765fa6cd05d is not approved (Temporary), skipping")
|
|
|
|
expect { scheme_service.create_scheme(scheme_xml) }
|
|
|
|
.not_to change(Scheme, :count)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context "and the scheme arrange type is direct" do
|
|
|
|
before do
|
|
|
|
scheme_xml.at_xpath("//mgmtgroup:arrangement_type").content = "D"
|
|
|
|
scheme_xml.at_xpath("//mgmtgroup:agent").content = ""
|
|
|
|
end
|
|
|
|
|
|
|
|
it "assigns both owning and managing organisation to the same one" do
|
|
|
|
scheme = scheme_service.create_scheme(scheme_xml)
|
|
|
|
expect(scheme.owning_organisation).to eq(owning_org)
|
|
|
|
expect(scheme.managing_organisation).to eq(owning_org)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|