NodeJS Web App, upload de arquivo é interrompido no início do arquivo

Estou trabalhando em um projeto no NodeJS que envolve o upload de arquivos. O upload é feito no lado do cliente com o código:

$('#file-upload').bind('change focus click', function() {
    var file = jQuery(this)[0].files[0];
    if (file && file.fileName) {
        var xhr = new XMLHttpRequest();
        xhr.upload.addEventListener('progress', onProgressHandler, false);
        xhr.upload.addEventListener('load', transferComplete, false);
        xhr.open('POST', '/upload', true);
        xhr.setRequestHeader('X-Requested-With', 'XMLHttpRequest');
        xhr.setRequestHeader('X-File-Name', encodeURIComponent(file.fileName));
        xhr.setRequestHeader('Content-Type', 'application/octet-stream');
        xhr.send(file);


        function onProgressHandler(evt) {
            var percentage = event.loaded/event.total*100;
            console.log(percentage);
        }
        function transferComplete(evt) {
            console.log('Done');
        }
    }
});

E no lado do servidor, eu uso:

app.post('/upload', function(req, res, next) {
    if(req.xhr) {
        console.log('Uploading...');
        var fName = req.header('x-file-name');
        var fSize = req.header('x-file-size');
        var fType = req.header('x-file-type');
        var ws = fs.createWriteStream('./'+fName)

        req.on('data', function(data) {
            console.log('DATA');
            ws.write(data);
        });
        req.on('end', function() {
            console.log('All Done!!!!');
        });
    }
});

Este código funciona sozinho, mas quando combinado com o restante do meu projeto muito maior, ele mostra o início de arquivos grandes e ignora todos os arquivos pequenos. Se eu enviar um arquivo pequeno, o console.log ('DATA') nunca é acionado e é acionado para arquivos grandes, mas não para o início do arquivo. Acredito que, por algum motivo, ele esteja enviando o arquivo mais cedo e quando minha função o seleciona no início (ou, no caso de um arquivo pequeno, a coisa toda) já foi enviado. Mas não sei o que estaria causando isso.

Obrigado

questionAnswers(2)

yourAnswerToTheQuestion