Commit de1b5559 authored by Markus Koller's avatar Markus Koller

Merge branch 'jnnkl-static-sec-conf-dynamic-link' into 'master'

Dynamic Link static security configuration Page [RUN AS-IF-FOSS]

See merge request gitlab-org/gitlab!54093
parents 229a8457 d3f779ba
...@@ -7,6 +7,12 @@ export default { ...@@ -7,6 +7,12 @@ export default {
GlLink, GlLink,
GlSprintf, GlSprintf,
}, },
inject: {
upgradePath: {
from: 'upgradePath',
default: '#',
},
},
i18n: { i18n: {
UPGRADE_CTA, UPGRADE_CTA,
}, },
...@@ -17,7 +23,7 @@ export default { ...@@ -17,7 +23,7 @@ export default {
<span> <span>
<gl-sprintf :message="$options.i18n.UPGRADE_CTA"> <gl-sprintf :message="$options.i18n.UPGRADE_CTA">
<template #link="{ content }"> <template #link="{ content }">
<gl-link target="_blank" href="https://about.gitlab.com/pricing/"> <gl-link target="_blank" :href="upgradePath">
{{ content }} {{ content }}
</gl-link> </gl-link>
</template> </template>
......
...@@ -14,13 +14,14 @@ export const initStaticSecurityConfiguration = (el) => { ...@@ -14,13 +14,14 @@ export const initStaticSecurityConfiguration = (el) => {
defaultClient: createDefaultClient(), defaultClient: createDefaultClient(),
}); });
const { projectPath } = el.dataset; const { projectPath, upgradePath } = el.dataset;
return new Vue({ return new Vue({
el, el,
apolloProvider, apolloProvider,
provide: { provide: {
projectPath, projectPath,
upgradePath,
}, },
render(createElement) { render(createElement) {
return createElement(SecurityConfigurationApp); return createElement(SecurityConfigurationApp);
......
# frozen_string_literal: true
module Projects
module Security
module ConfigurationHelper
def security_upgrade_path
'https://about.gitlab.com/pricing/'
end
end
end
end
::Projects::Security::ConfigurationHelper.prepend_if_ee('::EE::Projects::Security::ConfigurationHelper')
- breadcrumb_title _("Security Configuration") - breadcrumb_title _("Security Configuration")
- page_title _("Security Configuration") - page_title _("Security Configuration")
#js-security-configuration-static{ data: {project_path: @project.full_path} } #js-security-configuration-static{ data: { project_path: @project.full_path, upgrade_path: security_upgrade_path } }
# frozen_string_literal: true
module EE
module Projects
module Security
module ConfigurationHelper
extend ::Gitlab::Utils::Override
override :security_upgrade_path
def security_upgrade_path
return super unless show_discover_project_security?(@project)
project_security_discover_path(@project)
end
end
end
end
end
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe EE::Projects::Security::ConfigurationHelper do
include ActionView::Helpers::UrlHelper
let_it_be(:project) { create(:project) }
let(:current_user) { create(:user) }
subject { helper.security_upgrade_path }
before do
helper.instance_variable_set(:@project, project)
allow(helper).to receive(:show_discover_project_security?).and_return(can_access_discover_security)
end
context 'when user can access discover security' do
let(:can_access_discover_security) { true }
it { is_expected.to eq(project_security_discover_path(project)) }
end
context 'when user can not access discover security' do
let(:can_access_discover_security) { false }
it { is_expected.to eq('https://about.gitlab.com/pricing/') }
end
end
...@@ -2,27 +2,28 @@ import { mount } from '@vue/test-utils'; ...@@ -2,27 +2,28 @@ import { mount } from '@vue/test-utils';
import { UPGRADE_CTA } from '~/security_configuration/components/features_constants'; import { UPGRADE_CTA } from '~/security_configuration/components/features_constants';
import Upgrade from '~/security_configuration/components/upgrade.vue'; import Upgrade from '~/security_configuration/components/upgrade.vue';
const TEST_URL = 'http://www.example.test';
let wrapper; let wrapper;
const createComponent = () => { const createComponent = (componentData = {}) => {
wrapper = mount(Upgrade, {}); wrapper = mount(Upgrade, componentData);
}; };
beforeEach(() => {
createComponent();
});
afterEach(() => { afterEach(() => {
wrapper.destroy(); wrapper.destroy();
}); });
describe('Upgrade component', () => { describe('Upgrade component', () => {
beforeEach(() => {
createComponent({ provide: { upgradePath: TEST_URL } });
});
it('renders correct text in link', () => { it('renders correct text in link', () => {
expect(wrapper.text()).toMatchInterpolatedText(UPGRADE_CTA); expect(wrapper.text()).toMatchInterpolatedText(UPGRADE_CTA);
}); });
it('renders link with correct attributes', () => { it('renders link with correct default attributes', () => {
expect(wrapper.find('a').attributes()).toMatchObject({ expect(wrapper.find('a').attributes()).toMatchObject({
href: 'https://about.gitlab.com/pricing/', href: TEST_URL,
target: '_blank', target: '_blank',
}); });
}); });
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Projects::Security::ConfigurationHelper do
let(:current_user) { create(:user) }
describe 'security_upgrade_path' do
subject { security_upgrade_path }
it { is_expected.to eq('https://about.gitlab.com/pricing/') }
end
end
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