I'm trying to use FileReader object but 'onload' event is not fired.
I know that Jest uses jsdom behind the scenes. But I did a test using jsdom only and it worked! Please find below 1) a scenario using jsdom only (does work) 2) a scenario using Jest (does not work).
(I'm new to Jest so perhaps I could be missing something obvious; I'm sorry if that's the case...)
jsdom:
var jsdom = require("jsdom");
jsdom.env(
'',
function(err, window) {
function dataURLtoFile(dataurl, filename) {
var arr = dataurl.split(','),
mime = arr[0].match(/:(.*?);/)[1],
bstr = window.atob(arr[1]),
n = bstr.length,
u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
return new window.File([u8arr], filename, {
type: mime
});
}
var imageB64 = '';
var file = dataURLtoFile(imageB64, 'myfile');
var reader = new window.FileReader();
// 'ONLOAD' EVENT IS FIRED SUCCESSFULLY
reader.addEventListener("load", function(event) {
console.log(reader.result);
});
reader.readAsDataURL(file);
}
);
Jest:
test('event "onload" is not fired', function() {
function dataURLtoFile(dataurl, filename) {
var arr = dataurl.split(','),
mime = arr[0].match(/:(.*?);/)[1],
bstr = atob(arr[1]),
n = bstr.length,
u8arr = new Uint8Array(n);
while (n--) {
u8arr[n] = bstr.charCodeAt(n);
}
return new File([u8arr], filename, {
type: mime
});
}
var imageB64 = '';
var file = dataURLtoFile(imageB64, 'myfile');
var reader = new FileReader();
// 'ONLOAD' EVENT IS NOT FIRED
reader.addEventListener("load", function(event) {
console.log("'load' event has been fired!");
});
reader.readAsDataURL(file);
});
Thanks!
You should pass a done callback because this is async code
test('event "onload" is not fired', function(done) {
// test code...
reader.addEventListener("load", function(event) {
console.log("'load' event has been fired!");
try {
expect(expected).toEqual(received);
done();
} catch(error) {
done.fail(error);
}
});
}
Since expect can throw error, you need to wrap in try/catch clause, so done can be always called.
Most helpful comment
You should pass a
donecallback because this is async codeSince
expectcan throw error, you need to wrap in try/catch clause, sodonecan be always called.