Commit ff168740 authored by Rémy Coutable's avatar Rémy Coutable

Merge branch '11729-better-license-alert' into 'master'

Refactor Geo Node License Flash

Closes #11729

See merge request gitlab-org/gitlab!22933
parents d6cdeac2 adec0618
import initVueAlerts from '~/vue_alerts';
document.addEventListener('DOMContentLoaded', initVueAlerts);
...@@ -7,8 +7,7 @@ class Admin::Geo::ApplicationController < Admin::ApplicationController ...@@ -7,8 +7,7 @@ class Admin::Geo::ApplicationController < Admin::ApplicationController
def check_license! def check_license!
unless Gitlab::Geo.license_allows? unless Gitlab::Geo.license_allows?
flash[:alert] = _('You need a different license to use Geo replication.') render_403
redirect_to admin_license_path
end end
end end
end end
...@@ -10,10 +10,6 @@ class Admin::Geo::NodesController < Admin::Geo::ApplicationController ...@@ -10,10 +10,6 @@ class Admin::Geo::NodesController < Admin::Geo::ApplicationController
@nodes = GeoNode.all.order(:id) @nodes = GeoNode.all.order(:id)
@node = GeoNode.new @node = GeoNode.new
unless Gitlab::Geo.license_allows?
flash.now[:alert] = _('You need a different license to use Geo replication.')
end
unless Gitlab::Database.postgresql_minimum_supported_version? unless Gitlab::Database.postgresql_minimum_supported_version?
flash.now[:warning] = _('Please upgrade PostgreSQL to version 9.6 or greater. The status of the replication cannot be determined reliably with the current version.') flash.now[:warning] = _('Please upgrade PostgreSQL to version 9.6 or greater. The status of the replication cannot be determined reliably with the current version.')
end end
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
class Admin::Geo::SettingsController < Admin::ApplicationSettingsController class Admin::Geo::SettingsController < Admin::ApplicationSettingsController
helper ::EE::GeoHelper helper ::EE::GeoHelper
before_action :check_license! before_action :check_license!, except: :show
def show def show
end end
...@@ -11,8 +11,7 @@ class Admin::Geo::SettingsController < Admin::ApplicationSettingsController ...@@ -11,8 +11,7 @@ class Admin::Geo::SettingsController < Admin::ApplicationSettingsController
def check_license! def check_license!
unless Gitlab::Geo.license_allows? unless Gitlab::Geo.license_allows?
flash[:alert] = _('You need a different license to use Geo replication.') render_403
redirect_to admin_license_path
end end
end end
end end
...@@ -88,6 +88,10 @@ module LicenseHelper ...@@ -88,6 +88,10 @@ module LicenseHelper
@current_license = License.current @current_license = License.current
end end
def current_license_title
@current_license_title ||= License.current ? License.current.plan.titleize : 'Core'
end
def new_trial_url def new_trial_url
return_to_url = CGI.escape(Gitlab.config.gitlab.url) return_to_url = CGI.escape(Gitlab.config.gitlab.url)
uri = URI.parse(::EE::SUBSCRIPTIONS_URL) uri = URI.parse(::EE::SUBSCRIPTIONS_URL)
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
= render_enable_hashed_storage_warning = render_enable_hashed_storage_warning
= render_migrate_hashed_storage_warning = render_migrate_hashed_storage_warning
= render partial: 'admin/geo/shared/license_alert'
.d-flex.align-items-center.border-bottom.border-default.mb-4 .d-flex.align-items-center.border-bottom.border-default.mb-4
%h2.page-title %h2.page-title
......
- page_title "Geo Settings" - page_title "Geo Settings"
- @content_class = "limit-container-width geo-admin-settings" unless fluid_layout - @content_class = "limit-container-width geo-admin-settings" unless fluid_layout
= render partial: 'admin/geo/shared/license_alert'
= render_if_exists 'admin/geo/settings/form' = render_if_exists 'admin/geo/settings/form'
- return if Gitlab::Geo.license_allows?
.js-vue-alert{ 'v-cloak': true, data: { variant: 'tip',
primary_button_text: _('Manage your license'),
primary_button_link: admin_license_path,
dismissible: 'true' } }
= _('This GitLab instance is licensed at the %{insufficient_license} tier. Geo is only available for users who have at least a Premium license.') % { insufficient_license: current_license_title }
...@@ -3,12 +3,8 @@ require 'spec_helper' ...@@ -3,12 +3,8 @@ require 'spec_helper'
describe Admin::Geo::NodesController do describe Admin::Geo::NodesController do
shared_examples 'unlicensed geo action' do shared_examples 'unlicensed geo action' do
it 'redirects to the license page' do it 'redirects to the 403 page' do
expect(response).to redirect_to(admin_license_path) expect(response).to have_gitlab_http_status(:forbidden)
end
it 'displays a flash message' do
expect(controller).to set_flash[:alert].to('You need a different license to use Geo replication.')
end end
end end
...@@ -42,24 +38,31 @@ describe Admin::Geo::NodesController do ...@@ -42,24 +38,31 @@ describe Admin::Geo::NodesController do
get :index get :index
end end
context 'with add-on license available' do context 'with valid license' do
before do before do
allow(Gitlab::Geo).to receive(:license_allows?).and_return(true) allow(Gitlab::Geo).to receive(:license_allows?).and_return(true)
go
end end
it_behaves_like 'no flash message', :alert it 'does not show license alert' do
expect(response).to render_template(partial: '_license_alert')
expect(response.body).not_to include('Geo is only available for users who have at least a Premium license.')
end
end end
context 'without add-on license available' do context 'without valid license' do
before do before do
allow(Gitlab::Geo).to receive(:license_allows?).and_return(false) allow(Gitlab::Geo).to receive(:license_allows?).and_return(false)
go
end end
it_behaves_like 'with flash message', :alert, 'You need a different license to use Geo replication' it 'does show license alert' do
expect(response).to render_template(partial: '_license_alert')
expect(response.body).to include('Geo is only available for users who have at least a Premium license.')
end
it 'does not redirects to the license page' do it 'does not redirects to the 403 page' do
go expect(response).not_to redirect_to(:forbidden)
expect(response).not_to redirect_to(admin_license_path)
end end
end end
......
...@@ -14,9 +14,8 @@ describe Admin::Geo::ProjectsController, :geo do ...@@ -14,9 +14,8 @@ describe Admin::Geo::ProjectsController, :geo do
shared_examples 'license required' do shared_examples 'license required' do
context 'without a valid license' do context 'without a valid license' do
it 'redirects to license page with a flash message' do it 'redirects to 403 page' do
expect(subject).to redirect_to(admin_license_path) expect(subject).to have_gitlab_http_status(:forbidden)
expect(flash[:alert]).to include('You need a different license to use Geo replication')
end end
end end
end end
......
...@@ -14,9 +14,8 @@ describe Admin::Geo::SettingsController, :geo do ...@@ -14,9 +14,8 @@ describe Admin::Geo::SettingsController, :geo do
shared_examples 'license required' do shared_examples 'license required' do
context 'without a valid license' do context 'without a valid license' do
it 'redirects to license page with a flash message' do it 'redirects to 403 page' do
expect(subject).to redirect_to(admin_license_path) expect(subject).to have_gitlab_http_status(:forbidden)
expect(flash[:alert]).to include('You need a different license to use Geo replication')
end end
end end
end end
...@@ -26,20 +25,37 @@ describe Admin::Geo::SettingsController, :geo do ...@@ -26,20 +25,37 @@ describe Admin::Geo::SettingsController, :geo do
sign_in(admin) sign_in(admin)
end end
subject { get :show } context 'without a valid license' do
subject { get :show }
render_views
it_behaves_like 'license required' before do
stub_licensed_features(geo: false)
end
it 'does not redirects to the 403 page' do
expect(subject).not_to redirect_to(:forbidden)
end
it 'does show license alert' do
expect(subject).to render_template(partial: '_license_alert')
expect(subject.body).to include('Geo is only available for users who have at least a Premium license.')
end
end
context 'with a valid license' do context 'with a valid license' do
subject { get :show }
render_views render_views
before do before do
stub_licensed_features(geo: true) stub_licensed_features(geo: true)
end end
it 'renders the show template' do it 'does not show license alert' do
expect(subject).to have_gitlab_http_status(200) expect(subject).to render_template(partial: '_license_alert')
expect(subject).to render_template(:show) expect(subject.body).not_to include('Geo is only available for users who have at least a Premium license.')
end end
end end
end end
......
...@@ -21,9 +21,8 @@ describe Admin::Geo::UploadsController, :geo do ...@@ -21,9 +21,8 @@ describe Admin::Geo::UploadsController, :geo do
shared_examples 'license required' do shared_examples 'license required' do
context 'without a valid license' do context 'without a valid license' do
it 'redirects to license page with a flash message' do it 'redirects to 403 page' do
expect(subject).to redirect_to(admin_license_path) expect(subject).to have_gitlab_http_status(:forbidden)
expect(flash[:alert]).to include('You need a different license to use Geo replication')
end end
end end
end end
......
...@@ -13,6 +13,11 @@ describe 'Admin updates EE-only settings' do ...@@ -13,6 +13,11 @@ describe 'Admin updates EE-only settings' do
context 'Geo settings' do context 'Geo settings' do
context 'when the license has Geo feature' do context 'when the license has Geo feature' do
it 'hides JS alert' do
visit admin_geo_settings_path
expect(page).not_to have_content("Geo is only available for users who have at least a Premium license.")
end
it 'allows users to change Geo settings' do it 'allows users to change Geo settings' do
visit admin_geo_settings_path visit admin_geo_settings_path
page.within('section') do page.within('section') do
...@@ -28,12 +33,12 @@ describe 'Admin updates EE-only settings' do ...@@ -28,12 +33,12 @@ describe 'Admin updates EE-only settings' do
end end
context 'when the license does not have Geo feature' do context 'when the license does not have Geo feature' do
it 'shows empty page' do it 'shows JS alert' do
allow(License).to receive(:feature_available?).and_return(false) allow(License).to receive(:feature_available?).and_return(false)
visit admin_geo_settings_path visit admin_geo_settings_path
expect(page).to have_content 'You need a different license to use Geo replication' expect(page).to have_content("Geo is only available for users who have at least a Premium license.")
end end
end end
end end
......
...@@ -11547,6 +11547,9 @@ msgstr "" ...@@ -11547,6 +11547,9 @@ msgstr ""
msgid "Manage two-factor authentication" msgid "Manage two-factor authentication"
msgstr "" msgstr ""
msgid "Manage your license"
msgstr ""
msgid "Manifest" msgid "Manifest"
msgstr "" msgstr ""
...@@ -19226,6 +19229,9 @@ msgstr "" ...@@ -19226,6 +19229,9 @@ msgstr ""
msgid "This GitLab instance does not provide any shared Runners yet. Instance administrators can register shared Runners in the admin area." msgid "This GitLab instance does not provide any shared Runners yet. Instance administrators can register shared Runners in the admin area."
msgstr "" msgstr ""
msgid "This GitLab instance is licensed at the %{insufficient_license} tier. Geo is only available for users who have at least a Premium license."
msgstr ""
msgid "This action can lead to data loss. To prevent accidental actions we ask you to confirm your intention." msgid "This action can lead to data loss. To prevent accidental actions we ask you to confirm your intention."
msgstr "" msgstr ""
...@@ -21889,9 +21895,6 @@ msgstr "" ...@@ -21889,9 +21895,6 @@ msgstr ""
msgid "You need a different license to enable FileLocks feature" msgid "You need a different license to enable FileLocks feature"
msgstr "" msgstr ""
msgid "You need a different license to use Geo replication."
msgstr ""
msgid "You need git-lfs version %{min_git_lfs_version} (or greater) to continue. Please visit https://git-lfs.github.com" msgid "You need git-lfs version %{min_git_lfs_version} (or greater) to continue. Please visit https://git-lfs.github.com"
msgstr "" msgstr ""
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment