사용자 정의보기 매처
Espresso는 자체 사용자 지정 뷰 매처를 생성 할 수있는 다양한 옵션을 제공하며 Hamcrest 매처를 기반으로 합니다. Custom matcher는 프레임 워크를 확장하고 우리 취향에 맞게 프레임 워크를 사용자 정의하는 매우 강력한 개념입니다. 커스텀 매처를 작성할 때의 장점은 다음과 같습니다.
자체 사용자 정의보기의 고유 한 기능을 활용하려면
Custom matcher는 AdapterView 기반 테스트 케이스에서 다른 유형의 기본 데이터와 일치 하도록 도와줍니다 .
여러 매처의 기능을 결합하여 현재 매처를 단순화하려면
우리는 수요가 발생할 때 새로운 matcher를 만들 수 있으며 매우 쉽습니다. TextView 의 id와 text를 테스트하기 위해 matcher를 반환하는 새로운 사용자 지정 matcher를 만들어 보겠습니다 .
Espresso는 새 매처를 작성하기 위해 다음 두 가지 클래스를 제공합니다.
TypeSafeMatcher
BoundedMatcher
BoundedMatcher 가 올바른 유형을 수동으로 확인하지 않고 올바른 유형으로 오브젝트의 캐스팅을 투명하게 처리 한다는 점을 제외하면 두 클래스는 본질적으로 유사 합니다. BoundedMatcher 클래스를 사용하여 새로운 matcher withIdAndText 를 생성 합니다. 새 매처를 작성하는 단계를 확인해 보겠습니다.
app / build.gradle 파일 에 아래 종속성을 추가 하고 동기화하십시오.
dependencies {
implementation 'androidx.test.espresso:espresso-core:3.1.1'
}
매처 (메소드)를 포함 할 새 클래스를 만들고 최종적으로 표시합니다.
public final class MyMatchers {
}
필요한 인수를 사용하여 새 클래스 내에서 정적 메서드를 선언하고 Matcher <View>를 반환 형식으로 설정합니다.
public final class MyMatchers {
@NonNull
public static Matcher<View> withIdAndText(final Matcher<Integer>
integerMatcher, final Matcher<String> stringMatcher) {
}
}
정적 메서드 내부에 아래 서명을 사용하여 새 BoundedMatcher 객체 (반환 값도 포함)를 만듭니다.
public final class MyMatchers {
@NonNull
public static Matcher<View> withIdAndText(final Matcher<Integer>
integerMatcher, final Matcher<String> stringMatcher) {
return new BoundedMatcher<View, TextView>(TextView.class) {
};
}
}
재정 describeTo 및 matchesSafely 의 방법 BoundedMatcher의 개체를. describeTo에는 반환 유형이없는 Description 유형의 단일 인수가 있으며 매처 관련 오류 정보에 사용됩니다. matchesSafely 는 반환 유형이 부울 인 TextView 유형의 단일 인수를 가지며 뷰를 일치시키는 데 사용됩니다.
코드의 최종 버전은 다음과 같습니다.
public final class MyMatchers {
@NonNull
public static Matcher<View> withIdAndText(final Matcher<Integer>
integerMatcher, final Matcher<String> stringMatcher) {
return new BoundedMatcher<View, TextView>(TextView.class) {
@Override
public void describeTo(final Description description) {
description.appendText("error text: ");
stringMatcher.describeTo(description);
integerMatcher.describeTo(description);
}
@Override
public boolean matchesSafely(final TextView textView) {
return stringMatcher.matches(textView.getText().toString()) &&
integerMatcher.matches(textView.getId());
}
};
}
}
마지막으로 mew matcher를 사용하여 아래와 같이 테스트 케이스를 작성할 수 있습니다.
@Test
public void view_customMatcher_isCorrect() {
onView(withIdAndText(is((Integer) R.id.textView_hello), is((String) "Hello World!")))
.check(matches(withText("Hello World!")));
}