ruby-on-rails – RSpec Capybara请求规格与JS无法正常工作

使用 Javascript时,我无法获得请求规范.
如果我在没有Javascript的情况下运行它们,我的规范就会通过(该页面可以使用或不使用JS).

具体来说,当我做Post.should有(1).record这样的断言时,规范就失败了.
Capybara只是不从DB中获取记录,并且在运行之间不会清理数据库.

我已经尝试使用DatabaseCleaner禁用事务夹具 – 我猜这是常见的方法.没有骰子.

我也尝试(并且,理想情况下更喜欢)在没有DatabaseCleaner的情况下运行,使用事务夹具并强制AR在线程之间共享相同的连接(a patch described by José Valim).再一次,没有骰子.

此外,我也试过在Capybara-webkit和Selenium之间切换 – 问题仍然存在.

我已经提出了一个只有一个基本的Post脚手架的示例应用程序,它复制了问题:https://github.com/cabgfx/js-specs
一个带有事务夹具和AR共享连接的spec_helper.rb,以及另一个场景的spec_helper_database_cleaner.rb.

我通常使用Spork,但我已经在spec_helper.rb文件中禁用了它,只是为了消除潜在的失败点(在两个应用程序中;“真正的”和示例应用程序).

我在Macbook Air上使用Pow进行本地开发,运行OS X 10.7.3,MRI 1.9.3至RVM. (我也试过1.9.2).

希望我有意义 – 非常感谢任何指导/帮助/指针!

解决方法

马特 – 非常感谢您花时间来帮助我!
我尝试使用您的spec_helper进行设置,使用Selenium作为javascript驱动程序.

该规范仍然失败 – 但我可以看到在Firefox中执行的正确行为…
然后它突然意识到,问题可能发生,因为Capybara没有等待AJAX​​请求完成.

然后我恢复到我最初的spec_helper(使用Spork而没有DatabaseCleaner),只是使用了Capybara的wait_until {page.has_content? “我正在用JS插入文本”}.

我更新了示例应用程序,并在请求规范中添加了sleep 1,因此您可以自己查看.它现在可以使用和不使用Spork,AR猴子补丁似乎完美无缺.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...