gpt4 book ai didi

ruby - 相当于 Ruby 1.9.2 Test::Unit 中 nUnit 的 TestCase

转载 作者:数据小太阳 更新时间:2023-10-29 08:29:06 25 4
gpt4 key购买 nike

当我不久前决定学习 Ruby 时,我还决定开始使用单元测试和 TDD 方法。我开始使用 Test::Unit 并编写了几个非常小的类来大致了解单元测试,尤其是 Ruby 和 Test::Unit。

到目前为止,一切都非常简单,但后来我想做一些类似于 nUnit 的 TestCase 的事情,因为我进行了 20 次测试,其中唯一改变的是输入和输出。

代码如下所示:

def test_2_inserted_return_true
actual = @prime_generator.is_prime?(2)
assert_equal(true, actual)
end

def test_3_inserted_return_true
actual = @prime_generator.is_prime?(3)
assert_equal(true, actual)
end

def test_5_inserted_return_true
actual = @prime_generator.is_prime?(5)
assert_equal(true, actual)
end

从 DRY 的角度来看,这是非常可怕的。我想要的是类似于 nUnit 的 TestCase 的东西。

像这样:

[TestCase(2.5d, 2d, Result=1.25d)]
[TestCase(-2.5d, 1d, Result = -2.5d)]
public double ValidateDivision(double numerator, double denominator)
{
var myClass = new MyClass();
return myClass.Divide(numerator,denominator);
}

我试过谷歌搜索但找不到任何关于 Test::Unit 的信息。我在 RSpec 和 Selenium 上找到了一些,但这并没有真正帮助我。我也尝试在这里搜索,但也找不到任何东西。

我想过让测试方法接受参数,但又像那样定义方法……对此并不满意。此外,如果我没记错的话,这甚至是不可能的(我现在无法测试,否则我会)。

所以,我的问题是:是否可以在 Ruby (1.9.2) 中使用 Test::Unit 进行数据驱动测试?如果不能,那么什么框架可以做到?

最佳答案

我们不要忘记好的循环:

def test_that_the_first_few_primes_are_detected_as_prime
[2, 3, 5, 7, 11, 13, 17].each do |p|
assert @primality_tester.prime?(p)
end
end

有些人会使用元编程来定义单独的测试方法,但在这种情况下我认为这是过大的:

[2, 3, 5, 7, 11, 13, 17].each do |p|
define_method :"test_that_#{p}_is_detected_as_prime" do
assert @primality_tester.prime?(p)
end
end

一般来说,我认为测试不应该是 DRY。它们应该是 DAMP(描述性和有意义的短语)。毕竟,测试是您的规范和文档,阅读它们的人可能不熟悉 Ruby,甚至不熟悉一般编程。所以,我什至不确定你原来的例子是否糟糕,特别是如果你像我上面那样清理它:

def test_that_2_is_detected_as_prime
assert @primality_tester.prime?(2)
end

def test_that_3_is_detected_as_prime
assert @primality_tester.prime?(3)
end

def test_that_5_is_detected_as_prime
assert @primality_tester.prime?(5)
end

这是我做的:

  • 重命名测试:现在,测试名称构成了一个完整的句子,而不仅仅是重复测试的内容。
  • 使用 assert 而不是 assert_equal:无论如何检查是否等于 true 几乎都不是一个好主意,并且 assert 已经检查结果是否真实,所以何必呢?
  • @prime_generator 重命名为 @primality_tester,因为它不会生成素数,它只会检查数字是否为素数.
  • is_prime? 重命名为 prime?,因为问号已经暗示了问题
  • 最后但并非最不重要的一点:修复格式,因为格式不仅与标准 Ruby 编码约定不一致,甚至在自身
  • 中也不一致

但是,最佳 IMO 解决方案是这样的:

def test_that_the_first_few_primes_are_detected_as_prime
assert @primality_tester.prime?(2)
assert @primality_tester.prime?(3)
assert @primality_tester.prime?(5)
end

那里有重复,但重复是保持测试可读和可发音所必需的。 DRY 是生产代码的一个很好的原则,它会不断发展和扩展,但对于测试来说,DRY 总是需要与 DAMP 保持平衡。 (也许写一个自定义断言是有意义的,但我对此表示怀疑。至少我不能为它想出一个好名字,这总是一个提示。)

一种完全不同的方法是基于属性的检查,类似于 Haskell 的 QuickCheck 或 .NET 的 Pex。有一个名为 RushCheck 的 QuickCheck 的 Ruby 端口,但自 2006 年以来一直没有维护,几周前才开始维护,还有很多工作要做,以使其在最新版本的 Ruby 上加快速度。

关于ruby - 相当于 Ruby 1.9.2 Test::Unit 中 nUnit 的 TestCase,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5566594/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com