summaryrefslogtreecommitdiff
path: root/web-server/opendc/api/v2/topologies/topologyId/test_endpoint.py
diff options
context:
space:
mode:
authorjc0b <j@jc0b.computer>2020-06-30 18:02:06 +0200
committerFabian Mastenbroek <mail.fabianm@gmail.com>2020-08-24 19:44:16 +0200
commit6a4703517e7e1ca5ee2c8d8e0a4c49f32d17c662 (patch)
treea6f228becf7bcaadb2a885ef4349901220d1f3f8 /web-server/opendc/api/v2/topologies/topologyId/test_endpoint.py
parentc78432a639979283b309a03f41589b9823bcaaf7 (diff)
Topologies completed
Diffstat (limited to 'web-server/opendc/api/v2/topologies/topologyId/test_endpoint.py')
-rw-r--r--web-server/opendc/api/v2/topologies/topologyId/test_endpoint.py72
1 files changed, 70 insertions, 2 deletions
diff --git a/web-server/opendc/api/v2/topologies/topologyId/test_endpoint.py b/web-server/opendc/api/v2/topologies/topologyId/test_endpoint.py
index 6243cc55..ac0d02aa 100644
--- a/web-server/opendc/api/v2/topologies/topologyId/test_endpoint.py
+++ b/web-server/opendc/api/v2/topologies/topologyId/test_endpoint.py
@@ -48,13 +48,81 @@ def test_get_topology_no_authorizations(client, mocker):
'''
PUT /topologies/{topologyId}
'''
+
+def test_update_topology_missing_parameter(client):
+ assert '400' in client.put('/api/v2/topologies/1').status
+
+def test_update_topology_non_existent(client, mocker):
+ mocker.patch.object(DB, 'fetch_one', return_value=None)
+ assert '404' in client.put('/api/v2/topologies/1',
+ json={
+ 'topology': {
+ 'name': 'test_topology',
+ 'rooms': {}
+ }
+ }).status
+
+def test_update_topology_not_authorized(client, mocker):
+ mocker.patch.object(DB,
+ 'fetch_one',
+ return_value={
+ '_id': '1',
+ 'simulationId': '1',
+ 'authorizations': [{
+ 'simulationId': '1',
+ 'authorizationLevel': 'VIEW'
+ }]
+ })
+ mocker.patch.object(DB, 'update', return_value={})
+ assert '403' in client.put('/api/v2/topologies/1',
+ json={
+ 'topology': {
+ 'name': 'updated_topology',
+ 'rooms': {}
+ }
+ }).status
+
+def test_update_topology(client, mocker):
+ mocker.patch.object(DB,
+ 'fetch_one',
+ return_value={
+ '_id': '1',
+ 'simulationId': '1',
+ 'authorizations': [{
+ 'simulationId': '1',
+ 'authorizationLevel': 'OWN'
+ }]
+ })
+ mocker.patch.object(DB, 'update', return_value={})
+
+ assert '200' in client.put('/api/v2/topologies/1',
+ json={
+ 'topology': {
+ 'name': 'updated_topology',
+ 'rooms': {}
+ }
+ }).status
+
+
'''
DELETE /topologies/{topologyId}
'''
def test_delete_topology(client, mocker):
- mocker.patch.object(DB, 'fetch_one', return_value={'_id': '1'})
- mocker.patch.object(DB, 'delete_one', return_value=None)
+ mocker.patch.object(DB,
+ 'fetch_one',
+ return_value={
+ '_id': '1',
+ 'simulationId': '1',
+ 'googleId': 'test',
+ 'topologyIds': ['1'],
+ 'authorizations': [{
+ 'simulationId': '1',
+ 'authorizationLevel': 'OWN'
+ }]
+ })
+ mocker.patch.object(DB, 'delete_one', return_value={})
+ mocker.patch.object(DB, 'update', return_value=None)
res = client.delete('/api/v2/topologies/1')
assert '200' in res.status