【问题标题】:rake test:units fails with status ()rake 测试:单元失败并显示状态()
【发布时间】:2010-04-18 17:14:04
【问题描述】:

新用户,我一直没有构建测试,所以我是个白痴。

应用程序正在运行,但测试失败。以下是似乎相关的内容:

.

...

** Execute test:units
/usr/local/bin/ruby -I"lib:test" "/usr/local/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake/rake_test_loader.rb" "test/unit/event_test.rb" "test/unit/helpers/calendar1_helper_test.rb" "test/unit/helpers/events_helper_test.rb" "test/unit/helpers/homepage_helper_test.rb" "test/unit/helpers/main_helper_test.rb" "test/unit/helpers/mobile_helper_test.rb" "test/unit/helpers/notes_helper_test.rb" "test/unit/helpers/password_resets_helper_test.rb" "test/unit/helpers/projects_helper_test.rb" "test/unit/helpers/search_helper_test.rb" "test/unit/helpers/start_helper_test.rb" "test/unit/helpers/superadmin_helper_test.rb" "test/unit/helpers/tasks_helper_test.rb" "test/unit/helpers/user_sessions_helper_test.rb" "test/unit/helpers/users_helper_test.rb" "test/unit/note_test.rb" "test/unit/notifier_test.rb" "test/unit/project_test.rb" "test/unit/task_test.rb" "test/unit/user_session_test.rb" "test/unit/user_test.rb" 
/usr/lib/ruby/gems/1.8/gems/rails-2.3.5/lib/rails/gem_dependency.rb:119:Warning: Gem::Dependency#version_requirements is deprecated and will be removed on or after August 2010.  Use #requirement
/usr/lib/ruby/gems/1.8/gems/hpricot-0.6.164/lib/universal-java1.6/fast_xs.bundle: [BUG] Segmentation fault
ruby 1.8.7 (2009-06-12 patchlevel 174) [i686-darwin10.2.0]

rake aborted!
Command failed with status (): [/usr/local/bin/ruby -I"lib:test" "/usr/loc...]
/usr/local/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:995:in `sh'
/usr/local/lib/ruby/gems/1.8/gems/rake-0.8.7/lib/rake.rb:1010:in `call'

【问题讨论】:

  • 任何人对错误所在的任何想法?提前致谢。

标签: ruby-on-rails rake testing


【解决方案1】:

Rake 未能报告其运行测试的子进程被信号杀死的事实。

rake aborted! Command failed with status ():

注意 () 之间缺少的退出代码。您可以通过运行“strace -o rake.strace rake”来发现信号,并在结果文件的末尾附近查看类似的内容

[{WIFSIGNALED(s) && WTERMSIG(s) == SIGVTALRM}], 0, NULL)

在我的情况下,这是(现在可能是臭名昭著的)mysql 2.8.1 gem 在 ruby​​-1.8.6 的较新补丁级别下运行时失败并出现“虚拟计时器已过期”(-p399 已损坏,不确定哪个较旧版本仍然有效)。

[哎呀,忘记修复了]

接下来的步骤...

  • 在 rake 之外或在 strace 下运行该进程,以找出信号是什么
  • 假设是 mysql 2.8.1 / Ruby 1.8.6-p399 问题并降级到 mysql '~>2.7.0' 或更早的 Ruby 1.8.6 补丁级别,或者升级到 Ruby 1.8.7

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2012-12-09
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-07-29
    • 2016-09-05
    相关资源
    最近更新 更多