6 changed files with 84 additions and 0 deletions
@ -0,0 +1,4 @@ |
|||||||
|
class DataProtectionConfirmation < ApplicationRecord |
||||||
|
belongs_to :organisation |
||||||
|
belongs_to :data_protection_officer, class_name: "User" |
||||||
|
end |
@ -0,0 +1,11 @@ |
|||||||
|
class CreateDataProtectionConfirmation < ActiveRecord::Migration[7.0] |
||||||
|
def change |
||||||
|
create_table :data_protection_confirmations do |t| |
||||||
|
t.belongs_to :organisation |
||||||
|
t.belongs_to :data_protection_officer, class_name: "User", index: { name: :dpo_user_id } |
||||||
|
t.column :confirmed, :boolean |
||||||
|
|
||||||
|
t.timestamps |
||||||
|
end |
||||||
|
end |
||||||
|
end |
@ -0,0 +1,7 @@ |
|||||||
|
<dataprotect:dataprotect xmlns:dataprotect="dclg:dataprotect"> |
||||||
|
<dataprotect:id>7c5bd5fb549c09a2c55d7cb90d7ba84927e64618</dataprotect:id> |
||||||
|
<dataprotect:institution>7c5bd5fb549c09a2c55d7cb90d7ba84927e64618</dataprotect:institution> |
||||||
|
<dataprotect:data-protection>true</dataprotect:data-protection> |
||||||
|
<dataprotect:dp-user>John Doe</dataprotect:dp-user> |
||||||
|
<dataprotect:change-date>05/06/2018 10:36:49:34</dataprotect:change-date> |
||||||
|
</dataprotect:dataprotect> |
@ -0,0 +1,48 @@ |
|||||||
|
require "rails_helper" |
||||||
|
|
||||||
|
RSpec.describe Imports::UserImportService do |
||||||
|
let(:fixture_directory) { "spec/fixtures/softwire_imports/users" } |
||||||
|
let(:old_org_id) { "7c5bd5fb549c09a2c55d7cb90d7ba84927e64618" } |
||||||
|
let(:old_data_protection_confirmation_id) { old_org_id } |
||||||
|
let(:import_file) { File.open("#{fixture_directory}/#{old_data_protection_confirmation_id}.xml") } |
||||||
|
let(:storage_service) { instance_double(StorageService) } |
||||||
|
|
||||||
|
context "when importing users" do |
||||||
|
subject(:import_service) { described_class.new(storage_service) } |
||||||
|
|
||||||
|
before do |
||||||
|
allow(storage_service) |
||||||
|
.to receive(:list_files) |
||||||
|
.and_return(["data_protection_directory/#{old_data_protection_confirmation_id}.xml"]) |
||||||
|
allow(storage_service) |
||||||
|
.to receive(:get_file_io) |
||||||
|
.with("user_directory/#{old_data_protection_confirmation_id}.xml") |
||||||
|
.and_return(import_file) |
||||||
|
end |
||||||
|
|
||||||
|
it "successfully create a data protection confirmation record with the expected data" do |
||||||
|
FactoryBot.create(:organisation, old_org_id:) |
||||||
|
import_service.create_data_protection_confirmations("data_protection_directory") |
||||||
|
|
||||||
|
confirmation = Organisation.find_by(old_user_id:).data_protection_confirmations.last |
||||||
|
expect(confirmation.user.name).to eq("John Doe") |
||||||
|
expect(confirmation.confirmed).to be_truthy |
||||||
|
end |
||||||
|
|
||||||
|
it "refuses to create a data protection confirmation belonging to a non existing organisation" do |
||||||
|
expect { import_service.create_data_protection_confirmations("data_protection_directory") } |
||||||
|
.to raise_error(ActiveRecord::RecordInvalid, /Organisation must exist/) |
||||||
|
end |
||||||
|
|
||||||
|
context "when the data protection record has already been imported previously" do |
||||||
|
before do |
||||||
|
org = FactoryBot.create(:organisation, old_org_id:) |
||||||
|
end |
||||||
|
|
||||||
|
it "logs that the user already exists" do |
||||||
|
expect(Rails.logger).to receive(:warn) |
||||||
|
import_service.create_data_protection_confirmations("data_protection_directory") |
||||||
|
end |
||||||
|
end |
||||||
|
end |
||||||
|
end |
Loading…
Reference in new issue