加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails-3 – 堆栈级别太深,在rspec中使用`puts response`

发布时间:2020-12-17 02:36:59 所属栏目:百科 来源:网络整理
导读:控制器测试中的rspec和rails有一个奇怪的问题.每当我们在一个规范中添加put响应时,它就会输出很多这些 200{"Content-Type"="text/html; charset=utf-8"}200{"Content-Type"="text/html; charset=utf-8"}200{"Content-Type"="text/html; charset=utf-8"}200{"
控制器测试中的rspec和rails有一个奇怪的问题.每当我们在一个规范中添加put响应时,它就会输出很多这些

200
{"Content-Type"=>"text/html; charset=utf-8"}
200
{"Content-Type"=>"text/html; charset=utf-8"}
200
{"Content-Type"=>"text/html; charset=utf-8"}
200
{"Content-Type"=>"text/html; charset=utf-8"}

然后使用SystemStackError失败:堆栈级别太深.通过pry检查响应效果很好,打印其他东西也很好.

升级到最新的rspec(2.11)并没有什么不同.我们注意到puts在响应上调用to_a,它返回一个[@status,@ header,self]数组,所以不知何故它会导致这个奇怪的递归?

更新:这是一个带代码规范的gist

解决方法

我相信你遇到了机架中的错误. [rack_response] .flatten进入无限循环.有关详细信息,请参阅这些问题

> https://github.com/rspec/rspec-rails/issues/601
> https://github.com/rspec/rspec-expectations/issues/166
> https://github.com/rack/rack/issues/419

解决方案是不对响应对象本身设置任何期望,而是单独设置对状态,标题或正文的期望,例如:

last_response.status.should eq(200)
last_response.body.should include("some text")
last_response.headers.should include("Content-Type" => "text/plain")

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读