diff options
author | Frederick Muriuki Muriithi | 2022-11-24 11:36:42 +0300 |
---|---|---|
committer | Frederick Muriuki Muriithi | 2022-11-24 11:36:42 +0300 |
commit | 1f68ade38e8d3694e7e64f98282ed3eab09feac6 (patch) | |
tree | 27d8922bc0660ced5efeb6da18b8f088b74a72c9 /tests/unit/auth/test_resources.py | |
parent | d0d08d513e403f7836da450a1d05eaeb89a5ba30 (diff) | |
download | genenetwork3-1f68ade38e8d3694e7e64f98282ed3eab09feac6.tar.gz |
tests: Add test for `create_resource`
* gn3/auth/authorisation/resources.py: Define Resource and ResourceCategory
classes. Create the `create_resource` stub.
* tests/unit/auth/test_resources.py: test for `create_resource` function
Diffstat (limited to 'tests/unit/auth/test_resources.py')
-rw-r--r-- | tests/unit/auth/test_resources.py | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/tests/unit/auth/test_resources.py b/tests/unit/auth/test_resources.py new file mode 100644 index 0000000..04d0017 --- /dev/null +++ b/tests/unit/auth/test_resources.py @@ -0,0 +1,33 @@ +"""Test resource-management functions""" +import uuid + +import pytest + +from gn3.auth.authorisation.groups import Group +from gn3.auth.authorisation.resources import ( + Resource, create_resource, ResourceCategory) + +group = Group(uuid.UUID("9988c21d-f02f-4d45-8966-22c968ac2fbf"), "TheTestGroup") +resource_category = ResourceCategory( + uuid.UUID("fad071a3-2fc8-40b8-992b-cdefe7dcac79"), "mrna", "mRNA Dataset") +create_resource_failure = { + "status": "error", + "message": "Unauthorised: Could not create resource" +} + +@pytest.mark.unit_test +@pytest.mark.parametrize( + "user_id,expected", ( + ("ecb52977-3004-469e-9428-2a1856725c7f", Resource( + group, uuid.UUID("d32611e3-07fc-4564-b56c-786c6db6de2b"), + "test_resource", resource_category)), + ("21351b66-8aad-475b-84ac-53ce528451e3", create_resource_failure), + ("ae9c6245-0966-41a5-9a5e-20885a96bea7", create_resource_failure), + ("9a0c7ce5-2f40-4e78-979e-bf3527a59579", create_resource_failure), + ("e614247d-84d2-491d-a048-f80b578216cb", create_resource_failure))) +def test_create_resource(test_app, test_users_in_group, user_id, expected): + """Test that resource creation works as expected.""" + conn, _group, _users = test_users_in_group + with test_app.app_context() as flask_context: + flask_context.g.user_id = uuid.UUID(user_id) + assert create_resource(conn, "test_resource", resource_category) == expected |