एस्प्रेसो टेस्टिंग फ्रेमवर्क - मैचर्स देखें

एस्प्रेसो फ्रेमवर्क कई व्यू मैचर्स प्रदान करता है। मिलान करने वाले का उद्देश्य दृश्य, पाठ, और बच्चे के देखने की उपलब्धता जैसे दृश्य की विभिन्न विशेषताओं का उपयोग करके एक दृश्य का मिलान करना है। प्रत्येक मिलानकर्ता दृश्य के एक विशेष गुण से मेल खाता है और विशेष प्रकार के दृश्य पर लागू होता है। उदाहरण के लिए, withId मिलान से मेल खाता क्रमांक जबकि withText मिलान से मेल खाता देखने के संपत्ति और सभी को देखने के लिए लागू होता है, पाठ को देखने के संपत्ति और पर लागू होता है TextView केवल।

इस अध्याय में, आइए हम एस्प्रेसो परीक्षण ढांचे के साथ-साथ एस्प्रेसो पुस्तकालय के निर्माण के लिए एस्प्रेसो परीक्षण ढांचे द्वारा प्रदान किए गए विभिन्न मिलानों को जानें ।

हैमरेस्ट लाइब्रेरी

Hamcrest लाइब्रेरी एस्प्रेसो टेस्टिंग फ्रेमवर्क के दायरे में एक महत्वपूर्ण लाइब्रेरी है। हैमरेस्ट अपने आप में मैच्योर ऑब्जेक्ट्स लिखने की एक रूपरेखा है। एस्प्रेसो फ्रेमवर्क व्यापक रूप से हैमरेस्ट लाइब्रेरी का उपयोग करता है और जब भी आवश्यक हो सरल और विस्तार योग्य मिलान प्रदान करने के लिए इसे बढ़ाता है।

Hamcrest किसी भी ऑब्जेक्ट को मुखर करने के लिए एक साधारण फ़ंक्शन assertThat और मैचर्स का संग्रह प्रदान करता है । मुखर तीन तर्क हैं और वे नीचे दिखाए गए हैं -

  • स्ट्रिंग (परीक्षण का विवरण, वैकल्पिक)

  • वस्तु (वास्तविक)

  • मिलानकर्ता (अपेक्षित)

आइए हम एक साधारण उदाहरण लिखें कि क्या किसी वस्तु का अपेक्षित मूल्य है या नहीं।

import static org.hamcrest.Matchers.hasItem;
import static org.hamcrest.MatcherAssert.assertThat;
@Test
public void list_hasValue() {
   ArrayList<String> list = new ArrayList<String>();
   list.add("John");
   assertThat("Is list has John?", list, hasItem("John"));
}

यहाँ, hasItem एक मिलानकर्ता लौटाता है, जो जाँचता है कि क्या वास्तविक सूची में आइटम में से एक के रूप में निर्दिष्ट मूल्य है।

हैमरेस्ट में बहुत सारे बिल्ट-इन मैचर्स हैं और नए मैचर्स बनाने के विकल्प भी हैं। एस्प्रेसो टेस्टिंग फ्रेमवर्क में उपयोगी कुछ महत्वपूर्ण अंतर्निहित मेकर्स इस प्रकार हैं -

कुछ भी - हमेशा मैचर्स

तार्किक आधारित मैचर्स

  • allOf - किसी भी संख्या के मैचर्स और मैचों को तभी स्वीकार करें जब सभी मैचर्स सफल हो जाएं।

  • anyOf - किसी भी मैचर के सफल होने पर किसी भी संख्या में मैचर्स और मैचों को स्वीकार करें।

  • not - एक माचिस और माचिस तभी स्वीकार करें जब माचिस फेल हो जाए और इसके विपरीत।

पाठ आधारित मिलान

  • equalToIgnoringCase - यह परीक्षण करने के लिए उपयोग किया जाता है कि क्या वास्तविक इनपुट अपेक्षित स्ट्रिंग अनदेखी मामले के बराबर है।

  • equalToIgnoringWhiteSpace - यह परीक्षण करने के लिए उपयोग किया जाता है कि क्या वास्तविक इनपुट निर्दिष्ट स्ट्रिंग अनदेखी मामले और सफेद रिक्त स्थान के बराबर है।

  • containsString - यह परीक्षण करने के लिए उपयोग किया जाता है कि क्या वास्तविक इनपुट में निर्दिष्ट स्ट्रिंग है।

  • endsWith - यह परीक्षण करने के लिए उपयोग किया जाता है कि क्या वास्तविक इनपुट निर्दिष्ट स्ट्रिंग से शुरू होता है।

  • startsWith - यह जांचने के लिए उपयोग किया जाता है कि क्या वास्तविक इनपुट निर्दिष्ट स्ट्रिंग के साथ समाप्त होता है।

नंबर आधारित माचिस

  • closeTo - यह परीक्षण करने के लिए उपयोग किया जाता है कि वास्तविक इनपुट अपेक्षित संख्या के करीब है या नहीं।

  • greaterThan - यह परीक्षण करने के लिए उपयोग किया जाता है कि वास्तविक इनपुट अपेक्षित संख्या से अधिक है या नहीं।

  • greaterThanOrEqualTo - यह जांचने के लिए उपयोग किया जाता है कि वास्तविक इनपुट अपेक्षित संख्या से अधिक है या बराबर है।

  • lessThan - यह परीक्षण करने के लिए उपयोग किया जाता है कि वास्तविक इनपुट अपेक्षित संख्या से कम है या नहीं।

  • lessThanOrEqualTo - यह परीक्षण करने के लिए उपयोग किया जाता है कि वास्तविक इनपुट अपेक्षित संख्या से कम या उसके बराबर है या नहीं।

ऑब्जेक्ट आधारित मैचर्स

  • equalTo - यह परीक्षण करने के लिए उपयोग किया जाता है कि वास्तविक इनपुट अपेक्षित वस्तु के बराबर है या नहीं

  • hasToString - यह जांचने के लिए उपयोग किया जाता है कि वास्तविक इनपुट में स्ट्रींग विधि है या नहीं।

  • instanceOf - यह परीक्षण करने के लिए उपयोग किया जाता है कि वास्तविक इनपुट अपेक्षित वर्ग का उदाहरण है या नहीं।

  • isCompatibleType - यह परीक्षण करने के लिए उपयोग किया जाता है कि वास्तविक इनपुट अपेक्षित प्रकार के साथ संगत है या नहीं।

  • notNullValue - यह परीक्षण करने के लिए उपयोग किया जाता है कि क्या वास्तविक इनपुट शून्य नहीं है।

  • sameInstance - यह परीक्षण करने के लिए उपयोग किया जाता है कि क्या वास्तविक इनपुट और अपेक्षित एक ही उदाहरण के हैं।

  • hasProperty - यह परीक्षण करने के लिए उपयोग किया जाता है कि वास्तविक इनपुट में अपेक्षित संपत्ति है या नहीं

है - बराबर के लिए चीनी या शॉर्ट कट

matchers

एस्प्रेसो विचारों को मिलाने और खोजने के लिए onView () विधि प्रदान करता है। यह मैच देखने वालों को स्वीकार करता है और मिलान किए गए दृश्य के साथ बातचीत करने के लिए ViewInteraction ऑब्जेक्ट देता है। मैच देखने वालों की अक्सर उपयोग की जाने वाली सूची नीचे वर्णित है -

withId ()

withId () प्रकार int के तर्क को स्वीकार करता है और तर्क दृश्य की आईडी को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो दृश्य की आईडी का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withId(R.id.testView))

withText ()

withText () प्रकार स्ट्रिंग के एक तर्क को स्वीकार करता है और तर्क दृश्य की पाठ संपत्ति के मूल्य को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो दृश्य के पाठ मान का उपयोग करके दृश्य से मेल खाता है। यह केवल TextView पर लागू होता है । नमूना कोड निम्नानुसार है,

onView(withText("Hello World!"))

withContentDescription ()

withContentDescription () प्रकार स्ट्रिंग के एक तर्क को स्वीकार करता है और तर्क दृश्य की सामग्री विवरण संपत्ति के मूल्य को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो दृश्य के विवरण का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withContentDescription("blah"))

हम टेक्स्ट के बजाय टेक्स्ट वैल्यू के रिसोर्स आईडी को भी पास कर सकते हैं।

onView(withContentDescription(R.id.res_id_blah))

hasContentDescription ()

hasContentDescription () का कोई तर्क नहीं है। यह एक मिलानकर्ता लौटाता है, जो उस दृश्य से मेल खाता है जिसका कोई भी सामग्री विवरण है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), hasContentDescription()))

withTagKey ()

withTagKey () प्रकार स्ट्रिंग के एक तर्क को स्वीकार करता है और तर्क दृश्य की टैग कुंजी को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो अपनी टैग कुंजी का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withTagKey("blah"))

हम टैग नाम के बजाय टैग नाम की संसाधन आईडी भी पास कर सकते हैं।

onView(withTagKey(R.id.res_id_blah))

withTagValue ()

withTagValue () एक प्रकार के मिलानकर्ता <ऑब्जेक्ट> के तर्क को स्वीकार करता है और तर्क दृश्य के टैग मान को संदर्भित करता है। यह एक मिलानकर्ता लौटाता है, जो अपने टैग मूल्य का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withTagValue(is((Object) "blah")))

यहाँ, है Hamcrest मिलान है।

withClassName ()

withClassName () प्रकार मिलान के एक तर्क को स्वीकार करता है <स्ट्रिंग> और तर्क दृश्य के वर्ग नाम मान को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो अपने वर्ग के नाम का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withClassName(endsWith("EditText")))

यहाँ, एंडस हैमरेस्ट मैचर है और रिटर्न मैचर <स्ट्रिंग> है

withHint ()

withHint () प्रकार के मिलान के एक तर्क को स्वीकार करता है <string> और तर्क दृश्य के संकेत मूल्य को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो दृश्य के संकेत का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withClassName(endsWith("Enter name")))

withInputType ()

InInputType () प्रकार int के तर्क को स्वीकार करता है और तर्क इनपुट प्रकार के दृश्य को संदर्भित करता है। यह एक मिलानकर्ता लौटाता है, जो अपने इनपुट प्रकार का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withInputType(TYPE_CLASS_DATETIME))

यहां, TYPE_CLASS_DATETIME संपादन दृश्य सहायक तिथियों और समय को संदर्भित करता है।

withResourceName ()

withResourceName () प्रकार मिलान के एक तर्क को स्वीकार करता है <स्ट्रिंग> और तर्क दृश्य के वर्ग नाम मान को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो दृश्य के संसाधन नाम का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withResourceName(endsWith("res_name")))

यह स्ट्रिंग तर्क को भी स्वीकार करता है। नमूना कोड निम्नानुसार है,

onView(withResourceName("my_res_name"))

withAlpha ()

withAlpha () प्रकार फ्लोट के एक तर्क को स्वीकार करता है और तर्क दृश्य के अल्फा मूल्य को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो दृश्य के अल्फा मान का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withAlpha(0.8))

withEffectiveVisibility ()

withEffectiveVisibility () एक प्रकार का व्यूमेचर्स स्वीकार करता है। विजिबिलिटी और तर्क दृश्य की प्रभावी दृश्यता को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो दृश्य की दृश्यता का उपयोग करके दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(withEffectiveVisibility(withEffectiveVisibility.INVISIBLE))

withSpinnerText ()

withSpinnerText () प्रकार मिलान के एक तर्क को स्वीकार करता है <string> और यह तर्क स्पिनर के वर्तमान चयनित दृश्य मान को संदर्भित करता है। यह एक मिलानकर्ता को लौटाता है, जो स्पिनर से मेल खाता है, यह चयनित आइटम के इनररिंग मूल्य पर आधारित है। नमूना कोड निम्नानुसार है,

onView(withSpinnerText(endsWith("USA")))

यह स्ट्रिंग तर्क या स्ट्रिंग के संसाधन आईडी को भी स्वीकार करता है। नमूना कोड निम्नानुसार है,

onView(withResourceName("USA"))
onView(withResourceName(R.string.res_usa))

withSubstring ()

withSubString () withText () के समान है, सिवाय इसके कि यह दृश्य के पाठ मान के प्रतिस्थापन का परीक्षण करने में मदद करता है।

onView(withSubString("Hello"))

hasLinks ()

hasLinks () में कोई तर्क नहीं है और यह एक मिलानकर्ता लौटाता है, जो लिंक वाले दृश्य से मेल खाता है। यह केवल TextView पर लागू होता है। नमूना कोड निम्नानुसार है,

onView(allOf(withSubString("Hello"), hasLinks()))

यहाँ, allOf एक Hamcrest मैचर है। allOf एक मिलानकर्ता को लौटाता है, जो सभी उत्तीर्ण मिलानकर्ताओं से मेल खाता है और यहाँ, इसका उपयोग किसी दृश्य के मिलान के साथ-साथ यह देखने के लिए भी किया जाता है कि क्या दृश्य के पाठ मान में लिंक हैं या नहीं।

hasTextColor ()

hasTextColor () प्रकार int के एक तर्क को स्वीकार करता है और तर्क रंग की संसाधन आईडी को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो अपने रंग के आधार पर TextView से मेल खाता है । यह केवल TextView पर लागू होता है । नमूना कोड निम्नानुसार है,

onView(allOf(withSubString("Hello"), hasTextColor(R.color.Red)))

hasEllipsizedText ()

hasEllipsizedText () का कोई तर्क नहीं है। यह एक मिलानकर्ता को लौटाता है, जो लंबे समय से पाठ वाले TextView से मेल खाता है और या तो दीर्घवृत्त (पहले .. दस .. अंतिम) या कट (पहले ...)। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_text_view_id), hasEllipsizedText()))

hasMultilineText ()

hasMultilineText () का कोई तर्क नहीं है। यह एक मिलानकर्ता लौटाता है, जो किसी भी मल्टी लाइन टेक्स्ट वाले TextView से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_test_view_id), hasMultilineText()))

hasBackground ()

hasBackground () प्रकार int के एक तर्क को स्वीकार करता है और तर्क पृष्ठभूमि संसाधन की संसाधन आईडी को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो अपने पृष्ठभूमि संसाधनों के आधार पर दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId("image"), hasBackground(R.drawable.your_drawable)))

hasErrorText ()

hasErrorText () प्रकार मिलान के एक तर्क को स्वीकार करता है <String> और तर्क दृश्य के (EditText) त्रुटि स्ट्रिंग मान को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो दृश्य के त्रुटि स्ट्रिंग का उपयोग करके दृश्य से मेल खाता है। यह केवल EditText पर लागू होता है । नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.editText_name), hasErrorText(is("name is required"))))

यह स्ट्रिंग तर्क को भी स्वीकार करता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.editText_name), hasErrorText("name is required")))

hasImeAction ()

hasImeAction () प्रकार के मिलान के एक तर्क को स्वीकार करता है <Integer> और यह तर्क दृश्य (EditText) समर्थित इनपुट विधियों को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो दृश्य के समर्थित इनपुट पद्धति का उपयोग करके दृश्य से मेल खाता है। यह केवल EditText पर लागू होता है । नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.editText_name),
hasImeAction(is(EditorInfo.IME_ACTION_GO))))

यहां, EditorInfo.IME_ACTION_GO इनपुट विधियों के विकल्पों पर है। hasImeAction () पूर्णांक तर्क को भी स्वीकार करता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.editText_name),
hasImeAction(EditorInfo.IME_ACTION_GO)))

supportsInputMethods ()

SupportInputMethods () का कोई तर्क नहीं है। यह एक मिलानकर्ता को लौटाता है, जो इनपुट विधियों का समर्थन करने पर दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.editText_name), supportsInputMethods()))

isRoot ()

isRoot () का कोई तर्क नहीं है। यह एक मिलानकर्ता देता है, जो रूट दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_root_id), isRoot()))

प्रदर्शित किया गया है()

isisplayed () का कोई तर्क नहीं है। यह एक मिलानकर्ता को लौटाता है, जो वर्तमान में प्रदर्शित किए गए दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), isDisplayed()))

isDisplayingAtLeast ()

isDisplayingAtLeast () प्रकार int का एक भी तर्क स्वीकार करता है। यह एक मिलानकर्ता लौटाता है, जो उस दृश्य से मेल खाता है जो वर्तमान में कम से कम निर्दिष्ट प्रतिशत में प्रदर्शित होता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), isDisplayingAtLeast(75)))

isCompletelyDisplayed ()

isCompletelyDisplayed () का कोई तर्क नहीं है। यह एक मिलानकर्ता देता है, जो उस दृश्य से मेल खाता है जो वर्तमान में पूरी तरह से स्क्रीन पर प्रदर्शित होता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), isCompletelyDisplayed()))

सक्षम किया गया है()

isEnabled () का कोई तर्क नहीं है। यह एक मिलानकर्ता देता है, जो उस दृश्य से मेल खाता है जो सक्षम है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), isEnabled()))

isFocusable ()

isFocusable () का कोई तर्क नहीं है। यह एक मिलानकर्ता लौटाता है, जो उस दृश्य से मेल खाता है जिसमें फोकस विकल्प है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), isFocusable()))

hasFocus ()

hasFocus () का कोई तर्क नहीं है। यह एक मिलानकर्ता लौटाता है, जो उस दृश्य से मेल खाता है जो वर्तमान में केंद्रित है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), hasFocus()))

isClickable ()

isClickable () का कोई तर्क नहीं है। यह एक मिलानकर्ता देता है, जो उस दृश्य से मेल खाता है जो क्लिक विकल्प है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), isClickable()))

चूना गया()

IsSelected () का कोई तर्क नहीं है। यह एक मिलानकर्ता लौटाता है, जो वर्तमान में चयनित दृश्य से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), isSelected()))

की जाँच कर ली गयी है()

isChecked () का कोई तर्क नहीं है। यह एक मिलानकर्ता देता है, जो उस दृश्य से मेल खाता है जो CompoundButton (या इसके उपप्रकार) का है और जाँच की स्थिति में है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_view_id), isChecked()))

isNotChecked ()

isNotChecked () isChecked के ठीक विपरीत है। नमूना कोड इस प्रकार है:

onView(allOf(withId(R.id.my_view_id), isNotChecked()))

isJavascriptEnabled ()

javascriptEnabled () का कोई तर्क नहीं है। यह एक मिलानकर्ता लौटाता है, जो जावास्क्रिप्ट का मूल्यांकन करने वाले WebView से मेल खाता है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.my_webview_id), isJavascriptEnabled()))

मम्मी - पापा के साथ()

withParent () प्रकार के एक तर्क को स्वीकार करता है मिलानकर्ता <View>। तर्क एक दृश्य को संदर्भित करता है। यह एक मिलानकर्ता देता है, जो उस दृश्य से मेल खाता है जो निर्दिष्ट दृश्य माता-पिता का दृश्य है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.childView), withParent(withId(R.id.parentView))))

hasSibling ()

hasSibling () प्रकार मिलान के एक तर्क को स्वीकार करता है> दृश्य <। तर्क एक दृश्य को संदर्भित करता है। यह एक मैच्योर रिटर्न देता है, जो उस दृश्य से मेल खाता है जो पारित हुआ दृश्य इसके भाई के दृश्य में से एक है। नमूना कोड निम्नानुसार है,

onView(hasSibling(withId(R.id.siblingView)))

बच्चे के साथ()

withChild () प्रकार के एक तर्क को स्वीकार करता है मिलानकर्ता <View>। तर्क एक दृश्य को संदर्भित करता है। यह एक मैच्योर रिटर्न देता है, जो उस दृश्य से मेल खाता है जो पास किया गया दृश्य चाइल्ड व्यू है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.parentView), withChild(withId(R.id.childView))))

hasChildCount ()

hasChildCount () प्रकार int के एक तर्क को स्वीकार करता है। तर्क एक दृश्य की बाल गणना को संदर्भित करता है। यह एक मिलानकर्ता को लौटाता है, जो उस दृश्य से मेल खाता है जिसमें तर्क में निर्दिष्ट बच्चे के दृश्य की बिल्कुल समान संख्या है। नमूना कोड निम्नानुसार है,

onView(hasChildCount(4))

hasMinimumChildCount ()

hasMinimumChildCount () प्रकार int के एक तर्क को स्वीकार करता है। तर्क एक दृश्य की बाल गणना को संदर्भित करता है। यह एक मिलानकर्ता लौटाता है, जो उस दृश्य से मेल खाता है जिसमें तर्क में निर्दिष्ट के रूप में कम से कम बच्चे के दृश्य हैं। नमूना कोड निम्नानुसार है,

onView(hasMinimumChildCount(4))

hasDescendant ()

hasDescenders () प्रकार के एक तर्क को स्वीकार करता है मिलानकर्ता <View>। तर्क एक दृश्य को संदर्भित करता है। यह एक मैच्योर रिटर्न देता है, जो उस दृश्य से मेल खाता है जो पारित हुआ दृश्य व्यू पदानुक्रम में एक वंशज दृश्य है। नमूना कोड निम्नानुसार है,

onView(hasDescendant(withId(R.id.descendantView)))

isDescendantOfA ()

isDescendersOfA () प्रकार मिलान के एक तर्क को स्वीकार करता है <View>। तर्क एक दृश्य को संदर्भित करता है। यह एक मैच्योर रिटर्न देता है, जो उस दृश्य से मेल खाता है जो पारित हुआ दृश्य व्यू पदानुक्रम में पूर्वजों के दृश्य में से एक है। नमूना कोड निम्नानुसार है,

onView(allOf(withId(R.id.myView), isDescendantOfA(withId(R.id.parentView))))