我正在编写一个与Rails集成的gem,我希望能够在我的gem的测试套件中使用rspec测试一个虚拟应用程序。当我测试我的虚拟rails应用程序是否通过加载/几个模块时,问题出现了rspec规范/integration/rails/load_path_spec.rb到目前为止,这是我所拥有的:#spec/support/rails_app/config/environment.rb#LoadtheRailsapplication.requireFile.expand_path('../application',__FILE__)#Loadthegemrequire'skinny_con
我正在测试一些Ruby代码并且有一个失败的Test::Unit::TestCase。不幸的是,失败报告只给我最上面的错误,而不是完整的堆栈跟踪。具体来说,它说:1)Failure:test_tp_make(TestScripts::TestTpMake)[test/test_scripts.rb:73]:Exceptionraised:>.引用的行号(73)是我的测试用例中assert_nothing_raised代码块的开始,它又开始了另一个代码块,该代码块又调用了一个大型库。我已经尝试使用--verbose标志运行测试,不幸的是这不会改变异常输出。我尝试查阅Test::Unit文档
我正在使用seeds.rb填充一些状态模型引用数据:State.create:name=>'Alabama',:abbreviation=>'AL'State.create:name=>'Alaska',:abbreviation=>'AK'#...虽然我没有使用状态固定装置(因为它是种子数据,我认为纯粹为了测试而复制它不会是DRY),Rails测试框架似乎删除了所有状态种子数据测试。(我正在删除、重新创建、迁移和重新播种测试数据库,并在单元测试运行之前确认数据在那里。)结果是此断言在seeds.rb中成功但在单行测试中失败:assert_equal51,State.all.size1
我正在尝试使用Rack::Test为我的Sinatra应用程序编写RSpec测试。我不明白如何使用cookie。例如,如果我的应用程序设置了cookie(不是通过:session),我如何检查该cookie是否设置正确?另外,我如何使用该cookie发送请求? 最佳答案 Rack::Test保留一个cookiejar,该cookiejar在请求期间持续存在。您可以使用rack_mock_session.cookies访问它。假设您有这样的处理程序:get'/cookie/set'doresponse.set_cookie"foo",
我最近尝试使用这个工具来提高我的Rails技能:http://github.com/edgecase/ruby_koans但我无法通过一些测试。此外,我不确定我是否正确地做了一些事情,因为目标只是通过测试,有很多方法可以通过它,我可能正在做一些不符合标准的事情。有没有办法确认我做的事情是否正确?具体例子:在about_nil中,deftest_nil_is_an_objectassert_equal__,nil.is_a?(Object),"UnlikeNULLinotherlanguages"end它是告诉我检查第二个子句是否等于一个对象(所以我可以说nil是一个对象)或者只是把as
我对RubyonRails中的各种测试设备的用途感到困惑。我已经使用该框架大约6个月了,但我从未理解它的测试部分。我使用过的唯一测试是Java中的JUnit3,而且只是简短的。我读过的关于它的一切都只是显示了测试验证。rails中的验证不应该起作用吗?看起来更像是测试框架而不是测试您的代码。为什么需要测试验证?此外,测试对于代码中的任何更改似乎都非常脆弱。因此,如果您更改模型中的任何内容,则必须更改测试和装置以匹配。这不是违反了DRY原则吗?第三,编写测试代码似乎需要很多时间。这是正常的吗?刷新我的浏览器并查看它是否有效不是更快吗?我已经不得不使用我的应用程序来查看它是否正确流动并确保
我正在测试lib/pdf_helper.rb。所以我创建了spec/lib目录。然后我在spec/lib目录中创建一个文件pdf_helper_spec.rb。当我测试pdf文件夹应该在public文件夹中时,这是我的代码require'spec_helper'require'pdf_helper'describe"Pdfhelpers"doit"Shouldbeinpublicfolder"dofile=File.new("#{Rails.root}/public/pdf")ifFile.exist?(file)=='true'puts"Success"elseputs"failed
很多时候,人们编写的测试在弄乱状态时不会自行清理。通常这无关紧要,因为对于大多数测试而言,对象往往会被拆除并重新创建,但在某些不幸的情况下,对象的全局状态会在整个测试运行期间持续存在,并且当您运行测试时,这取决于和修改那个全局状态,按照某种顺序,他们失败了。这些测试和可能的实现显然需要修复,但是当相互影响的测试可能不是完整测试套件中唯一的东西时,试图找出导致失败的原因是一件痛苦的事情。当最初不清楚故障是否与顺序相关,并且可能间歇性地或在一台机器上而不是另一台机器上失败时,这尤其困难。例如:rspectest1_spec.rbtest2_spec.rb#failuresintest2rs
我正在编写一个sinatra应用程序并使用rspec和rack/test对其进行测试(如sinatrarb.com上所述)。到目前为止它一直很棒,直到我将一些相当程序化的代码从我的域对象移动到sinatra助手。从那时起,我就一直在尝试弄清楚如何单独测试这些? 最佳答案 我通过将辅助方法放在它自己的模块中来单独测试我的sinatra辅助方法。由于我的sinatra应用程序比通常的helloworld示例稍大,我需要将它分成更小的部分。通用助手模块非常适合我的用例。如果您编写了一个快速演示,并且在helpers{...}block中定
我想在我的开发环境中进行单元测试输出颜色。但是,我无法让它在Linux(Debian和Ubuntu)上运行。当我包含以下库时:require'minitest/autorun'require'minitest/unit'require'minitest/pride'我得到:/usr/local/rvm/gems/ruby-1.9.2-p136/gems/minitest-2.3.1/lib/minitest/pride.rb:35:in`':undefinedmethod`output'forMiniTest::Unit:Class(NoMethodError)由代码引起:MiniTe