|
| 1 | +// Flags: --env-file test/fixtures/dotenv/valid.env |
| 2 | +'use strict'; |
| 3 | + |
| 4 | +const common = require('../common'); |
| 5 | +const assert = require('node:assert'); |
| 6 | +const fs = require('node:fs'); |
| 7 | +const path = require('node:path'); |
| 8 | + |
| 9 | +// Sets basic environment variable |
| 10 | +assert.strictEqual(process.env.BASIC, 'basic'); |
| 11 | +// Reads after a skipped line |
| 12 | +assert.strictEqual(process.env.AFTER_LINE, 'after_line'); |
| 13 | +// Defaults empty values to empty string |
| 14 | +assert.strictEqual(process.env.EMPTY, ''); |
| 15 | +assert.strictEqual(process.env.EMPTY_SINGLE_QUOTES, ''); |
| 16 | +assert.strictEqual(process.env.EMPTY_DOUBLE_QUOTES, ''); |
| 17 | +assert.strictEqual(process.env.EMPTY_BACKTICKS, ''); |
| 18 | +// Escapes single quoted values |
| 19 | +assert.strictEqual(process.env.SINGLE_QUOTES, 'single_quotes'); |
| 20 | +// Respects surrounding spaces in single quotes |
| 21 | +assert.strictEqual(process.env.SINGLE_QUOTES_SPACED, ' single quotes '); |
| 22 | +// Escapes double quoted values |
| 23 | +assert.strictEqual(process.env.DOUBLE_QUOTES, 'double_quotes'); |
| 24 | +// Respects surrounding spaces in double quotes |
| 25 | +assert.strictEqual(process.env.DOUBLE_QUOTES_SPACED, ' double quotes '); |
| 26 | +// Respects double quotes inside single quotes |
| 27 | +assert.strictEqual(process.env.DOUBLE_QUOTES_INSIDE_SINGLE, 'double "quotes" work inside single quotes'); |
| 28 | +// Respects spacing for badly formed brackets |
| 29 | +assert.strictEqual(process.env.DOUBLE_QUOTES_WITH_NO_SPACE_BRACKET, '{ port: $MONGOLAB_PORT}'); |
| 30 | +// Respects single quotes inside double quotes |
| 31 | +assert.strictEqual(process.env.SINGLE_QUOTES_INSIDE_DOUBLE, "single 'quotes' work inside double quotes"); |
| 32 | +// Respects backticks inside single quotes |
| 33 | +assert.strictEqual(process.env.BACKTICKS_INSIDE_SINGLE, '`backticks` work inside single quotes'); |
| 34 | +// Respects backticks inside double quotes |
| 35 | +assert.strictEqual(process.env.BACKTICKS_INSIDE_DOUBLE, '`backticks` work inside double quotes'); |
| 36 | +assert.strictEqual(process.env.BACKTICKS, 'backticks'); |
| 37 | +assert.strictEqual(process.env.BACKTICKS_SPACED, ' backticks '); |
| 38 | +// Respects double quotes inside backticks |
| 39 | +assert.strictEqual(process.env.DOUBLE_QUOTES_INSIDE_BACKTICKS, 'double "quotes" work inside backticks'); |
| 40 | +// Respects single quotes inside backticks |
| 41 | +assert.strictEqual(process.env.SINGLE_QUOTES_INSIDE_BACKTICKS, "single 'quotes' work inside backticks"); |
| 42 | +// Respects single quotes inside backticks |
| 43 | +assert.strictEqual( |
| 44 | + process.env.DOUBLE_AND_SINGLE_QUOTES_INSIDE_BACKTICKS, |
| 45 | + "double \"quotes\" and single 'quotes' work inside backticks", |
| 46 | +); |
| 47 | +// Ignores inline comments |
| 48 | +assert.strictEqual(process.env.INLINE_COMMENTS, 'inline comments'); |
| 49 | +// Ignores inline comments and respects # character inside of single quotes |
| 50 | +assert.strictEqual(process.env.INLINE_COMMENTS_SINGLE_QUOTES, 'inline comments outside of #singlequotes'); |
| 51 | +// Ignores inline comments and respects # character inside of double quotes |
| 52 | +assert.strictEqual(process.env.INLINE_COMMENTS_DOUBLE_QUOTES, 'inline comments outside of #doublequotes'); |
| 53 | +// Ignores inline comments and respects # character inside of backticks |
| 54 | +assert.strictEqual(process.env.INLINE_COMMENTS_BACKTICKS, 'inline comments outside of #backticks'); |
| 55 | +// Treats # character as start of comment |
| 56 | +assert.strictEqual(process.env.INLINE_COMMENTS_SPACE, 'inline comments start with a'); |
| 57 | +// Respects equals signs in values |
| 58 | +assert.strictEqual(process.env.EQUAL_SIGNS, 'equals=='); |
| 59 | +// Retains inner quotes |
| 60 | +assert.strictEqual(process.env.RETAIN_INNER_QUOTES, '{"foo": "bar"}'); |
| 61 | +// Respects equals signs in values |
| 62 | +assert.strictEqual(process.env.EQUAL_SIGNS, 'equals=='); |
| 63 | +// Retains inner quotes |
| 64 | +assert.strictEqual(process.env.RETAIN_INNER_QUOTES, '{"foo": "bar"}'); |
| 65 | +assert.strictEqual(process.env.RETAIN_INNER_QUOTES_AS_STRING, '{"foo": "bar"}'); |
| 66 | +assert.strictEqual(process.env.RETAIN_INNER_QUOTES_AS_BACKTICKS, '{"foo": "bar\'s"}'); |
| 67 | +// Retains spaces in string |
| 68 | +assert.strictEqual(process.env.TRIM_SPACE_FROM_UNQUOTED, 'some spaced out string'); |
| 69 | +// Parses email addresses completely |
| 70 | +assert.strictEqual(process.env.USERNAME, '[email protected]'); |
| 71 | +// Parses keys and values surrounded by spaces |
| 72 | +assert.strictEqual(process.env.SPACED_KEY, 'parsed'); |
| 73 | + |
| 74 | +// Check if NODE_OPTIONS is set properly |
| 75 | +assert.throws(() => { |
| 76 | + fs.readFileSync(path.join(__dirname, 'test-dotenv.js'), 'utf8'); |
| 77 | +}, common.expectsError({ |
| 78 | + code: 'ERR_ACCESS_DENIED', |
| 79 | + permission: 'FileSystemRead', |
| 80 | +})); |
0 commit comments