diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-06-16 18:25:58 +0000 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-06-16 18:25:58 +0000 |
commit | a5f4bba440d7f9ea47046a0a561d49adf0a1e6d4 (patch) | |
tree | fb69158581673816a8cd895f9d352dcb3c678b1e /spec/services/members/create_service_spec.rb | |
parent | d16b2e8639e99961de6ddc93909f3bb5c1445ba1 (diff) | |
download | gitlab-ce-a5f4bba440d7f9ea47046a0a561d49adf0a1e6d4.tar.gz |
Add latest changes from gitlab-org/gitlab@14-0-stable-eev14.0.0-rc42
Diffstat (limited to 'spec/services/members/create_service_spec.rb')
-rw-r--r-- | spec/services/members/create_service_spec.rb | 45 |
1 files changed, 44 insertions, 1 deletions
diff --git a/spec/services/members/create_service_spec.rb b/spec/services/members/create_service_spec.rb index 916941e1111..ffe63a8a94b 100644 --- a/spec/services/members/create_service_spec.rb +++ b/spec/services/members/create_service_spec.rb @@ -8,7 +8,8 @@ RSpec.describe Members::CreateService, :aggregate_failures, :clean_gitlab_redis_ let_it_be(:member) { create(:user) } let_it_be(:user_ids) { member.id.to_s } let_it_be(:access_level) { Gitlab::Access::GUEST } - let(:params) { { user_ids: user_ids, access_level: access_level } } + let(:additional_params) { { invite_source: '_invite_source_' } } + let(:params) { { user_ids: user_ids, access_level: access_level }.merge(additional_params) } subject(:execute_service) { described_class.new(user, params.merge({ source: source })).execute } @@ -82,4 +83,46 @@ RSpec.describe Members::CreateService, :aggregate_failures, :clean_gitlab_redis_ expect(OnboardingProgress.completed?(source.namespace, :user_added)).to be(false) end end + + context 'when tracking the invite source', :snowplow do + context 'when invite_source is not passed' do + let(:additional_params) { {} } + + it 'tracks the invite source as unknown' do + expect { execute_service }.to raise_error(ArgumentError, 'No invite source provided.') + + expect_no_snowplow_event + end + end + + context 'when invite_source is passed' do + it 'tracks the invite source from params' do + execute_service + + expect_snowplow_event( + category: described_class.name, + action: 'create_member', + label: '_invite_source_', + property: 'existing_user', + user: user + ) + end + end + + context 'when it is a net_new_user' do + let(:additional_params) { { invite_source: '_invite_source_', user_ids: 'email@example.org' } } + + it 'tracks the invite source from params' do + execute_service + + expect_snowplow_event( + category: described_class.name, + action: 'create_member', + label: '_invite_source_', + property: 'net_new_user', + user: user + ) + end + end + end end |