gpt4 book ai didi

ruby-on-rails - 如何确保我的 Capybara 测试中的每个场景都不会调用 Redis 和 thinking sphinx

转载 作者:IT王子 更新时间:2023-10-29 06:15:59 26 4
gpt4 key购买 nike

我在我的 Rails 应用程序中使用 Capybara 和 Cucumber。我想运行 Sphinx 重新索引和 Redis 服务器,以便为某些特定的测试场景运行。但这里的缺点是场景非常非常慢,需要运行数小时。

这是我的 env.rb 文件

require 'rubygems'

ENV["RAILS_ENV"] = "cucumber"

require 'cucumber/rails'
require 'capybara/cucumber'
require 'capybara/rails'
require 'capybara/session'
require 'rake'

Capybara.default_selector = :css
ActionController::Base.allow_rescue = false
Cucumber::Rails::World.use_transactional_fixtures = true
Capybara.default_wait_time = 4
Capybara.ignore_hidden_elements=false
Capybara::Server.new(Capybara.app).boot

include Rake::DSL
Rake::Task["db:fixtures:load"].invoke

Before('@javascript') do
Capybara.register_driver :selenium do |app|
Capybara::Selenium::Driver.new(app,:browser=>:chrome )
end
Capybara.current_driver = :selenium
Capybara.javascript_driver=:selenium
end

Before('@javascript', '@index') do
`rake ts:in RAILS_ENV=cucumber` unless ThinkingSphinx.sphinx_running?
`rake ts:start RAILS_ENV=cucumber`
end

After('@javascript','@index') do
`rake ts:stop RAILS_ENV=cucumber`
end

Before('@javascript','@redis','@javascript') do
`redis-server config/test_redis.conf`
`rake redis_specifics:cache_build RAILS_ENV=cucumber --trace`
end

After('@javascript','@redis','@javascript') do
pid = `ps aux | grep 'config/test_redis.conf'| grep -v 'grep' | awk '{print $2}'`
`pkill #{pid}`
end

还有一个问题是当我在不同的机器上运行它时,有一个依赖关系,即安装了 Redis 并且用户有权创建和销毁文件夹。有没有更好的方法来处理这种情况?可能是为了实现 Rails 的 Normal 测试框架使用的类似事务风格的固定装置?

非常感谢任何帮助。

最佳答案

我建议使用像 fakeredis (https://github.com/guilleiguaran/fakeredis) 这样的库。这将消除测试中对 redis 的依赖,并确保数据不会在测试之间保留。

我希望 sphinx 也有类似的东西,但我一时想不起来。

关于ruby-on-rails - 如何确保我的 Capybara 测试中的每个场景都不会调用 Redis 和 thinking sphinx,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12196768/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com