demarches-normaliennes/spec/controllers/gestionnaires/groupe_gestionnaire_commentaires_controller_spec.rb
2024-08-22 09:26:48 +02:00

188 lines
7.5 KiB
Ruby

# frozen_string_literal: true
describe Gestionnaires::GroupeGestionnaireCommentairesController, type: :controller do
let(:gestionnaire) { create(:gestionnaire).tap { _1.user.update(last_sign_in_at: Time.zone.now) } }
let(:administrateur) { administrateurs(:default_admin) }
let(:groupe_gestionnaire) { create(:groupe_gestionnaire, gestionnaires: [gestionnaire], administrateurs: [administrateur]) }
let!(:commentaire) { create(:commentaire_groupe_gestionnaire, groupe_gestionnaire: groupe_gestionnaire, sender: administrateur) }
describe "#index" do
let(:subject_gestionnaire) { gestionnaire }
let(:subject_groupe_gestionnaire) { groupe_gestionnaire }
render_views
subject { get :index, params: { groupe_gestionnaire_id: subject_groupe_gestionnaire.id } }
context "when not logged" do
before { subject }
it { expect(response).to redirect_to(new_user_session_path) }
end
describe "when logged in" do
before do
sign_in(subject_gestionnaire.user)
subject
end
context "in a root group" do
it do
expect(response).to have_http_status(:ok)
expect(assigns(:groupe_gestionnaire).current_commentaires_groupe_and_children_commentaires_groupe.select("sender_id, sender_type, sender_email, MAX(id) as id, MAX(created_at) as created_at").group(:sender_id, :sender_type, :sender_email).order("MAX(id) DESC")).to include(commentaire)
expect(response.body).to include(commentaire.sender_email)
expect(response.body).not_to include("Messages avec le groupe gestionnaire parent")
end
end
context "in a child group" do
let(:child_gestionnaire) { create(:gestionnaire).tap { _1.user.update(last_sign_in_at: Time.zone.now) } }
let!(:child_groupe_gestionnaire) { create(:groupe_gestionnaire, ancestry: "/#{groupe_gestionnaire.id}/", gestionnaires: [child_gestionnaire]) }
let(:subject_groupe_gestionnaire) { child_groupe_gestionnaire }
let(:subject_gestionnaire) { child_gestionnaire }
let!(:commentaire_to_parent_groupe_gestionnaire) { create(:commentaire_groupe_gestionnaire, groupe_gestionnaire: child_groupe_gestionnaire, sender: child_gestionnaire) }
it do
expect(response).to have_http_status(:ok)
expect(assigns(:groupe_gestionnaire).current_commentaires_groupe_and_children_commentaires_groupe.or(CommentaireGroupeGestionnaire.where(groupe_gestionnaire_id: child_groupe_gestionnaire.id, sender: child_gestionnaire)).select("sender_id, sender_type, sender_email, MAX(id) as id, MAX(created_at) as created_at").group(:sender_id, :sender_type, :sender_email).order("MAX(id) DESC")).to include(commentaire_to_parent_groupe_gestionnaire)
expect(response.body).to include(commentaire_to_parent_groupe_gestionnaire.sender_email)
expect(response.body).to include("Messages avec le groupe gestionnaire parent")
end
end
end
end
describe "#show" do
render_views
subject { get :show, params: { groupe_gestionnaire_id: groupe_gestionnaire.id, id: commentaire.id } }
context "when not logged" do
before { subject }
it { expect(response).to redirect_to(new_user_session_path) }
end
context "when logged in" do
before do
sign_in(gestionnaire.user)
subject
end
it do
expect(response).to have_http_status(:ok)
expect(assigns(:groupe_gestionnaire).commentaire_groupe_gestionnaires.where(sender: administrateur)).to include(commentaire)
expect(response.body).to include(commentaire.body)
end
end
end
describe "#create" do
before do
sign_in(gestionnaire.user)
post :create,
params: {
id: commentaire.id,
groupe_gestionnaire_id: groupe_gestionnaire.id,
commentaire_groupe_gestionnaire: { body: "avant\napres" }
}
end
context 'of a new commentaire' do
it do
expect(groupe_gestionnaire.reload.commentaire_groupe_gestionnaires.map(&:body)).to include("avant\napres")
expect(flash.notice).to eq("Message envoyé")
end
end
end
describe "#parent_groupe_gestionnaire" do
let!(:child_groupe_gestionnaire) { create(:groupe_gestionnaire, ancestry: "/#{groupe_gestionnaire.id}/", gestionnaires: [gestionnaire]) }
render_views
subject { get :parent_groupe_gestionnaire, params: { groupe_gestionnaire_id: child_groupe_gestionnaire.id } }
context "when not logged" do
before { subject }
it { expect(response).to redirect_to(new_user_session_path) }
end
describe "when logged in" do
before do
sign_in(gestionnaire.user)
subject
end
context "without a commentaire to parent_group_gestionnaire" do
it do
expect(response).to have_http_status(:ok)
expect(assigns(:groupe_gestionnaire).commentaire_groupe_gestionnaires.where(sender: gestionnaire)).not_to include(commentaire)
expect(response.body).not_to include(commentaire.body)
end
end
context "with a commentaire to parent_group_gestionnaire" do
let!(:commentaire) { create(:commentaire_groupe_gestionnaire, groupe_gestionnaire: child_groupe_gestionnaire, sender: gestionnaire) }
it do
expect(response).to have_http_status(:ok)
expect(assigns(:groupe_gestionnaire).commentaire_groupe_gestionnaires.where(sender: gestionnaire)).to include(commentaire)
expect(response.body).to include(commentaire.body)
end
end
end
end
describe "#create_parent_groupe_gestionnaire" do
let!(:child_groupe_gestionnaire) { create(:groupe_gestionnaire, ancestry: "/#{groupe_gestionnaire.id}/", gestionnaires: [gestionnaire]) }
before do
sign_in(gestionnaire.user)
post :create_parent_groupe_gestionnaire,
params: {
id: commentaire.id,
groupe_gestionnaire_id: child_groupe_gestionnaire.id,
commentaire_groupe_gestionnaire: { body: "avant\napres" }
}
end
context 'of a new commentaire' do
it do
expect(child_groupe_gestionnaire.reload.commentaire_groupe_gestionnaires.map(&:body)).to include("avant\napres")
expect(flash.notice).to eq("Message envoyé")
end
end
end
describe "#destroy" do
before do
sign_in(gestionnaire.user)
end
def remove_commentaire(commentaire)
delete :destroy,
params: {
groupe_gestionnaire_id: groupe_gestionnaire.id,
id: commentaire_to_delete.id
},
format: :turbo_stream
end
context 'when the commentaire was created by the gestionnaire' do
let(:commentaire_to_delete) { create(:commentaire_groupe_gestionnaire, groupe_gestionnaire: groupe_gestionnaire, gestionnaire: gestionnaire, sender: administrateur) }
before { remove_commentaire(commentaire_to_delete) }
it do
expect(groupe_gestionnaire.reload.commentaire_groupe_gestionnaires.count).to eq(2)
expect(commentaire_to_delete.reload.discarded?).to eq(true)
expect(flash.notice).to eq("Votre message a été supprimé")
end
end
context 'when the commentaire was not created by the gestionnaire' do
let(:commentaire_to_delete) { commentaire }
before { remove_commentaire(commentaire_to_delete) }
it do
expect(groupe_gestionnaire.reload.commentaire_groupe_gestionnaires.count).to eq(1)
expect(commentaire_to_delete.reload.discarded?).to eq(false)
expect(flash.alert).to eq("Impossible de supprimer le message, celui-ci ne vous appartient pas")
end
end
end
end