diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-11-15 15:11:17 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-11-15 15:11:17 +0300 |
commit | 0687020509cafe1e24eb0bfa0e0f5c9f6c4799d2 (patch) | |
tree | dd7e5d8e3612a24874ce0c15f2866a82086367a8 /spec/views/projects | |
parent | 260e9dadce54e1bafefa6c34a9f09bf6b70f5c18 (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/views/projects')
-rw-r--r-- | spec/views/projects/issues/_service_desk_info_content.html.haml_spec.rb | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/spec/views/projects/issues/_service_desk_info_content.html.haml_spec.rb b/spec/views/projects/issues/_service_desk_info_content.html.haml_spec.rb new file mode 100644 index 00000000000..1c6d729ddce --- /dev/null +++ b/spec/views/projects/issues/_service_desk_info_content.html.haml_spec.rb @@ -0,0 +1,95 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe 'projects/issues/_service_desk_info_content' do + let_it_be(:project) { create(:project) } + let_it_be(:user) { create(:user) } + let_it_be(:service_desk_address) { 'address@example.com' } + + before do + assign(:project, project) + allow(project).to receive(:service_desk_address).and_return(service_desk_address) + allow(view).to receive(:current_user).and_return(user) + end + + context 'when service desk is disabled' do + before do + allow(project).to receive(:service_desk_enabled?).and_return(false) + end + + context 'when the logged user is at least maintainer' do + before do + project.add_maintainer(user) + end + + it 'shows the info including the project settings link', :aggregate_failures do + render + + expect(rendered).to have_text('Use Service Desk') + expect(rendered).not_to have_text(service_desk_address) + expect(rendered).to have_link(href: "/#{project.full_path}/edit") + end + end + + context 'when the logged user is at only a developer' do + before do + project.add_developer(user) + end + + it 'shows the info without the project settings link', :aggregate_failures do + render + + expect(rendered).to have_text('Use Service Desk') + expect(rendered).not_to have_text(service_desk_address) + expect(rendered).not_to have_link(href: "/#{project.full_path}/edit") + end + end + end + + context 'when service desk is enabled' do + before do + allow(project).to receive(:service_desk_enabled?).and_return(true) + end + + context 'when the logged user is at least reporter' do + before do + project.add_reporter(user) + end + + it 'shows the info including the email address', :aggregate_failures do + render + + expect(rendered).to have_text('Use Service Desk') + expect(rendered).to have_text(service_desk_address) + expect(rendered).not_to have_link(href: "/#{project.full_path}/edit") + end + end + + context 'when the logged user is at only a guest' do + before do + project.add_guest(user) + end + + it 'shows the info without the email address', :aggregate_failures do + render + + expect(rendered).to have_text('Use Service Desk') + expect(rendered).not_to have_text(service_desk_address) + expect(rendered).not_to have_link(href: "/#{project.full_path}/edit") + end + end + + context 'when user is not logged in' do + let(:user) { nil } + + it 'shows the info without the email address', :aggregate_failures do + render + + expect(rendered).to have_text('Use Service Desk') + expect(rendered).not_to have_text(service_desk_address) + expect(rendered).not_to have_link(href: "/#{project.full_path}/edit") + end + end + end +end |