From b4af0b06bd5a77fa3b008a78d0552aac1d344a2b Mon Sep 17 00:00:00 2001 From: jc0b Date: Thu, 25 Jun 2020 22:45:57 +0200 Subject: POST for topologies with tests --- opendc/api/v2/topologies/endpoint.py | 33 ++++++++++++++++++++++ opendc/api/v2/topologies/test_endpoint.py | 23 +++++++++++++++ .../api/v2/topologies/topologyId/test_endpoint.py | 7 ----- 3 files changed, 56 insertions(+), 7 deletions(-) create mode 100644 opendc/api/v2/topologies/endpoint.py create mode 100644 opendc/api/v2/topologies/test_endpoint.py 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,12 +1,5 @@ from opendc.util.database import DB -''' -POST /topologies -''' - - - - ''' GET /topologies/{topologyId} ''' -- cgit v1.2.3