我通过创建一个扩展到库类的子类来扩展现有的库。在子类中,我能够测试initialize方法中的大部分功能,但无法模拟super调用。子类如下所示。classChild如何编写rspec测试(使用mocha)以便我可以模拟super调用?请注意,我正在测试Child类中的initialize方法的功能。当提供额外参数时,我是否必须创建不调用super的单独代码路径? 最佳答案 你不能模拟super,你也不应该。当您模拟某些内容时,您正在验证是否收到了特定消息,而super不是一条消息——它是一个关键字。相反,弄清楚如果缺少super调
我正在尝试使用webmock模拟WebAPI的意外行为,例如未找到服务器和超时。执行此操作的最佳方法是什么?我能想到的就是做这样的事情:stubbed_request=stub_request(:get,"#{host}/api/something.json").with(:headers=>{'Accept'=>'*/*','Content-Type'=>'application/json','User-Agent'=>'Ruby'}).to_return(:status=>[500,"InternalServerError"])这应该适用于404等问题,但我如何测试超时、未找到服务
知道模拟%[]的方法吗?我正在为进行一些系统调用的代码编写测试,例如:deflog(file)%x[gitlog#{file}]end并希望在测试此方法时避免实际执行系统调用。理想情况下,我想模拟%x[..]并断言已将正确的shell命令传递给它。 最佳答案 %x{…}是Ruby内置的语法,它实际上会调用内核方法Backtick(`).所以你可以重新定义那个方法。由于反引号方法返回在子shell中运行cmd的标准输出,您重新定义的方法应该返回类似的东西,例如,一个字符串。moduleKerneldef`(cmd)"call#{cmd
如何在ruby中模拟类Java注解?(好吧,我有答案了,概括一下http://bens.me.uk/2009/java-style-annotations-in-ruby) 最佳答案 本文改编自apieceofcodeIwroteinananswertoanotherquestion几个星期前,虽然它当然不是原创的。这是一个著名的Ruby习语,毕竟它已经使用了很多年,至少从rakes的desc方法开始.moduleAnnotationsdefannotations(meth=nil)return@__annotations__[me
我整理了一个简单的例子,试图使用一个基本的例子来证明Rails中的并发请求。请注意,我使用的是MRIRuby2和Rails4.2。defapi_callsleep(10)render:json=>"done"end然后我在我的Mac(I7/4Core)上的Chrome中访问4个不同的选项卡,看看它们是串行还是并行运行(真正并发,这很接近但不是一回事)。即,http://localhost:3000/api_call我无法使用Puma、Thin或Unicorn使其工作。每个请求都是连续出现的。10秒后的第一个标签,20秒后的第二个(因为它必须等待第一个完成),之后的第三个......根据
我们有一个异步任务,它为一个对象执行一个可能长时间运行的计算。然后将结果缓存在对象上。为了防止多个任务重复相同的工作,我们添加了带有原子SQL更新的锁定:UPDATEobjectsSETlocked=1WHEREid=1234ANDlocked=0加锁只针对异步任务。对象本身仍可由用户更新。如果发生这种情况,旧版本对象的任何未完成任务都应丢弃其结果,因为它们可能已过时。使用原子SQL更新也很容易做到这一点:UPDATEobjectsSETresults='...'WHEREid=1234ANDversion=1如果对象已更新,其版本将不匹配,因此结果将被丢弃。这两个原子更新应该处理任何
我真的不明白什么是Mocks和Stubs。我想知道我们何时、为何以及如何在我们的测试用例中使用模拟。我知道RubyonRails中的Mocks和Stubs有很好的框架,但不知道用途,我不愿意在我的应用程序中使用它们。你能澄清一下模拟和stub吗?请帮忙。 最佳答案 我非常简单的回答是:mocks是与其他对象具有相似接口(interface)的对象stubs是虚假的方法并返回特定的答案我们都在尝试实现相同的目标:我们想单独测试特定单元(模型/View/Controller/模块)。例如。当我们测试Controller时,我们不想测试我
我有一个模型Lead和一个回调:after_commit:create,:send_to_SPL我正在使用Rails-4.1.0、ruby-2.1.1、RSpec。1)此规范未通过:context'callbacks'doit'shallcall\'send_to_SPL\'aftercreate'doexpect(lead).toreceive(:send_to_SPL)lead=Lead.create(init_hash)plead.new_record?#=>falseendend2)这个规范也没有通过:context'callbacks'doit'shallcall\'send
我们的电子商务网站存在一个问题,即用户偶尔会点击两次“结帐”并从他们的卡中扣款两次。这是一个非常常见的错误并且很容易修复,但我想在我们的capybara设置中测试该解决方案。一旦我调用了click_button('checkout'),我是否可以假装我是一个点击浏览器后退按钮的用户,然后第二次调用click_button('checkout')? 最佳答案 你可能想试试:When(/^Igoback$/)dopage.evaluate_script('window.history.back()')end这将需要在支持javascri
关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。关闭2年前。Improvethisquestion我注意到很多人更喜欢Mocha而不是RSpec的内置模拟框架。有人可以解释Mocha或任何替代方案相对于内置模拟框架的RSpec的优势吗?