Jest: 'onload' event of FileReader object is not fired

Created on 20 Jan 2017  路  1Comment  路  Source: facebook/jest

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!

Most helpful comment

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.

>All comments

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.

Was this page helpful?
0 / 5 - 0 ratings