This is a bare minimum sample app using Joist as an ORM.
There are two domain objects, Author
and Book
, and a single test, Author.test.ts
.
There are no examples of business logic or Joist's various features; for those see the docs.
yarn i
docker-compose up -d db
yarn pg-migrate
yarn joist-codegen
(if you've made migration/schema changes)yarn test
A typical workflow for adding a new entity looks like:
- Run
npm run pg-new-migration "add book review"
- Edit the
migrations/...add-book-review.ts
file and addcreateEntityTable(pgm, "book_reviews", { book_id: foreignKey("books"), rating: { type: "integer", notNull: true }, });
- Run
yarn pg-migrate
- If you change your migration, and want to re-apply it from scratch, run
docker-compose exec db ./reset.sh
- If you change your migration, and want to re-apply it from scratch, run
- Run
yarn joist-codegen
- Copy/paste the
Author.test.ts
and write a test forPublisher
TODO: Automate this with more, probably with mrm.
-
Install basic prettier/TypeScript/jest.
npm install -g mrm npm install -g \ @homebound/mrm-tasks-prettier \ @homebound/mrm-tasks-gitignore \ @homebound/mrm-tasks-typescript mrm @homebound/mrm-tasks-prettier \ @homebound/mrm-tasks-gitignore \ @homebound/mrm-tasks-typescript
-
Copy/paste
migrations/...author.ts
-
Add
joist-orm
,joist-migration-utils
,joist-codegen
topackage.json
-
Copy/paste
.env
, changed port -
Add
tsx
,env-cmd
topackage.json
- Should come from
mrm
?
- Should come from
-
Add
pg-migrate
script, run it -
Add
joist-codegen
script, run it -
Add
Author.test.ts
-
Add
dotenv
topackage.json
-
Add
pg-new-migration
topackage.json
-
Add
.gitattributes
to suppress diffs on generated files