Я начинаю думать, что это невозможно, но я все равно хочу спросить.
Я хочу проверить, что один из моих модулей ES6 вызывает другой модуль ES6 определенным образом. С Жасмин это очень просто -
Код приложения:
// myModule.js
import dependency from './dependency';
export default (x) => {
dependency.doSomething(x * 2);
}
И тестовый код:
//myModule-test.js
import myModule from '../myModule';
import dependency from '../dependency';
describe('myModule', () => {
it('calls the dependency with double the input', () => {
spyOn(dependency, 'doSomething');
myModule(2);
expect(dependency.doSomething).toHaveBeenCalledWith(4);
});
});
Что эквивалентно Jest? Я чувствую, что это такая простая вещь, которую хочется делать, но я рвал волосы, пытаясь понять это.
Ближе всего я пришел, заменив import
на require
s и перемещая их внутри тестов/функций. Ни то, что я хочу сделать.
// myModule.js
export default (x) => {
const dependency = require('./dependency'); // yuck
dependency.doSomething(x * 2);
}
//myModule-test.js
describe('myModule', () => {
it('calls the dependency with double the input', () => {
jest.mock('../dependency');
myModule(2);
const dependency = require('../dependency'); // also yuck
expect(dependency.doSomething).toBeCalledWith(4);
});
});
Для бонусных очков я бы хотел, чтобы все это работало, когда функция внутри dependency.js
является экспортом по умолчанию. Тем не менее, я знаю, что шпионаж об экспорте по умолчанию не работает в Jasmine (или, по крайней мере, я никогда не смог заставить его работать), поэтому я не надеюсь, что это возможно и в Jest.