- Work in a fork of this repository
- Work in a branch on your fork
- Write all of your code in a directory named
lab-+<your name>e.g.lab-susan - Open a pull request to this repository
- Submit on canvas a question and observation, how long you spent, and a link to your pull request
Configure the root of your repository with the following files and directories. Thoughtfully name and organize any additional configuration or module files.
- README.md - contains documentation
- .env - contains env variables (should be git ignored)
- .gitignore - contains a robust
.gitignorefile - .eslintrc.json - contains the course linter configuration
- .eslintignore - contains the course linter ignore configuration
- package.json - contains npm package config
- create a
lintscript for running eslint - create a
testscript for running tests - create a
startscript for running your server
- create a
- lib/ - contains module definitions
- model/ - contains module definitions
- route/ - contains module definitions
- __test__/ - contains test modules
For this assignment you will be building a RESTful HTTP server. The server will store all resources in memory.
The request parser module should return a promise that parses the request url, querystring, and POST or PUT body (as JSON).
In the model/ directory create a constructor for a resource (that is different from the class lecture resource). The model must include 4 properties, including an id property generated using node uuid.
Create the following routes for performing CRUD operations on your resource
POST /api/<resource-name>- pass data as stringifed JSON in the body of a POST request to create a new resource
- on success respond with a 200 status code and the created note
- on failure due to a bad request send a 400 status code
GET /api/<resource-name>andGET /api/<resource-name>?id={id}- with no id in the query string it should respond with an array of all of your resources
- with an id in the query string it should respond with the details of a specifc resource (as JSON)
- if the id is not found respond with a 404
DELETE /api/<resource-name?id={id}>- the route should delete a note with the given id
- on success this should return a 204 status code with no content in the body
- on failure due to lack of id in the query respond with a 400 status code
- on failure due to a resource with that id not existing respond with a 404 status code
- Write tests to ensure the
/api/resource-nameendpoint responds as described for each condition below:GET: test 404, it should respond with 'not found' for valid requests made with an id that was not foundGET: test 200, it should contain a response body for a request made with a valid idPOST: test 400, it should respond with 'bad request' if no request body was provided or the body was invalidPOST: test 200, it should respond with the body content for a post request with a valid body
