test_should_do_something_really_s
全部标签 我正在尝试测试以下方法:defunprocess_move(board,move)ifmove[0].instance_of?(Array)multi_move=@multi_move.pop(2).reversemulti_move.eachdo|single_move|unapply_move(board,single_move)endelseboard=unapply_move(board,move)endboardend我想为@multi_move设置状态,但我不想添加仅用于测试的访问器。有没有办法在没有访问器的情况下这样做?谢谢。 最佳答案
我在使用Rails4并注意到我的一些RSpec测试失败了,因为我的一些测试重构使用了前置过滤器(大概是因为事务)。这篇文章描述了一个类似的问题:railstestdatabasenotclearingaftersomeruns代替使用DatabaseCleanergem,是否有清除测试数据库的rake命令?我相信rakedb:test:prepare在Rails4中被弃用了。此外,如果在交易之前,如`post:create,user:Fabricate.attributes_for(:user)`是持久性的,是否有另一种重构方式来避免手动清除测试数据库的需要?
我正在编写一个模型来处理来自文本区域的用户输入。遵循http://blog.caboo.se/articles/2008/8/25/sanitize-your-users-html-input的建议,我在保存到数据库之前清理模型中的输入,使用before_validate回调。我模型的相关部分如下所示:includeActionView::Helpers::SanitizeHelperclassPost%w(biu))endend不用说,这是行不通的。当我尝试保存新帖子时出现以下错误。undefinedmethod`white_list_sanitizer'for#显然,Sanitiz
我想像这样将一位数转换为两位数:9==>095==>0512==124==>04我认为我可以放置一堆if-else语句(如果数字小于10,则执行gsub)但我认为那是可怕的编码。我知道Rails有number_with_precision但我发现它只适用于十进制数。关于如何将个位数转换为两位数有什么想法吗? 最佳答案 很多人使用sprintf(这是正确的做法),我认为如果你想对字符串执行此操作,最好保留注意rjust和ljust方法:"4".rjust(2,'0')这将使“4”右对齐,方法是确保它至少有2个字符长,并用“0”填充它。
ruby新手,戴上你的新手手套。以下两个片段之间是否有任何区别(模糊或实用)?my_array=[:uno,:dos,:tres]my_array.each{|item|putsitem}my_array=[:uno,:dos,:tres]my_array.eachdo|item|putsitemend我知道大括号语法可以让你把block放在一行上my_array.each{|item|putsitem}但除此之外,是否有任何令人信服的理由来使用一种语法而不是另一种语法? 最佳答案 Rubycookbook表示括号语法的优先顺序高于
背景:我在使用Thoughtbot的“工厂女孩”gem时遇到了一些问题,该gem用于创建要在单元测试和其他测试中使用的对象。我想转到控制台并运行不同的FactoryGirl调用以检查发生了什么。例如,我想去那里做...>>Factory(:user).inspect我知道您可以在不同的环境中运行控制台...$脚本/控制台RAILS_ENV=test但是当我这样做时,工厂类不可用。看起来好像test_helper.rb没有加载。我尝试了各种require调用,包括一个带有到test_helper.rb的绝对路径的调用,但它们的失败与此类似:$script/consoleRAILS_ENV
我正在观看Rails教程视频,但我无法弄清楚db:test:prepare命令的实际作用。有人可以提供解释吗? 最佳答案 Therakedb:migrateaboverunsanypendingmigrationsonthedevelopmentenvironmentandupdatesdb/schema.rb.Therakedb:test:loadrecreatesthetestdatabasefromthecurrentdb/schema.rb.Onsubsequentattempts,itisagoodideatofirstr
我有一个同事积极地试图说服我不应该使用do..end而是使用花括号在Ruby中定义多行block。我坚定地坚持只对短的单行代码使用大括号,对其他一切都使用do..end。但我想我会接触更大的社区以获得一些解决方案。那么它是什么,为什么?(一些shoulda代码的例子)contextdosetup{do_some_setup()}should"dosomthing"do#somemorecode...endend或context{setup{do_some_setup()}should("dosomthing"){#somemorecode...}}就我个人而言,仅看上面的内容就可以回答
我想做这样的事情:some_method.should_raise我应该怎么做?some_method.should_raiseexception...不起作用。 最佳答案 expect{some_method}.toraise_errorRSpec1语法:lambda{some_method}.shouldraise_error参见thedocumentation(对于RSpec1语法)和RSpec2documentation了解更多。 关于ruby-on-rails-如何在任何异常情
我经常想比较数组并确保它们以任何顺序包含相同的元素。在RSpec中有一种简洁的方法可以做到这一点吗?以下是NotAcceptable方法:#to_set例如:expect(array.to_set).toeqanother_array.to_set或array.to_set.should==another_array.to_set当数组包含重复项时,这将失败。#sort例如:expect(array.sort).toeqanother_array.sort或array.sort.should==another_array.sort当数组元素没有实现#时失败