jestでカスタム関数をモックしようとしていますが、問題があります。jestでコールバック関数をモックする方法
これは私の関数である:
export const resizeImage = (file, fileName, callback) => {
const MAX_WIDTH = avatarImage.maxWidth;
const MAX_HEIGHT = avatarImage.maxHeight;
const img = document.createElement('img');
img.src = window.URL.createObjectURL(file);
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
img.onload =() => {
const sizes = internalResizeImage(img, MAX_WIDTH, MAX_HEIGHT);
canvas.width = sizes.width;
canvas.height = sizes.height;
ctx.drawImage(img, 0, 0, sizes.width, sizes.height);
return callback(dataURItoFile(canvas.toDataURL(), fileName));
};
};
私はこのように呼ばれる:私はmockResizeImageがしたい
let mockResizeImage = jest.fn();
jest.mock('../../utilities/imageUtils',() => ({
resizeImage:() => mockResizeImage
}));
:私はこのようにそれをからかってる私のテストで
resizeImage(acceptedFiles[0], this.props.user.id, (res) => {
//dostuff
});
コールバックになり、私のテストで戻り値を変更します:
it('should call handleDrop and accept files',() => {
//mockResizeImage.mockReturnValue('something');
const instance = shallow(mockComponent()).instance();
const acceptFilesMock = ['test'];
instance.handleDrop(acceptFilesMock);
expect(clickSpy).toHaveBeenCalledTimes(1);
});
もしそれが約束だったのなら、それはすべていいですが、それはコールバックであり、私が間違っていることは分かりません。
ありがとうございました。
ありがとう、アンドレアス!それは動作しますが、resizeImageのインポートをテストする方法はわかりません。私はそれにスパイダーを追加する必要がありますか?ありがとう –
"test' resizeImage '"はどういう意味ですか? 'resizeImage'が正しいパラメータで呼び出されたことをテストしていますか? –
はい、私はこれをやっています: '' 'expect(resizeImage).toHaveBeenCalledTimes(1);' '' –