121 lines
4.7 KiB
Ruby
121 lines
4.7 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
describe Administrateurs::ChorusController, type: :controller do
|
|
let(:user) { create(:user) }
|
|
let(:admin) { create(:administrateur, user: create(:user)) }
|
|
let(:procedure) { create(:procedure, administrateurs: [admin]) }
|
|
|
|
describe '#edit' do
|
|
subject { get :edit, params: { procedure_id: procedure.id } }
|
|
|
|
context 'when user is not signed in' do
|
|
it { is_expected.to redirect_to(new_user_session_path) }
|
|
end
|
|
|
|
context 'when user is signed in but not admin of procedure' do
|
|
before { sign_in(user) }
|
|
it { is_expected.to redirect_to(new_user_session_path) }
|
|
end
|
|
|
|
context 'when user is signed as admin' do
|
|
before { sign_in(admin.user) }
|
|
it { is_expected.to have_http_status(200) }
|
|
|
|
context 'rendered' do
|
|
render_views
|
|
|
|
it { is_expected.to have_http_status(200) }
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#update' do
|
|
let(:chorus_configuration_params) { {} }
|
|
subject do
|
|
put :update,
|
|
params: {
|
|
procedure_id: procedure.id,
|
|
chorus_configuration: chorus_configuration_params
|
|
}
|
|
end
|
|
|
|
context 'when user is not signed in' do
|
|
it { is_expected.to redirect_to(new_user_session_path) }
|
|
end
|
|
|
|
context 'when user is signed in but not admin of procedure' do
|
|
before { sign_in(user) }
|
|
it { is_expected.to redirect_to(new_user_session_path) }
|
|
end
|
|
|
|
context 'when user is signed as admin' do
|
|
before { sign_in(admin.user) }
|
|
let(:domaine_fonctionnel) { nil }
|
|
let(:referentiel_de_programmation) { nil }
|
|
|
|
context "partial valid payload" do
|
|
let(:centre_de_cout) { '{"code":"D00C8DX004","label":"Aumôniers+protestant","ville":null,"code_postal":null,"description":"Aumoniers+protestants"}' }
|
|
let(:chorus_configuration_params) do
|
|
{
|
|
centre_de_cout:, domaine_fonctionnel:, referentiel_de_programmation:
|
|
}
|
|
end
|
|
it 'updates params and redirect back to complete all infos' do
|
|
expect(subject).to redirect_to(edit_admin_procedure_chorus_path(procedure))
|
|
expect(flash[:notice]).to eq("La configuration Chorus a été mise à jour. Veuillez renseigner le reste des informations pour faciliter le rapprochement des données.")
|
|
|
|
procedure.reload
|
|
|
|
expect(procedure.chorus_configuration.centre_de_cout).to eq(JSON.parse(centre_de_cout))
|
|
expect(procedure.chorus_configuration.domaine_fonctionnel).to eq(nil)
|
|
expect(procedure.chorus_configuration.referentiel_de_programmation).to eq(nil)
|
|
end
|
|
end
|
|
|
|
context "full valid payload" do
|
|
let(:centre_de_cout) { '{"code":"D00C8DX004","label":"Aumôniers+protestant","ville":null,"code_postal":null,"description":"Aumoniers+protestants"}' }
|
|
let(:domaine_fonctionnel) { '{"code":"0105-05-01","label":"Formation+des+élites+et+cadres+de+sécurité+et+de+défense","description":null,"code_programme":"105"}' }
|
|
let(:referentiel_de_programmation) { '{"code":"010101010101","label":"DOTATIONS+CARPA+AJ+ET+AUTRES+INTERVENTIONS","description":null,"code_programme":"101"}' }
|
|
let(:chorus_configuration_params) do
|
|
{
|
|
centre_de_cout:, domaine_fonctionnel:, referentiel_de_programmation:
|
|
}
|
|
end
|
|
|
|
it 'updates params and redirects to add champs EngagementJuridique' do
|
|
expect(subject).to redirect_to(add_champ_engagement_juridique_admin_procedure_chorus_path(procedure))
|
|
expect(flash[:notice]).to eq("La configuration Chorus a été mise à jour.")
|
|
|
|
procedure.reload
|
|
|
|
expect(procedure.chorus_configuration.centre_de_cout).to eq(JSON.parse(centre_de_cout))
|
|
expect(procedure.chorus_configuration.domaine_fonctionnel).to eq(JSON.parse(domaine_fonctionnel))
|
|
expect(procedure.chorus_configuration.referentiel_de_programmation).to eq(JSON.parse(referentiel_de_programmation))
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
describe '#add_champ_engagement_juridique' do
|
|
render_views
|
|
subject { get :add_champ_engagement_juridique, params: { procedure_id: procedure.id } }
|
|
|
|
context 'when user is not signed in' do
|
|
it { is_expected.to redirect_to(new_user_session_path) }
|
|
end
|
|
|
|
context 'when user is signed in but not admin of procedure' do
|
|
before { sign_in(user) }
|
|
it { is_expected.to redirect_to(new_user_session_path) }
|
|
end
|
|
|
|
context 'when user is signed as admin' do
|
|
before { sign_in(admin.user) }
|
|
|
|
it 'have links to add annotation' do
|
|
expect(subject).to have_http_status(:success)
|
|
expect(response.body).to have_link("Ajouter une annotation privée EJ", href: annotations_admin_procedure_path(procedure))
|
|
end
|
|
end
|
|
end
|
|
end
|