草庐IT

unit-testing

全部标签

ruby-on-rails - Rails - 使用功能测试测试 JSON API

我只是有一个简单的问题,但我找不到任何答案。我的ruby​​onrails3.2.2应用程序有一个带有设计session身份验证的JSONAPI。我的问题是:如何使用功能或集成测试来测试此API-是否有处理session的方法?我没有前端,只有一个可以执行GET操作的API。邮政。放。并使用JSON正文删除。哪个是测试此自动化的最佳方法?示例创建新用户发布www.exmaple.com/users{"user":{"email":"test@example.com","password":"mypass"}} 最佳答案 功能测试很容

Ruby:在代码中使用 rand() 但编写测试来验证概率

我有一些代码可以根据加权随机数提供内容。权重越大的东西越有可能被随机选择。现在作为一名优秀的ruby​​ist,我当然想用测试覆盖所有这些代码。我想测试是否根据正确的概率获取了东西。那么我该如何测试呢?为应该是随机的东西创建测试使得很难比较实际与预期。我有一些想法,以及为什么它们不会很好地工作:在我的测试中stubKernel.rand以返回固定值。这很酷,但是rand()被调用了多次,我不确定我是否可以通过足够的控制来装备它来测试我需要的东西。多次获取随机项目,并将实际比率与预期比率进行比较。但除非我可以无限次地运行它,否则这永远不会完美,并且如果我在RNG中运气不佳,可能会间歇性地

ruby - 如何测试其中包含 gets.chomp 的函数?

我有一个像这样使用gets.chomp的简单函数:defwelcome_userputs"Welcome!Whatwouldyouliketodo?"action=gets.chompend我想使用ruby内置的TestCase套件来测试它,如下所示:classViewTest问题是,当我运行那个测试时,gets.chomp停止了测试,因为它需要用户输入一些东西。有没有一种方法可以仅使用ruby来模拟用户输入? 最佳答案 您可以创建一个pipe并将其“读取端”分配给$stdin。写入管道的“写入端”然后模拟用户输入。下面是一个使用小

ruby-on-rails - 错误 : Command 'test' not recognized

我在Rails服务器中使用c9.io进行开发。我执行railstest并且它可以正常工作。第二天,我执行相同的命令,但出现错误:无法识别命令“测试”我没有做任何更改。我怎样才能恢复这个命令?注意:rake测试完美运行,但ruby​​页面http://edgeguides.rubyonrails.org/testing.html和ruby​​onrails教程,MichaelHartlhttps://www.railstutorial.org/book/static_pages谈论railstest命令,它对我有用2天。这是我的gem文件source'https://rubygems.o

ruby - Selenium RC :How to launch Interactive testing with Multiple browsers

我想自动化这个场景。用户A将一个项目分配给用户B,用户B收到一条警告消息。为此,我想用不同的帐户启动两个不同的浏览器来测试这种交互。有可能这样做吗?如果是,如何? 最佳答案 看起来这个问题已经在我的示例代码中得到了回答:http://stackoverflow.com/questions/213430/selenium-rc-run-tests-in-multiple-browsers-automatically。firefox=Selenium::SeleniumDriver.new("localhost",4444,'*fire

ruby-on-rails - RSpec::Mocks::ExampleMethods 的未定义方法 instance_double

我有一个这样的测试用例:describeWorkCardsControllerdoit"something"dowork_card=instance_double(WorkCard,{:started?=>true})#somemorecodeendend当我运行RSpec时,出现错误:undefinedmethod'instance_double'for#根据http://rubydoc.info/github/rspec/rspec-mocks/RSpec/Mocks/ExampleMethods这种方法存在。所以我尝试通过以下方式直接访问它:describeWorkCardsCo

ruby-on-rails - 何时以及何时不 stub /模拟测试

我正在齐心协力围绕Rspec进行研究,以便转向更多的TDD/BDD开发模式。但是,我还有很长的路要走,并且在一些基础知识上苦苦挣扎:比如,我究竟什么时候应该使用模拟/stub,什么时候不应该?以这种情况为例:我有一个Site模型has_many:blogs和Blog模型has_many:articles。在我的Site模型中,我有一个回调过滤器,它为每个新站点创建一组默认的博客和文章。我想测试该代码,所以这里是:describeSite,"whencreated"doincludeSiteSpecHelperbefore(:each)do@site=Site.createvalid_s

ruby-on-rails - Selenium RC : Run tests in multiple browsers automatically

所以,我已经开始创建一些使用SeleniumRC的Ruby单元测试。直接在浏览器中测试我的网络应用程序。我正在使用Selenum-Client对于ruby。我已经为所有其他selenium测试创建了一个基类来继承。这会创建许多SeleniumDriver实例,并且会在每个实例上调用所有缺少的方法。这实质上是并行运行测试。其他人是如何实现自动化的?这是我的实现:classSeleniumTest这行得通,但如果一个浏览器失败,整个测试就会失败,并且无法知道它在哪个浏览器上失败。 最佳答案 你试过了吗SeleniumGrid?我认为它创

ruby - 我如何获得 RSpec 的共享示例,例如 Ruby Test::Unit 中的行为?

在RSpecforTest::Unittests中是否有类似于shared_examples的插件/扩展? 最佳答案 如果您正在使用rails(或只是active_support),请使用Concern.require'active_support/concern'moduleSharedTestsextendActiveSupport::Concernincludeddo#Thisway,testnamecanbeastring:)test'bananabananabanana'doasserttrueendendend如果您不使

ruby - 在没有 Rails 的情况下使用 RSpec 加载 ActiveRecord fixtures

我正在Rails之外使用一些ActiveRecord模型,我正在为其编写单元测试。在我的测试中,我希望能够使用固定装置并认为我会使用一些rspec-rails为此的功能。我不能简单地使用require"rspec-rails"因为它有一些Rails依赖项而且我没有使用Rails。这是我正在使用的spec_helper:require'active_record'require'active_record/fixtures'require'active_support'require'rspec/rails/extensions/active_record/base'require'rs