From 8ab2604d6ea2aa1efb9582f919d59dcdd0b8ea78 Mon Sep 17 00:00:00 2001 From: jc0b Date: Fri, 26 Jun 2020 11:50:05 +0200 Subject: Moved topologies POST to simulations --- .../simulationId/topologies/__init__.py | 0 .../simulationId/topologies/endpoint.py | 33 ++++++++++++++++++++++ .../simulationId/topologies/test_endpoint.py | 23 +++++++++++++++ 3 files changed, 56 insertions(+) create mode 100644 opendc/api/v2/simulations/simulationId/topologies/__init__.py create mode 100644 opendc/api/v2/simulations/simulationId/topologies/endpoint.py create mode 100644 opendc/api/v2/simulations/simulationId/topologies/test_endpoint.py (limited to 'opendc/api/v2/simulations') diff --git a/opendc/api/v2/simulations/simulationId/topologies/__init__.py b/opendc/api/v2/simulations/simulationId/topologies/__init__.py new file mode 100644 index 00000000..e69de29b diff --git a/opendc/api/v2/simulations/simulationId/topologies/endpoint.py b/opendc/api/v2/simulations/simulationId/topologies/endpoint.py new file mode 100644 index 00000000..4104c4dd --- /dev/null +++ b/opendc/api/v2/simulations/simulationId/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({'name': request.params_body['topology']['name']}) + 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/simulations/simulationId/topologies/test_endpoint.py b/opendc/api/v2/simulations/simulationId/topologies/test_endpoint.py new file mode 100644 index 00000000..67973268 --- /dev/null +++ b/opendc/api/v2/simulations/simulationId/topologies/test_endpoint.py @@ -0,0 +1,23 @@ +from opendc.util.database import DB + + +def test_add_simulation_missing_parameter(client): + assert '400' in client.post('/api/v2/simulations/1/topologies/').status + + +def test_add_simulation(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', + 'topologyIds': [] + }) + mocker.patch.object(DB, 'update', return_value={}) + res = client.post('/api/v2/simulations/1/topologies/', json={'simulation': {'name': 'test simulation'}}) + assert 'datetimeCreated' in res.json['content'] + assert 'datetimeEdit' in res.json['content'] + assert 'topologyIds' in res.json['content'] + assert '200' in res.status -- cgit v1.2.3