Files
notifications-admin/tests/app/main/views/test_folder_permissions.py
Alex Janousek 6f5750f095 Removed all govuk css (#2814)
* Removed all govuk css

* Updated reference files

* Removing govuk js

* Fixed casing for modules, removed unused page

* Got more reference images

* Updated template page

* Removed govuk padding util

* Updated hint to uswds hint

* More govuk cleanup

* Commiting backstopjs ref files

* Fixed all unit tests that broke due to brittleness around govuk styling

* Added new ref images

* Final removal of govuk

* Officially removed all govuk references

* Updated reference file

* Updated link to button

* UI modernization

* Cleanup

* removed govuk escaping tests since they are no longer needed

* Fix CodeQL security issue in escapeElementName function

- Escape backslashes first before other special characters
- Prevents potential double-escaping vulnerability
- Addresses CodeQL alert about improper string escaping

* Found more govuk removal. Fixed unit tests

* Add missing pipeline check to pre-commit

* updated test

* Updated e2e test

* More update to e2e test

* Fixed another e2e test

* Simple PR comments addressed

* More updates

* Updated backstop ref files

* Refactored folder selection for non-admins

* Updated redundant line

* Updated tests to include correct mocks

* Added more ref files

* Addressing carlos comments

* Addressing Carlo comments, cleanup of window initing

* More cleanup and addressing carlo comments

* Fixing a11 scan

* Fixed a few issues with javascript

* Fixed for pr

* Fixing e2e tests

* Tweaking e2e test

* Added more ref files and cleaned up urls.js

* Fixed bug with creating new template

* Removed brittle test - addressed code ql comment

* e2e race condition fix

* More e2e test fixes

* Updated e2e tests to not wait for text sent

* Updated test to not wait for button click response

* Made tear down more resilent if staging is down

* reverted e2e test to what was working before main merge

* Updated backstopRef images

* Updated gulp to include job-polling differently
2025-10-06 09:38:54 -04:00

77 lines
2.1 KiB
Python

from tests.conftest import SERVICE_ONE_ID, sample_uuid
def test_select_all_button_works(
client_request,
mocker,
mock_get_users_by_service,
mock_get_invites_for_service,
):
mocker.patch(
"app.template_folder_api_client.get_template_folders",
return_value=[
{"id": "folder-1", "name": "Folder 1", "parent_id": None},
{"id": "folder-2", "name": "Folder 2", "parent_id": None},
],
)
page = client_request.get(
"main.edit_user_permissions",
service_id=SERVICE_ONE_ID,
user_id=sample_uuid(),
)
button = page.select_one("button#select-all-folders")
assert button is not None
assert button.text.strip() in ["Select all", "Deselect all"]
def test_javascript_parent_child_logic_exists(
client_request,
mocker,
mock_get_users_by_service,
mock_get_invites_for_service,
):
mocker.patch(
"app.template_folder_api_client.get_template_folders",
return_value=[
{"id": "folder-1", "name": "Parent", "parent_id": None},
{"id": "folder-2", "name": "Child", "parent_id": "folder-1"},
],
)
page = client_request.get(
"main.edit_user_permissions",
service_id=SERVICE_ONE_ID,
user_id=sample_uuid(),
_test_page_title=False,
)
page_html = str(page)
assert "handleParentSelection" in page_html
assert "data-parent-id" in page_html
assert "toggleSelectAll" in page_html
def test_hidden_from_platform_admins(
mocker,
client_request,
platform_admin_user,
mock_get_invites_for_service,
mock_get_template_folders,
):
mocker.patch("app.user_api_client.get_user", return_value=platform_admin_user)
mocker.patch(
"app.models.user.Users.client_method",
return_value=[platform_admin_user],
)
page = client_request.get(
"main.edit_user_permissions",
service_id=SERVICE_ONE_ID,
user_id=platform_admin_user["id"],
)
assert "Platform admin users can access all template folders" in page.text
assert page.select_one("div#custom-folder-permissions") is None