2017-07-18 4 views
1

Je semble incapable de copier readFileSync sur fs à partir du noyau NodeJS. Le code suivant isole le problème. L'exécution du test via les résultats Mocha dans les domaines suivants:Proxyquire: impossible de terminer fs.readFileSync

> mocha tests/test.js 

     Some description 
     1) "before all" hook 


     0 passing (15ms) 
     1 failing 

     1) Some description "before all" hook: 
     TypeError: Cannot read property 'charCodeAt' of undefined 
      at Object.stripBOM (internal/module.js:48:14) 
      at Object.require.extensions.(anonymous function) (node_modules/proxyquire/lib/proxyquire.js:276:43) 
      at Proxyquire._withoutCache (node_modules/proxyquire/lib/proxyquire.js:179:12) 
      at Proxyquire.load (node_modules/proxyquire/lib/proxyquire.js:136:15) 
      at Context.<anonymous> (tests/test.js:12:15) 

est ici tests/test.js

var proxyquire = require('proxyquire'), 
    sinon = require('sinon'), 
    fs = require('fs'), 
    sut; 

describe('Some description', function() { 
    var readFileSyncStub; 

    before(function() { 
     readFileSyncStub = sinon.stub(fs, 'readFileSync'); 
     readFileSyncStub.withArgs('someFile.js', { encoding: 'utf8' }).returns('some text'); 
     sut = proxyquire('../sut', { fs: { readFileSync: readFileSyncStub } }); // Exception encountered somewhere in here ... 
    }); 

    after(function() { 
     fs.readFileSync.restore(); // This is executed ... 
    }); 

    it('Some it', function() { 
     // This never happens ... 
    }); 
}); 

Et voici sut.js, qui est le module testé:

var fs = require('fs'); // The code in this file is never executed ... 

module.exports = function() { 
    return fs.readFileSync('someFile.js', { encoding: 'utf8' }); 
}; 

La structure de dossiers pour le projet est:

./sut.js 
./package.json 
./tests/test.js 

test.js peut être exécuté en exécutant mocha tests/test.js à partir de l'invite.

J'ai remarqué qu'il y a plusieurs années, un problème a été signalé sur Github à propos de quelque chose qui semble similaire, mais je ne peux pas dire si c'est le même problème, ou un problème différent. Voici le lien:

https://github.com/thlorenz/proxyquire/issues/12

Dans le cas où il aide, ce sont les dépendances dans mon fichier package.json. J'ai essayé d'utiliser des versions similaires aux dépendances pour proxyquire:

{ 
    ... 
    "devDependencies": { 
    "jshint": "^2.9.5", 
    "jslint": "^0.11.0", 
    "mocha": "~3.1", 
    "proxyquire": "^1.8.0", 
    "sinon": "~1.9" 
    }, 
    "dependencies": {} 
    ... 
} 

Toute aide est très appréciée!

Répondre

2

Vous n'avez pas besoin de bouchonner fs.readFileSync() si vous êtes également en utilisant proxyquire pour le remplacer (en fait, stubbing fs.readFileSync() est la cause de votre problème, car il est à la fois briser require() et proxyquire).

Essayez ceci:

describe('Some description', function() { 
    var readFileSyncStub; 

    before(function() { 
    readFileSyncStub = sinon.stub() 
          .withArgs('someFile.js', { encoding: 'utf8' }) 
          .returns('some text'); 
    sut = proxyquire('../sut', { fs : { readFileSync : readFileSyncStub } });       
    }); 

    it('Some it', function() { 
    let value = sut(); 
    assert.equal(value, 'some text'); 
    }); 

}); 
+0

Merci @robertklep, qui fonctionne très bien! Je suis un peu confus, cependant. Les exemples sur Github sont en train de talonner les méthodes pour fs: https://github.com/thlorenz/proxyquire/blob/master/examples/sinon/foo-tests.js. – Andrew

+1

@Andrew ces exemples sont vieux (5 ans pour ce fichier particulier). Je suppose qu'entre-temps, les internes de Node.js ont changé. Le simple ajout de 'fs.readFileSync()' provoque des problèmes dans les versions récentes de Node.js. – robertklep