2020-03-13 15:44:24 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-23 00:09:42 +05:30
|
|
|
RSpec.describe 'Admin mode', :clean_gitlab_redis_shared_state, :do_not_mock_admin_mode do
|
2020-03-13 15:44:24 +05:30
|
|
|
include MobileHelpers
|
|
|
|
include StubENV
|
|
|
|
|
|
|
|
let(:admin) { create(:admin) }
|
|
|
|
|
|
|
|
before do
|
|
|
|
stub_env('IN_MEMORY_APPLICATION_SETTINGS', 'false')
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'feature flag :user_mode_in_session is enabled', :request_store do
|
|
|
|
before do
|
|
|
|
sign_in(admin)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when not in admin mode' do
|
|
|
|
it 'has no leave admin mode button' do
|
|
|
|
visit new_admin_session_path
|
|
|
|
|
|
|
|
page.within('.navbar-sub-nav') do
|
|
|
|
expect(page).not_to have_link(href: destroy_admin_session_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'can open pages not in admin scope' do
|
|
|
|
visit new_admin_session_path
|
|
|
|
|
|
|
|
page.within('.navbar-sub-nav') do
|
|
|
|
find_all('a', text: 'Projects').first.click
|
|
|
|
end
|
|
|
|
|
|
|
|
expect(page).to have_current_path(dashboard_projects_path)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'is necessary to provide credentials again before opening pages in admin scope' do
|
|
|
|
visit general_admin_application_settings_path # admin logged out because not in admin_mode
|
|
|
|
|
|
|
|
expect(page).to have_current_path(new_admin_session_path)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'can enter admin mode' do
|
|
|
|
visit new_admin_session_path
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
fill_in 'user_password', with: admin.password
|
2020-03-13 15:44:24 +05:30
|
|
|
|
|
|
|
click_button 'Enter Admin Mode'
|
|
|
|
|
|
|
|
expect(page).to have_current_path(admin_root_path)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'on a read-only instance' do
|
|
|
|
before do
|
|
|
|
allow(Gitlab::Database).to receive(:read_only?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'can enter admin mode' do
|
|
|
|
visit new_admin_session_path
|
|
|
|
|
2020-04-08 14:13:33 +05:30
|
|
|
fill_in 'user_password', with: admin.password
|
2020-03-13 15:44:24 +05:30
|
|
|
|
|
|
|
click_button 'Enter Admin Mode'
|
|
|
|
|
|
|
|
expect(page).to have_current_path(admin_root_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when in admin_mode' do
|
|
|
|
before do
|
|
|
|
gitlab_enable_admin_mode_sign_in(admin)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'contains link to leave admin mode' do
|
|
|
|
page.within('.navbar-sub-nav') do
|
|
|
|
expect(page).to have_link(href: destroy_admin_session_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'can leave admin mode using main dashboard link', :js do
|
|
|
|
page.within('.navbar-sub-nav') do
|
|
|
|
click_on 'Leave Admin Mode'
|
|
|
|
|
|
|
|
expect(page).to have_link(href: new_admin_session_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'can leave admin mode using dropdown menu on smaller screens', :js do
|
|
|
|
resize_screen_xs
|
|
|
|
visit root_dashboard_path
|
|
|
|
|
|
|
|
find('.header-more').click
|
|
|
|
|
|
|
|
page.within '.navbar-sub-nav' do
|
|
|
|
click_on 'Leave Admin Mode'
|
|
|
|
|
|
|
|
find('.header-more').click
|
|
|
|
|
|
|
|
expect(page).to have_link(href: new_admin_session_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'can open pages not in admin scope' do
|
|
|
|
page.within('.navbar-sub-nav') do
|
|
|
|
find_all('a', text: 'Projects').first.click
|
|
|
|
|
|
|
|
expect(page).to have_current_path(dashboard_projects_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'nav bar' do
|
|
|
|
it 'shows admin dashboard links on bigger screen' do
|
|
|
|
visit root_dashboard_path
|
|
|
|
|
|
|
|
page.within '.navbar' do
|
|
|
|
expect(page).to have_link(text: 'Admin Area', href: admin_root_path, visible: true)
|
|
|
|
expect(page).to have_link(text: 'Leave Admin Mode', href: destroy_admin_session_path, visible: true)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'relocates admin dashboard links to dropdown list on smaller screen', :js do
|
|
|
|
resize_screen_xs
|
|
|
|
visit root_dashboard_path
|
|
|
|
|
|
|
|
page.within '.navbar' do
|
|
|
|
expect(page).not_to have_link(text: 'Admin Area', href: admin_root_path, visible: true)
|
|
|
|
expect(page).not_to have_link(text: 'Leave Admin Mode', href: destroy_admin_session_path, visible: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
find('.header-more').click
|
|
|
|
|
|
|
|
page.within '.navbar' do
|
|
|
|
expect(page).to have_link(text: 'Admin Area', href: admin_root_path, visible: true)
|
|
|
|
expect(page).to have_link(text: 'Leave Admin Mode', href: destroy_admin_session_path, visible: true)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'on a read-only instance' do
|
|
|
|
before do
|
|
|
|
allow(Gitlab::Database).to receive(:read_only?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'can leave admin mode', :js do
|
|
|
|
page.within('.navbar-sub-nav') do
|
|
|
|
click_on 'Leave Admin Mode'
|
|
|
|
|
|
|
|
expect(page).to have_link(href: new_admin_session_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'feature flag :user_mode_in_session is disabled' do
|
|
|
|
before do
|
|
|
|
stub_feature_flags(user_mode_in_session: false)
|
|
|
|
sign_in(admin)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'shows no admin mode buttons in navbar' do
|
|
|
|
visit admin_root_path
|
|
|
|
|
|
|
|
page.within('.navbar-sub-nav') do
|
|
|
|
expect(page).not_to have_link(href: new_admin_session_path)
|
|
|
|
expect(page).not_to have_link(href: destroy_admin_session_path)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|