You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							333 lines
						
					
					
						
							19 KiB
						
					
					
				
			
		
		
	
	
							333 lines
						
					
					
						
							19 KiB
						
					
					
				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
 | 
						|
 |