77 lines
1.9 KiB
Ruby
77 lines
1.9 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe 'Admin Mode Logout', :js do
|
|
include TermsHelper
|
|
include UserLoginHelper
|
|
include Spec::Support::Helpers::Features::TopNavSpecHelpers
|
|
|
|
let(:user) { create(:admin) }
|
|
|
|
shared_examples 'combined_menu: feature flag examples' do
|
|
before do
|
|
# TODO: This used to use gitlab_sign_in, instead of sign_in, but that is buggy. See
|
|
# this issue to look into why: https://gitlab.com/gitlab-org/gitlab/-/issues/331851
|
|
sign_in(user)
|
|
gitlab_enable_admin_mode_sign_in(user)
|
|
visit admin_root_path
|
|
end
|
|
|
|
it 'disable removes admin mode and redirects to root page' do
|
|
gitlab_disable_admin_mode
|
|
|
|
expect(current_path).to eq root_path
|
|
|
|
open_top_nav
|
|
|
|
within_top_nav do
|
|
expect(page).to have_link(href: new_admin_session_path)
|
|
end
|
|
end
|
|
|
|
it 'disable shows flash notice' do
|
|
gitlab_disable_admin_mode
|
|
|
|
expect(page).to have_selector('.flash-notice')
|
|
end
|
|
|
|
context 'on a read-only instance' do
|
|
before do
|
|
allow(Gitlab::Database).to receive(:read_only?).and_return(true)
|
|
end
|
|
|
|
it 'disable removes admin mode and redirects to root page' do
|
|
gitlab_disable_admin_mode
|
|
|
|
expect(current_path).to eq root_path
|
|
|
|
open_top_nav
|
|
|
|
within_top_nav do
|
|
expect(page).to have_link(href: new_admin_session_path)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with combined_menu feature flag on' do
|
|
let(:needs_rewrite_for_combined_menu_flag_on) { true }
|
|
|
|
before do
|
|
stub_feature_flags(combined_menu: true)
|
|
end
|
|
|
|
it_behaves_like 'combined_menu: feature flag examples'
|
|
end
|
|
|
|
context 'with combined_menu feature flag off' do
|
|
let(:needs_rewrite_for_combined_menu_flag_on) { false }
|
|
|
|
before do
|
|
stub_feature_flags(combined_menu: false)
|
|
end
|
|
|
|
it_behaves_like 'combined_menu: feature flag examples'
|
|
end
|
|
end
|