Skip to content

Latest commit

 

History

History
98 lines (68 loc) · 3.29 KB

README.md

File metadata and controls

98 lines (68 loc) · 3.29 KB

Fastify template

This project template serves as a starting point for building efficient and scalable server-side applications with Fastify, TypeScript, and best practices in place. It comes pre-configured with essential tools to ensure code quality, maintainability, and a streamlined development workflow.

Package License

Features

  • Fastify: A fast and low overhead web framework for Node.js.
  • TypeScript: Static typing with TypeScript, enhancing code quality and developer productivity.
  • Prettier & ESLint: Automatic code formatting and linting for consistent code style and adherence to best practices.
  • Jest: Unit & Feature testing framework for ensuring code quality and functionality.
  • Playwright: Acceptance/Integration testing framework for comprehensive testing of user interactions and browser behavior.
  • Husky: Git hooks for running linting and tests before commits, ensuring code quality standards are met.
  • TypeDoc: Automatic generation of TypeScript documentation for improved code clarity and collaboration.
  • Dagger: Dagger functions are provided to streamline CI/CD pipelines to allow ease of local development and allow for easy platform agnostic CI/CD pipeline integration.

Installation

npm ci

Prerequisites

Create a .env file in the root directory if one does not already exist and copy the contents of the desired environment file over. (.env.development or .env.production)

Running the app

# Development in watch mode
npm run dev

# Production mode
npm run build && npm run start

With Docker

docker build -t fastify-template . && docker run --rm fastify-template

With Docker Compose

# There are multiple profiles that can be run:
# dev -> Mounts the current directory to the container and runs the service in watch mode
# local -> Builds and runs the application image from the current code
docker compose --profile=PROFILE up --build

Database

You may need to run npx prisma migrate dev --name init in your terminal if you haven't already initialized the database. This only needs to be done the first time the database is created. (Or whenever the database has been recreated) This will happen automatically when using any profile in Docker Compose.

Endpoints documentation (API specification)

Once the app is running, documentation will be available at API_URL:PORT/docs.

Test

Unit & Feature tests

# Unit tests
npm run test

# Feature tests
npm run test:feature

# Test coverage
npm run test:coverage

Acceptance tests

npm run test:acceptance

With Docker Compose

# Run once and exit
docker compose --profile=test up --build --attach acceptance-once --exit-code-from acceptance-once

# Run multiple times
# There are multiple profiles that can be run for the acceptance tests:
# dev
# local
docker compose --profile=PROFILE up --build -d && docker compose --profile=PROFILE exec -ti dev sh -c "npm run test:acceptance"

License

This project is licensed under the MIT License. Feel free to customize and use it for your own projects.