Как я могу использовать Hamcrest для проверки того, является ли каждый элемент в массиве двойников "близким" к каждому элементу другого массива?

Я хотел бы сравнить два массива двойников. Используя vanilla 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, желательно, не создавая настраиваемых Матчи (если возможно). Что-то похожее на использование "закрывающего" матчи для каждого элемента в массиве.

Ответ 1

Если вы измените a на Double[], вы можете сделать 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);
}

Вы можете сделать это с помощью примитивного массива, но для этого вам понадобится специальный макет.