JUnit 延迟断言消息创建



我正在使用JUnit断言消息输出一些调试信息:

assertEquals(debugString, a, b);

创建此字符串的成本很高,并且我只想仅在断言失败时才创建它。我该怎么做?

这有点麻烦,但您可以使用 if s 和 fail 自己模拟所有断言。 例如,代替:

assertEquals(debugString, a, b);

您的测试可能具有:

if (!a.equals(b)) {
    fail (debugString);
}

您可以使用Hamcrest,它仅在失败时创建消息AFAIK。

String x ="x";
String y="y";
assertThat(x, is(equalTo(y));

如果发生故障,它会生成

java.lang.AssertionError: 
Expected: is "y"
     but: was "x"

为了完整起见,一旦 JUnit 5 可用,您将能够使用函数参数创建消息,该参数仅在断言失败时进行评估。 它的形式可能是这样的:

 assertTrue(() -> expensiveMessage(), testResult == expectedResult);

您可以捕获断言错误,然后将其与消息一起重新抛出。 我刚刚编写的一些示例代码在消息创建移出循环时速度提高了 100 倍以上:

@Test
public void shouldHaveCorrectParameters() {
  for(int r = 1; r <= 50; r++) {
    for(int mce = 1; mce <= 64; mce++) {
      Encoder encoder = new Encoder(r, mce);
      for(int l = 1; l <= 16384; l++) {
        EncodeParameters params = encoder.determineParameters(l);
        double effectiveRedundancy = (params.n - params.k) * 100 / (double)params.k;
        try {
          assertTrue(params.n - params.k >= mce);
          assertTrue(params.n - params.k <= mce * 2);
          assertTrue(effectiveRedundancy >= r);
        }
        catch(AssertionError e) {
          String msg = "redundancy=" + r + "%; minimumCorrectableErrors=" + mce + "; fileLength=" + l + "; k=" + params.k + "; n=" + params.n + String.format("; effectiveRedundancy=%.3f%%", effectiveRedundancy);
          throw new AssertionError(msg, e);
        }
      }
    }
  }
}

最新更新