debian-mirror-gitlab/spec/controllers/registrations/welcome_controller_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

136 lines
3.6 KiB
Ruby
Raw Normal View History

2021-01-29 00:20:46 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
RSpec.describe Registrations::WelcomeController, feature_category: :system_access do
2021-01-29 00:20:46 +05:30
let(:user) { create(:user) }
describe '#welcome' 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) }
end
context 'when role and setup_for_company is set' do
before do
user.update!(setup_for_company: false)
sign_in(user)
end
2022-10-11 01:57:18 +05:30
it { is_expected.to redirect_to(dashboard_projects_path) }
2021-01-29 00:20:46 +05:30
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
2023-03-17 16:20:25 +05:30
context 'when 2FA is required from group' do
2021-01-29 00:20:46 +05:30
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
2023-05-27 22:25:52 +05:30
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
2021-01-29 00:20:46 +05:30
end
describe '#update' do
subject(:update) do
2021-10-27 15:23:28 +05:30
patch :update, params: { user: { role: 'software_developer', setup_for_company: 'false' } }
2021-01-29 00:20:46 +05:30
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
2022-10-11 01:57:18 +05:30
it { is_expected.to redirect_to(dashboard_projects_path) }
2021-04-29 21:17:54 +05:30
2021-06-08 01:23:25 +05:30
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
2021-12-11 22:18:48 +05:30
context 'when tasks to be done are assigned' do
2023-03-17 16:20:25 +05:30
let!(:member1) { create(:group_member, user: user, tasks_to_be_done: %w[ci code]) }
2021-12-11 22:18:48 +05:30
it { is_expected.to redirect_to(issues_dashboard_path(assignee_username: user.username)) }
end
2021-06-08 01:23:25 +05:30
end
2021-01-29 00:20:46 +05:30
end
end
end