性能测试——抗攻击-hyenae-ddos攻击
全部标签 我有一个模型方法,它在执行时返回以下内容。{"data"=>[{"product"=>"PRODUCTA","orders"=>3,"ordered"=>6,"revenue"=>600.0},{"product"=>"PRODUCTB","orders"=>1,"ordered"=>5,"revenue"=>100.0}]}我想测试以确保第一个哈希中的“收入”存在,然后测试该值是否等于600。subject{described_class.order_items_by_revenue}it"includesrevenuekey"doexpect(subject).toinclude(
我有一个Rails项目,我忽略了为其构建测试(很遗憾!),并且代码库已经变得相当大。我的一个friend说RSpec很难用,除非你从一开始就使用它。这是真的?是什么让他这么说?那么,考虑到可用的测试套件和代码库已经存在的事实,让这个东西可测试的最佳行动方案是什么?这真的与从头开始做有很大不同吗? 最佳答案 这个问题cameuprecently在RSpec邮件列表上,我们通常给出的建议是:除非您打算更改它,否则不要费心尝试将规范改造为现有的、有效的代码-这会让人筋疲力尽,而且除非代码需要更改,否则毫无意义。从现在起开始为您所做的任何更
我经常运行各种测试组,例如:raketest:unitsraketest:functionals我也喜欢运行单独的测试文件或单独的测试:ruby-Itesttest/unit/file_test.rbruby-Itesttest/unit/file_test.rb-n'/somecontextImworkingon/'还有:raketestTEST=test/unit/file_test.rb我什至在我的Rakefile中创建了自定义分组:Rake::TestTask.new(:ps3)do|t|t.libs我还没有弄清楚的是如何在命令行运行多个临时测试。换句话说,如何将test_fi
我编写了一个简单的类方法Buy.get_days(string),并尝试使用不同的文本字符串输入对其进行测试。但是我觉得它非常冗长。是否有更简洁的方法来测试以下内容?有没有相当于subjectformethods我可以继续传递输入不同的参数并检查结果?有没有办法避免在每个它处进行不必要的描述?谢谢describeBuydodescribe'.get_days'doit'shouldgetdays'doBuy.get_days('Includesa1-weeknightstayforupto4people').should==1endit'shouldgetdays'doBuy.get_
我想在rspec中测试是否存在提交按钮。我也在用capybara。我试过:shouldhave_tag("input","Submitbutton")和shouldhave_content("Submit,button")但它要么引发异常,要么给出误报。 最佳答案 这些都是很好的建议,但是如果你想确认它是一个按钮并且它有正确的值(用于显示),你必须更详细一点:page.shouldhave_selector("input[type=submit][value='PressMe']")我不知道现有的匹配器可以做到这一点。这是我编写的自
我需要一个工具来测量Ruby下的测试覆盖率。我试过rcov,但无法在Windows、Cygwin或Ubuntu下安装它。哪些程序(不一定免费)计算Ruby测试的分支和/或行覆盖率并与RubyonRails一起工作? 最佳答案 Simplecov.Rcov在Ruby1.9.*下工作得不是很好,但simplecov可以。 关于ruby-on-rails-Ruby测试覆盖率工具,我们在StackOverflow上找到一个类似的问题: https://stackove
我的模型有default_scope(:order=>'created_at')我的测试(rspec、factorygirl、shoulda等)是:require'spec/spec_helper.rb'describeCatMembershipdocontext"isvalid"dosubject{Factory.build(:cat_membership)}it{shouldbe_valid}it{shouldbelong_to:cat}it{shouldbelong_to:cat_group}it{shouldhave_db_column(:start_date)}it{shou
我正在处理的项目有一个相当大的测试套件。我目前正在编写单独运行时通过的测试,但是当我运行整个测试套件$rspec时,我遇到了一些导致测试失败的非常时髦的行为。现在测试是这样嵌套的:spec/folder1/folder2/folder3/test.rb这些命令中的每一个都可以正常运行测试并且一切都通过了:$rspecspec/folder1/folder2/folder3$rspecspec/folder1/folder2$rspecspec/folder1/与folder1处于同一级别的大约10个其他文件夹我不想单独与套件的其余部分一起运行,以确定哪个文件夹包含破坏测试的测试我正在努
如何强制Rails将值中带点的参数视为google.com(例如/some_action/google.com)单个参数而不是"id"=>"google","format"=>"com"?参数值应该是"id"=>"google.com" 最佳答案 默认情况下,动态段不接受点-这是因为点用作格式化路由的分隔符。但是,您可以向路由参数添加一些正则表达式要求。在这里,您要在参数中允许点。match'some_action/:id'=>'controller#action',:constraints=>{:id=>/[0-z\.]+/}在r
我编写了一个使用Mechanize遍历站点的小程序。我想为它编写测试,但不希望它在我每次运行测试时都实际登录该站点。我想模拟互联网,这样当它访问某个站点时,它只会返回存储的结果。这是一个小例子,假装我的代码的目的是从google主页中提取链接,所以我编写了一个测试以确保我的代码找到的第一个链接包含文本“图像”。我可能会这样写:require'rubygems'require'mechanize'require'test/unit'defmy_code_to_find_linksgoogle=WWW::Mechanize.new.get('http://www.google.com')#