Testing
Test Organization#
Parallel Tests (can run simultaneously):
- Client tests
- Package tests
- E2E tests (isolated databases)
Sequential Tests (shared resources):
- Server tests (shared database)
- CKEditor plugin tests
Test Frameworks#
- Vitest - Unit and integration tests
- Playwright - E2E tests
- Happy-DOM - DOM testing environment
Test locations#
apps/
├── server/
│ └── src/**/*.spec.ts # Server tests
├── client/
│ └── src/**/*.spec.ts # Client tests
└── server-e2e/
│ └── tests/**/*.spec.ts # E2E tests
└── desktop/
└── e2e
└── tests/**/*.spec.ts # E2E testsRunning tests#
At project root:
pnpm test:all # All tests
pnpm test:parallel # Fast parallel tests
pnpm test:sequential # Sequential tests onlyUnit testing and integration testing#
Using vitest, there are some unit and integration tests done for both the client and the server.
These tests can be found by looking for the corresponding .spec.ts in the same directory as the source file.
To run the server-side tests: To view the code coverage for the server: Afterwards, a friendly HTML report can be found in | To run the client-side tests: To view the code coverage for the client: Afterwards, a friendly HTML report can be found in |
To run both client and server-side tests:
npm run testNote that some integration tests rely on an in-memory database in order to function.
REST API testing for the server#
API tests are handled via vitest and supertest to initialize the Express server and run assertions without having to make actual requests to the server.
An important aspect is that we have access to the Express app which allows for interesting assertions such as checking the state of the server, registering debug middleware and so on.
One example is src/share/routes.spec.ts, or for the ETAPI in apps/server/spec/etapi.
These integration tests are run alongside unit tests.
End-to-end testing#
See End-to-end tests.