4

我最近开始了一个节点项目,作为一名测试驱动开发人员,我很快就遇到了我全新模块的依赖注入问题。以下是我认为我应该进行依赖注入的方法。重要的是要注意我使用vows作为 BDD 框架并用Sinon扩展它。

我的模块:

exports.myMethod = function () {
  var crypto = exports.cryptoLib || require('ezcrypto').Crypto;
  crypto.HMAC(
    crypto.SHA256,
    'I want to encrypt this',
    'with this very tasty salt'
  );
};

我的测试:

var vows = require('vows'),
  sinon = require('sinon');

vows.describe('myObject').addBatch({
  'myMethod':{
    'topic':true,
    'calls ezcrypto.HMAC':function () {
      var myObject = require('../playground.js');
      var mock = sinon.mock(require('ezcrypto').Crypto);

      myObject.cryptoLib = mock;
      myObject.cryptoLib.HMAC = mock.expects("HMAC").once().withExactArgs(
        require('ezcrypto').Crypto.SHA256,
        'I want to encrypt this',
        'with this very tasty salt'
      );
      myObject.cryptoLib.SHA256 = require('ezcrypto').Crypto.SHA256;
      myObject.cryptoLib = mock;
      myObject.myMethod();
      mock.verify();
    }
  }
}).export(module);

你认为这是正确的方法吗?我喜欢这个解决方案,因为当你使用模块时它不需要更多(比如在 require 语句后添加“()”)。

4

1 回答 1

3

这不是用测试的东西来破坏你的代码的好方法。代码的第 2 行

var crypto = exports.cryptoLib || require('ezcrypto').Crypto;

看起来像不必要的界面。我建议你用

var crypto = require('ezcrypto').Crypto;

干净多了。并且在测试中只是模拟“ezcrypto”模块的加密方法。只是不要忘记在使用后将其恢复。

于 2012-03-20T10:16:02.850 回答