草庐IT

字典顺序

全部标签

Ruby - 使用 rake 以随机顺序执行测试

如何让我的Rails应用程序的测试以随机顺序执行?有没有使用rake的简单解决方案? 最佳答案 给你,在lib/tasks/tasks.rb中定义它namespace:testdonamespace:randomizedodesc"Randomizetests"Rake::TestTask.new(:all=>"db:test:prepare")do|t|t.libs运行:raketest:randomize:all请记住,在文件内测试仍将按照它们出现的顺序执行。我猜你可以猴子补丁测试单元来考虑到这一点。

ruby-on-rails - RSpec 期望接收带有数组的方法,但顺序无关紧要

假设我有方法#sum,它接受一个数组并计算所有元素的总和。我正在stub:beforedoexpect(calculation_service).toreceive(:sum?).with([1,2,3]){6}end不幸的是,我的测试服以随机顺序传递数组。由于引发了该错误:Failure/Error:subject{do_crazy_stuff!}#received:sum?withunexpectedargumentsexpected:([1,2,3])got:([3,2,1])是否可以忽略数组元素的顺序对方法调用进行stub?array_including(1,2,3)无法确保数

ruby - 在 Ruby 中,如何控制 Test::Unit 测试的运行顺序?

例如,当运行这些测试时,我想确保test_fizz总是先运行。require'test/unit'classFooTest更新:我为什么要这样做?我的想法是,某些测试(那些测试更简单、更基本的方法)的早期失败将使跟踪系统中的问题变得更容易。例如,bar的成功取决于fizz是否正常工作。如果fizz坏了,我想马上知道,因为没有必要担心bar,它也会失败,但输出要复杂得多测试结果。 最佳答案 您可以使用Test::Unit::TestCase#test_order=:defined定义测试顺序例子:gem'test-unit'#Iuse

ruby - Ruby 字符串字典中的快速模糊/近似搜索

我有一个包含50K到100K字符串的字典(最多可以包含50个以上的字符),我正在尝试查找给定字符串是否在具有“编辑”距离公差的字典中。(例如Levenshtein)。在进行搜索之前,我可以预先计算任何类型的数据结构。我的目标是尽快针对该字典运行数千个字符串并返回最近的邻居。如果有一个明显更快的算法,我会得到一个bool值来说明给定的是否在字典中为此,我首先尝试计算所有Levenshtein距离并取最小值,这显然非常慢。所以我尝试根据这篇文章实现一个LevenshteinTriehttp://stevehanov.ca/blog/index.php?id=114在这里查看我的重现基准的要

ruby-on-rails - 表中元素的 cucumber 测试顺序

我想运行一个测试元素顺序的测试我希望订单按日期升序排列。这是我的cucumber功能场景和最后一句话的步骤。Scenario:OrderoftheeventsshouldbeAscendingGivenIamsignedintoanaccountcalled"GorillaTech"asacustomerWhenIfollow"Register"AndIfollow"Events"AndIfollow"Registernewevent"ThenIshouldseetheheader"Usetheformbelowtoregisteranewevent"AndIfillin"Title"

ruby - Ruby uniq 是否保留顺序?

文档对此没有任何说明(http://www.ruby-doc.org/core-2.2.0/Array.html#method-i-uniq)。此外,它是使用简单的O(n^2)搜索还是其他类似hashmap的东西?在后一种情况下,我是否应该理解我的元素必须具有hash和eql的正确实现?当我想将它们统一化时? 最佳答案 给定Array#uniq的代码(C语言)rb_ary_uniq(VALUEary){VALUEhash,uniq,v;longi;if(RARRAY_LEN(ary)在一般情况下(elseblock),它从数组中创建

Ruby:想要一个保留顺序的类似集合的对象

...或者一个防止重复条目的数组。Ruby中是否有某种对象:响应[]、[]=和默默地删除重复的条目是可枚举的(或至少支持find_all)保留条目插入的顺序?据我所知,数组支持点1、3和4;而Set支持1、2和3(但不支持4)。而SortedSet不会做,因为我的条目没有实现。 最佳答案 从Ruby1.9开始,内置的Hash对象保留了插入顺序。例如:h={}h[:z]=1h[:b]=2h[:a]=3h[:x]=0ph.keys#=>[:z,:b,:a,:x]h.delete:bph.keys#=>[:z,:a,:x]h[:b]=1p

ruby - 如何处理 Ruby 中的方法顺序?

我是Ruby新手。我熟悉其他几种语言。我的问题是关于乱序调用方法。例如:defmyfunctionmyfunction2enddefmyfunction2puts"in2"end如何在声明之前调用myfunction2?有几种语言允许您在顶部或.h文件中声明它。ruby是如何处理的?我是否总是需要遵循这个:defmyfunction2puts"in2"enddefmyfunctionmyfunction2end主要是当我需要为一个类调用definitialize中的另一个方法时,这让我很烦。 最佳答案 您不能在定义方法之前调用它。但

Ruby 以相反的顺序按条件对数组进行排序

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:SortinganarrayindescendingorderinRuby我想根据某些条件对元素数组进行排序,但逆序除外。所以基本上无论它会做什么然后逆转。例如,我有一个字符串数组,我想通过减少字符串长度对其进行排序a=["test","test2","s"]a.sort_by!{|str|str.length}.reverse!虽然这样做了……有没有一种方法可以指定条件,以便排序算法可以反向执行?

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