https://github.com/la3rence/node-express-example
Template Node.js Project (integration with swagger for API docs, mocha for testing, code coverage, dockerize, and ci/cd by Jenkins) Node.js 模版项目
https://github.com/la3rence/node-express-example
best-practice express http-server javascript mocha nodejs swagger template-project template-repository
Last synced: 3 months ago
JSON representation
Template Node.js Project (integration with swagger for API docs, mocha for testing, code coverage, dockerize, and ci/cd by Jenkins) Node.js 模版项目
- Host: GitHub
- URL: https://github.com/la3rence/node-express-example
- Owner: la3rence
- Created: 2021-12-17T16:03:13.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2025-04-11T00:00:59.000Z (3 months ago)
- Last Synced: 2025-04-11T01:18:31.465Z (3 months ago)
- Topics: best-practice, express, http-server, javascript, mocha, nodejs, swagger, template-project, template-repository
- Language: JavaScript
- Homepage: https://node.lawrenceli.me
- Size: 764 KB
- Stars: 2
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# My Express Template
[](https://github.com/la3rence/express-api/actions/workflows/ci.yaml)
[](https://codecov.io/gh/la3rence/node-express-example)This is a demo app when I was learning Node.js with pure ESM support, test coverage, ci/cd, container support and swagger integration.
## Start
```sh
pnpm start
```This will listen the tcp port 8080 to provide the http service.
## Test
```sh
pnpm test
```Using `mocha`, `chai` to do the E2E testing. (Assertion library and test framework)
Using `c8` to do the code coverage. Try `pnpm run test:coverage` to see the coverage report under the `coverage` directory.TIPS: Using `mocha -g ${keyword}` to execute the test cases with name contains `${keyword}`.
or `pnpm run test:grep ${keyword}`.## Env
Touch a file called `.env` to export env variables on local dev machine (by `dotenv`).
## Swagger
This project using `swagger-ui` to provide the swagger UI and using `swagger-autogen` to generate the swagger spec json file. The default swagger ui page is `/api/docs`.
## Serverless
The default directory for these functions is `./api`.
I'm not using the way Vercel recommends, but the traditional way based on express - which makes it easier for me to deploy by any means, like using Docker or directly using node.js.
## License
MIT