Capybara + Selemium:如何在集成测试代码中初始化数据库并使其在Rails应用程序中可见?
配置:使用RSpec,Capybara,Selemium驱动程序,SQLite数据库对Rails项目进行集成测试。
情况:我很少与Capybara和默认的rack_test驱动程序进行集成测试。 他们直接在数据库中创建用户注册(对于Devise gem)。 然后他们像用户一样使用Capybara DSL登录并测试场景。
问题:我尝试将驱动程序更改为Selenium以测试JavaScript代码。 现在测试失败,因为应用程序没有看到测试创建的用户注册。
调查:看起来Selenium驱动程序与转换的工作方式不同,因此在测试中所做的更改在Web应用程序中是不可见的。 可能的解决方案包括:
config.use_transactional_fixtures = false DatabaseCleaner.strategy = :truncation
对我来说,从这里和这里工作解决方案:
- 添加到Gemfile
gem database_cleaner
- 使用内容创建文件
spec/support/javascript.rb
`
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秒)。