nodejs sinon, как заглушить встроенный требуемый объект из класса - PullRequest
0 голосов
/ 01 мая 2018

Я пытаюсь заглушить класс, который делает некоторые вещи в строке, требующей строки. Например, скажем, я пишу модульный тест для abc-handler.js, который зависит от query-helper и logger. С другой стороны, query-helper также зависит от logger. Тем не менее, я не смог найти правильный способ справиться с заглушкой регистратора и внедрить его в связанные зависимости.

Вот несколько примеров классов, которые у меня есть.

запрос-helper.js

var logger = require('./log/logger.js').getDefaultLogger();

class QueryHelper {
  static save() {
    // save stuff
  }
}

АБВ-handler.js

const logger = require('./log/logger.js').getDefaultLogger();
const QueryHelper = require('./query-helper.js');
var Handler = require('./handler.js');

/**
    Handler for 'binance' exchange
*/
class ABCHandler extends Handler {
    constructor(params) {
        super(params);
    }

    doStuff() {}
}

logger.js

var Log = require('log');
var fs = require('fs');
var dir = './logs';
const config = require('./config.js');
class LoggerFactory {
    static getDefaultLogger() {
        this._createDir();
        if (this.logger === null || this.logger === undefined) {
            this.logger = new Logger("application");
        }
        return this.logger;
    }

    static _createDir() {
        if (!fs.existsSync(dir)) {
            fs.mkdirSync(dir);
        }
    }
}

class Logger {
    constructor(operationType) {
        this.logger = new Log("debug", fs.createWriteStream("logs/" + operationType + ".log"), {flags: "a"});
    }
}

module.exports = LoggerFactory;

Вот пример блока из юнит-теста. Здесь abcHandler создает каталог ./log, чего не должно быть, потому что я передаю loggerStub

var sinon = require('sinon');
var proxyquire = require('proxyquire');
var Log = require('log');
...

logger = proxyquire('./logger.js', {'./config.js': config});
loggerStub = sinon.createStubInstance(Log);
_createDirStub = sinon.stub(logger, "getDefaultLogger").returns(loggerStub);

queryHelper = proxyquire('./query-helper.js' , {'./logger.js': logger});
queryHelperGetLastDataStub = sinon.stub(queryHelper, "save");

abcHandler = proxyquire('.abc-handler.js'
                                    , {'./logger.js': logger,
                                        './query-helper.js': queryHelper,
                                        './config.js': config});

Спасибо!

1 Ответ

0 голосов
/ 01 мая 2018

Я решил эту инициализацию proxyquire с noCallThru().

var proxyquire = require('proxyquire').noCallThru();

объяснено здесь https://github.com/thlorenz/proxyquire#preventing-call-thru-to-original-dependency

...