Skip to content

Latest commit

 

History

History
87 lines (61 loc) · 3.5 KB

readme.md

File metadata and controls

87 lines (61 loc) · 3.5 KB

Introduction

This repository is an example to automatic generate OpenAPI documentation (see https://swagger.io/specification/).

Sample servers

Sample servers are provided, placed in folders with the format, server-[package], where the [package] represent the library used to perform the OpenAPI documentation generation.

Swagger UI

Using the OpenAPI documentation (json or yaml format), it can be feed into Swagger UI (self hosted or uploaded to https://editor.swagger.io/), you'll obtain a Swagger UI page as shown below. Here the developers can use it to perform quick tests on the REST APIs that they developed. It also allow the Software Assurance team to familiarize themselves with the REST APIs.

Swagger UI
Swagger UI

OpenAPI Documentation
OpenAPI Documentation (json)

The above is the OpenAPI documentation in json format.

Test Tools

Rest Client Extension for Visual Studio

Rest Client Extension
Rest Client .html file and HTTP request result

REST Client (https://github.com/Huachao/vscode-restclient) allows you to send HTTP request and view the response in Visual Studio Code directly. It eliminates the need for a separate tool to test REST APIs and makes API testing convenient and efficient.

.http test scripts are located in ./tests

Flashpost

Flashpost
Flashpost Test Runner

Flashpost (https://github.com/subasraj/flashpost-support/tree/main), a VS Code extension enables you to develop and test your REST APIs directly from Visual Studio Code.

Flashpost test scripts are located in ./Flashpost-tests

Bruno

Bruno
Bruno Test Runner

Bruno Test Report
Bruno Test Report (html)

Bruno (https://www.usebruno.com/) is a Fast and Git-Friendly Opensource API client, aimed at revolutionizing the status quo represented by Postman, Insomnia and similar tools out there.

Bruno test scripts are located in ./tests/bruno

Endpoints

Endpoint Description
http://localhost:3000 Hello world
http://localhost:3000/form Form page
http://localhost:3000/fetchDemo/server Performs a fetch from server
http://localhost:3000/fetchDemo/client Performs a fetch from client
http://localhost:3000/tasks Tasks API
http://localhost:3000/api-docs OpenAPI Documentation

Miscellaneous

Problem Details Response middleware

Included in the sample server is the problem details response middleware which can help in standardizing error responses. Developer just throw an HttpError exception for it to trigger.

Example #1

throw new createHttpError.NotFound("Task not found");

RestAPI - Not Found

Example #2

const errors = validationResult(req);

if (!errors.isEmpty()) {
  const err = new createHttpError.BadRequest("Invalid request");
  throw createHttpError(err.status, err, { invalidParams: errors.array() });
}

RestAPI - Bad Request