首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在rspec系统规范中ActionCable引发异常

在rspec系统规范中ActionCable引发异常
EN

Stack Overflow用户
提问于 2017-11-15 11:10:33
回答 1查看 699关注 0票数 3

我有一个问题,使用ActionCable与系统规格使用凯巴拉。ActionCable在我的开发服务器上运行得很好,但是当使用系统规范进行测试时,它无法连接到Websockets。

/log/test.log的输出显示:

代码语言:javascript
运行
复制
Started GET "/cable" for 127.0.0.1 at 2017-11-15 18:17:04 +0900
Started GET "/cable/" [WebSocket] for 127.0.0.1 at 2017-11-15 18:17:04 +0900
Successfully upgraded to WebSocket (REQUEST_METHOD: GET, HTTP_CONNECTION: Upgrade, HTTP_UPGRADE: websocket)
WebSocket error occurred: undefined method `write_nonblock' for nil:NilClass
WebSocket error occurred: undefined method `write_nonblock' for nil:NilClass
WebSocket error occurred: undefined method `write_nonblock' for nil:NilClass

我在用:

  • ruby 2.4.1
  • rails 5.1.4
  • rspec 3.7.0
  • 水豚2.13.0
  • 美洲狮3.10.0
  • selenium-WebDriver3.6.0

我试过:

代码语言:javascript
运行
复制
Capybara.server = :puma

这并没有什么区别(可能是因为系统规范已经在使用Puma了)。

我调试这个问题的尝试:

仔细观察错误,在nil上调用方法nil,这发生在第45行:

cable/connection/stream.rb#L45

@rack_hijack_io似乎被设置为nil,这很可能发生在这里的hijack_rack_socket方法中:

cable/connection/stream.rb#L102

@socket_object.env["rack.hijack_io"]返回nil,因此我们没有"rack.hijack_io"密钥。因此,这个错误似乎与Rack劫持API有关。

EN

回答 1

Stack Overflow用户

发布于 2019-12-12 13:59:45

我不知道您测试的细节,但在我的例子中,问题是在config.log_level = :debug in config/environments/[env]中。

因为ActionCable产生了大量关于广播的调试信息。例如,如果您有100个连接的客户端,您的日志文件将被每个广播的100条消息所污染。

PS:我在NGINX +客运(6.0.4)+ GKE和Stackdriver上发现了这个错误。

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

https://stackoverflow.com/questions/47305850

复制
相关文章

相似问题

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