Browse Source
* Add test as a proof of the bug we have in prod * Refactor script to create users with unique email * Add rake task to import missing data protection confirmationspull/1731/head
Jack
2 years ago
committed by
GitHub
4 changed files with 204 additions and 129 deletions
@ -1,177 +1,217 @@ |
|||||||
require "rails_helper" |
require "rails_helper" |
||||||
require "rake" |
require "rake" |
||||||
|
|
||||||
describe "rake core:data_import", type: :task do |
describe "data import", type: :task do |
||||||
subject(:task) { Rake::Task["core:data_import"] } |
|
||||||
|
|
||||||
let(:instance_name) { "paas_import_instance" } |
let(:instance_name) { "paas_import_instance" } |
||||||
let(:storage_service) { instance_double(Storage::S3Service) } |
|
||||||
let(:paas_config_service) { instance_double(Configuration::PaasConfigurationService) } |
let(:paas_config_service) { instance_double(Configuration::PaasConfigurationService) } |
||||||
|
let(:storage_service) { instance_double(Storage::S3Service) } |
||||||
|
|
||||||
before do |
describe "core:data_import" do |
||||||
Rake.application.rake_require("tasks/data_import") |
subject(:task) { Rake::Task["core:data_import"] } |
||||||
Rake::Task.define_task(:environment) |
|
||||||
task.reenable |
|
||||||
|
|
||||||
allow(Storage::S3Service).to receive(:new).and_return(storage_service) |
|
||||||
allow(Configuration::PaasConfigurationService).to receive(:new).and_return(paas_config_service) |
|
||||||
allow(ENV).to receive(:[]) |
|
||||||
allow(ENV).to receive(:[]).with("IMPORT_PAAS_INSTANCE").and_return(instance_name) |
|
||||||
end |
|
||||||
|
|
||||||
context "when importing organisation data" do |
|
||||||
let(:type) { "organisation" } |
|
||||||
let(:import_service) { instance_double(Imports::OrganisationImportService) } |
|
||||||
let(:fixture_path) { "spec/fixtures/imports/organisations" } |
|
||||||
|
|
||||||
before do |
before do |
||||||
allow(Imports::OrganisationImportService).to receive(:new).and_return(import_service) |
Rake.application.rake_require("tasks/data_import") |
||||||
|
Rake::Task.define_task(:environment) |
||||||
|
task.reenable |
||||||
|
|
||||||
|
allow(Storage::S3Service).to receive(:new).and_return(storage_service) |
||||||
|
allow(Configuration::PaasConfigurationService).to receive(:new).and_return(paas_config_service) |
||||||
|
allow(ENV).to receive(:[]) |
||||||
|
allow(ENV).to receive(:[]).with("IMPORT_PAAS_INSTANCE").and_return(instance_name) |
||||||
end |
end |
||||||
|
|
||||||
it "creates an organisation from the given XML file" do |
context "when importing organisation data" do |
||||||
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
let(:type) { "organisation" } |
||||||
expect(Imports::OrganisationImportService).to receive(:new).with(storage_service) |
let(:import_service) { instance_double(Imports::OrganisationImportService) } |
||||||
expect(import_service).to receive(:create_organisations).with(fixture_path) |
let(:fixture_path) { "spec/fixtures/imports/organisations" } |
||||||
|
|
||||||
task.invoke(type, fixture_path) |
before do |
||||||
end |
allow(Imports::OrganisationImportService).to receive(:new).and_return(import_service) |
||||||
end |
end |
||||||
|
|
||||||
context "when importing user data" do |
it "creates an organisation from the given XML file" do |
||||||
let(:type) { "user" } |
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
||||||
let(:import_service) { instance_double(Imports::UserImportService) } |
expect(Imports::OrganisationImportService).to receive(:new).with(storage_service) |
||||||
let(:fixture_path) { "spec/fixtures/imports/users" } |
expect(import_service).to receive(:create_organisations).with(fixture_path) |
||||||
|
|
||||||
before do |
task.invoke(type, fixture_path) |
||||||
allow(Imports::UserImportService).to receive(:new).and_return(import_service) |
end |
||||||
end |
end |
||||||
|
|
||||||
it "creates a user from the given XML file" do |
context "when importing user data" do |
||||||
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
let(:type) { "user" } |
||||||
expect(Imports::UserImportService).to receive(:new).with(storage_service) |
let(:import_service) { instance_double(Imports::UserImportService) } |
||||||
expect(import_service).to receive(:create_users).with(fixture_path) |
let(:fixture_path) { "spec/fixtures/imports/users" } |
||||||
|
|
||||||
task.invoke(type, fixture_path) |
before do |
||||||
end |
allow(Imports::UserImportService).to receive(:new).and_return(import_service) |
||||||
end |
end |
||||||
|
|
||||||
context "when importing data protection confirmation data" do |
it "creates a user from the given XML file" do |
||||||
let(:type) { "data-protection-confirmation" } |
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
||||||
let(:import_service) { instance_double(Imports::DataProtectionConfirmationImportService) } |
expect(Imports::UserImportService).to receive(:new).with(storage_service) |
||||||
let(:fixture_path) { "spec/fixtures/imports/data_protection_confirmations" } |
expect(import_service).to receive(:create_users).with(fixture_path) |
||||||
|
|
||||||
before do |
task.invoke(type, fixture_path) |
||||||
allow(Imports::DataProtectionConfirmationImportService).to receive(:new).and_return(import_service) |
end |
||||||
end |
end |
||||||
|
|
||||||
it "creates an organisation from the given XML file" do |
context "when importing data protection confirmation data" do |
||||||
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
let(:type) { "data-protection-confirmation" } |
||||||
expect(Imports::DataProtectionConfirmationImportService).to receive(:new).with(storage_service) |
let(:import_service) { instance_double(Imports::DataProtectionConfirmationImportService) } |
||||||
expect(import_service).to receive(:create_data_protection_confirmations).with(fixture_path) |
let(:fixture_path) { "spec/fixtures/imports/data_protection_confirmations" } |
||||||
|
|
||||||
task.invoke(type, fixture_path) |
before do |
||||||
end |
allow(Imports::DataProtectionConfirmationImportService).to receive(:new).and_return(import_service) |
||||||
end |
end |
||||||
|
|
||||||
context "when importing organisation rent period data" do |
it "creates an organisation from the given XML file" do |
||||||
let(:type) { "organisation-rent-periods" } |
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
||||||
let(:import_service) { instance_double(Imports::OrganisationRentPeriodImportService) } |
expect(Imports::DataProtectionConfirmationImportService).to receive(:new).with(storage_service) |
||||||
let(:fixture_path) { "spec/fixtures/imports/organisation_rent_periods" } |
expect(import_service).to receive(:create_data_protection_confirmations).with(fixture_path) |
||||||
|
|
||||||
before do |
task.invoke(type, fixture_path) |
||||||
allow(Imports::OrganisationRentPeriodImportService).to receive(:new).and_return(import_service) |
end |
||||||
end |
end |
||||||
|
|
||||||
it "creates an organisation la from the given XML file" do |
context "when importing organisation rent period data" do |
||||||
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
let(:type) { "organisation-rent-periods" } |
||||||
expect(Imports::OrganisationRentPeriodImportService).to receive(:new).with(storage_service) |
let(:import_service) { instance_double(Imports::OrganisationRentPeriodImportService) } |
||||||
expect(import_service).to receive(:create_organisation_rent_periods).with(fixture_path) |
let(:fixture_path) { "spec/fixtures/imports/organisation_rent_periods" } |
||||||
|
|
||||||
task.invoke(type, fixture_path) |
before do |
||||||
end |
allow(Imports::OrganisationRentPeriodImportService).to receive(:new).and_return(import_service) |
||||||
end |
end |
||||||
|
|
||||||
context "when importing lettings logs" do |
it "creates an organisation la from the given XML file" do |
||||||
let(:type) { "lettings-logs" } |
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
||||||
let(:import_service) { instance_double(Imports::LettingsLogsImportService) } |
expect(Imports::OrganisationRentPeriodImportService).to receive(:new).with(storage_service) |
||||||
let(:fixture_path) { "spec/fixtures/imports/lettings_logs" } |
expect(import_service).to receive(:create_organisation_rent_periods).with(fixture_path) |
||||||
|
|
||||||
before do |
task.invoke(type, fixture_path) |
||||||
allow(Imports::LettingsLogsImportService).to receive(:new).and_return(import_service) |
end |
||||||
end |
end |
||||||
|
|
||||||
it "creates lettings logs from the given XML file" do |
context "when importing lettings logs" do |
||||||
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
let(:type) { "lettings-logs" } |
||||||
expect(Imports::LettingsLogsImportService).to receive(:new).with(storage_service) |
let(:import_service) { instance_double(Imports::LettingsLogsImportService) } |
||||||
expect(import_service).to receive(:create_logs).with(fixture_path) |
let(:fixture_path) { "spec/fixtures/imports/lettings_logs" } |
||||||
|
|
||||||
|
before do |
||||||
|
allow(Imports::LettingsLogsImportService).to receive(:new).and_return(import_service) |
||||||
|
end |
||||||
|
|
||||||
task.invoke(type, fixture_path) |
it "creates lettings logs from the given XML file" do |
||||||
|
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
||||||
|
expect(Imports::LettingsLogsImportService).to receive(:new).with(storage_service) |
||||||
|
expect(import_service).to receive(:create_logs).with(fixture_path) |
||||||
|
|
||||||
|
task.invoke(type, fixture_path) |
||||||
|
end |
||||||
end |
end |
||||||
end |
|
||||||
|
|
||||||
context "when importing sales logs" do |
context "when importing sales logs" do |
||||||
let(:type) { "sales-logs" } |
let(:type) { "sales-logs" } |
||||||
let(:import_service) { instance_double(Imports::SalesLogsImportService) } |
let(:import_service) { instance_double(Imports::SalesLogsImportService) } |
||||||
let(:fixture_path) { "spec/fixtures/imports/sales_logs" } |
let(:fixture_path) { "spec/fixtures/imports/sales_logs" } |
||||||
|
|
||||||
before do |
before do |
||||||
allow(Imports::SalesLogsImportService).to receive(:new).and_return(import_service) |
allow(Imports::SalesLogsImportService).to receive(:new).and_return(import_service) |
||||||
|
end |
||||||
|
|
||||||
|
it "creates sales logs from the given XML file" do |
||||||
|
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
||||||
|
expect(Imports::SalesLogsImportService).to receive(:new).with(storage_service) |
||||||
|
expect(import_service).to receive(:create_logs).with(fixture_path) |
||||||
|
|
||||||
|
task.invoke(type, fixture_path) |
||||||
|
end |
||||||
end |
end |
||||||
|
|
||||||
it "creates sales logs from the given XML file" do |
context "when importing scheme data" do |
||||||
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
let(:type) { "scheme" } |
||||||
expect(Imports::SalesLogsImportService).to receive(:new).with(storage_service) |
let(:import_service) { instance_double(Imports::SchemeImportService) } |
||||||
expect(import_service).to receive(:create_logs).with(fixture_path) |
let(:fixture_path) { "spec/fixtures/imports/schemes" } |
||||||
|
|
||||||
|
before do |
||||||
|
allow(Imports::SchemeImportService).to receive(:new).and_return(import_service) |
||||||
|
end |
||||||
|
|
||||||
|
it "creates a scheme from the given XML file" do |
||||||
|
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
||||||
|
expect(Imports::SchemeImportService).to receive(:new).with(storage_service) |
||||||
|
expect(import_service).to receive(:create_schemes).with(fixture_path) |
||||||
|
|
||||||
task.invoke(type, fixture_path) |
task.invoke(type, fixture_path) |
||||||
|
end |
||||||
end |
end |
||||||
end |
|
||||||
|
|
||||||
context "when importing scheme data" do |
context "when importing scheme location data" do |
||||||
let(:type) { "scheme" } |
let(:type) { "scheme-location" } |
||||||
let(:import_service) { instance_double(Imports::SchemeImportService) } |
let(:import_service) { instance_double(Imports::SchemeLocationImportService) } |
||||||
let(:fixture_path) { "spec/fixtures/imports/schemes" } |
let(:fixture_path) { "spec/fixtures/imports/organisations" } |
||||||
|
|
||||||
before do |
before do |
||||||
allow(Imports::SchemeImportService).to receive(:new).and_return(import_service) |
allow(Imports::SchemeLocationImportService).to receive(:new).and_return(import_service) |
||||||
|
end |
||||||
|
|
||||||
|
it "creates a scheme location from the given XML file" do |
||||||
|
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
||||||
|
expect(Imports::SchemeLocationImportService).to receive(:new).with(storage_service) |
||||||
|
expect(import_service).to receive(:create_scheme_locations).with(fixture_path) |
||||||
|
|
||||||
|
task.invoke(type, fixture_path) |
||||||
|
end |
||||||
end |
end |
||||||
|
|
||||||
it "creates a scheme from the given XML file" do |
it "raises an exception if no parameters are provided" do |
||||||
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
expect { task.invoke }.to raise_error(/Usage/) |
||||||
expect(Imports::SchemeImportService).to receive(:new).with(storage_service) |
end |
||||||
expect(import_service).to receive(:create_schemes).with(fixture_path) |
|
||||||
|
|
||||||
task.invoke(type, fixture_path) |
it "raises an exception if a single parameter is provided" do |
||||||
|
expect { task.invoke("one_parameter") }.to raise_error(/Usage/) |
||||||
|
end |
||||||
|
|
||||||
|
it "raises an exception if the type is not supported" do |
||||||
|
expect { task.invoke("unknown_type", "my_path") }.to raise_error(/Type unknown_type is not supported/) |
||||||
end |
end |
||||||
end |
end |
||||||
|
|
||||||
context "when importing scheme location data" do |
describe "core:data_protection_confirmation_import" do |
||||||
let(:type) { "scheme-location" } |
subject(:task) { Rake::Task["core:data_protection_confirmation_import"] } |
||||||
let(:import_service) { instance_double(Imports::SchemeLocationImportService) } |
|
||||||
let(:fixture_path) { "spec/fixtures/imports/organisations" } |
let(:import_service) { instance_double(Imports::DataProtectionConfirmationImportService) } |
||||||
|
# let(:fixture_path) { "spec/fixtures/imports/data_protection_confirmations" } |
||||||
|
let(:storage_service) { instance_double(Storage::S3Service) } |
||||||
|
let(:archive_service) { instance_double(Storage::ArchiveService) } |
||||||
|
|
||||||
|
let!(:organisation_without_dpc_with_old_org_id) { create(:organisation, :without_dpc, old_org_id: 1) } |
||||||
|
|
||||||
before do |
before do |
||||||
allow(Imports::SchemeLocationImportService).to receive(:new).and_return(import_service) |
Rake.application.rake_require("tasks/data_import") |
||||||
end |
Rake::Task.define_task(:environment) |
||||||
|
task.reenable |
||||||
|
|
||||||
|
allow(Storage::S3Service).to receive(:new).and_return(storage_service) |
||||||
|
allow(Configuration::PaasConfigurationService).to receive(:new).and_return(paas_config_service) |
||||||
|
allow(ENV).to receive(:[]) |
||||||
|
allow(ENV).to receive(:[]).with("IMPORT_PAAS_INSTANCE").and_return(instance_name) |
||||||
|
allow(Imports::DataProtectionConfirmationImportService).to receive(:new).and_return(import_service) |
||||||
|
|
||||||
it "creates a scheme location from the given XML file" do |
allow(Storage::ArchiveService).to receive(:new).and_return(archive_service) |
||||||
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
allow(archive_service).to receive(:folder_present?).with("dataprotect").and_return(true) |
||||||
expect(Imports::SchemeLocationImportService).to receive(:new).with(storage_service) |
|
||||||
expect(import_service).to receive(:create_scheme_locations).with(fixture_path) |
|
||||||
|
|
||||||
task.invoke(type, fixture_path) |
_org_without_old_org_id = create(:organisation, old_org_id: nil) |
||||||
|
_organisation_without_dp = create(:organisation, :without_dpc, old_org_id: nil) |
||||||
end |
end |
||||||
end |
|
||||||
|
|
||||||
it "raises an exception if no parameters are provided" do |
|
||||||
expect { task.invoke }.to raise_error(/Usage/) |
|
||||||
end |
|
||||||
|
|
||||||
it "raises an exception if a single parameter is provided" do |
it "creates an organisation from the given XML file" do |
||||||
expect { task.invoke("one_parameter") }.to raise_error(/Usage/) |
expect(Storage::S3Service).to receive(:new).with(paas_config_service, instance_name) |
||||||
end |
expect(storage_service).to receive(:get_file_io).with("#{organisation_without_dpc_with_old_org_id.old_org_id}.zip") |
||||||
|
expect(Imports::DataProtectionConfirmationImportService).to receive(:new).with(archive_service) |
||||||
|
expect(import_service).to receive(:create_data_protection_confirmations).with("dataprotect") |
||||||
|
|
||||||
it "raises an exception if the type is not supported" do |
task.invoke |
||||||
expect { task.invoke("unknown_type", "my_path") }.to raise_error(/Type unknown_type is not supported/) |
end |
||||||
end |
end |
||||||
end |
end |
||||||
|
Loading…
Reference in new issue