草庐IT

EXPECT_FLOAT_EQ

全部标签

ruby - 哪种风格,lambda..should 或 expect..to,更适合在 RSpec 中测试预期?

我看到两种样式都被广泛使用:#1lambda{raise"Boom"}.shouldraise_error和#2expect{raise"Boom"}.toraise_error.我喜欢expect..tomore,因为它读起来更好,并且隐藏了过程的创建。我查看了rspec代码,似乎expect..to是suggested,但是我经常遇到使用lambda..should的库。期望..更新,因此还不是“著名”吗? 最佳答案 expect从rspec-2开始使用,之前必须使用lambda。RSpec“正式”建议使用expect,他们可能

ruby - rspec expect语法不支持operator matchers,所以必须传一个matcher给 `#to`

使用新的expect语法:expect(@line.filter_results_and_display_them).to==@processed出现此错误:ArgumentError:Theexpectsyntaxdoesnotsupportoperatormatchers,soyoumustpassamatcherto'#to' 最佳答案 此语法有效:expect(@line.filter_results_and_display_them).toeq@processed 关于ruby

ruby - 如何有效地清除 Ruby 的负零 float ?

在Ruby中,0.0*-1==-0.0。我有一个应用程序,我将一堆Float对象与-1相乘,但我不喜欢-0.0输出,因为它令人困惑。是否有一种聪明的方法可以使Float#to_s输出0.0而不是-0.0?我完全可以通过某种清理器/辅助方法运行每个Float对象,但以下只会让我更加困惑:defclean_output(amount)ifamount.zero?0.0elseamountendend更新:为了更准确地说明我在寻找什么,我想要一个可以在一大堆float上运行的解决方案,其中一些是负数,一些是正数。负数应该保持负数,除非它们是负零,即-0.0。例子:clean_output(-

ruby - 是否有适用于 Ruby 的 Expect 等效 gem?

是否有适用于Ruby的Expect等效gem?我尝试在code.google和ruby​​gems.org上搜索,但遗憾的是它没有出现。仅供引用:Expect是一个Unix自动化和测试工具,由DonLibes编写,作为Tcl脚本语言的扩展,用于交互式应用程序,例如telnet、ftp、passwd、fsck、rlogin、tip、ssh等。 最佳答案 Ruby带有PTY用于设置伪终端以驱动交互式命令行应用程序的模块。随之而来的是expectmethod允许您与类似Expect的应用程序进行交互。对于学习如何使用expect,我发现“

ruby-on-rails - Ruby BigDecimal 健全性检查( float newb)

我的理解是否正确,即使用RubyBigDecimal类型(即使具有不同的精度和标度长度)应该准确计算还是我应该预测浮点恶作剧?我在Rails应用程序中的所有值都是BigDecimal类型,我看到了一些错误(它们确实有不同的小数长度),希望这只是我的方法而不是我的对象类型。 最佳答案 使用浮点运算时有两个常见的陷阱。第一个问题是Rubyfloat具有固定的精度。在实践中,这要么是1)对您来说没问题,要么2)灾难性的,或者3)介于两者之间。请考虑以下事项:#float1.0e+25-9999999999999999900000000.0

ruby - 何时在 expect Rspec 方法中使用大括号与圆括号?

我有一个测试是这样做的:expect(@parser.parse('adsadasdas')).toraise_error(Errno::ENOENT)但它没有用。我改为:expect{@parser.parse('adsadasdas')}.toraise_error(Errno::ENOENT)它奏效了。我们什么时候使用大括号,什么时候使用圆括号? 最佳答案 为了回应OP的评论,我编辑并完全重写了我的答案。我意识到我原来的答案被过于简单化了,以至于它可能被认为是不正确的。您的问题实际上已被另一个StackOverflowques

ruby - 截断 float 而不向上舍入

我有一个float,我想截断到3个位置,但我不想四舍五入。例如,将1.0155555555555555转换为1.015(而不是1.016)。我将如何在Ruby中执行此操作? 最佳答案 您还可以转换为BigDecimal,然后对其调用truncate。1.237.to_d.truncate(2).to_f#willreturn1.23 关于ruby-截断float而不向上舍入,我们在StackOverflow上找到一个类似的问题: https://stackov

ruby - 将 ruby float 向上或向下舍入到最接近的 0.05

我得到像这样的数字2.363636363636364.5675631.23456646544846510.5857447736我如何让Ruby将这些数字向上(或向下)舍入到最接近的0.05? 最佳答案 [2.36363636363636,4.567563,1.23456646544846,10.5857447736].mapdo|x|(x*20).round/20.0end#=>[2.35,4.55,1.25,10.6] 关于ruby-将rubyfloat向上或向下舍入到最接近的0.05

ruby - Rspec `eq` 与 `eql` 测试中的 `expect`

在rspec测试中使用eq和eql有什么区别?有区别吗:it"addsthecorrectinformationtoentries"do#book=AddressBook.new#=>Replacedbyline4book.add_entry('AdaLovelace','010.012.1815','augusta.king@lovelace.com')new_entry=book.entries[0]expect(new_entry.name).toeq('AdaLovelace')expect(new_entry.phone_number).toeq('010.012.1815'

如果整数,则 Ruby 将 float 舍入为 int

在ruby​​中,如果float是整数,我想将其转换为int。例如a=1.0b=2.5a.to_int_if_whole#=>1b.to_int_if_whole#=>2.5基本上,我试图避免在任何没有小数的数字上显示“.0”。我正在寻找一种优雅的(或内置的)方式来做defto_int_if_whole(float)(float%1==0)?float.to_i:floatend 最佳答案 一个简单的方法是:classFloatdefprettifyto_i==self?to_i:selfendend那是因为:irb>1.0==1=