कस्टम व्यू मैचर्स
एस्प्रेसो हमारे अपने कस्टम व्यू मैचर्स बनाने के लिए विभिन्न विकल्प प्रदान करता है और यह हैमरेस्ट मैचर्स पर आधारित है । कस्टम मिलानर फ्रेमवर्क का विस्तार करने के लिए और हमारे स्वाद के लिए फ्रेमवर्क को अनुकूलित करने के लिए एक बहुत शक्तिशाली अवधारणा है। कस्टम मैचर्स लिखने के कुछ फायदे इस प्रकार हैं,
अपने स्वयं के कस्टम विचारों की अनूठी विशेषता का फायदा उठाने के लिए
कस्टम मिलानकर्ता विभिन्न प्रकार के अंतर्निहित डेटा के साथ मिलान करने के लिए एडेप्टर व्यू आधारित परीक्षण मामलों में मदद करता है ।
एकाधिक मिलान करने वाले की विशेषताओं को मिलाकर वर्तमान मिलान को सरल बनाने के लिए
जब और जब मांग उठती है तब हम नया मिलान कर सकते हैं और यह काफी आसान है। आइए हम एक नया कस्टम मैचर बनाते हैं, जो एक मिलानकर्ता को एक टेक्स्ट व्यू की आईडी और टेक्स्ट दोनों का परीक्षण करने के लिए देता है ।
एस्प्रेसो नए मिलान लिखने के लिए निम्नलिखित दो कक्षाएं प्रदान करता है -
TypeSafeMatcher
BoundedMatcher
दोनों वर्ग प्रकृति में समान हैं सिवाय इसके कि बाउन्डमैचर पारदर्शी रूप से सही प्रकार के लिए जाँच किए बिना ऑब्जेक्ट की कास्टिंग को सही प्रकार से संभालता है। हम एक नया माचिस बनाएँगे , withIdAndText बाउंडेडमैच क्लास का उपयोग करके । आइए हम नए मिलान लिखने के लिए चरणों की जाँच करें।
एप्लिकेशन / 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) {
}
}
स्थैतिक विधि के अंदर नीचे हस्ताक्षर के साथ एक नया बाउंडेडमैचर ऑब्जेक्ट (साथ ही वापसी मूल्य) बनाएं,
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) {
};
}
}
बाउंडऑटमैच ऑब्जेक्ट में वर्णन को ओवरराइड करें और मिलान करें । descriptionTo में बिना रिटर्न प्रकार के विवरण का एकल तर्क है और इसका उपयोग मिलानकर्ताओं के बारे में जानकारी को त्रुटि देने के लिए किया जाता है। मैचसैफली में रिटर्न टाइप बूलियन के साथ टेक्स्टव्यू टाइप का एक ही तर्क है और इसका उपयोग दृश्य से मिलान करने के लिए किया जाता है।
कोड का अंतिम संस्करण इस प्रकार है,
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());
}
};
}
}
अंत में, हम नीचे परीक्षण के रूप में बोए गए मामले को लिखने के लिए हमारे एमई मैचर का उपयोग कर सकते हैं,
@Test
public void view_customMatcher_isCorrect() {
onView(withIdAndText(is((Integer) R.id.textView_hello), is((String) "Hello World!")))
.check(matches(withText("Hello World!")));
}