Commit 953b4c31 authored by Alexander Turinske's avatar Alexander Turinske

Add ability to change security policy project

- to owners only
- hide to all other users
- add tests
parent 36adf4b2
...@@ -10,14 +10,19 @@ export default { ...@@ -10,14 +10,19 @@ export default {
GlAlert, GlAlert,
ScanNewPolicyModal, ScanNewPolicyModal,
}, },
inject: ['documentationPath', 'assignedPolicyProject', 'newPolicyPath'], inject: [
'assignedPolicyProject',
'disableSecurityPolicyProject',
'documentationPath',
'newPolicyPath',
],
i18n: { i18n: {
title: s__('NetworkPolicies|Policies'), title: s__('SecurityOrchestration|Policies'),
subtitle: s__( subtitle: s__(
'NetworkPolicies|Enforce security for this project. %{linkStart}More information.%{linkEnd}', 'SecurityOrchestration|Enforce security for this project. %{linkStart}More information.%{linkEnd}',
), ),
newPolicyButtonText: s__('NetworkPolicies|New policy'), newPolicyButtonText: s__('SecurityOrchestration|New policy'),
editPolicyButtonText: s__('NetworkPolicies|Edit policy project'), editPolicyProjectButtonText: s__('SecurityOrchestration|Edit policy project'),
}, },
data() { data() {
return { return {
...@@ -86,12 +91,13 @@ export default { ...@@ -86,12 +91,13 @@ export default {
</p> </p>
</div> </div>
<gl-button <gl-button
v-if="!disableSecurityPolicyProject"
data-testid="edit-project-policy-button" data-testid="edit-project-policy-button"
class="gl-mr-4" class="gl-mr-4"
:loading="projectIsBeingLinked" :loading="projectIsBeingLinked"
@click="showNewPolicyModal" @click="showNewPolicyModal"
> >
{{ $options.i18n.editPolicyButtonText }} {{ $options.i18n.editPolicyProjectButtonText }}
</gl-button> </gl-button>
<gl-button data-testid="new-policy-button" variant="confirm" :href="newPolicyPath"> <gl-button data-testid="new-policy-button" variant="confirm" :href="newPolicyPath">
{{ $options.i18n.newPolicyButtonText }} {{ $options.i18n.newPolicyButtonText }}
......
...@@ -23,6 +23,7 @@ describe('Policies Header Component', () => { ...@@ -23,6 +23,7 @@ describe('Policies Header Component', () => {
documentationPath, documentationPath,
newPolicyPath, newPolicyPath,
assignedPolicyProject: null, assignedPolicyProject: null,
disableSecurityPolicyProject: false,
...provide, ...provide,
}, },
stubs: { stubs: {
...@@ -36,58 +37,70 @@ describe('Policies Header Component', () => { ...@@ -36,58 +37,70 @@ describe('Policies Header Component', () => {
wrapper.destroy(); wrapper.destroy();
}); });
beforeEach(() => { describe('project owner', () => {
createWrapper(); beforeEach(() => {
}); createWrapper();
});
it('displays New policy button with correct text and link', () => { it('displays New policy button with correct text and link', () => {
expect(findNewPolicyButton().text()).toBe('New policy'); expect(findNewPolicyButton().text()).toBe('New policy');
expect(findNewPolicyButton().attributes('href')).toBe(newPolicyPath); expect(findNewPolicyButton().attributes('href')).toBe(newPolicyPath);
}); });
it('displays the Edit policy project button', () => { it('displays the Edit policy project button', () => {
expect(findEditPolicyProjectButton().text()).toBe('Edit policy project'); expect(findEditPolicyProjectButton().text()).toBe('Edit policy project');
}); });
it('does not display the alert component by default', () => { it('does not display the alert component by default', () => {
expect(findAlert().exists()).toBe(false); expect(findAlert().exists()).toBe(false);
}); });
it('displays the alert component when scan new modal policy emits events', async () => {
const text = 'Project was linked successfully.';
findScanNewPolicyModal().vm.$emit('project-updated', {
text,
variant: 'success',
});
it('displays the alert component when scan new modal policy emits events', async () => { // When the project is updated it displays the output message.
const text = 'Project was linked successfully.'; await wrapper.vm.$nextTick();
expect(findAlert().text()).toBe(text);
findScanNewPolicyModal().vm.$emit('project-updated', { // When the project is being updated once again, it removes the alert so that
text, // the new one will be displayed.
variant: 'success', findScanNewPolicyModal().vm.$emit('updating-project');
await wrapper.vm.$nextTick();
expect(findAlert().exists()).toBe(false);
}); });
// When the project is updated it displays the output message. it('mounts the scan new policy modal', () => {
await wrapper.vm.$nextTick(); expect(findScanNewPolicyModal().exists()).toBe(true);
expect(findAlert().text()).toBe(text); });
// When the project is being updated once again, it removes the alert so that it('displays scan new policy modal when the action button is clicked', async () => {
// the new one will be displayed. await findEditPolicyProjectButton().trigger('click');
findScanNewPolicyModal().vm.$emit('updating-project');
await wrapper.vm.$nextTick();
expect(findAlert().exists()).toBe(false);
});
it('mounts the scan new policy modal', () => { expect(findScanNewPolicyModal().props().visible).toBe(true);
expect(findScanNewPolicyModal().exists()).toBe(true); });
});
it('displays scan new policy modal when the action button is clicked', async () => { it('displays the header', () => {
await findEditPolicyProjectButton().trigger('click'); expect(findHeader().text()).toBe('Policies');
});
expect(findScanNewPolicyModal().props().visible).toBe(true); it('displays the subheader', () => {
expect(findSubheader().text()).toContain('Enforce security for this project.');
expect(findMoreInformationLink().attributes('href')).toBe(documentationPath);
});
}); });
it('displays the header', () => { describe('project user', () => {
expect(findHeader().text()).toBe('Policies'); beforeEach(() => {
}); createWrapper({ provide: { disableSecurityPolicyProject: true } });
});
it('displays the subheader', () => { it('does not display the Edit policy project button', () => {
expect(findSubheader().text()).toContain('Enforce security for this project.'); expect(findEditPolicyProjectButton().exists()).toBe(false);
expect(findMoreInformationLink().attributes('href')).toBe(documentationPath); });
}); });
}); });
...@@ -22040,12 +22040,6 @@ msgstr "" ...@@ -22040,12 +22040,6 @@ msgstr ""
msgid "NetworkPolicies|Edit policy" msgid "NetworkPolicies|Edit policy"
msgstr "" msgstr ""
msgid "NetworkPolicies|Edit policy project"
msgstr ""
msgid "NetworkPolicies|Enforce security for this project. %{linkStart}More information.%{linkEnd}"
msgstr ""
msgid "NetworkPolicies|Enforcement status" msgid "NetworkPolicies|Enforcement status"
msgstr "" msgstr ""
...@@ -22088,9 +22082,6 @@ msgstr "" ...@@ -22088,9 +22082,6 @@ msgstr ""
msgid "NetworkPolicies|Please %{installLinkStart}install%{installLinkEnd} and %{configureLinkStart}configure a Kubernetes Agent for this project%{configureLinkEnd} to enable alerts." msgid "NetworkPolicies|Please %{installLinkStart}install%{installLinkEnd} and %{configureLinkStart}configure a Kubernetes Agent for this project%{configureLinkEnd} to enable alerts."
msgstr "" msgstr ""
msgid "NetworkPolicies|Policies"
msgstr ""
msgid "NetworkPolicies|Policies are a specification of how groups of pods are allowed to communicate with each other's network endpoints." msgid "NetworkPolicies|Policies are a specification of how groups of pods are allowed to communicate with each other's network endpoints."
msgstr "" msgstr ""
...@@ -29504,9 +29495,21 @@ msgstr "" ...@@ -29504,9 +29495,21 @@ msgstr ""
msgid "SecurityOrchestration|An error occurred assigning your security policy project" msgid "SecurityOrchestration|An error occurred assigning your security policy project"
msgstr "" msgstr ""
msgid "SecurityOrchestration|Edit policy project"
msgstr ""
msgid "SecurityOrchestration|Enforce security for this project. %{linkStart}More information.%{linkEnd}"
msgstr ""
msgid "SecurityOrchestration|New policy"
msgstr ""
msgid "SecurityOrchestration|Only owners can update Security Policy Project" msgid "SecurityOrchestration|Only owners can update Security Policy Project"
msgstr "" msgstr ""
msgid "SecurityOrchestration|Policies"
msgstr ""
msgid "SecurityOrchestration|Security policy project was linked successfully" msgid "SecurityOrchestration|Security policy project was linked successfully"
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