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

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – 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

解决方法

对于我从 herehere的工作解决方案:

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

猜你在找的Ruby相关文章