Skip to main content

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
warning

.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.

  1. Rename your .env file to .env.development
.env.development
DATABASE_URL="postgresql://prisma:prisma@localhost:5433/dev"
  1. Create a new .env.sample file and change the database name to sample (or your preferred name)
.env.sample
DATABASE_URL="postgresql://prisma:prisma@localhost:5433/sample"
  1. 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.

info

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

package.json
  "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

package.json
  "scripts": {
"test": "dotenv -e .env.sample -- jest -i"
},