# Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ require 'rails_helper' RSpec.describe 'Profile', type: :system do it 'shows profile link in navigation' do visit 'dashboard' find('a[href="#current_user"]').click expect(page).to have_css('.dropdown-menu > li > a[href="#profile"]') end context 'when user is an agent with no user_preferences permission', authenticated_as: :new_user do let(:role) { create(:role, permissions: [Permission.find_by(name: 'ticket.agent')]) } let(:new_user) { create(:user, roles: [role]) } it 'does not show profile link in navigation' do visit 'dashboard' find('a[href="#current_user"]').click expect(page).to have_no_css('.dropdown-menu > li > a[href="#profile"]') end end context "Don't provide option to create API-Token if authentication via API token is disabled #3168" do before do visit 'profile' end it 'does show the navbar link Token Access based on the Setting api_token_access' do expect(page).to have_text('Token Access') # disable token access visit 'system/api' click 'label[for=api_token_access]' visit 'profile' expect(page).to have_no_text('Token Access') # enable token access visit 'system/api' click 'label[for=api_token_access]' visit 'profile' expect(page).to have_text('Token Access') end end context 'when password login is disabled', authenticated_as: :authenticate do let(:user) { create(:agent) } def authenticate Setting.set('user_show_password_login', false) user end before do visit 'profile' end it 'does not show password profile' do expect(page).to have_no_text('Password') end context 'with admin user' do let(:user) { create(:admin) } it 'does show password profile' do expect(page).to have_text('Password') end end end end