diff options
| author | jc0b <j@jc0b.computer> | 2020-06-25 22:45:57 +0200 |
|---|---|---|
| committer | jc0b <j@jc0b.computer> | 2020-06-25 22:45:57 +0200 |
| commit | b4af0b06bd5a77fa3b008a78d0552aac1d344a2b (patch) | |
| tree | a4a50ad9b7e5d52ac30039c6980d4410f9848727 /opendc/api | |
| parent | 61cf27a9529e503d3c56854c9d664f2d9520213a (diff) | |
POST for topologies with tests
Diffstat (limited to 'opendc/api')
| -rw-r--r-- | opendc/api/v2/topologies/endpoint.py | 33 | ||||
| -rw-r--r-- | opendc/api/v2/topologies/test_endpoint.py | 23 | ||||
| -rw-r--r-- | opendc/api/v2/topologies/topologyId/test_endpoint.py | 7 |
3 files changed, 56 insertions, 7 deletions
diff --git a/opendc/api/v2/topologies/endpoint.py b/opendc/api/v2/topologies/endpoint.py new file mode 100644 index 00000000..be4c5382 --- /dev/null +++ b/opendc/api/v2/topologies/endpoint.py @@ -0,0 +1,33 @@ +from datetime import datetime + +from opendc.models.topology import Topology +from opendc.util import exceptions +from opendc.util.rest import Response +from opendc.models.user import User +from opendc.util.database import Database + + +def POST(request): + """Add a new Topology and return it""" + + # Make sure required parameters are there + + try: + request.check_required_parameters(body={'topology': {'name': 'string'}}) + except exceptions.ParameterError as e: + return Response(400, str(e)) + + # Instantiate a Topology object from our request, and add some metadata + + topology = Topology({'topology': request.params_body['topology']}) + topology.set_property('datetimeCreated', Database.datetime_to_string(datetime.now())) + topology.set_property('datetimeLastEdited', Database.datetime_to_string(datetime.now())) + topology.insert() + + # Instantiate the user from the request, and add this topology object to their authorizations + + user = User.from_google_id(request.google_id) + user.obj['authorizations'].append({'topologyId': topology.obj['_id'], 'authorizationLevel': 'OWN'}) + user.update() + + return Response(200, 'Successfully inserted topology.', topology.obj) diff --git a/opendc/api/v2/topologies/test_endpoint.py b/opendc/api/v2/topologies/test_endpoint.py new file mode 100644 index 00000000..283aac67 --- /dev/null +++ b/opendc/api/v2/topologies/test_endpoint.py @@ -0,0 +1,23 @@ +from opendc.util.database import DB + +''' +POST /topologies +''' + +def test_add_topology_missing_parameter(client): + assert '400' in client.post('/api/v2/topologies').status + +def test_add_topology(client, mocker): + mocker.patch.object(DB, 'fetch_one', return_value={'_id': '1', 'authorizations': []}) + mocker.patch.object(DB, + 'insert', + return_value={ + '_id': '1', + 'datetimeCreated': '000', + 'datetimeEdit': '000' + }) + mocker.patch.object(DB, 'update', return_value={}) + res = client.post('/api/v2/topologies', json={'topology': {'name': 'test topology'}}) + assert 'datetimeCreated' in res.json['content'] + assert 'datetimeEdit' in res.json['content'] + assert '200' in res.status diff --git a/opendc/api/v2/topologies/topologyId/test_endpoint.py b/opendc/api/v2/topologies/topologyId/test_endpoint.py index 0e264270..e54052aa 100644 --- a/opendc/api/v2/topologies/topologyId/test_endpoint.py +++ b/opendc/api/v2/topologies/topologyId/test_endpoint.py @@ -1,13 +1,6 @@ from opendc.util.database import DB ''' -POST /topologies -''' - - - - -''' GET /topologies/{topologyId} ''' |
