diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2023-07-14 18:07:17 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2023-07-14 18:07:17 +0300 |
commit | 2aea9a0c91723b8800b016335930c59390cda7c9 (patch) | |
tree | f223b5ef5cf7ee847cfc4875b3c02ec265f91c2d /spec/controllers | |
parent | 14a0edee5c04b04b5281f99ce7f6ba75b919dba1 (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/controllers')
-rw-r--r-- | spec/controllers/concerns/onboarding/status_spec.rb | 106 | ||||
-rw-r--r-- | spec/controllers/registrations/welcome_controller_spec.rb | 2 |
2 files changed, 107 insertions, 1 deletions
diff --git a/spec/controllers/concerns/onboarding/status_spec.rb b/spec/controllers/concerns/onboarding/status_spec.rb new file mode 100644 index 00000000000..3f6e597a235 --- /dev/null +++ b/spec/controllers/concerns/onboarding/status_spec.rb @@ -0,0 +1,106 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe Onboarding::Status, feature_category: :onboarding do + let_it_be(:member) { create(:group_member) } + let_it_be(:user) { member.user } + let_it_be(:tasks_to_be_done) { %w[ci code] } + let_it_be(:source) { member.group } + + describe '#continue_full_onboarding?' do + subject { described_class.new(nil).continue_full_onboarding? } + + it { is_expected.to eq(false) } + end + + describe '#single_invite?' do + subject { described_class.new(user).single_invite? } + + context 'when there is only one member for the user' do + context 'when the member source exists' do + it { is_expected.to eq(true) } + end + end + + context 'when there is more than one member for the user' do + before do + create(:group_member, user: user) + end + + it { is_expected.to eq(false) } + end + + context 'when there are no members for the user' do + let(:user) { build_stubbed(:user) } + + it { is_expected.to eq(false) } + end + end + + describe '#last_invited_member' do + subject { described_class.new(user).last_invited_member } + + it { is_expected.to eq(member) } + + context 'when another member exists and is most recent' do + let!(:last_member) { create(:group_member, user: user) } + + it { is_expected.to eq(last_member) } + end + + context 'when there are no members' do + let_it_be(:user) { build_stubbed(:user) } + + it { is_expected.to be_nil } + end + end + + describe '#last_invited_member_source' do + subject { described_class.new(user).last_invited_member_source } + + context 'when a member exists' do + it { is_expected.to eq(source) } + end + + context 'when no members exist' do + let_it_be(:user) { build_stubbed(:user) } + + it { is_expected.to be_nil } + end + + context 'when another member exists and is most recent' do + let!(:last_member_source) { create(:group_member, user: user).group } + + it { is_expected.to eq(last_member_source) } + end + end + + describe '#invite_with_tasks_to_be_done?' do + subject { described_class.new(user).invite_with_tasks_to_be_done? } + + context 'when there are tasks_to_be_done with one member' do + let_it_be(:member) { create(:group_member, user: user, tasks_to_be_done: tasks_to_be_done) } + + it { is_expected.to eq(true) } + end + + context 'when there are multiple members and the tasks_to_be_done is on only one of them' do + before do + create(:group_member, user: user, tasks_to_be_done: tasks_to_be_done) + end + + it { is_expected.to eq(true) } + end + + context 'when there are no tasks_to_be_done' do + it { is_expected.to eq(false) } + end + + context 'when there are no members' do + let_it_be(:user) { build_stubbed(:user) } + + it { is_expected.to eq(false) } + end + end +end diff --git a/spec/controllers/registrations/welcome_controller_spec.rb b/spec/controllers/registrations/welcome_controller_spec.rb index 4118754144c..5a3feefc1ba 100644 --- a/spec/controllers/registrations/welcome_controller_spec.rb +++ b/spec/controllers/registrations/welcome_controller_spec.rb @@ -117,7 +117,7 @@ RSpec.describe Registrations::WelcomeController, feature_category: :system_acces 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 + it 'redirects to the most recent membership group activity page' do member2 = create(:group_member, user: user) expect(subject).to redirect_to(activity_group_path(member2.source)) |