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