5

我正在尝试配置自动测试,以便当我运行我的测试套件并且我的测试失败时,自动测试会停止测试并等待我在再次测试之前进行更改。使用我当前的配置,自动测试在遇到失败的测试时会继续进行不确定的测试,这使得处理起来有点麻烦(每次测试失败时都必须进入终端并停止自动测试服务器)。

我正在使用 RSpec、Zentest 和 Spork 开发 Rails 应用程序。

相关宝石版本:

autotest (4.4.6)
rspec (2.6.0)
rspec-core (2.6.4)
rspec-expectations (2.6.0)
rspec-mocks (2.6.0)
rspec-rails (2.6.1)
spork (0.9.0.rc8)
ZenTest (4.5.0)

我的 .autotest 文件:

module Autotest::Notify
  def self.notify title, msg, img, pri='low', time=3000
    `notify-send -i #{img} -u #{pri} -t #{time} '#{msg}'`
  end

  Autotest.add_hook :ran_command do |autotest|
    results = [autotest.results].flatten.join("\n")
    output = results.slice(/(\d+)\s+examples?,\s*(\d+)\s+failures?(,\s*(\d+)\s+pending)?/)
    folder = "~/.autotest_icons/"
    if output  =~ /[1-9]\d*\sfailures?/
      notify "FAIL:", "#{output}", folder+"failed.png", 'critical', 10000
    elsif output  =~ /[1-9]\d*\spending?/
      notify "PENDING:", "#{output}", folder+"pending.png", 'normal', 10000
    else
      notify "PASS:", "#{output}", folder+"passed.png"
    end
  end
end

注意:我的大部分 .autotest 文件都是为了让弹出窗口在 linux 中工作,以显示我的测试是通过还是失败。

我一直在寻找这个问题的答案,但没有运气,我发现很难获得一些好的 Autotest 文档。我已经盯着 Zentest 的RDoc看了很长一段时间了,我一定是错过了一些东西。

任何帮助、示例链接等,将不胜感激。

4

2 回答 2

4

我遇到了同样的问题,发现我的开发服务器正在写入日志文件。在我将它添加到我的 .autotest 文件后,问题就消失了:

Autotest.add_hook :initialize do |at|
  at.add_exception(%r{^\./\.git})
  at.add_exception(%r{^\./log})
end
于 2011-09-24T22:36:46.207 回答
1

当我有一个正在将数据写入 ZenTest 正在监视的目录的 gem 时,我在 ZenTest 中看到了类似的问题。IIRC,它是一个进行全文搜索的 gem——搜索生成的索引文件触发 ZenTest 再次运行,从而重新生成索引。

我通过修改 Growl 通知来跟踪问题,告诉我哪些文件正在触发自动测试运行(当时我在 Mac 上运行)。

解决方案是向 .autotest 文件添加异常/排除,告诉它忽略索引。

(我刚刚看到:Spork 在自动测试中反复重新运行失败的测试,这听起来与您的问题非常相似)

于 2011-07-13T10:49:09.963 回答