summaryrefslogtreecommitdiff
path: root/web-server/opendc/api/v2/projects/projectId/experiments
diff options
context:
space:
mode:
Diffstat (limited to 'web-server/opendc/api/v2/projects/projectId/experiments')
-rw-r--r--web-server/opendc/api/v2/projects/projectId/experiments/__init__.py0
-rw-r--r--web-server/opendc/api/v2/projects/projectId/experiments/endpoint.py35
-rw-r--r--web-server/opendc/api/v2/projects/projectId/experiments/test_endpoint.py78
3 files changed, 113 insertions, 0 deletions
diff --git a/web-server/opendc/api/v2/projects/projectId/experiments/__init__.py b/web-server/opendc/api/v2/projects/projectId/experiments/__init__.py
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/web-server/opendc/api/v2/projects/projectId/experiments/__init__.py
diff --git a/web-server/opendc/api/v2/projects/projectId/experiments/endpoint.py b/web-server/opendc/api/v2/projects/projectId/experiments/endpoint.py
new file mode 100644
index 00000000..2e5b93df
--- /dev/null
+++ b/web-server/opendc/api/v2/projects/projectId/experiments/endpoint.py
@@ -0,0 +1,35 @@
+from opendc.models.experiment import Experiment
+from opendc.models.project import Project
+from opendc.util.rest import Response
+
+
+def POST(request):
+ """Add a new Experiment for this Project."""
+
+ request.check_required_parameters(path={'projectId': 'string'},
+ body={
+ 'experiment': {
+ 'topologyId': 'string',
+ 'traceId': 'string',
+ 'schedulerName': 'string',
+ 'name': 'string',
+ }
+ })
+
+ project = Project.from_id(request.params_path['projectId'])
+
+ project.check_exists()
+ project.check_user_access(request.google_id, True)
+
+ experiment = Experiment(request.params_body['experiment'])
+
+ experiment.set_property('projectId', request.params_path['projectId'])
+ experiment.set_property('state', 'QUEUED')
+ experiment.set_property('lastSimulatedTick', 0)
+
+ experiment.insert()
+
+ project.obj['experimentIds'].append(experiment.get_id())
+ project.update()
+
+ return Response(200, 'Successfully added Experiment.', experiment.obj)
diff --git a/web-server/opendc/api/v2/projects/projectId/experiments/test_endpoint.py b/web-server/opendc/api/v2/projects/projectId/experiments/test_endpoint.py
new file mode 100644
index 00000000..11b79154
--- /dev/null
+++ b/web-server/opendc/api/v2/projects/projectId/experiments/test_endpoint.py
@@ -0,0 +1,78 @@
+from opendc.util.database import DB
+
+
+def test_add_experiment_missing_parameter(client):
+ assert '400' in client.post('/api/v2/projects/1/experiments').status
+
+
+def test_add_experiment_non_existing_project(client, mocker):
+ mocker.patch.object(DB, 'fetch_one', return_value=None)
+ assert '404' in client.post('/api/v2/projects/1/experiments',
+ json={
+ 'experiment': {
+ 'topologyId': '1',
+ 'traceId': '1',
+ 'schedulerName': 'default',
+ 'name': 'test',
+ }
+ }).status
+
+
+def test_add_experiment_not_authorized(client, mocker):
+ mocker.patch.object(DB,
+ 'fetch_one',
+ return_value={
+ '_id': '1',
+ 'projectId': '1',
+ 'authorizations': [{
+ 'projectId': '1',
+ 'authorizationLevel': 'VIEW'
+ }]
+ })
+ assert '403' in client.post('/api/v2/projects/1/experiments',
+ json={
+ 'experiment': {
+ 'topologyId': '1',
+ 'traceId': '1',
+ 'schedulerName': 'default',
+ 'name': 'test',
+ }
+ }).status
+
+
+def test_add_experiment(client, mocker):
+ mocker.patch.object(DB,
+ 'fetch_one',
+ return_value={
+ '_id': '1',
+ 'projectId': '1',
+ 'experimentIds': ['1'],
+ 'authorizations': [{
+ 'projectId': '1',
+ 'authorizationLevel': 'EDIT'
+ }]
+ })
+ mocker.patch.object(DB,
+ 'insert',
+ return_value={
+ '_id': '1',
+ 'topologyId': '1',
+ 'traceId': '1',
+ 'schedulerName': 'default',
+ 'name': 'test',
+ 'state': 'QUEUED',
+ 'lastSimulatedTick': 0,
+ })
+ mocker.patch.object(DB, 'update', return_value=None)
+ res = client.post(
+ '/api/v2/projects/1/experiments',
+ json={'experiment': {
+ 'topologyId': '1',
+ 'traceId': '1',
+ 'schedulerName': 'default',
+ 'name': 'test',
+ }})
+ assert 'topologyId' in res.json['content']
+ assert 'state' in res.json['content']
+ assert 'lastSimulatedTick' in res.json['content']
+ assert '200' in res.status