一尘不染

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

selenium

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

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

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

研究: Selenium驱动程序在转换中的工作方式似乎有所不同,因此测试中所做的更改在Web应用程序中是不可见的。可能的解决方案包括:

config.use_transactional_fixtures = false 
DatabaseCleaner.strategy = :truncation

阅读 294

收藏
2020-06-26

共1个答案

一尘不染

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

  • 添加到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秒)。

2020-06-26