反応アプリケーションでいくつかの XHR サービスをサポートするためにスーパーエージェントを使用しています。構成を簡単にするために、スーパーエージェントの周りに非常に薄いラッパーを作成しました。この薄い層をテストしようとすると、かなりの頭痛の種になることが証明されています.
jest とノード コアの依存関係に問題があることは認識しており、dontMock
スーパーエージェントの依存関係を ing することで問題を解決できます。しかし、私はsuperagent
、デフォルトで爆破せずに冗談を言うことを好むでしょう。
unMockedModulePatterns
その結果、package.json に非常に冗長なテスト イントロまたはエントリが表示されます。より良い方法はありますか?
// my-module.js
'use strict';
var request = require('superagent');
module.exports = function () {
return request.get('http://stackoverflow.com/questions/tagged/jestjs');
};
テストの例:
// __tests__/my-module-test.js
'use strict';
jest.dontMock('../');
// T_T
jest.dontMock('superagent');
jest.dontMock('debug');
jest.dontMock('tty');
jest.dontMock('util');
jest.dontMock('stream');
jest.dontMock('fs');
jest.dontMock('delayed-stream');
jest.dontMock('mime');
jest.dontMock('path');
describe('mymodule', function () {
var myModule, request;
beforeEach(function () {
myModule = require('../');
request = require('superagent');
request.get = jest.genMockFunction(function () {
return {
get: jest.genMockFunction()
}
})
});
it('makes an xhr request using superagent', function() {
var req = myModule();
expect(request.get).toBeCalledWith('http://stackoverflow.com/questions/tagged/jestjs');
});
});