我正在对需要环境变量的函数进行测试,但结果却不确定。 我尝试但不起作用的解决方案:
1 /在我的测试文件中添加require('dotenv').config({path:'../.env'})
2 /在package.json中传递全局变量
"jest": {
"globals": {
"USER_ENDPOINT":"xxx",
"USER_KEY":"xxx"
}
}
3 /在package.json的测试命令中传递我的变量
"test": "USER_ENDPOINT:xxx USER_KEY:xxx jest --watchAll --detectOpenHandles"
4 /在我的测试文件中的beforeEach()中添加了一个Object.assign
beforeEach(() => {
process.env = Object.assign(process.env, {USER_ENDPOINT:"xxx", USER_KEY:"xxx" });
});
并收到错误消息“ Jest遇到意外令牌”
5 /我在根目录上创建了一个jest.config.js文件
require('dotenv').config({path:'./.env'});
module.exports = {
globals: {
USER_ENDPOINT:"xxx",
USER_KEY:"xxx"
}
};
在这里建议这些解决方案中的大多数: https://github.com/vuejs/vue-test-utils/issues/193 但没有一个起作用
答案 0 :(得分:1)
使用dotenv
程序包加载环境变量即可正常工作。
例如
index.test.js
:
const path = require('path');
require('dotenv').config({ path: path.resolve(__dirname, './.env') });
describe('61781150', () => {
it('should pass', () => {
expect(process.env.USER_ENDPOINT).toBe('http://localhost:3000');
expect(process.env.USER_KEY).toBe('abc123');
});
});
.env
:
USER_ENDPOINT=http://localhost:3000
USER_KEY=abc123
您很有可能需要通过.env
方法获取path.resolve
文件的路径。
单元测试结果:
PASS stackoverflow/61781150/index.test.js (8.236s)
61781150
✓ should pass (2ms)
Test Suites: 1 passed, 1 total
Tests: 1 passed, 1 total
Snapshots: 0 total
Time: 9.264s, estimated 11s