https://github.com/ivandotv/vitest-database-containers
Example repository that demonstrates how to test MongoDB and PostgreSQL databases with Docker containers and Jest.
https://github.com/ivandotv/vitest-database-containers
docker mongodb nodejs postgresql vitest
Last synced: 9 months ago
JSON representation
Example repository that demonstrates how to test MongoDB and PostgreSQL databases with Docker containers and Jest.
- Host: GitHub
- URL: https://github.com/ivandotv/vitest-database-containers
- Owner: ivandotv
- License: mit
- Created: 2023-07-20T18:04:36.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-11-23T05:30:06.000Z (over 1 year ago)
- Last Synced: 2024-11-23T06:20:44.435Z (over 1 year ago)
- Topics: docker, mongodb, nodejs, postgresql, vitest
- Language: TypeScript
- Homepage:
- Size: 223 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# MongoDB and PostgreSQL database testing with vitest and Docker containers
This is an example repository that demonstrates how to test MongoDB and PostgreSQL databases with Docker containers
using Vitest.
## How it works
When Vitest is started, and before the tests are executed, we create two docker database containers (MongoDB and PostgreSQL) each test file (Vitest Worker) gets a new database inside the container.
If the detected OS is Linux, we use the `tmpfs` file system inside the containers which increases the speed of execution since in that case all database data is held in memory.
### Test execution
- Before each test, the database is seeded.
- After each test, the database is cleared.
- When all tests in the file are done, the database is discarded.
- When Vitest is done running all the tests, database containers are stopped and removed.
Vitest **watch** mode is supported, in that case, everything works that same, but database containers will not be stopped and removed until you exit _watch_ mode.
### Running on Github Actions
Github actions file is included. Default Ubuntu Github Actions image comes with Docker preinstalled so there are no issues running the tests in a continuous integration environment.
## Blog post
I will eventually write a blog post detailing the whole setup process. You can follow me on [Twitter](https://twitter.com/iki_xx) or on [Dev.to](https://dev.to/ivandotv)
to be notified of new blog posts.
I use this setup in my projects, so this repository will be kept up to date.
If you have suggestions on how this process could be improved, feel free to open an issue or pull a request.
There is also a Jest setup, but I'm not maintaining that one anymore.