微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Sinon:存根使用 fetch api 的包装方法,该方法在 web 组件的 main 函数中被调用

如何解决Sinon:存根使用 fetch api 的包装方法,该方法在 web 组件的 main 函数中被调用

我在 fetch api 上有一个包装方法,它返回一个承诺。请看下面的代码示例:

const fetchWrapper = (url,opts) => {
  const fetchPromise = fetch(url,opts);
  const wrapper = new Promise((resolve,reject) => {
    fetchPromise
      .then((response) => {
        if (response.status === 400 && response.headers.get('Content-Type') === 'application/json') {
          response.json()
            .then((data) => {
              if (!data.success) {
                resolve(new Promise(() => {}));
              } else {
                resolve(response);
              }
            })
            .catch(() => resolve(response));
        } else {
          resolve(response);
        }
      },reject);
  });
return wrapper;

所以,现在我有一个方法调用这个 fetchWrapper 方法,如下所示:

 async loadData() {
    const response = await fetchWrapper('/sample-template.json');
    const json = await response.json();
    this.reportTypes = json.templates;
  }

这里的问题是,我想对loadData这个方法进行单元测试。所以,我正在尝试使用下面的单元测试代码来存根内部方法

const MOCK_JSON = {
    templates: [{"id": 1,"name": "Sample report 1"},{"id": 2,"name": "Sample report 2"}]
};

const jsonOk = (body) => {
    const mockResponse = new window.Response(JSON.stringify(body),{
      status: 200,headers: {
        'Content-type': 'application/json',},});
    return Promise.resolve(mockResponse);
  };

describe('load data api',async () => {
    let stub;
    beforeEach(() => {
        stub = sinon.stub(fetchWrapper);
        stub.onCall(0).returns(jsonOk(MOCK_JSON));
        console.log(stub.calledOnce);
    });
    afterEach(() => { 
        stub.restore();
    });
 
   it('load all report types',async () => {
     const res = loadData();
   });
});

请让我知道进行单元测试的解决方案是什么。我尝试了多种方法,但没有找到任何可行的解决方案。帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?