Protected containers: Delete protection rule in project settings ui
requested to merge gitlab-community/gitlab:441345-gerardo-navarro-protected-contaioners-project-settings-ui-delete into master
What does this MR do and why?
- Adding button "Delete rule" for each row containing a protection rule
- Sending a graphql mutation "deleteContainerRegistryProtectionRule" when the button "Delete rule" is clicked
- Showing an alert when the graphql mutation fails
- Adding tests for button 'Delete rule'
- Code mostly taken from related MR, see Protected packages: Delete protection rule in p... (!140483 - merged)
MR acceptance checklist
Please evaluate this MR against the MR acceptance checklist. It helps you analyze changes to reduce risks in quality, performance, reliability, security, and maintainability.
MR Checklist (@gerardo-navarro)
-
Changelog entry added, if necessary -
Documentation created/updated via this MR -
Documentation reviewed by technical writer or follow-up review issue created -
Tests added for this feature/bug -
Tested in all supported browsers -
Conforms to the code review guidelines -
Conforms to the merge request performance guidelines -
Conforms to the style guides -
Conforms to the javascript style guides -
Conforms to the database guides
Screenshots or screen recordings
Short screencast: https://www.loom.com/share/7c54e76c5942418498e223dc06c57cda
Before | After |
---|---|
How to set up and validate locally
- Enable Registry by editting
config/gitlab.yml
with the following setting
registry:
enabled: true
- Restart GDK, see also https://docs.gitlab.com/ee/administration/packages/container_registry.html#configure-container-registry-under-an-existing-gitlab-domain
gdk restart
- In rails console enable the experiment fully
Feature.enable(:container_registry_protected_containers)
- Create some container protection rules to show in the table
15.times { |i| ContainerRegistry::Protection::Rule.create(project: Project.find(7), repository_path_pattern: "flightjs/flight#{i}", push_protected_up_to_access_level: :maintainer, delete_protected_up_to_access_level: :developer) }
- Go to http://gdk.test:3000/flightjs/Flight/-/settings/packages_and_registries
- Start deleting and re-adding container protection rules
Related to #441345 (closed)
Edited by Gerardo Navarro