首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用fetch-mock获取请求正文

如何使用fetch-mock获取请求正文
EN

Stack Overflow用户
提问于 2019-09-11 20:58:07
回答 1查看 631关注 0票数 2

我有一些测试使用fetch-mock来模拟主体中带有参数的post请求。

我可以模拟请求,但我找不到根据请求的正文返回响应的方法。

假设我有一个post请求:

代码语言:javascript
复制
const body = {flag : true} // can be either true or false
const configInit: RequestInit = {
        method: "POST",
        credentials: "include",
        body: JSON.stringify(body)
    };

fetch(REQUEST_URL, configInit)

目前我的mock看起来是这样的:

代码语言:javascript
复制
//.. some definithion of responseA and responseB 
fetchMock.post(
                REQUEST_URL,
                (url, opts) =>  opts && opts.body && opts.body.flag ? responseA : responseB ,
                { overwriteRoutes: true }
);

但是它说opts.body是一个'BodyInit‘对象,并且没有属性"flag“。

我已经找到了docomentation,但我在任何地方都找不到正确的方法。如何从我的模拟响应的请求中获取参数?这是最佳实践吗?也许我应该使用FunctionMatcher来分离请求(这对我也不起作用)?

EN

回答 1

Stack Overflow用户

发布于 2020-10-29 23:29:52

我不确定最好的模式或其他方法,但我的快速解决方案是调用BodyInit提供的toString()方法,例如:

代码语言:javascript
复制
fetchMock.get('someUrl', (_, opts) => {
  const body = JSON.parse(opts.body.toString())
})

很抱歉,我的答案不完整,希望能让您上路

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57889748

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档