require "rails_helper" require "rake" describe "full import", type: :task do let(:instance_name) { "paas_import_instance" } let(:paas_config_service) { instance_double(Configuration::PaasConfigurationService) } let(:env_config_service) { instance_double(Configuration::EnvConfigurationService) } let(:storage_service) { instance_double(Storage::S3Service) } let(:orgs_list) { "Institution name,Id,Old Completed lettings logs,Old In progress lettings logs,Old Completed sales logs,Old In progress sales logs\norg1,1.zip,0,0,0,0\norg2,2.zip,0,0,0,0" } before do allow(Storage::S3Service).to receive(:new).and_return(storage_service) allow(storage_service).to receive(:write_file).and_return(nil) allow(storage_service).to receive(:get_file_io).and_return(orgs_list) allow(Configuration::PaasConfigurationService).to receive(:new).and_return(paas_config_service) allow(Configuration::EnvConfigurationService).to receive(:new).and_return(env_config_service) allow(ENV).to receive(:[]) allow(ENV).to receive(:[]).with("IMPORT_PAAS_INSTANCE").and_return(instance_name) end describe "import:generate_reports" do subject(:task) { Rake::Task["import:generate_reports"] } before do Rake.application.rake_require("tasks/full_import") Rake::Task.define_task(:environment) task.reenable end context "when generating report" do let(:import_report_service) { instance_double(Imports::ImportReportService) } before do allow(Imports::ImportReportService).to receive(:new).and_return(import_report_service) end it "creates a report using given organisation csv when the VCAP_SERVICES environment variable exists" do allow(ENV).to receive(:[]).with("VCAP_SERVICES").and_return("dummy") expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) expect(Imports::ImportReportService).to receive(:new).with(storage_service, CSV.parse(orgs_list, headers: true)) expect(import_report_service).to receive(:create_reports).with("some_name") task.invoke("some_name") end it "creates a report using given organisation csv when the VCAP_SERVICES environment variable does not exist" do allow(ENV).to receive(:[]).with("VCAP_SERVICES") expect(Storage::S3Service).to receive(:new).with(env_config_service, instance_name) expect(Imports::ImportReportService).to receive(:new).with(storage_service, CSV.parse(orgs_list, headers: true)) expect(import_report_service).to receive(:create_reports).with("some_name") task.invoke("some_name") end end end describe "import:initial" do subject(:task) { Rake::Task["import:initial"] } let(:archive_service) { instance_double(Storage::ArchiveService) } before do Rake.application.rake_require("tasks/full_import") Rake::Task.define_task(:environment) task.reenable end context "when calling the initial import" do before do allow(Storage::ArchiveService).to receive(:new).and_return(archive_service) allow(archive_service).to receive(:folder_present?).and_return(false) allow(Imports::OrganisationImportService).to receive(:new).and_return(instance_double(Imports::OrganisationImportService)) allow(Imports::SchemeImportService).to receive(:new).and_return(instance_double(Imports::SchemeImportService)) allow(Imports::SchemeLocationImportService).to receive(:new).and_return(instance_double(Imports::SchemeLocationImportService)) allow(Imports::UserImportService).to receive(:new).and_return(instance_double(Imports::UserImportService)) allow(Imports::DataProtectionConfirmationImportService).to receive(:new).and_return(instance_double(Imports::DataProtectionConfirmationImportService)) allow(Imports::OrganisationRentPeriodImportService).to receive(:new).and_return(instance_double(Imports::OrganisationRentPeriodImportService)) end it "creates a report using given organisation csv" do expect(Storage::S3Service).to receive(:new).with(env_config_service, instance_name) expect(storage_service).to receive(:write_file).with("some_name_1_initial.log", / INFO -- : Performing initial imports for organisation org1/) expect(storage_service).to receive(:write_file).with("some_name_2_initial.log", / INFO -- : Performing initial imports for organisation org2/) task.invoke("some_name.csv") end end end describe "import:logs" do subject(:task) { Rake::Task["import:logs"] } let(:archive_service) { instance_double(Storage::ArchiveService) } before do Rake.application.rake_require("tasks/full_import") Rake::Task.define_task(:environment) task.reenable end context "when calling the logs import" do before do allow(Storage::ArchiveService).to receive(:new).and_return(archive_service) allow(archive_service).to receive(:folder_present?).and_return(false) allow(Imports::LettingsLogsImportService).to receive(:new).and_return(instance_double(Imports::LettingsLogsImportService)) allow(Imports::SalesLogsImportService).to receive(:new).and_return(instance_double(Imports::SalesLogsImportService)) end it "creates a report using given organisation csv" do expect(Storage::S3Service).to receive(:new).with(env_config_service, instance_name) expect(storage_service).to receive(:write_file).with("some_name_1_logs.log", / INFO -- : Importing logs for organisation org1, expecting 0 logs/) expect(storage_service).to receive(:write_file).with("some_name_2_logs.log", / INFO -- : Importing logs for organisation org2, expecting 0 logs/) task.invoke("some_name.csv") end end end end