Skip to content

Demonstrates RESTful API with Node.JS, ExpressJS. Unit tests with mocha framework and chai assertion library. Test coverage report is generated with Istanbul library.

khteh/Node.JSRestAPI

Repository files navigation

Node.JS API Server

Simple RESTful API using HTTP/2 SPDY server for Node.JS

Description

Teachers need a system where they can perform administrative functions for their students. Teachers and students are identified by their email addresses. Unit tests using mocha framework with chai assertion library. Test coverage report is generated with Istanbul library and SonarQube. Dependency check is done with OWASP dependency check CLI.

Installation

Database:

  • Thanks to TypeORM, database and tables are automatically created when the application is run.
CREATE DATABASE `school` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci */;
CREATE TABLE `teachers` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `email` varchar(320) NOT NULL,
  PRIMARY KEY (`id`),
  UNIQUE KEY `id_UNIQUE` (`id`),
  KEY `Non-Clustered` (`email`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
CREATE TABLE `students` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `email` varchar(320) NOT NULL,
  `isSuspended` tinyint(4) NOT NULL DEFAULT '0',
  UNIQUE KEY `id_UNIQUE` (`id`),
  KEY `Non-Clustered` (`email`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
CREATE TABLE `teacher_student` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `teacherid` int(11) NOT NULL,
  `studentid` int(11) NOT NULL,
  PRIMARY KEY (`id`),
  KEY `teacherid_idx` (`teacherid`),
  KEY `studentid_idx` (`studentid`),
  CONSTRAINT `studentid` FOREIGN KEY (`studentid`) REFERENCES `students` (`id`),
  CONSTRAINT `teacherid` FOREIGN KEY (`teacherid`) REFERENCES `teachers` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;

Dependencies:

npm install

Start the application:

  • Generate self-signed cert for serving HTTP/2 over HTTPS.
  • Edit config/default.json to configure the database connection parameters
  • To run in development mode with nodemon:
$ npm run dev
  • To run in production mode:
$ npm start
  • Default port number is 4433 using HTTPS scheme
  • To run the application listening on different port:
$ set PORT=8888 & npm start

Use Cases

Fibonacci API

  • GET https://localhost:4433/api/fibonacci?n=20
  • Response:
{
    "message":"Fibonacci(20): 6765"
}

Greetings API

  • GET https://localhost:4433/api/greetings
  • Response:
{
    "message": "Hello! It's 6/17/2020, 01:42:56 PM now."
}
  • GET https://localhost:4433/api/greetings?name=Mickey%20Mouse
  • Response:
{
    "message": "Hello Mickey Mouse! It's 6/17/2020, 01:43:30 PM now."
}

Register one or more students to a specified teacher.

  • POST /api/register
{
  "teacher": "teacherken@gmail.com"
  "students":
    [
      "studentjon@gmail.com",
      "studenthon@gmail.com"
    ]
}

Retrieve students who are registered to ALL of the given teachers:

  • GET /api/commonstudents?teacher=teacher1%40gmail.com&teacher=teacher2%40gmail.com
  • Sample successful response:
{
  "students" :
    [
      "commonstudent1@gmail.com",
      "commonstudent2@gmail.com"
    ]
}

Suspend a specified student:

  • POST /api/suspend
{
  "student" : "studentmary@gmail.com"
}

Retrieve a list of students who can receive a given notification:

  • POST /api/retrievefornotifications
  • Sample request body (1):
{
  "teacher":  "teacherken@gmail.com",
  "notification": "Hello students! @studentagnes@gmail.com @studentmiche@gmail.com"
}
  • Sample successful response to (1):
{
  "recipients":
    [
      "studentbob@gmail.com",
      "studentagnes@gmail.com",
      "studentmiche@gmail.com"
    ]
}
  • Sample request body (2):
{
  "teacher":  "teacherken@gmail.com",
  "notification": "Hey everybody"
}
  • Sample successful response to (2):
{
  "recipients":
    [
      "studentbob@gmail.com"
    ]
}

Run tests:

  • Edit config/test.json to configure the database connection parameters.
  • WARNING! All tables in the database configured for test will be emptied for testing purpose.
  • Generates test_reports/mocha/test-results.xml
npm test

Run tests with coverage report:

  • Use Istanbul library with mocha to generate test coverage report.
  • Generates text and html reports
npm run cover
  • Sample output:
------------------------------|----------|----------|----------|----------|-------------------|
File                          |  % Stmts | % Branch |  % Funcs |  % Lines | Uncovered Line #s |
------------------------------|----------|----------|----------|----------|-------------------|
All files                     |    87.38 |    63.32 |    97.52 |    87.06 |                   |
 Node.JSRestAPI               |       80 |        0 |        0 |       80 |                   |
  app.js                      |       80 |        0 |        0 |       80 |    24,30,31,34,35 |
 Node.JSRestAPI/BusinessLogic |    78.53 |    64.92 |      100 |    77.78 |                   |
  commonstudents.js           |    76.14 |    67.39 |      100 |    74.07 |... 07,108,109,110 |
  greetings.js                |      100 |      100 |      100 |      100 |                   |
  notifications.js            |    77.22 |    70.21 |      100 |    76.62 |... 93,94,96,97,98 |
  registration.js             |    81.25 |    63.64 |      100 |     80.8 |... 79,187,188,189 |
  suspend.js                  |    69.05 |       50 |      100 |    69.05 |... 61,62,63,64,66 |
 Node.JSRestAPI/lib           |    78.57 |       50 |      100 |    78.57 |                   |
  db.js                       |    78.57 |       50 |      100 |    78.57 |          17,18,23 |
 Node.JSRestAPI/routes        |    95.65 |      100 |    83.33 |    94.44 |                   |
  api.js                      |      100 |      100 |      100 |      100 |                   |
  index.js                    |       80 |      100 |        0 |       80 |                 6 |
 Node.JSRestAPI/tests         |    98.62 |      100 |     98.9 |    98.62 |                   |
  greetingsapi_tests.js       |    90.91 |      100 |     87.5 |    90.91 |       15,16,17,18 |
  teachersapi_tests.js        |      100 |      100 |      100 |      100 |                   |
------------------------------|----------|----------|----------|----------|-------------------|

Run dependency check

Run SonarQube scan

About

Demonstrates RESTful API with Node.JS, ExpressJS. Unit tests with mocha framework and chai assertion library. Test coverage report is generated with Istanbul library.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published