routes: replace the email param in the Avis URLs by a query param
This commit is contained in:
parent
ab442cd8d1
commit
b5bde6608c
7 changed files with 14 additions and 9 deletions
|
@ -91,7 +91,7 @@ module Experts
|
||||||
redirect_to url_for(expert_all_avis_path)
|
redirect_to url_for(expert_all_avis_path)
|
||||||
else
|
else
|
||||||
flash[:alert] = user.errors.full_messages
|
flash[:alert] = user.errors.full_messages
|
||||||
redirect_to url_for(sign_up_expert_avis_path(procedure_id, avis_id, email))
|
redirect_to sign_up_expert_avis_path(procedure_id, avis_id, email: email)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
- content_for(:title, 'Invitation à donner votre avis')
|
- content_for(:title, 'Invitation à donner votre avis')
|
||||||
- avis_link = @avis.expert.user.active?.present? ? expert_avis_url(@avis.procedure, @avis) : sign_up_expert_avis_url(@avis.procedure, @avis.id, @avis.expert.email)
|
- avis_link = @avis.expert.user.active?.present? ? expert_avis_url(@avis.procedure, @avis) : sign_up_expert_avis_url(@avis.procedure, @avis.id, email: @avis.expert.email)
|
||||||
|
|
||||||
- content_for(:footer) do
|
- content_for(:footer) do
|
||||||
Merci de ne pas répondre à cet email. Donnez votre avis
|
Merci de ne pas répondre à cet email. Donnez votre avis
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
%p.description= @dossier.procedure.libelle
|
%p.description= @dossier.procedure.libelle
|
||||||
%p.dossier Dossier nº #{@dossier.id}
|
%p.dossier Dossier nº #{@dossier.id}
|
||||||
.column
|
.column
|
||||||
= form_for(User.new, url: { controller: "experts/avis", action: :update_expert }, method: :post, html: { class: "form" }) do |f|
|
= form_for(User.new, url: sign_up_expert_avis_path(email: @email), method: :post, html: { class: "form" }) do |f|
|
||||||
%h1 Créez-vous un compte
|
%h1 Créez-vous un compte
|
||||||
|
|
||||||
= f.label :email, "Email"
|
= f.label :email, "Email"
|
||||||
|
|
|
@ -313,8 +313,13 @@ Rails.application.routes.draw do
|
||||||
post 'avis' => 'avis#create_avis'
|
post 'avis' => 'avis#create_avis'
|
||||||
get 'bilans_bdf'
|
get 'bilans_bdf'
|
||||||
|
|
||||||
get 'sign_up/email/:email' => 'avis#sign_up', constraints: { email: /.*/ }, as: 'sign_up'
|
get 'sign_up' => 'avis#sign_up'
|
||||||
post 'sign_up/email/:email' => 'avis#update_expert', constraints: { email: /.*/ }
|
post 'sign_up' => 'avis#update_expert'
|
||||||
|
|
||||||
|
# This redirections are ephemeral, to ensure that emails sent to experts before are still valid
|
||||||
|
# TODO : remove these lines after September, 2021
|
||||||
|
get 'sign_up/email/:email' => 'avis#sign_up', constraints: { email: /.*/ }, as: 'sign_up_legacy'
|
||||||
|
post 'sign_up/email/:email' => 'avis#update_expert', constraints: { email: /.*/ }, as: 'update_expert_legacy'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -12,7 +12,7 @@ feature 'Inviting an expert:' do
|
||||||
|
|
||||||
context 'when I don’t already have an account' do
|
context 'when I don’t already have an account' do
|
||||||
scenario 'I can sign up' do
|
scenario 'I can sign up' do
|
||||||
visit sign_up_expert_avis_path(avis.dossier.procedure, avis, avis.expert.email)
|
visit sign_up_expert_avis_path(avis.dossier.procedure, avis, email: avis.expert.email)
|
||||||
|
|
||||||
expect(page).to have_field('Email', with: avis.expert.email, disabled: true)
|
expect(page).to have_field('Email', with: avis.expert.email, disabled: true)
|
||||||
fill_in 'Mot de passe', with: 'This is a very complicated password !'
|
fill_in 'Mot de passe', with: 'This is a very complicated password !'
|
||||||
|
@ -29,7 +29,7 @@ feature 'Inviting an expert:' do
|
||||||
avis.expert.user.reload
|
avis.expert.user.reload
|
||||||
end
|
end
|
||||||
scenario 'I can sign in' do
|
scenario 'I can sign in' do
|
||||||
visit sign_up_expert_avis_path(avis.dossier.procedure, avis, avis.expert.email)
|
visit sign_up_expert_avis_path(avis.dossier.procedure, avis, email: avis.expert.email)
|
||||||
|
|
||||||
expect(page).to have_current_path(new_user_session_path)
|
expect(page).to have_current_path(new_user_session_path)
|
||||||
login_as avis.expert.user, scope: :user
|
login_as avis.expert.user, scope: :user
|
||||||
|
|
|
@ -45,7 +45,7 @@ feature 'Inviting an expert:', js: true do
|
||||||
|
|
||||||
invitation_email = open_email(expert.email.to_s)
|
invitation_email = open_email(expert.email.to_s)
|
||||||
avis = expert.avis.find_by(dossier: dossier)
|
avis = expert.avis.find_by(dossier: dossier)
|
||||||
sign_up_link = sign_up_expert_avis_path(avis.dossier.procedure, avis, avis.expert.email)
|
sign_up_link = sign_up_expert_avis_path(avis.dossier.procedure, avis, email: avis.expert.email)
|
||||||
expect(invitation_email.body).to include(sign_up_link)
|
expect(invitation_email.body).to include(sign_up_link)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,7 @@ RSpec.describe AvisMailer, type: :mailer do
|
||||||
it { expect(subject.body).to include(instructeur_avis_url(avis.dossier.procedure.id, avis)) }
|
it { expect(subject.body).to include(instructeur_avis_url(avis.dossier.procedure.id, avis)) }
|
||||||
|
|
||||||
context 'when the recipient is not already registered' do
|
context 'when the recipient is not already registered' do
|
||||||
it { expect(subject.body).to include(sign_up_expert_avis_url(avis.dossier.procedure.id, avis.id, avis.expert.email)) }
|
it { expect(subject.body).to include(sign_up_expert_avis_url(avis.dossier.procedure.id, avis.id, email: avis.expert.email)) }
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'when the dossier has been deleted before the avis was sent' do
|
context 'when the dossier has been deleted before the avis was sent' do
|
||||||
|
|
Loading…
Reference in a new issue