单元测试时模拟ES6依赖项

时间:2016-03-05 21:58:35

标签: javascript unit-testing ecmascript-6

假设以下两个ES6类:

MY-random.js:

export default class MyRandom {
    get() { return Math.random(); }
}

app.js:

import MyRandom from './random';

export default class App {
    get() {
        let r = new MyRandom();
        let total = r.get() * r.get(); // Complex calc goes here!
        return total;
    }
}

现在我想从getapp.js进行单元测试。所以我想模仿MyRandom。 Todo我发现了一个非常有趣的库Mocktail

根据文档,您应该将my-random.js更改为

import {mock} from 'mocktail';
class MyRandom {
    get() { return Math.random(); }
}
export default mock(MyRandom);

在您的测试文件中,您必须告诉环境您正在测试如下:

import {env, ENV, inject} from 'mocktail';
env(ENV.TESTING);

class MyRandomMock {
    get() {
        return 10; // Not so random anymore
    }
}
inject('MyRandom', MyRandomMock);

你应该能够测试app.js。不幸的是,当我尝试这个时,MyRandom永远不会被模拟类所取代。任何帮助将不胜感激!!

我已经在github上设置了一个测试项目here来证明这个问题。如您所见,测试将失败:(

如果有更好的方法来实现我的需要,请告诉我!

1 个答案:

答案 0 :(得分:1)

我认为您需要在测试文件中setup之前导入App,这将注入模拟并在App中调用它。

import './setup';    
import App from '../src/app';