Skip to content

Latest commit

 

History

History
76 lines (50 loc) · 4.08 KB

README.md

File metadata and controls

76 lines (50 loc) · 4.08 KB

TODO

  • [ ]: Instructions to publish to a private npm registry. Can/should we consider publishing straight to GitHub instead?
  • [ ]: Add pushing Docker images to a registry or another deployment mechanism.
  • [x]: Build only apps and packages that have changed.
  • [x]: Be able to easily extract an app/package into its own repository.
  • [x]: Scripts to build all packages and apps and publish changed packages.
  • [x]: Consider splitting dockerfiles for different app types. This has already been done for test-e2e and can also be done for test-api because they depend on more files and have a different start command. One way to achieve this is with multiple Dockerfiles in the same directory by type (e.g. app.Dockerfile, test-api.Dockerfile, test-e2e.Dockerfile). Also consider using turborepo with npm scripts in each app that know how to build their own docker image (e.g. npx turbo run docker:build --scope=test-e2e would only run the npm script in the test-e2e app).
  • [x]: Determine a consistent way to build and execute each app.
  • [x]: When transpiling TypeScript apps, by default they are compiled to CommonJS. We can compile to ESM by setting "module": "ESNext" in tsconfig.json. However, when doing this, we must also import with file extensions (e.g. import './module.js' versus import './module'. Is it just better to include explicit file extensions in all imports? Most sources say it's better to explicitly include the file extensions.

starter-monorepo

NOTE: This starter project is incomplete and not ready for use!

This is a monorepo starter for multiple services and packages. Public packages are intended to be published, such as types or clients/SDKs.

Getting Started

  1. Install dependencies:
    npm install
  2. Run in development mode:
    npm run dev
  3. Visit http://localhost:3001

Unit Tests

Run unit tests for all workspaces:

npm run test

Run unit tests and record coverage for the main project:

npm run test:coverage -w=main

API Tests

API tests are a lower-cost replacement for integration tests. They are essentially E2E tests for API routes. For any new route use case, you should write a new API test to validate the results. These tests are intended to run in every data center just after a deployment to validate that the deployment was successful.

  1. Run the main app (see Getting Started)
  2. Run the tests against your local machine
    npm run test:local -w=api-tests

Docker

There is a base.Dockerfile to build common parts for all other app images (that use Alpine Linux), except for Playwright apps because Playwright is not supported on Alpine. Build this base image first in order to build other images via .github/docker/build-base.sh.

You can build individual apps via APP=backend APP_TYPE=node .github/docker/build-app.sh backend.

Spin up the full environment with docker-compose up. Include the --build flag to rebuild the images. This will first start the database, run migrations, start the backend then the frontend, and finally run API and E2E tests.

Build and run a single app with docker-compose up --build {app}. For example docker-compose up --build backend.

Run tests via docker-compose up --build test-api. Use the --build flag when code has changed.

For the GitHub Actions workflow to run properly, every package.json must have a dockerfileType field corresponding to the Dockerfile type to use, e.g. node to reference the Dockerfile at .github/docker/node.Dockerfile.

Packages

Publish packages to the npm registry with .github/docker/build-base.sh && .github/docker/publish-packages.sh. The GitHub Actions workflow will publish packages on pushes to the main branch.

CI Pipeline

TODO

act is an incredibly useful tool for testing out GitHib Actions workflows locally.