demarches-normaliennes/spec/system/users/sign_up_spec.rb

159 lines
6.2 KiB
Ruby
Raw Normal View History

describe 'Signing up:' do
let(:user_email) { generate :user_email }
let(:user_password) { 'my-s3cure-p4ssword' }
let(:procedure) { create :simple_procedure, :with_service }
scenario 'a new user can sign-up from scratch' do
visit new_user_registration_path
sign_up_with user_email, user_password
expect(page).to have_content "nous avons besoin de vérifier votre adresse #{user_email}"
click_confirmation_link_for user_email
2020-09-01 15:28:31 +02:00
expect(page).to have_content('Votre compte a bien été confirmé.')
expect(page).to have_current_path dossiers_path
end
context 'when the user makes a typo in their email address' do
2019-12-02 15:27:02 +01:00
let(:procedure) { create :simple_procedure, :with_service }
before do
visit commencer_path(path: procedure.path)
click_on "Créer un compte #{APPLICATION_NAME}"
2019-12-02 15:27:02 +01:00
expect(page).to have_selector('.suspect-email', visible: false)
2023-06-28 10:24:37 +02:00
fill_in 'Adresse électronique', with: 'bidou@yahoo.rf'
fill_in 'Mot de passe', with: '12345'
2019-12-02 15:27:02 +01:00
end
2023-08-31 09:59:18 +02:00
scenario 'they can accept the suggestion', js: true, retry: 3 do
2019-12-02 15:27:02 +01:00
expect(page).to have_selector('.suspect-email', visible: true)
click_on 'Oui'
2023-06-28 10:24:37 +02:00
expect(page).to have_field("Adresse électronique", :with => 'bidou@yahoo.fr')
2019-12-02 15:27:02 +01:00
expect(page).to have_selector('.suspect-email', visible: false)
end
2023-08-31 09:59:18 +02:00
scenario 'they can discard the suggestion', js: true, retry: 3 do
2019-12-02 15:27:02 +01:00
expect(page).to have_selector('.suspect-email', visible: true)
click_on 'Non'
2023-06-28 10:24:37 +02:00
expect(page).to have_field("Adresse électronique", :with => 'bidou@yahoo.rf')
2019-12-02 15:27:02 +01:00
expect(page).to have_selector('.suspect-email', visible: false)
end
2023-08-31 09:59:18 +02:00
scenario 'they can fix the typo themselves', js: true, retry: 3 do
expect(page).to have_selector('.suspect-email', visible: true)
2023-06-28 10:24:37 +02:00
fill_in 'Adresse électronique', with: 'bidou@yahoo.fr'
blur
expect(page).to have_selector('.suspect-email', visible: false)
end
2019-12-02 15:27:02 +01:00
end
scenario 'a new user cant sign-up with too short password when visiting a procedure' do
visit commencer_path(path: procedure.path)
click_on "Créer un compte #{APPLICATION_NAME}"
expect(page).to have_current_path new_user_registration_path
sign_up_with user_email, '1234567'
expect(page).to have_current_path user_registration_path
expect(page).to have_content "Le champ « Mot de passe » est trop court. Saisir un mot de passe avec au moins 8 caractères"
# Then with a good password
sign_up_with user_email, user_password
expect(page).to have_current_path new_user_confirmation_path user: { email: user_email }
expect(page).to have_content "nous avons besoin de vérifier votre adresse #{user_email}"
end
context 'when visiting a procedure' do
let(:procedure) { create :simple_procedure, :with_service }
scenario 'a new user can sign-up and fill the procedure' do
visit commencer_path(path: procedure.path)
click_on 'Créer un compte'
2019-01-16 11:57:58 +01:00
expect(page).to have_current_path new_user_registration_path
sign_up_with user_email, user_password
expect(page).to have_content "nous avons besoin de vérifier votre adresse #{user_email}"
click_confirmation_link_for(user_email, in_another_browser: true)
# After confirmation, the user is redirected to the procedure they were initially starting
# (even when confirming the account in another browser).
expect(page).to have_current_path(commencer_path(path: procedure.path))
2020-09-01 15:28:31 +02:00
expect(page).to have_content I18n.t('devise.confirmations.confirmed')
click_on 'Commencer la démarche'
2019-01-16 11:57:58 +01:00
expect(page).to have_current_path identite_dossier_path(procedure.reload.dossiers.last)
expect(page).to have_content(procedure.libelle)
end
end
context 'when the user is not confirmed yet' do
before do
create(:user, :unconfirmed, email: user_email, password: user_password)
end
scenario 'the email confirmation page is displayed' do
visit commencer_path(path: procedure.path)
click_on 'Créer un compte'
sign_up_with user_email, user_password
# The same page than for initial sign-ups is displayed, to avoid leaking informations
# about the account existence.
expect(page).to have_content "nous avons besoin de vérifier votre adresse #{user_email}"
# The confirmation email is sent again
confirmation_email = open_email(user_email)
expect(confirmation_email.body).to have_text('Pour activer votre compte')
click_confirmation_link_for(user_email, in_another_browser: true)
# After confirmation, the user is redirected to the procedure they were initially starting
# (even when confirming the account in another browser).
expect(page).to have_current_path(commencer_path(path: procedure.path))
2020-09-01 15:28:31 +02:00
expect(page).to have_content I18n.t('devise.confirmations.confirmed')
expect(page).to have_content 'Commencer la démarche'
end
end
context 'when the user already has a confirmed account' do
before do
create(:user, email: user_email, password: user_password)
end
scenario 'they get a warning email, containing a link to the procedure' do
visit commencer_path(path: procedure.path)
click_on 'Créer un compte'
sign_up_with user_email, user_password
# The same page than for initial sign-ups is displayed, to avoid leaking informations
# about the accound existence.
expect(page).to have_content "nous avons besoin de vérifier votre adresse #{user_email}"
# A warning email is sent
warning_email = open_email(user_email)
expect(warning_email.body).to have_text('Votre compte existe déjà')
# When clicking the main button, the user is redirected directly to
# the sign-in page for the procedure they were initially starting.
click_procedure_sign_in_link_for user_email
expect(page).to have_current_path new_user_session_path
end
end
context 'when the user already has a confirmed account but is blocked' do
before do
create(:user, email: user_email, password: user_password, blocked_at: Time.current)
end
scenario 'they cannot signed in' do
visit new_user_session_path
sign_in_with user_email, user_password
expect(page).to have_current_path new_user_session_path
end
end
end