2019-12-21 20:55:43 +05:30
# frozen_string_literal: true
2019-12-04 20:38:33 +05:30
require 'spec_helper'
2017-08-17 22:00:37 +05:30
2020-07-28 23:09:34 +05:30
RSpec . describe UsersHelper do
2018-10-15 14:42:47 +05:30
include TermsHelper
2017-08-17 22:00:37 +05:30
let ( :user ) { create ( :user ) }
2020-03-13 15:44:24 +05:30
def filter_ee_badges ( badges )
badges . reject { | badge | badge [ :text ] == 'Is using seat' }
end
2022-04-04 11:22:00 +05:30
describe 'display_public_email?' do
let_it_be ( :user ) { create ( :user , :public_email ) }
subject { helper . display_public_email? ( user ) }
it { is_expected . to be true }
context 'when user public email is blank' do
let_it_be ( :user ) { create ( :user , public_email : '' ) }
it { is_expected . to be false }
end
end
2017-08-17 22:00:37 +05:30
describe '#user_link' do
subject { helper . user_link ( user ) }
it " links to the user's profile " do
is_expected . to include ( " href= \" #{ user_path ( user ) } \" " )
end
it " has the user's email as title " do
is_expected . to include ( " title= \" #{ user . email } \" " )
end
end
2018-03-27 19:54:05 +05:30
describe '#profile_tabs' do
subject ( :tabs ) { helper . profile_tabs }
before do
allow ( helper ) . to receive ( :current_user ) . and_return ( user )
allow ( helper ) . to receive ( :can? ) . and_return ( true )
end
2018-11-18 11:00:15 +05:30
context 'with public profile' do
it 'includes all the expected tabs' do
2019-10-12 21:52:04 +05:30
expect ( tabs ) . to include ( :activity , :groups , :contributed , :projects , :starred , :snippets )
2018-11-18 11:00:15 +05:30
end
end
context 'with private profile' do
before do
allow ( helper ) . to receive ( :can? ) . with ( user , :read_user_profile , nil ) . and_return ( false )
end
it 'is empty' do
expect ( tabs ) . to be_empty
end
2018-03-27 19:54:05 +05:30
end
end
2018-10-15 14:42:47 +05:30
2018-11-20 20:47:30 +05:30
describe '#user_internal_regex_data' do
using RSpec :: Parameterized :: TableSyntax
where ( :user_default_external , :user_default_internal_regex , :result ) do
false | nil | { user_internal_regex_pattern : nil , user_internal_regex_options : nil }
false | '' | { user_internal_regex_pattern : nil , user_internal_regex_options : nil }
false | 'mockRegexPattern' | { user_internal_regex_pattern : nil , user_internal_regex_options : nil }
true | nil | { user_internal_regex_pattern : nil , user_internal_regex_options : nil }
true | '' | { user_internal_regex_pattern : nil , user_internal_regex_options : nil }
2019-03-02 22:35:43 +05:30
true | 'mockRegexPattern' | { user_internal_regex_pattern : 'mockRegexPattern' , user_internal_regex_options : 'i' }
2018-11-20 20:47:30 +05:30
end
with_them do
before do
stub_application_setting ( user_default_external : user_default_external )
stub_application_setting ( user_default_internal_regex : user_default_internal_regex )
end
subject { helper . user_internal_regex_data }
it { is_expected . to eq ( result ) }
end
end
2018-10-15 14:42:47 +05:30
describe '#current_user_menu_items' do
subject ( :items ) { helper . current_user_menu_items }
before do
allow ( helper ) . to receive ( :current_user ) . and_return ( user )
allow ( helper ) . to receive ( :can? ) . and_return ( false )
end
2019-12-26 22:10:19 +05:30
after do
expect ( items ) . not_to include ( :start_trial )
end
2018-10-15 14:42:47 +05:30
it 'includes all default items' do
expect ( items ) . to include ( :help , :sign_out )
end
it 'includes the profile tab if the user can read themself' do
expect ( helper ) . to receive ( :can? ) . with ( user , :read_user , user ) { true }
expect ( items ) . to include ( :profile )
end
it 'includes the settings tab if the user can update themself' do
2020-04-22 19:07:51 +05:30
expect ( helper ) . to receive ( :can? ) . with ( user , :update_user , user ) { true }
2018-10-15 14:42:47 +05:30
2020-04-22 19:07:51 +05:30
expect ( items ) . to include ( :settings )
2018-10-15 14:42:47 +05:30
end
context 'when terms are enforced' do
before do
enforce_terms
end
it 'hides the profile and the settings tab' do
expect ( items ) . not_to include ( :settings , :profile , :help )
end
end
end
2019-03-02 22:35:43 +05:30
describe '#user_badges_in_admin_section' do
before do
allow ( helper ) . to receive ( :current_user ) . and_return ( user )
end
context 'with a blocked user' do
it " returns the blocked badge " do
blocked_user = create ( :user , state : 'blocked' )
badges = helper . user_badges_in_admin_section ( blocked_user )
2022-04-04 11:22:00 +05:30
expect ( filter_ee_badges ( badges ) ) . to match_array ( [ text : " Blocked " , variant : " danger " ] )
2019-03-02 22:35:43 +05:30
end
end
2021-01-03 14:25:43 +05:30
context 'with a pending approval user' do
it 'returns the pending approval badge' do
blocked_pending_approval_user = create ( :user , :blocked_pending_approval )
badges = helper . user_badges_in_admin_section ( blocked_pending_approval_user )
2022-04-04 11:22:00 +05:30
expect ( filter_ee_badges ( badges ) ) . to match_array ( [ text : 'Pending approval' , variant : 'info' ] )
2021-01-03 14:25:43 +05:30
end
end
2021-06-08 01:23:25 +05:30
context 'with a banned user' do
it 'returns the banned badge' do
banned_user = create ( :user , :banned )
badges = helper . user_badges_in_admin_section ( banned_user )
2022-04-04 11:22:00 +05:30
expect ( filter_ee_badges ( badges ) ) . to match_array ( [ text : 'Banned' , variant : 'danger' ] )
2021-06-08 01:23:25 +05:30
end
end
2019-03-02 22:35:43 +05:30
context 'with an admin user' do
it " returns the admin badge " do
admin_user = create ( :admin )
badges = helper . user_badges_in_admin_section ( admin_user )
2022-04-04 11:22:00 +05:30
expect ( filter_ee_badges ( badges ) ) . to match_array ( [ text : " Admin " , variant : " success " ] )
2019-03-02 22:35:43 +05:30
end
end
context 'with an external user' do
it 'returns the external badge' do
external_user = create ( :user , external : true )
badges = helper . user_badges_in_admin_section ( external_user )
2022-04-04 11:22:00 +05:30
expect ( filter_ee_badges ( badges ) ) . to match_array ( [ text : " External " , variant : " secondary " ] )
2019-03-02 22:35:43 +05:30
end
end
context 'with the current user' do
it 'returns the "It\'s You" badge' do
badges = helper . user_badges_in_admin_section ( user )
2022-04-04 11:22:00 +05:30
expect ( filter_ee_badges ( badges ) ) . to match_array ( [ text : " It's you! " , variant : " muted " ] )
2019-03-02 22:35:43 +05:30
end
end
context 'with an external blocked admin' do
it 'returns the blocked, admin and external badges' do
user = create ( :admin , state : 'blocked' , external : true )
badges = helper . user_badges_in_admin_section ( user )
2022-04-04 11:22:00 +05:30
expect ( badges ) . to match_array ( [
2019-03-02 22:35:43 +05:30
{ text : " Blocked " , variant : " danger " } ,
{ text : " Admin " , variant : " success " } ,
{ text : " External " , variant : " secondary " }
] )
end
end
2022-04-04 11:22:00 +05:30
context 'with a locked user' , time_travel_to : '2020-02-25 10:30:45 -0700' do
it 'returns the "Locked" badge' do
locked_user = create ( :user , locked_at : DateTime . parse ( '2020-02-25 10:30:00 -0700' ) )
badges = helper . user_badges_in_admin_section ( locked_user )
expect ( filter_ee_badges ( badges ) ) . to match_array ( [ text : " Locked " , variant : " warning " ] )
end
end
2019-03-02 22:35:43 +05:30
context 'get badges for normal user' do
it 'returns no badges' do
user = create ( :user )
badges = helper . user_badges_in_admin_section ( user )
2020-03-13 15:44:24 +05:30
expect ( filter_ee_badges ( badges ) ) . to be_empty
2019-03-02 22:35:43 +05:30
end
end
end
2020-04-08 14:13:33 +05:30
2021-01-03 14:25:43 +05:30
describe '#can_force_email_confirmation?' do
subject { helper . can_force_email_confirmation? ( user ) }
context 'for a user that is already confirmed' do
it { is_expected . to eq ( false ) }
end
context 'for a user that is not confirmed' do
let ( :user ) { create ( :user , :unconfirmed ) }
it { is_expected . to eq ( true ) }
end
end
2020-04-08 14:13:33 +05:30
describe '#work_information' do
2021-01-29 00:20:46 +05:30
let ( :with_schema_markup ) { false }
2020-04-08 14:13:33 +05:30
2021-01-29 00:20:46 +05:30
subject { helper . work_information ( user , with_schema_markup : with_schema_markup ) }
2020-04-08 14:13:33 +05:30
2021-01-29 00:20:46 +05:30
context 'when neither organization nor job_title are present' do
it { is_expected . to be_nil }
2020-04-08 14:13:33 +05:30
end
2021-01-29 00:20:46 +05:30
context 'when user parameter is nil' do
let ( :user ) { nil }
2020-04-08 14:13:33 +05:30
2021-01-29 00:20:46 +05:30
it { is_expected . to be_nil }
2020-04-08 14:13:33 +05:30
end
2021-01-29 00:20:46 +05:30
context 'without schema markup' do
context 'when both job_title and organization are present' do
let ( :user ) { build ( :user , organization : 'GitLab' , job_title : 'Frontend Engineer' ) }
2020-04-08 14:13:33 +05:30
2021-01-29 00:20:46 +05:30
it 'returns job title concatenated with organization' do
is_expected . to eq ( 'Frontend Engineer at GitLab' )
end
2020-04-08 14:13:33 +05:30
end
2021-01-29 00:20:46 +05:30
context 'when only organization is present' do
let ( :user ) { build ( :user , organization : 'GitLab' ) }
it " returns organization " do
is_expected . to eq ( 'GitLab' )
end
end
context 'when only job_title is present' do
let ( :user ) { build ( :user , job_title : 'Frontend Engineer' ) }
it 'returns job title' do
is_expected . to eq ( 'Frontend Engineer' )
end
end
2020-04-08 14:13:33 +05:30
end
2021-01-29 00:20:46 +05:30
context 'with schema markup' do
let ( :with_schema_markup ) { true }
2020-04-08 14:13:33 +05:30
2021-01-29 00:20:46 +05:30
context 'when both job_title and organization are present' do
let ( :user ) { build ( :user , organization : 'GitLab' , job_title : 'Frontend Engineer' ) }
it 'returns job title concatenated with organization' do
is_expected . to eq ( '<span itemprop="jobTitle">Frontend Engineer</span> at <span itemprop="worksFor">GitLab</span>' )
end
end
context 'when only organization is present' do
let ( :user ) { build ( :user , organization : 'GitLab' ) }
it " returns organization " do
is_expected . to eq ( '<span itemprop="worksFor">GitLab</span>' )
end
end
context 'when only job_title is present' do
let ( :user ) { build ( :user , job_title : 'Frontend Engineer' ) }
it 'returns job title' do
is_expected . to eq ( '<span itemprop="jobTitle">Frontend Engineer</span>' )
end
end
2020-04-08 14:13:33 +05:30
end
end
2021-02-22 17:27:13 +05:30
describe '#user_display_name' do
subject { helper . user_display_name ( user ) }
before do
stub_current_user ( nil )
end
context 'for a confirmed user' do
let ( :user ) { create ( :user ) }
before do
stub_profile_permission_allowed ( true )
end
it { is_expected . to eq ( user . name ) }
end
context 'for an unconfirmed user' do
let ( :user ) { create ( :user , :unconfirmed ) }
before do
stub_profile_permission_allowed ( false )
end
it { is_expected . to eq ( 'Unconfirmed user' ) }
context 'when current user is an admin' do
before do
admin_user = create ( :admin )
stub_current_user ( admin_user )
stub_profile_permission_allowed ( true , admin_user )
end
it { is_expected . to eq ( user . name ) }
end
context 'when the current user is self' do
before do
stub_current_user ( user )
stub_profile_permission_allowed ( true , user )
end
it { is_expected . to eq ( user . name ) }
end
end
context 'for a blocked user' do
let ( :user ) { create ( :user , :blocked ) }
it { is_expected . to eq ( 'Blocked user' ) }
end
def stub_current_user ( user )
allow ( helper ) . to receive ( :current_user ) . and_return ( user )
end
def stub_profile_permission_allowed ( allowed , current_user = nil )
allow ( helper ) . to receive ( :can? ) . with ( current_user , :read_user_profile , user ) . and_return ( allowed )
end
end
describe '#admin_users_data_attributes' do
subject ( :data ) { helper . admin_users_data_attributes ( [ user ] ) }
2021-03-08 18:12:59 +05:30
before do
allow ( helper ) . to receive ( :current_user ) . and_return ( user )
end
2021-02-22 17:27:13 +05:30
it 'users matches the serialized json' do
entity = double
expect_next_instance_of ( Admin :: UserSerializer ) do | instance |
2022-07-16 23:28:13 +05:30
expect ( instance ) . to receive ( :represent ) . with ( [ user ] , { current_user : user } ) . and_return ( entity )
2021-02-22 17:27:13 +05:30
end
expect ( entity ) . to receive ( :to_json ) . and_return ( " { \" username \" : \" admin \" } " )
expect ( data [ :users ] ) . to eq " { \" username \" : \" admin \" } "
end
it 'paths matches the schema' do
expect ( data [ :paths ] ) . to match_schema ( 'entities/admin_users_data_attributes_paths' )
end
end
2021-09-30 23:02:18 +05:30
describe '#confirm_user_data' do
confirm_admin_user_path = '/admin/users/root/confirm'
before do
allow ( helper ) . to receive ( :confirm_admin_user_path ) . with ( user ) . and_return ( confirm_admin_user_path )
end
subject ( :confirm_user_data ) { helper . confirm_user_data ( user ) }
it 'sets `path` key correctly' do
expect ( confirm_user_data [ :path ] ) . to eq ( confirm_admin_user_path )
end
it 'sets `modal_attributes` key to valid json' do
expect ( confirm_user_data [ :modal_attributes ] ) . to be_valid_json
end
context 'when `user.unconfirmed_email` is set' do
2021-12-11 22:18:48 +05:30
let ( :user ) { create ( :user , :unconfirmed , unconfirmed_email : 'foo@bar.com' ) }
2021-09-30 23:02:18 +05:30
it 'sets `modal_attributes.messageHtml` correctly' do
expect ( Gitlab :: Json . parse ( confirm_user_data [ :modal_attributes ] ) [ 'messageHtml' ] ) . to eq ( 'This user has an unconfirmed email address (foo@bar.com). You may force a confirmation.' )
end
end
context 'when `user.unconfirmed_email` is not set' do
it 'sets `modal_attributes.messageHtml` correctly' do
expect ( Gitlab :: Json . parse ( confirm_user_data [ :modal_attributes ] ) [ 'messageHtml' ] ) . to eq ( 'This user has an unconfirmed email address. You may force a confirmation.' )
end
end
end
describe '#admin_user_actions_data_attributes' do
subject ( :data ) { helper . admin_user_actions_data_attributes ( user ) }
before do
allow ( helper ) . to receive ( :current_user ) . and_return ( user )
allow ( Admin :: UserEntity ) . to receive ( :represent ) . and_call_original
end
it 'user matches the serialized json' do
expect ( data [ :user ] ) . to be_valid_json
expect ( Admin :: UserEntity ) . to have_received ( :represent ) . with ( user , hash_including ( { current_user : user } ) )
end
it 'paths matches the schema' do
expect ( data [ :paths ] ) . to match_schema ( 'entities/admin_users_data_attributes_paths' )
end
end
2017-08-17 22:00:37 +05:30
end