334 lines
19 KiB
334 lines
19 KiB
4 months ago
|
require "rails_helper"
|
||
|
|
||
|
RSpec.describe Exports::ExportService do
|
||
|
subject(:export_service) { described_class.new(storage_service) }
|
||
|
|
||
|
let(:storage_service) { instance_double(Storage::S3Service) }
|
||
|
let(:expected_master_manifest_filename) { "Manifest_2022_05_01_0001.csv" }
|
||
|
let(:start_time) { Time.zone.local(2022, 5, 1) }
|
||
|
let(:user) { FactoryBot.create(:user, email: "test1@example.com") }
|
||
|
let(:organisations_export_service) { instance_double("Exports::OrganisationExportService", export_xml_organisations: {}) }
|
||
|
let(:users_export_service) { instance_double("Exports::UserExportService", export_xml_users: {}) }
|
||
|
|
||
|
before do
|
||
|
Timecop.freeze(start_time)
|
||
|
Singleton.__init__(FormHandler)
|
||
|
allow(storage_service).to receive(:write_file)
|
||
|
allow(Exports::LettingsLogExportService).to receive(:new).and_return(lettings_logs_export_service)
|
||
|
allow(Exports::UserExportService).to receive(:new).and_return(users_export_service)
|
||
|
allow(Exports::OrganisationExportService).to receive(:new).and_return(organisations_export_service)
|
||
|
end
|
||
|
|
||
|
after do
|
||
|
Timecop.return
|
||
|
end
|
||
|
|
||
|
context "when exporting daily XMLs" do
|
||
|
context "and no lettings archives get created in lettings logs export" do
|
||
|
let(:lettings_logs_export_service) { instance_double("Exports::LettingsLogExportService", export_xml_lettings_logs: {}) }
|
||
|
|
||
|
context "and no user or organisation archives get created in user export" do
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml
|
||
|
end
|
||
|
|
||
|
it "generates a master manifest with CSV headers but no data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and one user archive gets created in user export" do
|
||
|
let(:users_export_service) { instance_double("Exports::UserExportService", export_xml_users: { "some_user_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml
|
||
|
end
|
||
|
|
||
|
it "generates a master manifest with CSV headers and correct data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_user_file_base_name,2022-05-01 00:00:00 +0100,some_user_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and one organisation archive gets created in organisation export" do
|
||
|
let(:organisations_export_service) { instance_double("Exports::OrganisationExportService", export_xml_organisations: { "some_organisation_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml
|
||
|
end
|
||
|
|
||
|
it "generates a master manifest with CSV headers and correct data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_organisation_file_base_name,2022-05-01 00:00:00 +0100,some_organisation_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and user and organisation archive gets created in organisation export" do
|
||
|
let(:organisations_export_service) { instance_double("Exports::OrganisationExportService", export_xml_organisations: { "some_organisation_file_base_name" => start_time }) }
|
||
|
let(:users_export_service) { instance_double("Exports::UserExportService", export_xml_users: { "some_user_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml
|
||
|
end
|
||
|
|
||
|
it "generates a master manifest with CSV headers and correct data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_user_file_base_name,2022-05-01 00:00:00 +0100,some_user_file_base_name.zip\nsome_organisation_file_base_name,2022-05-01 00:00:00 +0100,some_organisation_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and one lettings archive gets created in lettings logs export" do
|
||
|
let(:lettings_logs_export_service) { instance_double("Exports::LettingsLogExportService", export_xml_lettings_logs: { "some_file_base_name" => start_time }) }
|
||
|
|
||
|
context "and no user archives get created in user export" do
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml
|
||
|
end
|
||
|
|
||
|
it "generates a master manifest with CSV headers and correct data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_file_base_name,2022-05-01 00:00:00 +0100,some_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and one user archive gets created in user export" do
|
||
|
let(:users_export_service) { instance_double("Exports::UserExportService", export_xml_users: { "some_user_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml
|
||
|
end
|
||
|
|
||
|
it "generates a master manifest with CSV headers and correct data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_file_base_name,2022-05-01 00:00:00 +0100,some_file_base_name.zip\nsome_user_file_base_name,2022-05-01 00:00:00 +0100,some_user_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and multiple lettings archives get created in lettings logs export" do
|
||
|
let(:lettings_logs_export_service) { instance_double("Exports::LettingsLogExportService", export_xml_lettings_logs: { "some_file_base_name" => start_time, "second_file_base_name" => start_time }) }
|
||
|
|
||
|
context "and no user archives get created in user export" do
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml
|
||
|
end
|
||
|
|
||
|
it "generates a master manifest with CSV headers and correct data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_file_base_name,2022-05-01 00:00:00 +0100,some_file_base_name.zip\nsecond_file_base_name,2022-05-01 00:00:00 +0100,second_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and multiple user archive gets created in user export" do
|
||
|
let(:users_export_service) { instance_double("Exports::UserExportService", export_xml_users: { "some_user_file_base_name" => start_time, "second_user_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml
|
||
|
end
|
||
|
|
||
|
it "generates a master manifest with CSV headers and correct data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_file_base_name,2022-05-01 00:00:00 +0100,some_file_base_name.zip\nsecond_file_base_name,2022-05-01 00:00:00 +0100,second_file_base_name.zip\nsome_user_file_base_name,2022-05-01 00:00:00 +0100,some_user_file_base_name.zip\nsecond_user_file_base_name,2022-05-01 00:00:00 +0100,second_user_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and multiple user and organisation archives gets created in user export" do
|
||
|
let(:users_export_service) { instance_double("Exports::UserExportService", export_xml_users: { "some_user_file_base_name" => start_time, "second_user_file_base_name" => start_time }) }
|
||
|
let(:organisations_export_service) { instance_double("Exports::OrganisationExportService", export_xml_organisations: { "some_organisation_file_base_name" => start_time, "second_organisation_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml
|
||
|
end
|
||
|
|
||
|
it "generates a master manifest with CSV headers and correct data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_file_base_name,2022-05-01 00:00:00 +0100,some_file_base_name.zip\nsecond_file_base_name,2022-05-01 00:00:00 +0100,second_file_base_name.zip\nsome_user_file_base_name,2022-05-01 00:00:00 +0100,some_user_file_base_name.zip\nsecond_user_file_base_name,2022-05-01 00:00:00 +0100,second_user_file_base_name.zip\nsome_organisation_file_base_name,2022-05-01 00:00:00 +0100,some_organisation_file_base_name.zip\nsecond_organisation_file_base_name,2022-05-01 00:00:00 +0100,second_organisation_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when exporting specific lettings log collection" do
|
||
|
context "and no lettings archives get created in lettings logs export" do
|
||
|
let(:lettings_logs_export_service) { instance_double("Exports::LettingsLogExportService", export_xml_lettings_logs: {}) }
|
||
|
|
||
|
context "and user archive gets created in user export" do
|
||
|
let(:users_export_service) { instance_double("Exports::UserExportService", export_xml_users: { "some_user_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml(full_update: true, collection: "2022")
|
||
|
end
|
||
|
|
||
|
it "does not write user data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml(full_update: true, collection: "2022")
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and lettings archive gets created in lettings logs export" do
|
||
|
let(:lettings_logs_export_service) { instance_double("Exports::LettingsLogExportService", export_xml_lettings_logs: { "some_file_base_name" => start_time }) }
|
||
|
|
||
|
context "and user archive gets created in user export" do
|
||
|
let(:users_export_service) { instance_double("Exports::UserExportService", export_xml_users: { "some_user_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml(full_update: true, collection: "2023")
|
||
|
end
|
||
|
|
||
|
it "does not write user data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_file_base_name,2022-05-01 00:00:00 +0100,some_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml(full_update: true, collection: "2023")
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when exporting user collection" do
|
||
|
context "and no user archives get created in users export" do
|
||
|
context "and lettings log archive gets created in lettings logs export" do
|
||
|
let(:lettings_logs_export_service) { instance_double("Exports::LettingsLogExportService", export_xml_lettings_logs: { "some_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml(full_update: true, collection: "users")
|
||
|
end
|
||
|
|
||
|
it "does not write lettings log data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml(full_update: true, collection: "users")
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and users archive gets created in users export" do
|
||
|
let(:lettings_logs_export_service) { instance_double("Exports::LettingsLogExportService", export_xml_lettings_logs: { "some_file_base_name" => start_time }) }
|
||
|
|
||
|
context "and lettings log archive gets created in lettings log export" do
|
||
|
let(:users_export_service) { instance_double("Exports::UserExportService", export_xml_users: { "some_user_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml(full_update: true, collection: "users")
|
||
|
end
|
||
|
|
||
|
it "does not write lettings log data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_user_file_base_name,2022-05-01 00:00:00 +0100,some_user_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml(full_update: true, collection: "users")
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "when exporting organisation collection" do
|
||
|
context "and no organisation archives get created in organisations export" do
|
||
|
let(:organisations_export_service) { instance_double("Exports::OrganisationExportService", export_xml_organisations: {}) }
|
||
|
|
||
|
context "and lettings log archive gets created in lettings logs export" do
|
||
|
let(:lettings_logs_export_service) { instance_double("Exports::LettingsLogExportService", export_xml_lettings_logs: { "some_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml(full_update: true, collection: "organisations")
|
||
|
end
|
||
|
|
||
|
it "does not write lettings log data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml(full_update: true, collection: "organisations")
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
context "and organisations archive gets created in organisations export" do
|
||
|
let(:lettings_logs_export_service) { instance_double("Exports::LettingsLogExportService", export_xml_lettings_logs: { "some_file_base_name" => start_time }) }
|
||
|
|
||
|
context "and lettings log archive gets created in lettings log export" do
|
||
|
let(:organisations_export_service) { instance_double("Exports::OrganisationExportService", export_xml_organisations: { "some_organisation_file_base_name" => start_time }) }
|
||
|
|
||
|
it "generates a master manifest with the correct name" do
|
||
|
expect(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args)
|
||
|
export_service.export_xml(full_update: true, collection: "organisations")
|
||
|
end
|
||
|
|
||
|
it "does not write lettings log data" do
|
||
|
actual_content = nil
|
||
|
expected_content = "zip-name,date-time zipped folder generated,zip-file-uri\nsome_organisation_file_base_name,2022-05-01 00:00:00 +0100,some_organisation_file_base_name.zip\n"
|
||
|
allow(storage_service).to receive(:write_file).with(expected_master_manifest_filename, any_args) { |_, arg2| actual_content = arg2&.string }
|
||
|
|
||
|
export_service.export_xml(full_update: true, collection: "organisations")
|
||
|
expect(actual_content).to eq(expected_content)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|