describe InstructeursImportService do describe '#import_groupes' do let(:procedure) { create(:procedure) } let(:procedure_groupes) do procedure .groupe_instructeurs .map { |gi| [gi.label, gi.instructeurs.map(&:email)] } .to_h end subject { described_class.import_groupes(procedure, lines) } context 'nominal case' do let(:lines) do [ { "groupe" => "Auvergne Rhone-Alpes", "email" => "john@lennon.fr" }, { "groupe" => " Occitanie ", "email" => "paul@mccartney.uk" }, { "groupe" => "Occitanie", "email" => "ringo@starr.uk" } ] end it 'imports groupes' do errors = subject expect(procedure_groupes.keys).to contain_exactly("Auvergne Rhone-Alpes", "Occitanie", "défaut") expect(procedure_groupes["Auvergne Rhone-Alpes"]).to contain_exactly("john@lennon.fr") expect(procedure_groupes["Occitanie"]).to contain_exactly("paul@mccartney.uk", "ringo@starr.uk") expect(procedure_groupes["défaut"]).to be_empty expect(errors).to match_array([]) end end context 'when group already exists' do let!(:gi) { create(:groupe_instructeur, label: 'Occitanie', procedure: procedure) } let(:lines) do [ { "groupe" => "Occitanie", "email" => "ringo@starr.uk" } ] end before do gi.instructeurs << create(:instructeur, email: 'george@harisson.uk') end it 'adds instructeur to existing groupe' do subject expect(procedure_groupes.keys).to contain_exactly("Occitanie", "défaut") expect(procedure_groupes["Occitanie"]).to contain_exactly("george@harisson.uk", "ringo@starr.uk") expect(procedure_groupes["défaut"]).to be_empty end end context 'when an email is malformed' do let(:lines) do [ { "groupe" => "Occitanie", "email" => "paul" }, { "groupe" => "Occitanie", "email" => "  Paul@mccartney.uk " }, { "groupe" => "Occitanie", "email" => "ringo@starr.uk" } ] end it 'ignores or corrects' do errors = subject expect(procedure_groupes.keys).to contain_exactly("Occitanie", "défaut") expect(procedure_groupes["Occitanie"]).to contain_exactly("paul@mccartney.uk", "ringo@starr.uk") expect(procedure_groupes["défaut"]).to be_empty expect(errors).to contain_exactly("paul") end end context 'when an instructeur already exists' do let!(:instructeur) { create(:instructeur) } let(:lines) do [ { "groupe" => "Occitanie", "email" => instructeur.email }, { "groupe" => "Occitanie", "email" => "ringo@starr.uk" } ] end it 'reuses instructeur' do subject expect(procedure_groupes.keys).to contain_exactly("Occitanie", "défaut") expect(procedure_groupes["Occitanie"]).to contain_exactly(instructeur.email, "ringo@starr.uk") expect(procedure_groupes["défaut"]).to be_empty end end context 'when there are 2 emails of same instructeur to be imported' do let(:lines) do [ { "groupe" => "Occitanie", "email" => "ringo@starr.uk" }, { "groupe" => "Occitanie", "email" => "ringo@starr.uk" } ] end it 'ignores duplicated instructeur' do subject expect(procedure_groupes.keys).to contain_exactly("Occitanie", "défaut") expect(procedure_groupes["Occitanie"]).to contain_exactly("ringo@starr.uk") expect(procedure_groupes["défaut"]).to be_empty end end context 'when label of group is empty' do let(:lines) do [ { "groupe" => "", "email" => "ringo@starr.uk" }, { "groupe" => " ", "email" => "paul@starr.uk" } ] end it 'ignores instructeur' do errors = subject expect(procedure_groupes.keys).to contain_exactly("défaut") expect(procedure_groupes["défaut"]).to be_empty expect(errors).to contain_exactly("ringo@starr.uk", "paul@starr.uk") end end end describe '#import_instructeurs' do let(:procedure_non_routee) { create(:procedure) } subject { described_class.import_instructeurs(procedure_non_routee, emails) } context 'nominal case' do let(:emails) { [{ "email" => "john@lennon.fr" }, { "email" => "paul@mccartney.uk" }, { "email" => "ringo@starr.uk" }] } it 'imports instructeurs' do errors = subject expect(procedure_non_routee.defaut_groupe_instructeur.instructeurs.pluck(:email)).to contain_exactly("john@lennon.fr", "paul@mccartney.uk", "ringo@starr.uk") expect(errors).to match_array([]) end end end end