2011-10-10 28 views
0

我是ruby/rails中的新手,目前做railstutorial作为大学课程的一部分。 我使用的是Ubuntu 11.04,ruby 1.9.2p290和Rails 3.0.9,watchr(0.7),rspec(2.6.0),rspec-formatter-webkit(2.1.3)和spork(0.9.0.rc) 。Ruby/Rails使用通知和html输出进行连续自动化测试?

在github上,我碰到了this宝石,我认为这将是非常好的使用它。 所以基本上我试图实现的是 连续自动测试与通知如果完成,并且也生成它的好html输出。

所以我试过的是,我写这个剧本watchr:

require 'nokogiri' 
require 'open-uri' 

watch("spec/.*/*_spec.rb") do |match| 
    run_spec match[0] 
end 

watch("app/(.*/.*).rb") do |match| 
    run_spec %{spec/#{match[1]}_spec.rb} 
end 

def run_spec(file) 
    unless File.exist?(file) 
    puts "#{file} does not exist" 
    return 
    end 

puts "Running #{file}" 
result = `rspec -r rspec/core/formatters/webkit -f RSpec::Core::Formatters::WebKit #{file}` 
File.open('out.html', 'w') do |f| 
    f.puts result 
end 
notify(result) 
puts "DONE" 
end 

def send_notify title, msg, img, pri='low', time=5000 
    `notify-send -i #{img} -u #{pri} -t #{time} '#{msg}'` 
end 

def notify(result) 
    output = result 
    doc = Nokogiri::HTML(result) 
    doc.xpath('//div[@id = "summary"]').each do |node| 
    output = node.text.split.join(" ") 
    end 
    folder = "~/Pictures/autotest/" 
    if output =~ /([123456789]|[\d]{2,})\sfailed/ 
    send_notify "FAIL:", "#{output}", folder+"rails_fail.png", 'critical', 20000 
    elsif output =~ /[1-9]\d*\spending?/ 
    send_notify "PENDING:", "#{output}", folder+"rails_pending.png", 'normal', 15000 
    else 
    send_notify "PASS:", "#{output}", folder+"rails_ok.png" 
    end 
end 

处理通知,并生成测试时的输出。

如果我用watchr运行这个,一切都很好,而且工作,但是测试需要很长时间。

,问题就来这里:如果我尝试用叉勺,以加速测试时,我收到了一堆错误,开始用LoadError:

Exception encountered: #<LoadError: no such file to load -- rspec/core/formatters/webkit> 
backtrace: 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/activesupport-3.0.9/lib/active_support/dependencies.rb:239:in `require' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/activesupport-3.0.9/lib/active_support/dependencies.rb:239:in `block in require' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/activesupport-3.0.9/lib/active_support/dependencies.rb:225:in `block in load_dependency' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/activesupport-3.0.9/lib/active_support/dependencies.rb:596:in `new_constants_in' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/activesupport-3.0.9/lib/active_support/dependencies.rb:225:in `load_dependency' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/activesupport-3.0.9/lib/active_support/dependencies.rb:239:in `require' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/rspec-core-2.6.4/lib/rspec/core/configuration.rb:247:in `block in requires=' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/rspec-core-2.6.4/lib/rspec/core/configuration.rb:247:in `map' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/rspec-core-2.6.4/lib/rspec/core/configuration.rb:247:in `requires=' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/rspec-core-2.6.4/lib/rspec/core/configuration_options.rb:21:in `block in configure' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/rspec-core-2.6.4/lib/rspec/core/configuration_options.rb:20:in `each' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/rspec-core-2.6.4/lib/rspec/core/configuration_options.rb:20:in `configure' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/rspec-core-2.6.4/lib/rspec/core/command_line.rb:17:in `run' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/rspec-core-2.6.4/lib/rspec/monkey/spork/test_framework/rspec.rb:5:in `run_tests' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/spork-0.9.0.rc/lib/spork/run_strategy/forking.rb:13:in `block in run' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/spork-0.9.0.rc/lib/spork/forker.rb:21:in `block in initialize' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/spork-0.9.0.rc/lib/spork/forker.rb:18:in `fork' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/spork-0.9.0.rc/lib/spork/forker.rb:18:in `initialize' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/spork-0.9.0.rc/lib/spork/run_strategy/forking.rb:9:in `new' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/spork-0.9.0.rc/lib/spork/run_strategy/forking.rb:9:in `run' 
/usr/local/ruby/lib/ruby/gems/1.9.1/gems/spork-0.9.0.rc/lib/spork/server.rb:47:in `run' 
/usr/local/ruby/lib/ruby/1.9.1/drb/drb.rb:1558:in `perform_without_block' 
/usr/local/ruby/lib/ruby/1.9.1/drb/drb.rb:1518:in `perform' 
/usr/local/ruby/lib/ruby/1.9.1/drb/drb.rb:1592:in `block (2 levels) in main_loop' 
/usr/local/ruby/lib/ruby/1.9.1/drb/drb.rb:1588:in `loop' 
/usr/local/ruby/lib/ruby/1.9.1/drb/drb.rb:1588:in `block in main_loop' 

这当然真的不说任何对我来说,作为一个总新手。

有没有办法克服这种情况(或者以其他方式产生结果)?

任何帮助是极大的赞赏:)

+0

当你在安装这些宝石时,你是否逐步做到了,确保它们中的每一个都按照你的意图工作?我问,因为迹象指向rspec-formatter-webkit。这个宝石有特别的安装说明吗? – Tass

+0

我确实是逐步安装它们,并且所有程序都似乎正常工作。没有关于rsepc-formatter gem的具体说明,只需安装gem。它可以用于textmate方便地使用,但我没有,所以我写了一封信给创建者的宝石,他回答说,我可以用下面的方式:rspec -r rspec/core/formatters/webkit -f RSpec :: Core :: Formatters :: WebKit _file_ – tpv

+0

@Tass:如果它从命令行工作,并从watchr工作,是什么让你说“符号指向rspec-formatter-webkit”?那些是什么迹象? –

回答

0

你可能有更多的运气运行RSpec运行,而不是直接脱壳而出,如

require 'rspec/core' 
require 'rspec/core/formatters/webkit' 

# ...then in #run_spec 
puts "Running #{file}" 
File.open('out.html', 'w') do |f| 
    argv = [ '-f', 'RSpec::Core::Formatters::WebKit', file ] 
    RSpec::Core::Runner.run(argv, f) 
end 
notify(result) 
puts "DONE" 

的猴子的ActiveSupport(自由)-patched“内核。要求“在你提到的三种场景中似乎是不同的。

如果您找出ActiveSupport无法找到库的原因,我很乐意尝试在WebKit格式化程序中解决此问题。

相关问题