debian-mirror-gitlab/spec/controllers/registrations/welcome_controller_spec.rb
2023-07-09 08:55:56 +05:30

143 lines
3.8 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Registrations::WelcomeController, feature_category: :system_access do
let(:user) { create(:user) }
describe '#show' do
subject(:show) { get :show }
context 'without a signed in user' do
it { is_expected.to redirect_to new_user_registration_path }
end
context 'when role or setup_for_company is not set' do
before do
sign_in(user)
end
it { is_expected.to render_template(:show) }
end
context 'when role is required and setup_for_company is not set' do
before do
user.set_role_required!
sign_in(user)
end
it { is_expected.to render_template(:show) }
render_views
it 'has the expected submission url' do
show
expect(response.body).to include("action=\"#{users_sign_up_welcome_path}\"")
end
end
context 'when role and setup_for_company is set' do
before do
user.update!(setup_for_company: false)
sign_in(user)
end
it { is_expected.to redirect_to(dashboard_projects_path) }
end
context 'when role is set and setup_for_company is not set' do
before do
user.update!(role: :software_developer)
sign_in(user)
end
it { is_expected.to render_template(:show) }
end
context 'when 2FA is required from group' do
before do
user = create(:user, require_two_factor_authentication_from_group: true)
sign_in(user)
end
it 'does not perform a redirect' do
expect(subject).not_to redirect_to(profile_two_factor_auth_path)
end
end
context 'when welcome step is completed' do
before do
user.update!(setup_for_company: true)
end
context 'when user is confirmed' do
before do
sign_in(user)
end
it { is_expected.to redirect_to dashboard_projects_path }
end
context 'when user is not confirmed' do
before do
stub_application_setting_enum('email_confirmation_setting', 'hard')
sign_in(user)
user.update!(confirmed_at: nil)
end
it { is_expected.to redirect_to user_session_path }
end
end
end
describe '#update' do
subject(:update) do
patch :update, params: { user: { role: 'software_developer', setup_for_company: 'false' } }
end
context 'without a signed in user' do
it { is_expected.to redirect_to new_user_registration_path }
end
context 'with a signed in user' do
before do
sign_in(user)
end
it { is_expected.to redirect_to(dashboard_projects_path) }
context 'when the new user already has any accepted group membership' do
let!(:member1) { create(:group_member, user: user) }
it 'redirects to the group activity page' do
expect(subject).to redirect_to(activity_group_path(member1.source))
end
context 'when the new user already has more than 1 accepted group membership' do
it 'redirects to the most recent membership group activty page' do
member2 = create(:group_member, user: user)
expect(subject).to redirect_to(activity_group_path(member2.source))
end
end
context 'when the member has an orphaned source at the time of the welcome' do
it 'redirects to the project dashboard page' do
member1.source.delete
expect(subject).to redirect_to(dashboard_projects_path)
end
end
context 'when tasks to be done are assigned' do
let!(:member1) { create(:group_member, user: user, tasks_to_be_done: %w[ci code]) }
it { is_expected.to redirect_to(issues_dashboard_path(assignee_username: user.username)) }
end
end
end
end
end