Files
gitlabhq/spec/features/monitor_sidebar_link_spec.rb
2025-06-27 12:07:30 +00:00

223 lines
7.8 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe 'Monitor dropdown sidebar', :js, feature_category: :shared do
let_it_be_with_reload(:project) { create(:project, :internal, :repository) }
let_it_be(:user) { create(:user) }
let(:role) { nil }
before do
# TODO: When removing the feature flag,
# we won't need the tests for the issues listing page, since we'll be using
# the work items listing page.
stub_feature_flags(work_item_planning_view: false)
stub_feature_flags(hide_incident_management_features: false)
project.add_role(user, role) if role
sign_in(user)
project.update!(service_desk_enabled: true)
allow(::ServiceDesk).to receive(:supported?).and_return(true)
end
shared_examples 'shows common Monitor menu item based on the access level' do
using RSpec::Parameterized::TableSyntax
let(:enabled) { Featurable::PRIVATE }
let(:disabled) { Featurable::DISABLED }
where(:monitor_level, :render) do
ref(:enabled) | true
ref(:disabled) | false
end
with_them do
it 'renders when expected to' do
project.project_feature.update_attribute(:monitor_access_level, monitor_level)
visit project_issues_path(project)
click_button('Monitor')
within_testid('super-sidebar') do
if render
expect(page).to have_link('Incidents')
else
expect(page).not_to have_link('Incidents', visible: :all)
end
end
end
end
end
shared_examples 'monitor sub menu visibility based on feature flag' do
context "when hide_incident_management_features feature is enabled" do
before do
stub_feature_flags(hide_incident_management_features: true)
end
it 'does not show the incident menu' do
visit project_issues_path(project)
click_button('Monitor')
expect(page).not_to have_link('Incidents', href: project_incidents_path(project))
end
it 'does not show the alert menu' do
visit project_issues_path(project)
click_button('Monitor')
expect(page).not_to have_link('Alerts', href: project_alert_management_index_path(project))
end
end
context "when hide_incident_management_features feature is disabled" do
let(:role) { :developer }
before do
stub_feature_flags(hide_incident_management_features: false)
end
it 'shows the incident menu' do
visit project_issues_path(project)
click_button('Monitor')
expect(page).to have_link('Incidents', href: project_incidents_path(project))
end
it 'shows the alert menu' do
visit project_issues_path(project)
click_button('Monitor')
expect(page).to have_link('Alerts', href: project_alert_management_index_path(project))
end
end
end
context 'when user is not a member' do
let(:access_level) { ProjectFeature::PUBLIC }
before do
project.project_feature.update_attribute(:monitor_access_level, access_level)
visit project_issues_path(project)
click_button('Monitor')
end
it 'has the correct `Monitor` and `Operate` menu items' do
expect(page).to have_link('Incidents', href: project_incidents_path(project))
click_button('Operate')
expect(page).to have_link('Environments', href: project_environments_path(project))
expect(page).not_to have_link('Alerts', href: project_alert_management_index_path(project), visible: :all)
expect(page).not_to have_link('Error Tracking', href: project_error_tracking_index_path(project), visible: :all)
expect(page).not_to have_link('Kubernetes clusters', href: project_clusters_path(project), visible: :all)
end
context 'when monitor project feature is PRIVATE' do
let(:access_level) { ProjectFeature::PRIVATE }
it 'does not show common items of the `Monitor` menu' do
expect(page).not_to have_link('Error Tracking', href: project_incidents_path(project), visible: :all)
end
end
context 'when monitor project feature is DISABLED' do
let(:access_level) { ProjectFeature::DISABLED }
it 'does not show the `Incidents` menu' do
expect(page).not_to have_link('Error Tracking', href: project_incidents_path(project), visible: :all)
end
end
end
context 'when user has guest role' do
let(:role) { :guest }
it 'has the correct `Monitor` and `Operate` menu items' do
visit project_issues_path(project)
click_button('Monitor')
expect(page).to have_link('Incidents', href: project_incidents_path(project))
click_button('Operate')
expect(page).to have_link('Environments', href: project_environments_path(project))
expect(page).not_to have_link('Alerts', href: project_alert_management_index_path(project), visible: :all)
expect(page).not_to have_link('Error Tracking', href: project_error_tracking_index_path(project), visible: :all)
expect(page).not_to have_link('Kubernetes clusters', href: project_clusters_path(project), visible: :all)
end
it_behaves_like 'shows common Monitor menu item based on the access level'
it_behaves_like 'monitor sub menu visibility based on feature flag'
end
context 'when user has reporter role' do
let(:role) { :reporter }
it 'has the correct `Monitor` and `Operate` menu items' do
visit project_issues_path(project)
click_button('Monitor')
expect(page).to have_link('Incidents', href: project_incidents_path(project))
expect(page).to have_link('Error Tracking', href: project_error_tracking_index_path(project))
click_button('Operate')
expect(page).to have_link('Environments', href: project_environments_path(project))
expect(page).not_to have_link('Alerts', href: project_alert_management_index_path(project), visible: :all)
expect(page).not_to have_link('Kubernetes clusters', href: project_clusters_path(project), visible: :all)
end
it_behaves_like 'shows common Monitor menu item based on the access level'
it_behaves_like 'monitor sub menu visibility based on feature flag'
end
context 'when user has developer role' do
let(:role) { :developer }
it 'has the correct `Monitor` and `Operate` menu items' do
visit project_issues_path(project)
click_button('Monitor')
expect(page).to have_link('Alerts', href: project_alert_management_index_path(project))
expect(page).to have_link('Incidents', href: project_incidents_path(project))
expect(page).to have_link('Error Tracking', href: project_error_tracking_index_path(project))
click_button('Operate')
expect(page).to have_link('Environments', href: project_environments_path(project))
expect(page).to have_link('Kubernetes clusters', href: project_clusters_path(project))
end
it_behaves_like 'shows common Monitor menu item based on the access level'
it_behaves_like 'monitor sub menu visibility based on feature flag'
end
context 'when user has maintainer role' do
let(:role) { :maintainer }
it 'has the correct `Monitor` and `Operate` menu items' do
visit project_issues_path(project)
click_button('Monitor')
expect(page).to have_link('Alerts', href: project_alert_management_index_path(project))
expect(page).to have_link('Incidents', href: project_incidents_path(project))
expect(page).to have_link('Error Tracking', href: project_error_tracking_index_path(project))
click_button('Operate')
expect(page).to have_link('Environments', href: project_environments_path(project))
expect(page).to have_link('Kubernetes clusters', href: project_clusters_path(project))
end
it_behaves_like 'shows common Monitor menu item based on the access level'
it_behaves_like 'monitor sub menu visibility based on feature flag'
end
end