diff options
| author | jc0b <j@jc0b.computer> | 2020-07-08 17:00:42 +0200 |
|---|---|---|
| committer | Fabian Mastenbroek <mail.fabianm@gmail.com> | 2020-08-24 19:47:55 +0200 |
| commit | 5d5b32abb37330f1de5b49dfe639bb65b358f6f1 (patch) | |
| tree | 4100ff0f727325a55cc599a9809bddc9dcc13116 /web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py | |
| parent | b71a7714639a5d828e914a65357bef6c471dfad0 (diff) | |
prefab authorization changes
Diffstat (limited to 'web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py')
| -rw-r--r-- | web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py | 119 |
1 files changed, 119 insertions, 0 deletions
diff --git a/web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py b/web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py index e69de29b..c34bf6fa 100644 --- a/web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py +++ b/web-server/opendc/api/v2/prefabs/prefabId/test_endpoint.py @@ -0,0 +1,119 @@ +from opendc.util.database import DB + + +def test_get_prefab_non_existing(client, mocker): + mocker.patch.object(DB, 'fetch_one', return_value=None) + assert '404' in client.get('/api/v2/prefabs/1').status + + +def test_get_prefab_no_authorizations(client, mocker): + mocker.patch.object(DB, 'fetch_one', return_value={'authorizations': []}) + res = client.get('/api/v2/prefabs/1') + assert '403' in res.status + + +def test_get_prefab_not_authorized(client, mocker): + mocker.patch.object(DB, + 'fetch_one', + return_value={ + '_id': '1', + 'authorizations': [{ + 'prefabId': '2', + 'authorizationLevel': 'OWN' + }] + }) + res = client.get('/api/v2/prefabs/1') + assert '403' in res.status + + +def test_get_prefab(client, mocker): + mocker.patch.object(DB, + 'fetch_one', + return_value={ + '_id': '1', + 'authorizations': [{ + 'prefabId': '1', + 'authorizationLevel': 'EDIT' + }] + }) + res = client.get('/api/v2/prefabs/1') + assert '200' in res.status + + +def test_update_prefab_missing_parameter(client): + assert '400' in client.put('/api/v2/prefabs/1').status + + +def test_update_prefab_non_existing(client, mocker): + mocker.patch.object(DB, 'fetch_one', return_value=None) + assert '404' in client.put('/api/v2/prefabs/1', json={'prefab': {'name': 'S'}}).status + + +def test_update_prefab_not_authorized(client, mocker): + mocker.patch.object(DB, + 'fetch_one', + return_value={ + '_id': '1', + 'authorizations': [{ + 'prefabId': '1', + 'authorizationLevel': 'VIEW' + }] + }) + mocker.patch.object(DB, 'update', return_value={}) + assert '403' in client.put('/api/v2/prefabs/1', json={'prefab': {'name': 'S'}}).status + + +def test_update_prefab(client, mocker): + mocker.patch.object(DB, + 'fetch_one', + return_value={ + '_id': '1', + 'authorizations': [{ + 'prefabId': '1', + 'authorizationLevel': 'OWN' + }] + }) + mocker.patch.object(DB, 'update', return_value={}) + + res = client.put('/api/v2/prefabs/1', json={'prefab': {'name': 'S'}}) + assert '200' in res.status + + +def test_delete_prefab_non_existing(client, mocker): + mocker.patch.object(DB, 'fetch_one', return_value=None) + assert '404' in client.delete('/api/v2/prefabs/1').status + + +def test_delete_prefab_different_user(client, mocker): + mocker.patch.object(DB, + 'fetch_one', + return_value={ + '_id': '1', + 'googleId': 'other_test', + 'authorizations': [{ + 'prefabId': '1', + 'authorizationLevel': 'VIEW' + }], + 'topologyIds': [] + }) + mocker.patch.object(DB, 'delete_one', return_value=None) + assert '403' in client.delete('/api/v2/prefabs/1').status + + +def test_delete_prefab(client, mocker): + mocker.patch.object(DB, + 'fetch_one', + return_value={ + '_id': '1', + 'googleId': 'test', + 'authorizations': [{ + 'prefabId': '1', + 'authorizationLevel': 'OWN' + }], + 'topologyIds': [], + 'experimentIds': [], + }) + mocker.patch.object(DB, 'update', return_value=None) + mocker.patch.object(DB, 'delete_one', return_value={'googleId': 'test'}) + res = client.delete('/api/v2/prefabs/1') + assert '200' in res.status |
