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

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

概述控制器测试中的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 控制器测试中的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")
总结

以上是内存溢出为你收集整理的ruby-on-rails-3 – 堆栈级别太深,在rspec中使用`puts response`全部内容,希望文章能够帮你解决ruby-on-rails-3 – 堆栈级别太深,在rspec中使用`puts response`所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/langs/1280951.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-09
下一篇 2022-06-09

发表评论

登录后才能评论

评论列表(0条)

保存