在Rails中对阶段/生产环境进行烟雾测试的最佳方法是什么?

| 首先,设置... 我目前正在使用Ruby 1.8.7 MRI在Mac OS X上开发Rails 3应用程序,针对MySQL数据库运行测试和本地开发。我在公司中使用3个“其他”非本地环境,用于每个称为dev,tqa和prod的应用程序。它们在Tomcat中使用JRuby(1.8.7)在Oracle中作为后端运行。 如您所见,环境完全不同,并且在部署到本地不存在的Oracle / JRuby环境时遇到了一些错误(例如日期处理和在Oracle中指定默认模式)。 我喜欢在本地运行Cucumber / Webrat / Capybara之类的程序,以访问应用程序中公开的每个URL,以确保基本内容正常运行(例如,冒烟测试)。理想情况下,它会匹配每个网址,并会执行一些简单的操作,例如以表格形式输入数据并单击按钮等。 理想情况下,当我部署到dev / tqa时,我会运行类似的东西,除了指向已部署的应用程序而不是本地应用程序。 Cucumber似乎已经过优化,可以运行在本地运行的应用程序并与Rails很好地集成在一起,但是不能针对“外部”应用程序的所有意图进行运行(或者至少我找不到实际可行的简便方法)。 另外,当我部署到产品时,我希望运行类似的冒烟测试套件,除了它不会更改当前生产数据库的状态(即仅获取URL)。 我猜可以使用Selenium之类的东西,但是我真的很想运行一个rake任务并像使用Cucumber一样获得结果。 是否有任何Rails / Ruby方法可以做到这一点,还是其他所有人都只是使用wget或Selenium推出了自己的解决方案? 这里提出了类似的问题:部署后自动对应用程序中的所有网页进行烟雾测试 不过,我不确定这个问题是否正是我的想法。     
已邀请:
是的,您可以使用Cucumber和Capybara编写烟雾测试,并在远程服务器上运行它们。我已经做到了,而且可行。在某些项目上,我也做了
curl
/
wget
之类的事情,但是Cucumber + Capybara允许您与页面(甚至是使用Javascript的页面)进行交互,而不仅仅是抓取它们。 Capybara的
Rack::Test
驱动程序不支持远程请求。它的Javascript驱动程序。无论您实际上是否需要Javascript才能在要测试的页面上工作,都需要使用Javascript驱动程序。将Capybara配置为根据驱动程序的文档使用Javascript驱动程序,并标记测试“ 3”。 (我建议使用poltergeist / PhantomJS驱动程序;它比Selenium更快,比capybara-webkit提供更好的错误,并且易于设置。)奖励:您可以在需要Java的测试中完成操作,并且将对包括Javascript在内的整个堆栈进行冒烟测试。 编写您的测试,以便他们不需要自己进行清理或以生产数据库中安全的方式进行清理。他们不能使用DatabaseCleaner。 (为防止发生意外,请使用不包含DatabaseCleaner的Gemfile将测试放入其自己的项目中。)由于冒烟测试将针对远程服务器运行,因此无法使用事务来清除任何一个,因此它们必须不要修改数据库,或者必须专门删除它们创建的对象。 设置
Capybara.app_host = \"http://your-server.yourco.com\"
设置为ѭ5(不是必需的,但是没有必要运行您不会使用的本地服务器) 如果您的测试修改了数据库,请将您的测试数据库环境设置为您要进行冒烟测试的环境。 部署和测试。     
简单打败应用程序以查看其是否崩溃的一种方法是,从生产Web服务器日志文件中获取GET请求列表,并将这些请求馈送到
curl
wget
之类的程序中,这些程序将尽快将其全部提取。 这是一个简单的示例:
#!/usr/bin/env ruby
# rerun

require \'uri\'

def extract_from_log(base_uri, log_path)
  File.open(log_path) do |log|
    while (line = log.gets)
      if (line.match(%r{\"GET (/\\S+) HTTP/\\d\\.\\d\"}))
        uri = URI.join(base_uri, $1)
        puts uri.to_s
      end
    end
  end
end

base_uri, log_path = ARGV

if (base_uri and log_path)
  extract_from_log(ARGV[0], ARGV[1])
else
  puts \"Usage: #{File.basename($0)} <base_uri> <log_path>\"
  exit(-1)
end
给定一个标准的Web日志文件,其中的行与ѭ9匹配,您可以轻松提取路径,但是必须提供基本URI:
rerun http://example.com/ example.log
这将列出在该日志文件中找到的所有URL。您可以将其通过管道传递到
wget
以进行获取:
rerun http://example.com/ example.log | wget -i -
如果您有任何问题,将开始在应用程序中遇到错误,并且使用适当的通知系统,您将能够发现并跟踪它们。     

要回复问题请先登录注册