From 2d19540bd9d8c3eb366639945cebdede896b3b9f Mon Sep 17 00:00:00 2001 From: pgraham-sl Date: Thu, 6 Jul 2023 16:35:44 +0100 Subject: [PATCH] Initial README written. --- README.md | 154 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 153 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 3340094..0b42677 100644 --- a/README.md +++ b/README.md @@ -1 +1,153 @@ -# quantifying-ai \ No newline at end of file +# quantifying-ai + +The aim of this experiment is to gain an understanding of the productivity gains that are possible when using generative AI technologies to aid with development and testing work. + +# Developers + +The development task is to implement a web service that provides endpoints to manage a ToDo list. The choice of implementation language is at your discretion. Skeleton implementations have been provided in C#, Java and JavaScript on the start-here branch. It is also valid to start completely from scratch if you wish. + +# Static data + +The server data will be initialised with a list containing three tasks: + +[ + { + "uuid": "f360ba09-4682-448b-b32f-0a9e538502fa", + "name": "Walk the dog", + "description": "Walk the dog for forty five minutes", + "created": "2023-06-23T09:30:00Z", + "completed": null, + "complete": false + }, + { + "uuid": "fd5ff9df-f194-4c6e-966a-71b38f95e14f", + "name": "Mow the lawn", + "description": "Mow the lawn in the back garden", + "created": "2023-06-23T09:00:00Z", + "completed": null, + "complete": false + }, + { + "uuid": "5c3ec8bc-6099-4cd5-b6da-8e2956db3a34", + "name": "Test generative AI", + "description": "Use generative AI technology to write a simple web service", + "created": "2023-06-23T09:00:00Z", + "completed": null, + "complete": false + } +] + +The intial GET endpoint returns the list of tasks held by the server. If you are starting from scratch you need to implement this endpoint before continuing. + +# Changes required + +Change the existing GET endpoint to accept an optional boolean parameter, “complete”. The returned list of tasks should be filtered based on the value supplied for the parameter, if supplied. + +http://localhost:8080/todo{?complete=true} +A GET endpoint that takes an optional boolean parameter “complete”. +If the parameter is given then the endpoint returns a list of tasks that have been filtered based on the value supplied for the parameter: +http://localhost:8080/todo returns a list of all tasks with HTTP status 200. +http://localhost:8080/todo?complete=true returns a list only containing completed tasks with HTTP status 200. +http://localhost:8080/todo?complete=false returns a list only containing incomplete tasks with HTTP status 200. + +Add a new GET endpoint that uses a uuid as a path parameter to return a specific task from the list of tasks. + +http://localhost:8080/todo/{uuid} +A GET endpoint that uses a uuid as a path parameter to return the task with the supplied uuid from the list of tasks. +The endpoint returns the task with the given uuid if it exists, otherwise a fixed UNKNOWN_TASK is returned. +If an invalid uuid is supplied the endpoint will return a bad request error. +Given the static data data above: +http://localhost:8080/todo/5c3ec8bc-6099-4cd5-b6da-8e2956db3a34 returns +{ +"uuid": "5c3ec8bc-6099-4cd5-b6da-8e2956db3a34", +"name": "Test generative AI", +"description": "Use generative AI technology to write a simple web service", +"created": "2023-06-23T09:00:00Z", +"completed": null, +"complete": false +} +with HTTP status 200. +http://localhost:8080/todo/5c3ec8bc-6099-1a2b-b6da-8e2956db3a34 returns +{ +"uuid": "00000000-0000-0000-0000-000000000000", +"name": "Unknown Task", +"description": "Unknown Task", +"created": "1970-01-01T00:00:00.000Z", +"completed": null, +"complete": false +} +with HTTP status 200. +http://localhost:8080/todo/invalid-uuid returns +{ +"timestamp": "2023-06-27T12:32:05.590Z", +"status": 400, +"error": "Bad Request", +"path": "/todo/invalid-uuid" +} +with HTTP status 400. + +Add a new PUT endpoint that uses a uuid as a path parameter to mark a specific task from the list of tasks as complete. To mark the task as complete the “completed” field should be set to the current time and the “complete” boolean should be set to TRUE. If the task is already marked as completed then no change is made and the problem should be indicated in the response. + +http://localhost:8080/todo/completed/{uuid} +A PUT endpoint that uses a uuid as a path parameter to mark a specific task as complete. To mark a task as complete the “completed” fields should be set to the current time and the “complete” boolean value should be set to true. +The endpoint completes the task with the given uuid if it exists, the response should be in the form: +{ +"success": true, +"message": "This task has now been completed." +} +Given the static data above: +http://localhost:8080/todo/5c3ec8bc-6099-4cd5-b6da-8e2956db3a34 returns +{ +"success": true, +"message": "This task has now been completed." +} +with HTTP status 200. +A further call to http://localhost:8080/todo/5c3ec8bc-6099-4cd5-b6da-8e2956db3a34 returns +{ +"success": false, +"message": "Task already marked complete." +} +with HTTP status 200. +If the task is not found the response should be: +http://localhost:8080/todo/5c3ec8bc-6099-aaaa-b6da-8e2956db3a34 returns +{ +"success": false, +"message": "Task not found." +} +with HTTP status 200. +If an invalid uuid is supplied the endpoint will return a bad request error. +http://localhost:8080/todo/completed/invalid-uuid +{ +"timestamp": "2023-06-27T12:32:05.590Z", +"status": 400, +"error": "Bad Request", +"path": "/todo/completed/invalid-uuid" +} +with HTTP status 400. + +Add a new POST endpoint that takes two parameters, task name and task description, that creates a new task item. The new item will have no value for the completed timestamp and a value of false for the complete flag. The status of the response should be 201 (CREATED) for a successful operation. + +http://localhost:8080/todo/addTask{?name=Task Four&description=Description Four} +A POST endpoint that takes the name and description of a new task and creates a new task item. The uuid of the new task will be assigned by the server as a random uuid and the created timestamp should be set to the current time. The new task will have no value for the completed timestamp and the value of the complete flag will be false. +The endpoint adds the task with the given details, the response should be in the form: +{ +"taskId": "13f8e57c-49dc-4301-afe9-0bcf2e840056", +"message": "Task added successfully." +} +http://localhost:8080/todo/addTask?name=Task Four&description=Description Four returns: +{ +"taskId": "13f8e57c-49dc-4301-afe9-0bcf2e840056", +"message": "Task Task Four added successfully." +} +with HTTP status 201 (CREATED). Note that the uuid will be randomly generated. +If either parameter is missing the endpoint will return a bad request error. +http://localhost:8080/todo/addTask?name=Thing One +{ +"timestamp": "2023-06-27T12:32:05.590Z", +"status": 400, +"error": "Bad Request", +"path": "/todo/addTask?name=Thing%20One" +} +with HTTP status 400. + +# Testers