草庐IT

ruby-on-rails - 如何避免 rspec 中的长堆栈跟踪

是否可以简单地将堆栈跟踪限制为应用程序中的文件?长堆栈跟踪很困惑,大多数错误直接出现在应用程序中。 最佳答案 通常情况下,堆栈跟踪会自动缩短,除非您在.rspec文件中指定选项--backtrace。也许thisquestion对你有帮助。他们试图达到相反的目的,但它表明您可以Hook并否决它。 关于ruby-on-rails-如何避免rspec中的长堆栈跟踪,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.

ruby - 如何比较 RSpec 中的两个哈希值?

我有两个散列h1和h2我想在RSpec中进行比较。我想检查h1的元素在一些转换后是否与h2相同,我们称之为f。也就是说,我想验证对于h1中的每个键k,h1[k]==f(h2[k])。例如,如果h2中的所有值都是h1中相应值的两倍,那么我想检查每个键k在h1中,h2[k]==h1[k]*2。在RSpec中执行此操作的正确方法是什么?目前我这样做:h1=...expect(h2.all?{|k,v|v==f(h1[k])}).tobetrue但这看起来很笨重。 最佳答案 听起来您正在测试的是转换。我会考虑写这样的东西:it"transf

ruby-on-rails - 在 rails 3.1 中运行 rspec 测试时如何抑制/禁用 "cache miss"消息

在运行请求rspec规范时,我开始看到以下输出:cache:[GET/login]misscache:[GET/javascripts/jquery.min.js?1317513028]miss通常情况下,通过测试我会得到绿点,在错误消息中我会得到带有一些信息的红色F。有没有办法从输出中禁用缓存未命中消息? 最佳答案 我认为这与rspec无关,rspec只是打印出rails日志中的内容。我觉得这个postbyBrianWeaver在PhusionPassenger讨论组中可能会回答您的问题:Doyouhaverack-cachein

ruby-on-rails - 配置 rspec-rails 生成器

我想配置rpsec-rails生成器,这样我就可以禁用View和Controller测试,或者用工厂手动替换固定装置。我阅读了文档、博客文章并在rspecIRCchannel上提问,但没有找到好的答案。假设我想禁用View规范。我应该做类似的事情:config.generatorsdo|g|g.test_framework:rspec,views:falseend我的问题是在哪里可以找到所有可用选项的列表,例如“View”? 最佳答案 这是我所知道的Rspec的所有选项的列表:config.generatorsdo|generate

ruby-on-rails - 将录像带存储在存储库中是否正确?

我为一个RESTapi开发了一个Ruby接口(interface)。我使用rspec和vcr进行测试。所有测试都使用专门为其创建的帐户凭据。我无法决定:将我的测试(录像带)的缓存响应存储在存储库,或允许用户和订阅者编写自己的磁带?以皇帝之名!让圣战开始吧! 最佳答案 VCR的盒式磁带是您测试的固定装置。您确实需要将它们提交到存储库中,否则您的测试将无法在其他机器上正确运行,或者只能在严重外部依赖性的情况下进行更正,这违反了测试原则。当然,您需要在保留上述内容的同时向公众或团队隐藏您的凭据。解决方案是filter_senstive_d

ruby - RSpec 的 before、after 和 around 钩子(Hook)以什么顺序运行?

当我面对someissue我决定检查before和afterHook的执行顺序。这就是我所做的:require"spec_helper"describe"Theorder:"dobefore(:all){puts"before_all"}after(:all){puts"after_all"}before(:each){puts"before_each"}after(:each){puts"after_each"}describe"DESCA"dobefore{puts"A_before"}it"A_it_1"doexpect(1).toeq(1)endit"A_it_2"doexpe

ruby-on-rails - 在 rspec 中 stub 未实现的方法

我正在测试我的模块,我决定用匿名类来测试它:subject(:klass){Class.new{includeMyModule}}MyModule使用klass中的方法name。为了让我的规范工作,我需要stub这个方法name(未实现)。所以我写道:subject{klass.new}allow(subject).toreceive(:name).and_return('SOreadytohelp')}但它引发了:RSpec::Mocks::MockExpectationError:#:0x007feb67c7adf8>doesnotimplement:namefromspec-su

ruby-on-rails - 测试速度 : ActiveRecord use_transactional_fixtures vs. DatabaseCleaner.strategy = :transaction

从来源(database_cleaner,active_record)来看,它们应该同样快。但是有人声称使用database_cleaner的事务策略会降低Controller和模型规范的速度(forexample)。我手头没有用于基准测试的大型测试套件。任何人有任何见解或比较两者? 最佳答案 我花了一点时间在广泛使用ActiveRecord固定装置的中型代码库上比较两者。当我将其切换为使用DatabaseCleaner而不是use_transactional_fixtures时,模型规范开始花费大约两倍的时间。在进行了与您相同的比

ruby-on-rails - 如何在 Factory Girl 或 Minifacture 中使用随机唯一数据制作 Ruby 测试工厂?

我正在用一个典型的工厂测试一个典型的Rails模型:#Mymodelusesa3-letteruppercaseairportcode,#suchas"ATL"forAtlanta,"BOS"forBoston,etc.classAirport我正在添加更多测试并开始看到机场代码中的冲突:例如,工厂创建了一个代码为“XYZ”的机场,然后对工厂的后续调用尝试创建一个具有相同代码的机场。序列是解决这个问题的一种方法。例如,使用FactoryGirl序列、有序列表或预先计算的枚举,以及维护下一个可用代码状态的类似方法。我的问题是:解决这个问题的非序列方法是什么?我想使用随机数据,不是序列。我

ruby-on-rails - assign 在 rspec-rails 中做什么?

我正在处理我尚未编写的代码,并试图了解RSpec的工作原理。let(:course){create:new_course}before{assign:course,course}我知道let创建了一个内存变量。在此示例中,assign做了什么? 最佳答案 您一定是在查看View规范。在rspec-railsView规范中,assign将其第二个参数分配给第一个参数命名的模板实例变量。在您的示例中,assign:course,course将模板中的@course设置为course的值。更多信息:https://www.relishap