大佬教程收集整理的这篇文章主要介绍了Capybara + Selemium:如何在集成测试代码中初始化数据库并使其在Rails应用程序中可见?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
对我来说,从这里到这里工作解决方案:
`
@H_489_16@RSpec.configure do |config|
config.before(:suitE) do
DatabaseCleaner.strategy = :transaction
DatabaseCleaner.clean_with :truncation
end
config.before(:each) do
if example.Metadata[:Js]
Capybara.current_driver = :SELEnium
DatabaseCleaner.strategy = :truncation
else
DatabaseCleaner.strategy = :transaction
DatabaseCleaner.start
end
end
config.after(:each) do
Capybara.use_default_driver if example.Metadata[:Js]
DatabaseCleaner.clean
end
end
`
尽管这对我的控制器和模型规格执行时间造成了小损失(从40到43秒)。
配置: 使用RSpec,Capybara,SELER_673_11845@ium驱动程序,sqlite数据库对Rails项目进行集成测试。
情况: 我没有对Capybara和默认的rack_test驱动程序进行集成测试。他们直接在数据库中@R_764_10589@注册(用于Devise
gem)。然后他们像用户一样使用Capybara DSL登录并测试场景。
问题: 我也尝试将驱动程序更改为SELEnium来测试JavaScript代码。现在测试失败,因为应用程序看不到测试创建的用户注册。
研究: SELEnium驱动程序在转换中的工作方式似乎有所不同,因此测试中所做的更改在Web应用程序中是不可见的。可能的解决方案包括:
@H_489_16@config.use_transactional_fixtures = false
DatabaseCleaner.strategy = :truncation
以上是大佬教程为你收集整理的Capybara + Selemium:如何在集成测试代码中初始化数据库并使其在Rails应用程序中可见?全部内容,希望文章能够帮你解决Capybara + Selemium:如何在集成测试代码中初始化数据库并使其在Rails应用程序中可见?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。