java – hamcrest:如何匹配数组是另一个数组的子集?

前端之家收集整理的这篇文章主要介绍了java – hamcrest:如何匹配数组是另一个数组的子集?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
鉴于:
int[] a = {1,2,3,4};
int[] b = {1,4,5};

如何断言“a”是使用hamcrest匹配器的“b”的子集?

以下作品

assertThat(Arrays.asList(b),hasItems(a));

但是,由于我从“b”创建了“a”,所以我宁愿将“a”作为该值.
就像是

assertThat(a,isSubsetOf(b));

另外,最好避免将数组转换成列表.

解决方法

您可以使用 EveryIsIn匹配器的组合:
assertThat(Arrays.asList(a),everyItem(isIn(b)));

这样会检查是否每个项目都包含在b中.确保a和b的类型为整数[],否则可能会产生意想不到的结果.

在最新版本中,将isIn替换为,自第一个has been deprecated起.

猜你在找的Java相关文章