Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'spec/features/users/signup_spec.rb')
-rw-r--r--spec/features/users/signup_spec.rb501
1 files changed, 233 insertions, 268 deletions
diff --git a/spec/features/users/signup_spec.rb b/spec/features/users/signup_spec.rb
index bb08ed7d07d..6f13dfa08cc 100644
--- a/spec/features/users/signup_spec.rb
+++ b/spec/features/users/signup_spec.rb
@@ -3,54 +3,40 @@
require 'spec_helper'
RSpec.shared_examples 'Signup name validation' do |field, max_length, label|
- shared_examples 'signup validation' do
- before do
- visit new_user_registration_path
- end
-
- describe "#{field} validation" do
- it "does not show an error border if the user's fullname length is not longer than #{max_length} characters" do
- fill_in field, with: 'u' * max_length
-
- expect(find('.name')).not_to have_css '.gl-field-error-outline'
- end
+ before do
+ visit new_user_registration_path
+ end
- it 'shows an error border if the user\'s fullname contains an emoji' do
- simulate_input("##{field}", 'Ehsan 🦋')
+ describe "#{field} validation" do
+ it "does not show an error border if the user's fullname length is not longer than #{max_length} characters" do
+ fill_in field, with: 'u' * max_length
- expect(find('.name')).to have_css '.gl-field-error-outline'
- end
+ expect(find('.name')).not_to have_css '.gl-field-error-outline'
+ end
- it "shows an error border if the user\'s fullname is longer than #{max_length} characters" do
- fill_in field, with: 'n' * (max_length + 1)
+ it 'shows an error border if the user\'s fullname contains an emoji' do
+ simulate_input("##{field}", 'Ehsan 🦋')
- expect(find('.name')).to have_css '.gl-field-error-outline'
- end
+ expect(find('.name')).to have_css '.gl-field-error-outline'
+ end
- it "shows an error message if the user\'s #{label} is longer than #{max_length} characters" do
- fill_in field, with: 'n' * (max_length + 1)
+ it "shows an error border if the user\'s fullname is longer than #{max_length} characters" do
+ fill_in field, with: 'n' * (max_length + 1)
- expect(page).to have_content("#{label} is too long (maximum is #{max_length} characters).")
- end
+ expect(find('.name')).to have_css '.gl-field-error-outline'
+ end
- it 'shows an error message if the username contains emojis' do
- simulate_input("##{field}", 'Ehsan 🦋')
+ it "shows an error message if the user\'s #{label} is longer than #{max_length} characters" do
+ fill_in field, with: 'n' * (max_length + 1)
- expect(page).to have_content("Invalid input, please avoid emoji")
- end
+ expect(page).to have_content("#{label} is too long (maximum is #{max_length} characters).")
end
- end
- include_examples 'signup validation'
+ it 'shows an error message if the username contains emojis' do
+ simulate_input("##{field}", 'Ehsan 🦋')
- # Inline `shared_example 'signup validation'` again after feature flag
- # `restyle_login_page` was removed.
- context 'with feature flag restyle_login_page disabled' do
- before do
- stub_feature_flags(restyle_login_page: false)
+ expect(page).to have_content("Invalid input, please avoid emoji")
end
-
- include_examples 'signup validation'
end
end
@@ -66,344 +52,323 @@ RSpec.describe 'Signup', :js, feature_category: :user_management do
TEXT
end
- shared_examples 'signup process' do
+ before do
+ stub_feature_flags(arkose_labs_signup_challenge: false)
+ stub_application_setting(require_admin_approval_after_user_signup: false)
+ end
+
+ describe 'username validation' do
before do
- stub_feature_flags(arkose_labs_signup_challenge: false)
- stub_application_setting(require_admin_approval_after_user_signup: false)
+ visit new_user_registration_path
end
- describe 'username validation' do
- before do
- visit new_user_registration_path
- end
+ it 'does not show an error border if the username is available' do
+ fill_in 'new_user_username', with: 'new-user'
+ wait_for_requests
- it 'does not show an error border if the username is available' do
- fill_in 'new_user_username', with: 'new-user'
- wait_for_requests
+ expect(find('.username')).not_to have_css '.gl-field-error-outline'
+ end
- expect(find('.username')).not_to have_css '.gl-field-error-outline'
- end
+ it 'does not show an error border if the username contains dots (.)' do
+ simulate_input('#new_user_username', 'new.user.username')
+ wait_for_requests
- it 'does not show an error border if the username contains dots (.)' do
- simulate_input('#new_user_username', 'new.user.username')
- wait_for_requests
+ expect(find('.username')).not_to have_css '.gl-field-error-outline'
+ end
- expect(find('.username')).not_to have_css '.gl-field-error-outline'
- end
+ it 'does not show an error border if the username length is not longer than 255 characters' do
+ fill_in 'new_user_username', with: 'u' * 255
+ wait_for_requests
- it 'does not show an error border if the username length is not longer than 255 characters' do
- fill_in 'new_user_username', with: 'u' * 255
- wait_for_requests
+ expect(find('.username')).not_to have_css '.gl-field-error-outline'
+ end
- expect(find('.username')).not_to have_css '.gl-field-error-outline'
- end
+ it 'shows an error border if the username already exists' do
+ existing_user = create(:user)
- it 'shows an error border if the username already exists' do
- existing_user = create(:user)
+ fill_in 'new_user_username', with: existing_user.username
+ wait_for_requests
- fill_in 'new_user_username', with: existing_user.username
- wait_for_requests
+ expect(find('.username')).to have_css '.gl-field-error-outline'
+ end
- expect(find('.username')).to have_css '.gl-field-error-outline'
- end
+ it 'shows a success border if the username is available' do
+ fill_in 'new_user_username', with: 'new-user'
+ wait_for_requests
- it 'shows a success border if the username is available' do
- fill_in 'new_user_username', with: 'new-user'
- wait_for_requests
+ expect(find('.username')).to have_css '.gl-field-success-outline'
+ end
- expect(find('.username')).to have_css '.gl-field-success-outline'
- end
+ it 'shows an error border if the username contains special characters' do
+ fill_in 'new_user_username', with: 'new$user!username'
+ wait_for_requests
- it 'shows an error border if the username contains special characters' do
- fill_in 'new_user_username', with: 'new$user!username'
- wait_for_requests
+ expect(find('.username')).to have_css '.gl-field-error-outline'
+ end
- expect(find('.username')).to have_css '.gl-field-error-outline'
- end
+ it 'shows an error border if the username is longer than 255 characters' do
+ fill_in 'new_user_username', with: 'u' * 256
+ wait_for_requests
- it 'shows an error border if the username is longer than 255 characters' do
- fill_in 'new_user_username', with: 'u' * 256
- wait_for_requests
+ expect(find('.username')).to have_css '.gl-field-error-outline'
+ end
- expect(find('.username')).to have_css '.gl-field-error-outline'
- end
+ it 'shows an error message if the username is longer than 255 characters' do
+ fill_in 'new_user_username', with: 'u' * 256
+ wait_for_requests
- it 'shows an error message if the username is longer than 255 characters' do
- fill_in 'new_user_username', with: 'u' * 256
- wait_for_requests
+ expect(page).to have_content("Username is too long (maximum is 255 characters).")
+ end
- expect(page).to have_content("Username is too long (maximum is 255 characters).")
- end
+ it 'shows an error message if the username is less than 2 characters' do
+ fill_in 'new_user_username', with: 'u'
+ wait_for_requests
- it 'shows an error message if the username is less than 2 characters' do
- fill_in 'new_user_username', with: 'u'
- wait_for_requests
+ expect(page).to have_content("Username is too short (minimum is 2 characters).")
+ end
- expect(page).to have_content("Username is too short (minimum is 2 characters).")
- end
+ it 'shows an error message on submit if the username contains special characters' do
+ fill_in 'new_user_username', with: 'new$user!username'
+ wait_for_requests
- it 'shows an error message on submit if the username contains special characters' do
- fill_in 'new_user_username', with: 'new$user!username'
- wait_for_requests
+ click_button "Register"
- click_button "Register"
+ expect(page).to have_content("Please create a username with only alphanumeric characters.")
+ end
- expect(page).to have_content("Please create a username with only alphanumeric characters.")
- end
+ it 'shows an error border if the username contains emojis' do
+ simulate_input('#new_user_username', 'ehsan😀')
- it 'shows an error border if the username contains emojis' do
- simulate_input('#new_user_username', 'ehsan😀')
+ expect(find('.username')).to have_css '.gl-field-error-outline'
+ end
- expect(find('.username')).to have_css '.gl-field-error-outline'
- end
+ it 'shows an error message if the username contains emojis' do
+ simulate_input('#new_user_username', 'ehsan😀')
- it 'shows an error message if the username contains emojis' do
- simulate_input('#new_user_username', 'ehsan😀')
+ expect(page).to have_content("Invalid input, please avoid emoji")
+ end
- expect(page).to have_content("Invalid input, please avoid emoji")
- end
+ it 'shows a pending message if the username availability is being fetched',
+ quarantine: 'https://gitlab.com/gitlab-org/gitlab/-/issues/31484' do
+ fill_in 'new_user_username', with: 'new-user'
- it 'shows a pending message if the username availability is being fetched',
- quarantine: 'https://gitlab.com/gitlab-org/gitlab/-/issues/31484' do
- fill_in 'new_user_username', with: 'new-user'
+ expect(find('.username > .validation-pending')).not_to have_css '.hide'
+ end
- expect(find('.username > .validation-pending')).not_to have_css '.hide'
- end
+ it 'shows a success message if the username is available' do
+ fill_in 'new_user_username', with: 'new-user'
+ wait_for_requests
- it 'shows a success message if the username is available' do
- fill_in 'new_user_username', with: 'new-user'
- wait_for_requests
+ expect(find('.username > .validation-success')).not_to have_css '.hide'
+ end
- expect(find('.username > .validation-success')).not_to have_css '.hide'
- end
+ it 'shows an error message if the username is unavailable' do
+ existing_user = create(:user)
- it 'shows an error message if the username is unavailable' do
- existing_user = create(:user)
+ fill_in 'new_user_username', with: existing_user.username
+ wait_for_requests
- fill_in 'new_user_username', with: existing_user.username
- wait_for_requests
+ expect(find('.username > .validation-error')).not_to have_css '.hide'
+ end
- expect(find('.username > .validation-error')).not_to have_css '.hide'
- end
+ it 'shows a success message if the username is corrected and then available' do
+ fill_in 'new_user_username', with: 'new-user$'
+ wait_for_requests
+ fill_in 'new_user_username', with: 'new-user'
+ wait_for_requests
- it 'shows a success message if the username is corrected and then available' do
- fill_in 'new_user_username', with: 'new-user$'
- wait_for_requests
- fill_in 'new_user_username', with: 'new-user'
- wait_for_requests
+ expect(page).to have_content("Username is available.")
+ end
+ end
- expect(page).to have_content("Username is available.")
+ context 'with no errors' do
+ context 'when sending confirmation email' do
+ before do
+ stub_application_setting_enum('email_confirmation_setting', 'hard')
end
- end
- context 'with no errors' do
- context 'when sending confirmation email' do
+ context 'when email confirmation setting is not `soft`' do
before do
- stub_application_setting_enum('email_confirmation_setting', 'hard')
+ stub_feature_flags(identity_verification: false)
end
- context 'when email confirmation setting is not `soft`' do
- before do
- stub_feature_flags(identity_verification: false)
- end
-
- it 'creates the user account and sends a confirmation email, and pre-fills email address after confirming' do
- visit new_user_registration_path
-
- expect { fill_in_sign_up_form(new_user) }.to change { User.count }.by(1)
- expect(page).to have_current_path users_almost_there_path, ignore_query: true
- expect(page).to have_content("Please check your email (#{new_user.email}) to confirm your account")
-
- confirm_email(new_user)
-
- expect(find_field('Username or primary email').value).to eq(new_user.email)
- end
- end
+ it 'creates the user account and sends a confirmation email, and pre-fills email address after confirming' do
+ visit new_user_registration_path
- context 'when email confirmation setting is `soft`' do
- before do
- stub_application_setting_enum('email_confirmation_setting', 'soft')
- end
+ expect { fill_in_sign_up_form(new_user) }.to change { User.count }.by(1)
+ expect(page).to have_current_path users_almost_there_path, ignore_query: true
+ expect(page).to have_content("Please check your email (#{new_user.email}) to confirm your account")
- it 'creates the user account and sends a confirmation email' do
- visit new_user_registration_path
+ confirm_email(new_user)
- expect { fill_in_sign_up_form(new_user) }.to change { User.count }.by(1)
- expect(page).to have_current_path dashboard_projects_path
- end
+ expect(find_field('Username or primary email').value).to eq(new_user.email)
end
end
- context "when not sending confirmation email" do
+ context 'when email confirmation setting is `soft`' do
before do
- stub_application_setting_enum('email_confirmation_setting', 'off')
+ stub_application_setting_enum('email_confirmation_setting', 'soft')
end
- it 'creates the user account and goes to dashboard' do
+ it 'creates the user account and sends a confirmation email' do
visit new_user_registration_path
- fill_in_sign_up_form(new_user)
-
+ expect { fill_in_sign_up_form(new_user) }.to change { User.count }.by(1)
expect(page).to have_current_path dashboard_projects_path
end
end
+ end
- context 'with required admin approval enabled' do
- before do
- stub_application_setting(require_admin_approval_after_user_signup: true)
- end
+ context "when not sending confirmation email" do
+ before do
+ stub_application_setting_enum('email_confirmation_setting', 'off')
+ end
- it 'creates the user but does not sign them in' do
- visit new_user_registration_path
+ it 'creates the user account and goes to dashboard' do
+ visit new_user_registration_path
- expect { fill_in_sign_up_form(new_user) }.to change { User.count }.by(1)
- expect(page).to have_current_path new_user_session_path, ignore_query: true
- expect(page).to have_content(<<~TEXT.squish)
+ fill_in_sign_up_form(new_user)
+
+ expect(page).to have_current_path dashboard_projects_path
+ end
+ end
+
+ context 'with required admin approval enabled' do
+ before do
+ stub_application_setting(require_admin_approval_after_user_signup: true)
+ end
+
+ it 'creates the user but does not sign them in' do
+ visit new_user_registration_path
+
+ expect { fill_in_sign_up_form(new_user) }.to change { User.count }.by(1)
+ expect(page).to have_current_path new_user_session_path, ignore_query: true
+ expect(page).to have_content(<<~TEXT.squish)
You have signed up successfully. However, we could not sign you in
because your account is awaiting approval from your GitLab administrator
- TEXT
- end
+ TEXT
end
end
+ end
- context 'with errors' do
- it "displays the errors" do
- create(:user, email: new_user.email)
- visit new_user_registration_path
+ context 'with errors' do
+ it "displays the errors" do
+ create(:user, email: new_user.email)
+ visit new_user_registration_path
- fill_in_sign_up_form(new_user)
+ fill_in_sign_up_form(new_user)
- expect(page).to have_current_path user_registration_path, ignore_query: true
- expect(page).to have_content("error prohibited this user from being saved")
- expect(page).to have_content("Email has already been taken")
- end
+ expect(page).to have_current_path user_registration_path, ignore_query: true
+ expect(page).to have_content("error prohibited this user from being saved")
+ expect(page).to have_content("Email has already been taken")
+ end
- it 'redisplays all fields except password' do
- create(:user, email: new_user.email)
- visit new_user_registration_path
+ it 'redisplays all fields except password' do
+ create(:user, email: new_user.email)
+ visit new_user_registration_path
- fill_in_sign_up_form(new_user)
+ fill_in_sign_up_form(new_user)
- expect(page).to have_current_path user_registration_path, ignore_query: true
- expect(page.body).not_to match(/#{new_user.password}/)
+ expect(page).to have_current_path user_registration_path, ignore_query: true
+ expect(page.body).not_to match(/#{new_user.password}/)
- expect(find_field('First name').value).to eq(new_user.first_name)
- expect(find_field('Last name').value).to eq(new_user.last_name)
- expect(find_field('Username').value).to eq(new_user.username)
- expect(find_field('Email').value).to eq(new_user.email)
- end
+ expect(find_field('First name').value).to eq(new_user.first_name)
+ expect(find_field('Last name').value).to eq(new_user.last_name)
+ expect(find_field('Username').value).to eq(new_user.username)
+ expect(find_field('Email').value).to eq(new_user.email)
end
+ end
- context 'when terms are enforced' do
- before do
- enforce_terms
- end
+ context 'when terms are enforced' do
+ before do
+ enforce_terms
+ end
- it 'renders text that the user confirms terms by signing in' do
- visit new_user_registration_path
- expect(page).to have_content(terms_text)
+ it 'renders text that the user confirms terms by signing in' do
+ visit new_user_registration_path
+ expect(page).to have_content(terms_text)
- fill_in_sign_up_form(new_user)
+ fill_in_sign_up_form(new_user)
- expect(page).to have_current_path(dashboard_projects_path)
- end
+ expect(page).to have_current_path(dashboard_projects_path)
+ end
- it_behaves_like 'Signup name validation', 'new_user_first_name', 127, 'First name'
- it_behaves_like 'Signup name validation', 'new_user_last_name', 127, 'Last name'
+ it_behaves_like 'Signup name validation', 'new_user_first_name', 127, 'First name'
+ it_behaves_like 'Signup name validation', 'new_user_last_name', 127, 'Last name'
+ end
+
+ context 'when reCAPTCHA and invisible captcha are enabled' do
+ before do
+ stub_application_setting(invisible_captcha_enabled: true)
+ stub_application_setting(recaptcha_enabled: true)
+ allow_next_instance_of(RegistrationsController) do |instance|
+ allow(instance).to receive(:verify_recaptcha).and_return(true)
+ end
end
- context 'when reCAPTCHA and invisible captcha are enabled' do
+ context 'when reCAPTCHA detects malicious behaviour' do
before do
- stub_application_setting(invisible_captcha_enabled: true)
- stub_application_setting(recaptcha_enabled: true)
allow_next_instance_of(RegistrationsController) do |instance|
- allow(instance).to receive(:verify_recaptcha).and_return(true)
+ allow(instance).to receive(:verify_recaptcha).and_return(false)
end
end
- context 'when reCAPTCHA detects malicious behaviour' do
- before do
- allow_next_instance_of(RegistrationsController) do |instance|
- allow(instance).to receive(:verify_recaptcha).and_return(false)
- end
- end
+ it 'prevents from signing up' do
+ visit new_user_registration_path
+ expect { fill_in_sign_up_form(new_user) }.not_to change { User.count }
+ expect(page).to have_content(_('There was an error with the reCAPTCHA. Please solve the reCAPTCHA again.'))
+ expect(page).to have_content(
+ "Minimum length is #{Gitlab::CurrentSettings.minimum_password_length} characters")
+ end
+ end
+
+ context 'when invisible captcha detects malicious behaviour' do
+ context 'with form submitted quicker than timestamp_threshold', :freeze_time do
it 'prevents from signing up' do
visit new_user_registration_path
expect { fill_in_sign_up_form(new_user) }.not_to change { User.count }
- expect(page).to have_content(_('There was an error with the reCAPTCHA. Please solve the reCAPTCHA again.'))
- expect(page).to have_content(
- "Minimum length is #{Gitlab::CurrentSettings.minimum_password_length} characters")
+ expect(page).to have_content('That was a bit too quick! Please resubmit.')
end
end
- context 'when invisible captcha detects malicious behaviour' do
- context 'with form submitted quicker than timestamp_threshold', :freeze_time do
- it 'prevents from signing up' do
- visit new_user_registration_path
-
- expect { fill_in_sign_up_form(new_user) }.not_to change { User.count }
- expect(page).to have_content('That was a bit too quick! Please resubmit.')
- end
- end
-
- context 'with honeypot field is filled' do
- it 'prevents from signing up' do
- visit new_user_registration_path
+ context 'with honeypot field is filled' do
+ it 'prevents from signing up' do
+ visit new_user_registration_path
- find_field('If you are human, please ignore this field.',
- visible: false).execute_script("this.value = 'bot'")
+ find_field('If you are human, please ignore this field.',
+ visible: false).execute_script("this.value = 'bot'")
- expect { fill_in_sign_up_form(new_user) }.not_to change { User.count }
- end
+ expect { fill_in_sign_up_form(new_user) }.not_to change { User.count }
end
end
end
+ end
- it 'allows visiting of a page after initial registration' do
- visit new_user_registration_path
-
- fill_in_sign_up_form(new_user)
+ it 'allows visiting of a page after initial registration' do
+ visit new_user_registration_path
- visit new_project_path
+ fill_in_sign_up_form(new_user)
- expect(page).to have_current_path(new_project_path)
- end
+ visit new_project_path
- it 'does not redisplay the password' do
- create(:user, email: new_user.email)
- visit new_user_registration_path
+ expect(page).to have_current_path(new_project_path)
+ end
- fill_in_sign_up_form(new_user)
+ it 'does not redisplay the password' do
+ create(:user, email: new_user.email)
+ visit new_user_registration_path
- expect(page).to have_current_path user_registration_path, ignore_query: true
- expect(page.body).not_to match(/#{new_user.password}/)
- end
+ fill_in_sign_up_form(new_user)
- context 'with invalid email' do
- it_behaves_like 'user email validation' do
- let(:path) { new_user_registration_path }
- end
- end
+ expect(page).to have_current_path user_registration_path, ignore_query: true
+ expect(page.body).not_to match(/#{new_user.password}/)
end
- include_examples 'signup process'
-
- # Inline `shared_example 'signup process'` again after feature flag
- # `restyle_login_page` was removed.
- context 'with feature flag restyle_login_page disabled' do
- let(:terms_text) do
- <<~TEXT.squish
- By clicking Register, I agree that I have read and accepted the Terms of
- Use and Privacy Statement
- TEXT
+ context 'with invalid email' do
+ it_behaves_like 'user email validation' do
+ let(:path) { new_user_registration_path }
end
-
- before do
- stub_feature_flags(restyle_login_page: false)
- end
-
- include_examples 'signup process'
end
end