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秒)。