사용자 정의보기 매처

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) {
      };
   }
}
  • 재정 describeTomatchesSafely 의 방법 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!")));
}