2017-09-10 17:25:29 +05:30
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
describe ProfilesHelper do
|
2018-12-13 13:39:08 +05:30
|
|
|
describe '#commit_email_select_options' do
|
|
|
|
it 'returns an array with private commit email along with all the verified emails' do
|
|
|
|
user = create(:user)
|
|
|
|
create(:email, user: user)
|
|
|
|
confirmed_email1 = create(:email, :confirmed, user: user)
|
|
|
|
confirmed_email2 = create(:email, :confirmed, user: user)
|
|
|
|
|
|
|
|
private_email = user.private_commit_email
|
|
|
|
|
|
|
|
emails = [
|
|
|
|
["Use a private email - #{private_email}", Gitlab::PrivateCommitEmail::TOKEN],
|
|
|
|
user.email,
|
|
|
|
confirmed_email1.email,
|
|
|
|
confirmed_email2.email
|
|
|
|
]
|
|
|
|
|
|
|
|
expect(helper.commit_email_select_options(user)).to match_array(emails)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#selected_commit_email' do
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
|
|
|
it 'returns main email when commit email attribute is nil' do
|
|
|
|
expect(helper.selected_commit_email(user)).to eq(user.email)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns DB stored commit_email' do
|
|
|
|
user.update(commit_email: Gitlab::PrivateCommitEmail::TOKEN)
|
|
|
|
|
|
|
|
expect(helper.selected_commit_email(user)).to eq(Gitlab::PrivateCommitEmail::TOKEN)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
describe '#email_provider_label' do
|
|
|
|
it "returns nil for users without external email" do
|
|
|
|
user = create(:user)
|
|
|
|
allow(helper).to receive(:current_user).and_return(user)
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
expect(helper.attribute_provider_label(:email)).to be_nil
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
it "returns omniauth provider label for users with external attributes" do
|
|
|
|
stub_omniauth_setting(sync_profile_from_provider: ['cas3'])
|
|
|
|
stub_omniauth_setting(sync_profile_attributes: true)
|
2017-09-10 17:25:29 +05:30
|
|
|
stub_cas_omniauth_provider
|
2018-03-17 18:26:18 +05:30
|
|
|
cas_user = create(:omniauth_user, provider: 'cas3')
|
|
|
|
cas_user.create_user_synced_attributes_metadata(provider: 'cas3', name_synced: true, email_synced: true, location_synced: true)
|
2017-09-10 17:25:29 +05:30
|
|
|
allow(helper).to receive(:current_user).and_return(cas_user)
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
expect(helper.attribute_provider_label(:email)).to eq('CAS')
|
|
|
|
expect(helper.attribute_provider_label(:name)).to eq('CAS')
|
|
|
|
expect(helper.attribute_provider_label(:location)).to eq('CAS')
|
|
|
|
end
|
|
|
|
|
|
|
|
it "returns the correct omniauth provider label for users with some external attributes" do
|
|
|
|
stub_omniauth_setting(sync_profile_from_provider: ['cas3'])
|
|
|
|
stub_omniauth_setting(sync_profile_attributes: true)
|
|
|
|
stub_cas_omniauth_provider
|
|
|
|
cas_user = create(:omniauth_user, provider: 'cas3')
|
|
|
|
cas_user.create_user_synced_attributes_metadata(provider: 'cas3', name_synced: false, email_synced: true, location_synced: false)
|
|
|
|
allow(helper).to receive(:current_user).and_return(cas_user)
|
|
|
|
|
|
|
|
expect(helper.attribute_provider_label(:name)).to be_nil
|
|
|
|
expect(helper.attribute_provider_label(:email)).to eq('CAS')
|
|
|
|
expect(helper.attribute_provider_label(:location)).to be_nil
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
it "returns 'LDAP' for users with external email but no email provider" do
|
2018-03-17 18:26:18 +05:30
|
|
|
ldap_user = create(:omniauth_user)
|
|
|
|
ldap_user.create_user_synced_attributes_metadata(email_synced: true)
|
2017-09-10 17:25:29 +05:30
|
|
|
allow(helper).to receive(:current_user).and_return(ldap_user)
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
expect(helper.attribute_provider_label(:email)).to eq('LDAP')
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def stub_cas_omniauth_provider
|
|
|
|
provider = OpenStruct.new(
|
|
|
|
'name' => 'cas3',
|
|
|
|
'label' => 'CAS'
|
|
|
|
)
|
|
|
|
|
|
|
|
stub_omniauth_setting(providers: [provider])
|
|
|
|
end
|
|
|
|
end
|