Zoeken…


Voorbeeld van aangepaste matcher voor het testen van TextView-foutmelding

  1. Maak een klassenaam ErrorMatcher in uw testpakket met onderstaande 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());
            }
        };
    }
}

Bijpassende logica is het vinden van het TextView element, welke tekst van het foutbericht gelijk is aan de verwachte fouttekstwaarde, door de subset van TextView velden in de lay-outhiërarchie. describeTo methode wordt gebruikt voor foutopsporingsuitvoer.

  1. Vervolgens kunt u uw aangepaste matcher in de testcase gebruiken, zoals hieronder wordt getoond:
@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
Licentie onder CC BY-SA 3.0
Niet aangesloten bij Stack Overflow