如果我在没有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猴子补丁似乎完美无缺.