0

我有以下代码在我的项目中使用 axios 建立服务器连接:

    axios.get('/someurl')
    .then(function (response) {
        console.log(response);
    }.bind(this))
    .catch(function (response) {
      console.log(response);
    });

我正在使用 Jest 作为测试框架,并且我成功地模拟了 axios,但是我对这个 then-Function 有一个问题:

module.exports = {
  get: function(a)
    console.log(a);
    console.log(b);
    return "abc";
  }
 }

但是,在运行测试时,我收到以下错误消息:

TypeError: _axios2.default.get(...).then 不是函数

我必须以某种方式找到一种方法来告诉它存在并且是一个函数。我必须在 module.exports 中执行此操作。关于如何做到这一点的任何想法?

4

1 回答 1

1

您似乎期望该get函数返回一个Promise。这就是then函数的含义。为此,您可以将get模型更改为以下内容:

module.exports = {
  get: function(a) {
    return new Promise(function(resolve, reject) {
      console.log(a);
      console.log(b);
      resolve('abc');
    });
  }
};

或者,如果您知道它总是会成功,您可以使用以下方法简化它Promise.resolve

module.exports = {
  get: function(a) {
    console.log(a);
    console.log(b);
    return Promise.resolve('abc');
  }
};

Promises 的伟大之处在于它们简化了异步流程。对于您的模型,这就是您所需要的,但您可以使用相同的过程来处理异步值。

module.exports = {
  get: function(a) {
    return new Promise(function(resolve, reject) {
      // Wait some period of time
      setTimeout(function() {
         // 'abc' + a is passed to the `then` function
         resolve('abc' + a);
      }, 1000);
    });
  }
};

然后当你使用这个模块时,它很简单:

var axios = require('./my-mockup.js');
axios.get('def')
.then(function(response) {
  console.log(response); // 'abcdef'
});
于 2016-05-19T22:59:26.353 回答