android-espresso
So erstellen Sie benutzerdefinierte Matcher
Suche…
Beispiel eines benutzerdefinierten Matchers zum Testen der TextView-Fehlernachricht
- Erstellen
ErrorMatcherin IhremErrorMatchereinen KlassennamenErrorMatchermit dem folgenden Code:
public class ErrorMatcher {
@NonNull
public static Matcher<View> withError(final String expectedErrorText) {
Checks.checkNotNull(expectedErrorText);
return new BoundedMatcher<View, TextView>(TextView.class) {
@Override
public void describeTo(final Description description) {
description.appendText("error text: ");
stringMatcher.describeTo(description);
}
@Override
public boolean matchesSafely(final TextView textView) {
return expectedErrorText.equals(textView.getError().toString());
}
};
}
}
Die Übereinstimmungslogik besteht darin, das TextView Element zu finden, dessen TextView dem erwarteten Fehlertextwert entspricht, wobei die Teilmenge der TextView Felder in der TextView . describeTo Methode wird für die Debug-Ausgabe verwendet.
- Dann können Sie Ihren benutzerdefinierten Matcher wie unten gezeigt im Testfall verwenden:
@Test
public void verifiesSignInErrorIsShown() {
onView(withId(R.id.email_sign_in_button)).perform(click());
onView(ErrorMatcher.withError("Your error text")).check(matches(isDisplayed()));
}
Modified text is an extract of the original Stack Overflow Documentation
Lizenziert unter CC BY-SA 3.0
Nicht angeschlossen an Stack Overflow