Capybara + Selemium:如何在集成测试代码中初始化数据库并使其在Rails应用程序中可见?

Ale*_*xey 13 database selenium transactions ruby-on-rails capybara

配置: 使用RSpec,Capybara,Selemium驱动程序,SQLite数据库对Rails项目进行集成测试.

情况: 我很少与Capybara和默认的rack_test驱动程序进行集成测试.他们直接在数据库中创建用户注册(对于Devise gem).然后他们像用户一样使用Capybara DSL登录并测试场景.

问题: 我尝试将驱动程序更改为Selenium以测试JavaScript代码.现在测试失败,因为应用程序没有看到测试创建的用户注册.

调查: 看起来Selenium驱动程序与转换的工作方式不同,因此在测试中所做的更改在Web应用程序中是不可见的.可能的解决方案包括:

config.use_transactional_fixtures = false 
DatabaseCleaner.strategy = :truncation
Run Code Online (Sandbox Code Playgroud)

Ale*_*xey 14

对我来说,从这里这里工作解决方案:

  • 添加到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
Run Code Online (Sandbox Code Playgroud)

`

虽然它对我的控制器和型号规格执行时间造成了小的惩罚(从40到43秒).