Skip to content

Commit

Permalink
src: fix test local edge case
Browse files Browse the repository at this point in the history
PR-URL: nodejs#52702
Reviewed-By: Moshe Atlow <[email protected]>
Reviewed-By: Benjamin Gruenbaum <[email protected]>
Reviewed-By: James M Snell <[email protected]>
Reviewed-By: Tobias Nießen <[email protected]>
Reviewed-By: Marco Ippolito <[email protected]>
  • Loading branch information
ShogunPanda authored and Chenyu Yang committed May 8, 2024
1 parent e1330a0 commit 9d82931
Showing 1 changed file with 17 additions and 3 deletions.
20 changes: 17 additions & 3 deletions test/parallel/test-process-load-env-file.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ const common = require('../common');
const fixtures = require('../../test/common/fixtures');
const assert = require('node:assert');
const { describe, it } = require('node:test');
const { join } = require('node:path');

const basicValidEnvFilePath = fixtures.path('dotenv/basic-valid.env');
const validEnvFilePath = fixtures.path('dotenv/valid.env');
Expand Down Expand Up @@ -48,10 +49,23 @@ describe('process.loadEnvFile()', () => {
}, { code: 'ENOENT', syscall: 'open', path: missingEnvFile });
});

// The whole chdir flow here is to address a case where a developer
// has a .env in the worktree which is probably in the global .gitignore.
// In that case this test would fail. To avoid confusion, chdir to lib will
// make this way less likely to happen. Probably a temporary directory would
// be the best choice but given how edge this case is this is fine.
it('should throw when `.env` does not exist', async () => {
assert.throws(() => {
process.loadEnvFile();
}, { code: 'ENOENT', syscall: 'open', path: '.env' });
const originalCwd = process.cwd();

try {
process.chdir(join(originalCwd, 'lib'));

assert.throws(() => {
process.loadEnvFile();
}, { code: 'ENOENT', syscall: 'open', path: '.env' });
} finally {
process.chdir(originalCwd);
}
});

it('should check for permissions', async () => {
Expand Down

0 comments on commit 9d82931

Please sign in to comment.