1

我坚持为使用 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"]
}

我看到两种可能的解决方法,但都不像:

  1. 使用嵌入式承诺模拟 rsvp 承诺。缺点:单元测试会变得更加冗长,我需要模拟其他我不想做的函数,例如 rsvp.all。
  2. 从 rsvp 迁移到嵌入式承诺。这是可能的,但是我已经使用了一个依赖于 rsvp 的库来发出 ajax 请求。我也不确定嵌入式 Promise 是否可以替换 rsvp 提供的所有内容(例如“all”和其他辅助函数)。
4

1 回答 1

1

我找到了一个解决方案——或者,更好的说法是,一个解决方法。简而言之:坑方法不需要使用,可以用'it'代替,但是在完成之前所有定时器都应该运行,可以通过调用jest.runAllTimers()来完成。

这不是一个优雅的解决方案,因为我看不出为什么 rsvp 承诺不应该开玩笑而不是“嵌入式”承诺,但至少它有效。

于 2016-03-27T01:12:39.883 回答