我坚持为使用 rsvp 承诺的代码编写单元测试。我尝试使用pit
测试,但没有让测试通过 rsvp,但是嵌入式承诺工作得很好:
//jest.autoMockOff(); - even with this rsvp test is failing
jest.unmock('rsvp');
import rsvp from 'rsvp';
describe('my rsvp tests', () => {
// this test fails
pit('testing rsvp promise', () => {
return new rsvp.Promise((resolve) => {
resolve("getting something");
}).then(()=> { expect(1).toBe(1); });
});
// this test passes
pit('testing pure promise', () => {
return new Promise((resolve) => {
resolve("getting something");
}).then(()=> { expect(1).toBe(1); });
});
});
我的 package.json 中的相关细节:
"rsvp": "^3.2.1",
"babelify": "^7.2.0",
"babel-preset-es2015": "^6.6.0",
"babel-preset-react": "^6.5.0",
"babel-preset-stage-0": "^6.5.0",
"babel-jest": "^9.0.0",
"jest-cli": "*"
...
"scripts": {
"test": "jest"
},
"jest": {
"unmockedModulePathPatterns": [
"<rootDir>/node_modules/react",
"<rootDir>/node_modules/react-dom",
"<rootDir>/node_modules/react-addons-test-utils"
]
}
.babelrc:
{
"presets": ["es2015", "react", "stage-0"]
}
我看到两种可能的解决方法,但都不像:
- 使用嵌入式承诺模拟 rsvp 承诺。缺点:单元测试会变得更加冗长,我需要模拟其他我不想做的函数,例如 rsvp.all。
- 从 rsvp 迁移到嵌入式承诺。这是可能的,但是我已经使用了一个依赖于 rsvp 的库来发出 ajax 请求。我也不确定嵌入式 Promise 是否可以替换 rsvp 提供的所有内容(例如“all”和其他辅助函数)。