List<String> expectedStrings = Arrays.asList("link1", "link2");
List<String> strings = Arrays.asList("lalala link1 lalalla", "lalalal link2 lalalla");
对于每个expectedString,我需要声明'strings'中的任何字符串都包含expectedString。 我怎么用Hamcrest断言这个? 谢谢你的关注。
答案 0 :(得分:6)
在检查了这个旧答案之后,我发现你可以使用更好的内置匹配器组合,使断言和错误信息更具可读性:
expectedStrings.forEach(expectedString ->
assertThat(strings, hasItem(containsString(expectedString))));
你可以很容易地用流做到这一点:
assertThat(expectedStrings.stream().allMatch(
expectedString -> strings.stream()
.anyMatch(string -> string.contains(expectedString))),
is(true));
allMatch
将确保检查所有expectedStrings
,并在anyMatch
上使用strings
,您可以有效地检查是否有任何字符串包含预期的字符串
答案 1 :(得分:0)
目前在Hamcrest中没有任何匹配器具有此requeriment,尽管你可以组合多个这是不可能的。
所以,在像你这样的情况下,我认为最好的解决方案是创建自己的匹配器为什么?
所以在你的情况下你需要匹配第一个列表包含第二个的任何字符串,你可以像下一个创建一个匹配器:
public class ContainsStringsOf extends BaseMatcher<List<String>> {
private final List<String> valuesToCompare;
public ContainsStringsOf(List<String> valuesToCompare) {
this.valuesToCompare = valuesToCompare;
}
@Override
public void describeTo(Description description) {
description.appendText("doesn't contains all of " + valuesToCompare.toString() + " text");
}
@Override
public boolean matches(Object o) {
List<String> values = (List<String>) o;
for (String valueToCompare : valuesToCompare) {
boolean containsText = false;
for (String value : values) {
if (value.contains(valueToCompare)) {
containsText = true;
}
}
if (!containsText) {
return false;
}
}
return true;
//note: you can replace this impl with java-8 @florian answer comparison
//return valuesToCompare.stream().allMatch(exp -> strings.stream().anyMatch(st-> st.contains(exp)))
}
@Factory
public static Matcher<List<String>> containsStringsOf(List<String> collection) {
return new ContainsStringsOf(collection);
}
}
然后你可以使用它就像使用hamcrest匹配器一样:
List<String> expectedStrings = Arrays.asList("link1", "link2");
List<String> strings = Arrays.asList("lalala link1 lalalla", "lalalal link2 lalalla");
Assert.assertThat(strings , containsStringsOf(expectedStrings));