Using multiple .env files
There is a risk that your production database could be deleted if you store different connection URLs to each of your environments within a single .env
file.
One solution is to have multiple .env
files which each represent different environments. In practice, this means you create a file for each of your environments:
.env.development
.env.sample
.env.production
is omitted from the above list as it is not recommended to store your production credentials locally, even if they are git-ignored.
Then using a package like dotenv-cli
, you can load the correct connection URL for the environment you are working in.
Understanding Prisma's Default .env Behavior
Prisma automatically loads environment variables from a .env file located at the root of your project by default. When using tools like dotenv-cli to specify a different .env file (e.g., .env.test), Prisma behaves as follows:
- Primary Variables: It uses variables from the specified file (dotenv -e .env.test) only if they are not already set in the environment.
- Fallback Variables: For variables not included in the specified file, Prisma will load them from .env.
This means that .env acts as a fallback. As a result, if .env contains values not meant for the current environment, they may still be loaded unintentionally.
Setup multiple .env
files
For the purpose of this guide, it is assumed you have a dedicated development database that you use whilst developing your application.
- Rename your
.env
file to.env.development
DATABASE_URL="postgresql://prisma:prisma@localhost:5433/dev"
- Create a new
.env.sample
file and change the database name tosample
(or your preferred name)
DATABASE_URL="postgresql://prisma:prisma@localhost:5433/sample"
- Install
dotenv-cli
In order for Prisma ORM and Jest to know which .env
file to use, alter your package.json
scripts to include and call the dotenv
package and specify which file to use depending on what commands you are running and in which environment you want them to run.
Any top-level script that is running the tests and migrations needs the dotenv
command before it. This makes sure that the env variables from .env.sample
are passed to all commands, including Jest.
Running migrations on different environments
You can use the dotenv-cli
package to specify which environment file Prisma ORM should use when running a migration.
The below script uses dotenv-cli
to pass the .env.sample
environment file (which holds a DATABASE_URL
connection string) to the Prisma ORM migration script.
Migration script
"scripts": {
"migrate:postgres": "dotenv -e .env.sample -- npx prisma migrate deploy",
},
Running tests on different environments
When running tests, we advise you to mock Prisma Client. In doing so, you need to tell Jest which environment it should use when running its tests.
By default, Prisma Client will use the environment specified in the default .env
file located at the project's root.
If you have created a separate .env.sample
file to specify your testing database, then this environment will need to be passed to Jest.
The below script uses dotenv-cli
to pass the .env.sample
environment file (which holds a DATABASE_URL
connection string) to Jest.
Test script
"scripts": {
"test": "dotenv -e .env.sample -- jest -i"
},