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`所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)