我想比较两个双打数组。使用香草 JUnit,我可以这样做:
double[] a = new double[]{1.0, 2.0, 3.0};
double[] b = new double[]{1.0, 2.0, 3.0};
assertEquals(a, b, 1e-10);
我想知道如何使用 Hamcrest 来做到这一点,最好不要创建自定义匹配器(如果可能的话)。类似于对数组中的每个元素使用“关闭”匹配器。
如果您更改a
为 aDouble[]
那么您可以assertThat(a, arrayCloseTo(b, .2));
使用此辅助方法:
public static Matcher<Double[]> arrayCloseTo(double[] array, double error) {
List<Matcher<? super Double>> matchers = new ArrayList<Matcher<? super Double>>();
for (double d : array)
matchers.add(closeTo(d, error));
return arrayContaining(matchers);
}
您也可以使用原始数组来执行此操作,但您需要一个自定义匹配器。