2016-10-12 23 views
0

我正在使用testdouble.js来测试几个函数。对于下面的函数,我正在努力弄清楚如何最好地存储get API调用,以覆盖剩余的函数。看起来应该是直截了当的,但我认为我一直盯着它太久了。使用Testdouble.js存根API调用并解决承诺

var checkTags = function(tags) { 
    return new Promise(function(resolve) { 

     /* istanbul ignore if */ 
     if (process.env.NODE_ENV !== 'test') { 
      console.log("Entered Check Tags"); 
     } 
     var tagMSG; 
     var url = 'https://api.to.call/'; 
     tags.Tags.forEach(function(uaiTag) { 
      tagMSG = uaiTag.Key === 'UAI' ? uaiTag.Value : 'No Tag'; 
     }); 
     console.log(tagMSG); 
     if (tagMSG === "No Tag") return resolve('FAILED'); 
     request.get(url + tagMSG, function(error, response) { 
      var returnStatus = 'FAILED'; 
      console.log(returnStatus); 
      if (!error && response.statusCode === 200) { 
       returnStatus = 'PASSED'; 
      } 
      return resolve(returnStatus); 
     }) 
    }); 
}; 

我的测试看起来像下面:

it('should resolve2', function(done) { 
    td.replace(request, 'get', function() { 
     return new Promise((resolve) => resolve('PASSED')); 
    }); 

    var policy = require('../main/js-utils'); 
    should(policy.checkTags(require('./data/tags.json'))).be.equal(new Promise((resolve) => resolve())); 
    }); 

而我收到的错误:

AssertionError: expected [Promise] to be [Promise] 
    + expected - actual 

    { 
    - "_bitField": 0 
    + "_bitField": 33554432 
    "_fulfillmentHandler0": [undefined] 
    "_promise0": [undefined] 
    "_receiver0": [undefined] 
    - "_rejectionHandler0": [undefined] 
    + "_rejectionHandler0": "PASSED" 
    } 

回答

0

即使他们与解决这两个不同的承诺永远不会相等相同的结果(与{} === {}返回false相同)。 要解决此问题,您需要事先创建您的承诺,如下所示:

const promise = new Promise((resolve) => resolve('PASSED') 
td.replace(request, 'get', function() { 
    return promise 
}) 
var policy = require('../main/js-utils') 
should(policy.checkTags(require('./data/tags.json'))).be.equal(promise)