Skip to content

This project demostrates a CI/CD flow for CRUD APIs in Node.js. This includes tests in chai, a github workflow to run those tests on every commit/PR.

Notifications You must be signed in to change notification settings

lakshyajit165/node_postgres_cicd

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

39 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Configuring a simple CICD pipeline with unit and integration testing using Node.js and PostgreSQL

test endpoints

  • Create a simple CRUD application with the necessary endpoints/middlewares/ORM.
  • Connext to PostgreSQL database using docker on the local machine.
  • Write test cases for the endpoints using chai and mocha
  • Configure a github action workflow to test the end-points every time there is a push to a specific branch or a pull request.
  • Configure the branch protection rules in the repository similar to this: Screenshot from 2022-03-13 09-23-24
  • Now whenever the action is triggered and all checks pass, it will look something like this: Screenshot from 2022-03-12 20-31-26

This is what the .env file to be included in the project root:

DB_HOST=<db_host> (localhost)
DATABASE=<db_name>
DB_HMAC=<db_password>
DB_PORT=5432 (according to docker command above)
DB_DIALECT="postgres"
DB_POOL_CONNECTION_LIMIT=10 (say)
DB_POOL_IDLE_TIMEOUT=30000 (say)
APP_PORT=3000

Update 21/01/2024:

  • There was an intermittent error saying "could not find relation 'tasks'" in some of the failing test cases.
  • Added a script in the project root to create the table while spinning up a docker container in the local setup and modified the github action script to include a create table query so that the table is created before the tests are run as part of the github actions workflow.
  • The script to spin a docker container on local is modified as follows:
  • docker run -d -p 5432:5432 --name node-postgres -e POSTGRES_PASSWORD=postgres -e POSTGRES_DB=node_postgres_cicd -e POSTGRES_USER=postgres -v /Users/elkay/Documents/workspace/node_postgres_cicd/scripts:/docker-entrypoint-initdb.d postgres

About

This project demostrates a CI/CD flow for CRUD APIs in Node.js. This includes tests in chai, a github workflow to run those tests on every commit/PR.

Resources

Stars

Watchers

Forks

Packages

No packages published