135 lines
3.6 KiB
Ruby
135 lines
3.6 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe Registrations::WelcomeController, feature_category: :system_access do
|
|
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
|
|
|
|
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
|