एस्प्रेसो टेस्टिंग फ्रेमवर्क - क्विक गाइड

सामान्य तौर पर, मोबाइल स्वचालन परीक्षण एक कठिन और चुनौतीपूर्ण कार्य है। विभिन्न उपकरणों और प्लेटफार्मों के लिए Android उपलब्धता मोबाइल स्वचालन परीक्षण के लिए चीजों को थकाऊ बनाती है। इसे आसान बनाने के लिए, Google ने चुनौती ली और एस्प्रेसो ढांचे को विकसित किया। यह एक Android आवेदन में उपयोगकर्ता इंटरफेस को स्वचालित और परीक्षण करने के लिए एक बहुत ही सरल, सुसंगत और लचीला एपीआई प्रदान करता है। एस्प्रेसो परीक्षण जावा और कोटलिन दोनों में लिखे जा सकते हैं, जो एंड्रॉइड एप्लिकेशन विकसित करने के लिए एक आधुनिक प्रोग्रामिंग भाषा है।

एस्प्रेसो एपीआई सरल और सीखने में आसान है। आप बहु-थ्रेडेड परीक्षण की जटिलता के बिना आसानी से एंड्रॉइड यूआई परीक्षण कर सकते हैं। Google ड्राइव, मैप्स और कुछ अन्य एप्लिकेशन वर्तमान में एस्प्रेसो का उपयोग कर रहे हैं।

एस्प्रेसो की विशेषताएं

एस्प्रेसो द्वारा समर्थित कुछ मुख्य विशेषताएं इस प्रकार हैं,

  • बहुत सरल एपीआई और इसलिए, सीखना आसान है।

  • अत्यधिक स्केलेबल और लचीला।

  • Android WebView घटक का परीक्षण करने के लिए अलग मॉड्यूल प्रदान करता है।

  • Android Intents को मान्य करने के लिए अलग मॉड्यूल प्रदान करता है।

  • आपके एप्लिकेशन और परीक्षणों के बीच स्वचालित सिंक्रनाइज़ेशन प्रदान करता है।

एस्प्रेसो के लाभ

आइये अब एस्प्रेसो के क्या लाभ हैं।

  • अनिच्छुक अनुकूलता

  • सेटअप करने में आसान।

  • अत्यधिक स्थिर परीक्षण चक्र।

  • आवेदन के बाहर भी परीक्षण गतिविधियों का समर्थन करता है।

  • JUnit4 का समर्थन करता है

  • ब्लैक बॉक्स परीक्षण लिखने के लिए उपयुक्त यूआई स्वचालन।

इस अध्याय में, आइए समझते हैं कि एस्प्रेसो फ्रेमवर्क को कैसे स्थापित किया जाए, इसे एस्प्रेसो टेस्ट लिखने के लिए कॉन्फ़िगर करें और इसे हमारे एंड्रॉइड एप्लिकेशन में निष्पादित करें।

आवश्यक शर्तें

एस्प्रेसो एंड्रॉइड एसडीके का उपयोग करके जावा / कोटलिन भाषा में विकसित एंड्रॉइड एप्लिकेशन के परीक्षण के लिए एक उपयोगकर्ता इंटरफ़ेस-परीक्षण ढांचा है। इसलिए, एस्प्रेसो की एकमात्र आवश्यकता जावा या कोटलिन में एंड्रॉइड एसडीके का उपयोग करके एप्लिकेशन को विकसित करना है और नवीनतम एंड्रॉइड स्टूडियो होने की सलाह दी जाती है।

एस्प्रेसो फ्रेमवर्क में काम शुरू करने से पहले ठीक से कॉन्फ़िगर की जाने वाली वस्तुओं की सूची इस प्रकार है -

  • नवीनतम जावा JDK स्थापित करें और JAVA_HOME पर्यावरण चर को कॉन्फ़िगर करें।

  • नवीनतम Android स्टूडियो स्थापित करें (संस्करण 3.2 या उच्चतर)।

  • SDK प्रबंधक का उपयोग करके नवीनतम Android SDK इंस्टॉल करें और ANDROID_HOME पर्यावरण चर को कॉन्फ़िगर करें।

  • नवीनतम ग्रेडल बिल्ड टूल इंस्टॉल करें और GRADLE_HOME पर्यावरण चर को कॉन्फ़िगर करें।

एस्प्रेसोइटिंग फ्रेमवर्क को कॉन्फ़िगर करें

प्रारंभ में, एस्प्रेसो परीक्षण ढांचे को एंड्रॉइड सपोर्ट लाइब्रेरी के भाग के रूप में प्रदान किया गया है। बाद में, एंड्रॉइड टीम एक नया एंड्रॉइड लाइब्रेरी, एंड्रॉइड एक्स प्रदान करती है और नवीनतम एस्प्रेसो टेस्टिंग फ्रेमवर्क डेवलपमेंट को लाइब्रेरी में ले जाती है। AndroidX लाइब्रेरी में एस्प्रेसो टेस्टिंग फ्रेमवर्क का नवीनतम विकास (एंड्रॉइड 9.0, एपीआई स्तर 28 या उच्चतर) किया जाएगा।

किसी प्रोजेक्ट में एस्प्रेसो टेस्टिंग फ्रेमवर्क को शामिल करना उतना ही सरल है जितना कि एस्प्रेसो टेस्टिंग फ्रेमवर्क को एप्लिकेशन ग्रेड फ़ाइल, ऐप / बिल्ड.ग्रेडल में निर्भरता के रूप में सेट करना सरल है। पूर्ण कॉन्फ़िगरेशन निम्नानुसार है,

Android समर्थन लाइब्रेरी का उपयोग करना,

android {
   defaultConfig {
      testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
   }
}
dependencies {
   testImplementation 'junit:junit:4.12'
   androidTestImplementation 'com.android.support.test:runner:1.0.2'
   androidTestImplementation 'com.android.support.test.espresso:espressocore:3.0.2'
}

AndroidX लाइब्रेरी का उपयोग करना,

android {
   defaultConfig {
      testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
   }
}
dependencies {
   testImplementation 'junit:junit:4.12'
   androidTestImplementation 'com.androidx.test:runner:1.0.2'
   androidTestImplementation 'com.androidx.espresso:espresso-core:3.0.2'
}

testInstrumentationRunner में एंड्रॉयड / defaultConfig सेट AndroidJUnitRunner उपकरण परीक्षण चलाने के लिए वर्ग। में पहली पंक्ति निर्भरता शामिल JUnit परीक्षण ढांचे, में दूसरी पंक्ति निर्भरता परीक्षण मामलों को चलाने के लिए परीक्षण धावक पुस्तकालय भी शामिल है और अंत में में तीसरी लाइन निर्भरता एस्प्रेसो परीक्षण ढांचा भी शामिल है।

डिफ़ॉल्ट रूप से, एंड्रॉइड स्टूडियो एस्प्रेसो टेस्टिंग फ्रेमवर्क (एंड्रॉइड सपोर्ट लाइब्रेरी) को एक निर्भरता के रूप में सेट करता है जबकि एंड्रॉइड प्रोजेक्ट बनाते समय और ग्रेडेल मावेन रिपॉजिटरी से आवश्यक लाइब्रेरी डाउनलोड करेगा। आइए हम एक सरल हैलो वर्ल्ड एंड्रॉइड एप्लिकेशन बनाएं और जांचें कि क्या एस्प्रेसो टेस्टिंग फ्रेमवर्क ठीक से कॉन्फ़िगर किया गया है।

एक नया एंड्रॉइड एप्लिकेशन बनाने के चरणों का वर्णन नीचे दिया गया है -

  • Android स्टूडियो प्रारंभ करें।

  • फ़ाइल का चयन करें → नया → नया प्रोजेक्ट।

  • दर्ज आवेदन नाम (HelloWorldApp) और कंपनी डोमेन (espressosamples.tutorialspoint.com) और उसके बाद अगला

Android प्रोजेक्ट बनाने के लिए,

  • API 15: Android 4.0.3 (IceCreamSandwich) के रूप में न्यूनतम एपीआई का चयन करें और फिर अगला क्लिक करें।

Android उपकरणों को लक्षित करने के लिए,

  • खाली गतिविधि का चयन करें और फिर अगला क्लिक करें ।

मोबाइल में एक गतिविधि जोड़ने के लिए,

  • मुख्य गतिविधि के लिए नाम दर्ज करें और फिर समाप्त पर क्लिक करें

गतिविधि को कॉन्फ़िगर करने के लिए,

  • एक बार, एक नई परियोजना बनाई जाती है, एप्लिकेशन / बिल्ड.ग्रेड फ़ाइल खोलें और इसकी सामग्री की जांच करें। फ़ाइल की सामग्री नीचे दी गई है,

apply plugin: 'com.android.application'
android {
   compileSdkVersion 28
   defaultConfig {
      applicationId "com.tutorialspoint.espressosamples.helloworldapp"
      minSdkVersion 15
      targetSdkVersion 28
      versionCode 1
      versionName "1.0"
      testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
   }
   buildTypes {
      release {
         minifyEnabled false
         proguardFiles getDefaultProguardFile('proguard-android.txt'),    'proguard-rules.pro'
      }
   }
}
dependencies {
   implementation fileTree(dir: 'libs', include: ['*.jar'])
   implementation 'com.android.support:appcompat-v7:28.0.0'
   implementation 'com.android.support.constraint:constraint-layout:1.1.3'
   testImplementation 'junit:junit:4.12'
   androidTestImplementation 'com.android.support.test:runner:1.0.2'
   androidTestImplementation 'com.android.support.test.espresso:espressocore:3.0.2'
}

अंतिम पंक्ति एस्प्रेसो टेस्टिंग फ्रेमवर्क निर्भरता को निर्दिष्ट करती है। डिफ़ॉल्ट रूप से, एंड्रॉइड समर्थन पुस्तकालय कॉन्फ़िगर किया गया है। हम मेनू में AndroidX के लिए Refactorमाइग्रेट पर क्लिक करके AndroidX लाइब्रेरी का उपयोग करने के लिए एप्लिकेशन को फिर से कॉन्फ़िगर कर सकते हैं ।

Androidx पर माइग्रेट करने के लिए,

  • अब, नीचे दिए गए अनुसार app / build.gradle परिवर्तन,

apply plugin: 'com.android.application'
android {
   compileSdkVersion 28
   defaultConfig {
      applicationId "com.tutorialspoint.espressosamples.helloworldapp"
      minSdkVersion 15
      targetSdkVersion 28
      versionCode 1
      versionName "1.0"
      testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
   }
   buildTypes {
      release {
         minifyEnabled false
         proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
      }
   }
}
dependencies {
   implementation fileTree(dir: 'libs', include: ['*.jar'])
   implementation 'androidx.appcompat:appcompat:1.1.0-alpha01'
   implementation 'androidx.constraintlayout:constraintlayout:2.0.0-alpha3'
   testImplementation 'junit:junit:4.12'
   androidTestImplementation 'androidx.test:runner:1.1.1'
   androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
}

अब, अंतिम पंक्ति में AndroidX लाइब्रेरी से एस्प्रेसो टेस्टिंग फ्रेमवर्क शामिल है।

उपकरण सेटिंग्स

परीक्षण के दौरान, एंड्रॉइड डिवाइस पर एनीमेशन को बंद करने की सिफारिश की जाती है, जिसका उपयोग परीक्षण के लिए किया जाता है। यह बेकार के संसाधनों की जाँच करते समय भ्रम को कम करेगा।

आइए देखें कि एंड्रॉइड डिवाइस पर एनीमेशन को कैसे निष्क्रिय किया जाए - (सेटिंग्स → डेवलपर विकल्प),

  • विंडो एनीमेशन स्केल

  • संक्रमण एनीमेशन पैमाना

  • एनिमेटर अवधि पैमाने

यदि सेटिंग स्क्रीन में डेवलपर विकल्प मेनू उपलब्ध नहीं है , तो कई बार फोन के बारे में विकल्प के अंदर उपलब्ध बिल्ड नंबर पर क्लिक करें । यह डेवलपर विकल्प मेनू को सक्षम करता है ।

इस अध्याय में, आइए देखें कि एंड्रॉइड स्टूडियो का उपयोग करके परीक्षण कैसे चलाएं।

हर Android एप्लिकेशन में दो प्रकार के परीक्षण होते हैं -

  • कार्यात्मक / यूनिट परीक्षण

  • यंत्र परीक्षण

कार्यात्मक परीक्षण को डिवाइस या एमुलेटर में स्थापित और लॉन्च करने के लिए वास्तविक एंड्रॉइड एप्लिकेशन की आवश्यकता नहीं है और कार्यक्षमता का परीक्षण करें। इसे वास्तविक एप्लिकेशन को लागू किए बिना कंसोल में ही लॉन्च किया जा सकता है। हालांकि, इंस्ट्रूमेंटेशन परीक्षणों को उपयोगकर्ता इंटरफ़ेस और उपयोगकर्ता इंटरैक्शन जैसी कार्यक्षमता का परीक्षण करने के लिए वास्तविक एप्लिकेशन लॉन्च करने की आवश्यकता होती है। डिफ़ॉल्ट रूप से, यूनिट परीक्षण में लिखा जाता हैsrc/test/java/ फ़ोल्डर और इंस्ट्रूमेंटेशन टेस्ट में लिखा जाता है src/androidTest/java/फ़ोल्डर। एंड्रॉइड स्टूडियो परीक्षण वर्गों को चयनित परीक्षण कक्षाओं में लिखित परीक्षा को चलाने के लिए रन संदर्भ मेनू प्रदान करता है । डिफ़ॉल्ट रूप से, एक एंड्रॉइड एप्लिकेशन में दो वर्ग होते हैं - ExampleUnitTest in src / test folder और ExampleInstrumentedTest in src / androidTest फ़ोल्डर।

डिफ़ॉल्ट इकाई परीक्षण चलाने के लिए, Android स्टूडियो में ExampleUnitTest का चयन करें , उस पर राइट-क्लिक करें और फिर नीचे दिखाए गए अनुसार 'ExampleUnitTest' पर क्लिक करें।

यूनिट टेस्ट चलाएं

यह इकाई परीक्षण चलाएगा और कंसोल में परिणाम निम्न स्क्रीनशॉट में दिखाएगा -

यूनिट टेस्ट सफलता

डिफ़ॉल्ट इंस्ट्रूमेंटेशन टेस्ट को चलाने के लिए, Android स्टूडियो में ExampleInstrumentationTest का चयन करें, इसे राइट-क्लिक करें और फिर नीचे दिखाए गए अनुसार Run 'ExampleInstrumentationTest' पर क्लिक करें,

इंस्ट्रूमेंटेशन टेस्ट चलाएं

यह डिवाइस या एमुलेटर में एप्लिकेशन लॉन्च करके यूनिट टेस्ट चलाएगा और कंसोल में परिणाम निम्न स्क्रीनशॉट में दिखाएगा -

यंत्र परीक्षण सफल रहा।

इस अध्याय में, हम JUnit की मूल बातों को समझते हैं , जावा समुदाय द्वारा विकसित लोकप्रिय इकाई-परीक्षण रूपरेखा, जिस पर एस्प्रेसो परीक्षण ढांचे का निर्माण होता है।

JUnit एक जावा एप्लिकेशन के परीक्षण के लिए डी वास्तविक मानक है। हालांकि, यह इकाई परीक्षण के लिए लोकप्रिय है, इसमें इंस्ट्रूमेंटेशन परीक्षण के लिए भी पूरा समर्थन और प्रावधान है। एस्प्रेसो परीक्षण पुस्तकालय एंड्रॉइड आधारित इंस्ट्रूमेंटेशन परीक्षण का समर्थन करने के लिए आवश्यक JUnit कक्षाओं का विस्तार करता है।

एक साधारण यूनिट टेस्ट लिखें

आइए हम एक जावा वर्ग बनाते हैं, संगणना (Computation.java) और सरल गणितीय ऑपरेशन, संक्षेपण और गुणन लिखते हैं । फिर, हम JUnit का उपयोग करके परीक्षण मामलों को लिखेंगे और परीक्षण मामलों को चलाकर इसकी जांच करेंगे।

  • Android स्टूडियो प्रारंभ करें।

  • पिछले अध्याय में बनाया गया HelloWorldApp खोलें ।

  • एक फ़ाइल बनाएँ, Computation.java इन ऐप / src / main / java / com / tutorialspoint / espressosamples / helloworldapp / और दो कार्य लिखें - नीचे दिए अनुसार, Sum और गुणा करें,

package com.tutorialspoint.espressosamples.helloworldapp;
public class Computation {
   public Computation() {}
   public int Sum(int a, int b) {
      return a + b;
   }
   public int Multiply(int a, int b) {
      return a * b;
   }
}
  • एक फ़ाइल बनाएँ, ComputationUnitTest.java इन ऐप / src / test / java / com / tutorialspoint / espressosamples / helloworldapp और यूनिट टेस्ट मामलों को लिखें ताकि नीचे दी गई सुम और कार्यक्षमता का परीक्षण किया जा सके।

package com.tutorialspoint.espressosamples.helloworldapp;
import org.junit.Test;
import static org.junit.Assert.assertEquals;
public class ComputationUnitTest {
   @Test
   public void sum_isCorrect() {
      Computation computation = new Computation();
      assertEquals(4, computation.Sum(2,2));
   }
   @Test
   public void multiply_isCorrect() {
      Computation computation = new Computation();
      assertEquals(4, computation.Multiply(2,2));
   }
}

यहाँ, हमने दो नए शब्दों का उपयोग किया है - @Test और assertEquals । सामान्य तौर पर, JUnit एक वर्ग में परीक्षण मामलों की पहचान करने और परीक्षण मामलों को निष्पादित करने के तरीके के बारे में जानकारी के लिए जावा एनोटेशन का उपयोग करता है। @ टेस्ट एक ऐसा जावा एनोटेशन है, जो यह निर्दिष्ट करता है कि विशेष फ़ंक्शन एक जूनियर टेस्ट केस है। assertEquals एक फ़ंक्शन है जो यह तर्क देता है कि पहला तर्क (अपेक्षित मान) और दूसरा तर्क (गणना मूल्य) समान और समान हैं। JUnit विभिन्न परीक्षण परिदृश्यों के लिए कई मुखर तरीके प्रदान करता है।

  • अब, चलाने ComputationUnitTest वर्ग राइट-क्लिक करके और भागो लागू द्वारा एंड्रॉयड स्टूडियो में 'ComputationUnitTest' विकल्प के रूप में पिछले अध्याय में विस्तार से बताया। यह इकाई परीक्षण मामलों को चलाएगा और सफलता की रिपोर्ट करेगा।

अभिकलन इकाई परीक्षण का परिणाम निम्नानुसार है -

एनोटेशन

JUnit फ्रेमवर्क बड़े पैमाने पर एनोटेशन का उपयोग करता है । कुछ महत्वपूर्ण एनोटेशन इस प्रकार हैं -

  • @Test

  • @Before

  • @After

  • @BeforeClass

  • @AfterClass

  • @Rule

@ सबसे अधिक एनोटेशन

@ JUnit ढांचे में सबसे महत्वपूर्ण एनोटेशन है । @ टेस्ट टेस्ट विधि से एक सामान्य विधि को अलग करने के लिए टेस्ट का उपयोग किया जाता है। एक बार जब कोई विधि @ सबसे टिप्पणी के साथ सजाई जाती है , तो उस विशेष विधि को टेस्ट केस के रूप में माना जाता है और JUnit Runner द्वारा चलाया जाएगा । JUnit Runner एक विशेष वर्ग है, जिसका उपयोग जावा कक्षाओं के अंदर उपलब्ध JUnit परीक्षण मामलों को खोजने और चलाने के लिए किया जाता है । अभी के लिए, हम यूनिट परीक्षणों को चलाने के लिए एंड्रॉइड स्टूडियो के बिल्ड ऑप्शन का उपयोग कर रहे हैं (जो बदले में JUnit रनर को चलाते हैं )। एक नमूना कोड इस प्रकार है,

package com.tutorialspoint.espressosamples.helloworldapp;
import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class ComputationUnitTest {
   @Test
   public void multiply_isCorrect() {
      Computation computation = new Computation();
      assertEquals(4, computation.Multiply(2,2));
   }
}

@इससे पहले

@Before एनोटेशन का उपयोग किसी विधि को संदर्भित करने के लिए किया जाता है, जिसे किसी विशेष परीक्षण वर्ग में उपलब्ध किसी भी परीक्षण विधि को चलाने से पहले लागू करने की आवश्यकता होती है। हमारे नमूने में उदाहरण के लिए, कम्प्यूटेशन ऑब्जेक्ट को एक अलग विधि में बनाया जा सकता है और @Before के साथ एनोटेट किया जाता है ताकि यह sum_isCorrect और multiply_isCorrect टेस्ट केस दोनों से पहले चले । पूरा कोड इस प्रकार है,

package com.tutorialspoint.espressosamples.helloworldapp;
import org.junit.Before;
import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class ComputationUnitTest {
   Computation computation = null;
   @Before
   public void CreateComputationObject() {
      this.computation = new Computation();
   }
   @Test
   public void sum_isCorrect() {
      assertEquals(4, this.computation.Sum(2,2));
   }
   @Test
   public void multiply_isCorrect() {
      assertEquals(4, this.computation.Multiply(2,2));
   }
}

@उपरांत

@After के समान है @Before , लेकिन विधि के साथ एनोटेट @After कहा जाता है या बाद प्रत्येक परीक्षण का मामला चलाया जाता है निष्पादित किया जाएगा। नमूना कोड निम्नानुसार है,

package com.tutorialspoint.espressosamples.helloworldapp;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class ComputationUnitTest {
   Computation computation = null;
   @Before
   public void CreateComputationObject() {
      this.computation = new Computation();
   }
   @After
   public void DestroyComputationObject() {
      this.computation = null;
   }
   @Test
   public void sum_isCorrect() {
      assertEquals(4, this.computation.Sum(2,2));
   }
   @Test
   public void multiply_isCorrect() {
      assertEquals(4, this.computation.Multiply(2,2));
   }
}

@कक्षा से पहले

@BeforeClass के समान है @Before , लेकिन विधि के साथ एनोटेट @BeforeClass कहा जाता है या एक विशेष वर्ग में सभी प्रकार के परीक्षण चलाने से पहले केवल एक बार निष्पादित किया जाएगा। डेटाबेस कनेक्शन ऑब्जेक्ट जैसे संसाधन गहन ऑब्जेक्ट बनाने के लिए उपयोगी है। इससे परीक्षण मामलों के संग्रह को निष्पादित करने का समय कम हो जाएगा। ठीक से काम करने के लिए इस विधि को स्थिर करने की आवश्यकता है। हमारे नमूने में, हम नीचे दिए गए अनुसार सभी परीक्षण मामलों को चलाने से पहले एक बार कम्प्यूटेशन ऑब्जेक्ट बना सकते हैं,

package com.tutorialspoint.espressosamples.helloworldapp;
import org.junit.BeforeClass;
import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class ComputationUnitTest {
   private static Computation computation = null;
   @BeforeClass
   public static void CreateComputationObject() {
      computation = new Computation();
   }
   @Test
   public void sum_isCorrect() {
      assertEquals(4, computation.Sum(2,2));
   }
   @Test
   public void multiply_isCorrect() {
      assertEquals(4, computation.Multiply(2,2));
   }
}

@कक्षा के बाद

@AfterClass के समान है @BeforeClass , लेकिन विधि के साथ एनोटेट @AfterClass कहा जाता है या केवल एक बार के बाद एक विशेष वर्ग में सभी प्रकार के परीक्षण चलाए जा रहे हैं निष्पादित किया जाएगा। इस विधि को भी ठीक से काम करने के लिए स्थिर होने की आवश्यकता है। नमूना कोड इस प्रकार है -

package com.tutorialspoint.espressosamples.helloworldapp;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;
import static org.junit.Assert.assertEquals;

public class ComputationUnitTest {
   private static Computation computation = null;
   @BeforeClass
   public static void CreateComputationObject() {
      computation = new Computation();
   }
   @AfterClass
   public static void DestroyComputationObject() {
      computation = null;
   }
   @Test
   public void sum_isCorrect() {
      assertEquals(4, computation.Sum(2,2));
   }
   @Test
   public void multiply_isCorrect() {
      assertEquals(4, computation.Multiply(2,2));
   }
}

@Rule

@ नियम एनोटेशन JUnit के मुख्य आकर्षण में से एक है । इसका उपयोग परीक्षण मामलों में व्यवहार को जोड़ने के लिए किया जाता है। हम केवल TestRule के प्रकारों की व्याख्या कर सकते हैं । यह वास्तव में @Before और @Afteration द्वारा प्रदान की गई सुविधा सेट प्रदान करता है लेकिन एक कुशल और पुन: प्रयोज्य तरीके से। उदाहरण के लिए, हमें परीक्षण मामले के दौरान कुछ डेटा संग्रहीत करने के लिए एक अस्थायी फ़ोल्डर की आवश्यकता हो सकती है। आम तौर पर, हमें टेस्ट केस चलाने से पहले एक अस्थायी फ़ोल्डर बनाना होगा (या तो @Before या @BeforeClass एनोटेशन का उपयोग करके) और टेस्ट केस चलने के बाद इसे नष्ट करना होगा (या तो @After या @AfterClass एनोटेशन का उपयोग करके)। इसके बजाय, हम अपने सभी परीक्षण मामलों के लिए एक अस्थायी फ़ोल्डर बनाने के लिए JUnit फ्रेमवर्क द्वारा प्रदान किए गए TemporaryFolder (प्रकार TestRule ) वर्ग का उपयोग कर सकते हैं और परीक्षण मामले के चलने पर अस्थायी फ़ोल्डर को हटा दिया जाएगा। हमें अस्थायी अस्थाई फ़ोल्डर का एक नया चर बनाने की जरूरत है और नीचे दिए गए अनुसार @ नियम के साथ एनोटेट करने की आवश्यकता है ,

package com.tutorialspoint.espressosamples.helloworldapp;

import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.TemporaryFolder;
import java.io.File;
import java.io.IOException;
import static junit.framework.TestCase.assertTrue;
import static org.junit.Assert.assertEquals;

public class ComputationUnitTest {
   private static Computation computation = null;
   @Rule
   public TemporaryFolder folder = new TemporaryFolder();
   @Test
   public void file_isCreated() throws IOException {
      folder.newFolder("MyTestFolder");
      File testFile = folder.newFile("MyTestFile.txt");
      assertTrue(testFile.exists());
   }
   @BeforeClass
   public static void CreateComputationObject() {
      computation = new Computation();
   }
   @AfterClass
   public static void DestroyComputationObject() {
      computation = null;
   }
   @Test
   public void sum_isCorrect() {
      assertEquals(4, computation.Sum(2,2));
   }
   @Test
   public void multiply_isCorrect() {
      assertEquals(4, computation.Multiply(2,2));
   }
}

निष्पादन का आदेश

में JUnit , अलग एनोटेशन के साथ एनोटेट तरीकों, जिन्हें आप नीचे विशेष क्रम में निष्पादित किया जाएगा

  • @BeforeClass

  • @Rule

  • @Before

  • @Test

  • @After

  • @AfterClass

अभिकथन

परख यह जाँचने का एक तरीका है कि परीक्षण मामले के अपेक्षित मूल्य परीक्षण मामले के परिणाम के वास्तविक मूल्य से मेल खाते हैं या नहीं। JUnit विभिन्न परिदृश्यों के लिए अभिकथन प्रदान करता है; कुछ महत्वपूर्ण दावे नीचे सूचीबद्ध हैं -

  • fail() - स्पष्ट रूप से एक परीक्षण मामले को विफल करने के लिए।

  • assertTrue(boolean test_condition) - जाँचता है कि test_condition सत्य है

  • assertFalse(boolean test_condition) - जाँचता है कि test_condition झूठा है

  • assertEquals(expected, actual) - जाँचता है कि दोनों मूल्य समान हैं

  • assertNull(object) - जाँचता है कि वस्तु अशक्त है

  • assertNotNull(object) - जाँचता है कि वस्तु अशक्त नहीं है

  • assertSame(expected, actual) - जाँचता है कि दोनों एक ही वस्तु को संदर्भित करते हैं।

  • assertNotSame(expected, actual) - जाँचता है कि दोनों अलग-अलग ऑब्जेक्ट को संदर्भित करते हैं।

इस अध्याय में, आइए हम एस्प्रेसो टेस्टिंग फ्रेमवर्क की शर्तों को जानें, एक साधारण एस्प्रेसो टेस्ट केस कैसे लिखें और एस्प्रेसो टेस्टिंग फ्रेमवर्क का पूरा वर्कफ़्लो या आर्किटेक्चर।

अवलोकन

एस्प्रेसो उपयोगकर्ता इंटरफ़ेस और एक Android एप्लिकेशन के उपयोगकर्ता इंटरैक्शन का परीक्षण करने के लिए बड़ी संख्या में कक्षाएं प्रदान करता है। उन्हें नीचे सूचीबद्ध पांच श्रेणियों में बांटा जा सकता है -

JUnit धावक

एंड्रॉइड टेस्टिंग फ्रेमवर्क एक धावक, AndroidJUnitRunner को JUnit3 और JUnit4 स्टाइल टेस्ट मामलों में लिखे गए एस्प्रेसो टेस्ट मामलों को चलाने के लिए प्रदान करता है। यह एंड्रॉइड एप्लिकेशन के लिए विशिष्ट है और यह एस्प्रेसो टेस्ट मामलों और वास्तविक डिवाइस या एमुलेटर दोनों में परीक्षण के तहत एप्लिकेशन को लोड करने में पारदर्शी रूप से काम करता है, परीक्षण मामलों को निष्पादित करता है और परीक्षण मामलों के परिणाम की रिपोर्ट करता है। परीक्षण के मामले में AndroidJUnitRunner का उपयोग करने के लिए, हमें @RunWith एनोटेशन का उपयोग करके परीक्षण वर्ग को एनोटेट करने की आवश्यकता है और फिर नीचे दिए गए अनुसार AndroidJUnitRunner तर्क पास करें -

@RunWith(AndroidJUnit4.class)
   public class ExampleInstrumentedTest {
}

JUnit नियम

Android परीक्षण ढाँचा एक नियम प्रदान करता है, TestTestRule परीक्षण मामलों को निष्पादित करने से पहले एक Android गतिविधि शुरू करने के लिए। यह @ Test` और @Before के साथ एनोटेट किए गए प्रत्येक विधि से पहले गतिविधि को लॉन्च करता है। @After के साथ विधि एनोटेट किए जाने के बाद यह गतिविधि को समाप्त कर देगा। एक नमूना कोड इस प्रकार है,

@Rule
public ActivityTestRule<MainActivity> mActivityTestRule = new ActivityTestRule<>(MainActivity.class);

इधर, MainActivity एक टेस्ट केस चलाने से पहले लॉन्च की जाने वाली गतिविधि है और विशेष टेस्ट केस चलने के बाद नष्ट हो जाती है।

ViewMatchers

एस्प्रेसो बड़ी संख्या में देखने वाले मैचर्स क्लासेस ( androidx.test.espresso.matcher.ViewMatchers पैकेज में ) प्रदान करता है और एक एंड्रॉइड एक्टिविटी स्क्रीन के पदानुक्रम में यूआई तत्वों / दृश्यों को खोजने और खोजने के लिए। एस्प्रेसो की विधि onView प्रकार का एक भी तर्क लेता Matcher (देखें matchers), इसी यूआई देख सकते हैं और रिटर्न इसी पाता ViewInteraction वस्तु। दृश्य दृश्य पर लौटाए गए दृश्य ऑब्जेक्ट का उपयोग आगे की कार्रवाई के लिए किया जा सकता है जैसे मिलान किए गए दृश्य पर क्लिक करने के लिए या मिलान किए गए दृश्य को मुखर करने के लिए उपयोग किया जा सकता है। पाठ के साथ दृश्य को खोजने के लिए एक नमूना कोड, "हैलो वर्ल्ड!" इस प्रकार है,

ViewInteraction viewInteraction = Espresso.onView(withText("Hello World!"));

यहाँ, withText एक मिलानकर्ता है, जिसका उपयोग UI देखने के पाठ "हैलो वर्ल्ड!" से किया जा सकता है।

ViewActions

एस्प्रेसो चयनित / मिलान किए गए दृश्य पर अलग-अलग कार्रवाई करने के लिए बड़ी संख्या में व्यू एक्शन क्लासेस (androidx.test.espresso.action.ViewActions में) प्रदान करता है। एक बार जब onView मैच और रिटर्न ViewInteraction वस्तु, किसी भी कार्रवाई को "प्रदर्शन" की विधि द्वारा लागू किया जा सकता है ViewInteraction वस्तु और उचित दृश्य कार्यों के साथ इसे पारित। मिलान किए गए दृश्य पर क्लिक करने के लिए एक नमूना कोड निम्नानुसार है,

ViewInteraction viewInteraction = Espresso.onView(withText("Hello World!"));
viewInteraction.perform(click());

यहां, मिलान किए गए दृश्य की क्लिक कार्रवाई को आमंत्रित किया जाएगा।

ViewAssertions

मैच देखने वालों और देखने की क्रियाओं के समान, एस्प्रेसो मिलान किए गए दृश्य को मुखर करने के लिए ( androidx.test.espresso.assertion.ViewAssertions पैकेज में) बड़ी संख्या में दृश्य प्रदान करता है। एक बार जब onView से मेल खाता है और रिटर्न ViewInteraction वस्तु, किसी भी ज़ोर की जांच विधि का उपयोग कर जाँच की जा सकती ViewInteraction उचित दृश्य दावे से यह पारित करके। एक नमूना कोड मुखर है कि मिलान किया गया दृश्य निम्नानुसार है,

ViewInteraction viewInteraction = Espresso.onView(withText("Hello World!"));
viewInteraction.check(matches(withId(R.id.text_view)));

यहाँ, मैच देखने वाले को स्वीकार करते हैं और दृश्य को वापस लौटाते हैं, जिसे ViewInteraction के चेक विधि द्वारा चेक किया जा सकता है ।

एस्प्रेसो टेस्टिंग फ्रेमवर्क का वर्कफ़्लो

आइए हम समझते हैं कि एस्प्रेसो टेस्टिंग फ्रेमवर्क कैसे काम करता है और यह कैसे सरल और लचीले तरीके से किसी भी प्रकार की उपयोगकर्ता बातचीत करने के विकल्प प्रदान करता है। एस्प्रेसो परीक्षण मामले का वर्कफ़्लो नीचे वर्णित है,

  • जैसा कि हमने पहले सीखा, Android JUnit धावक, AndroidJUnit4 Android परीक्षण मामलों को चलाएगा। एस्प्रेसो परीक्षण मामलों को @RunWith (AndroidJUnut.class) के साथ चिह्नित करने की आवश्यकता है । सबसे पहले, AndroidJUnit4 परीक्षण मामलों को चलाने के लिए वातावरण तैयार करेगा। यह या तो कनेक्टेड एंड्रॉइड डिवाइस या एमुलेटर से शुरू होता है, एप्लिकेशन इंस्टॉल करता है और यह सुनिश्चित करता है कि जिस एप्लिकेशन का परीक्षण किया जाना है वह तैयार अवस्था में है। यह परीक्षण मामलों को चलाएगा और परिणामों की रिपोर्ट करेगा।

  • एस्प्रेसो को गतिविधि को निर्दिष्ट करने के लिए कम से कम एक JUnit प्रकार की गतिविधि TestRule का नियम चाहिए । Android JUnit धावक एक्टिविटीटेस्ट नियम का उपयोग करके लॉन्च की जाने वाली गतिविधि को शुरू करेगा ।

  • हर परीक्षण का मामला एक की एक न्यूनतम जरूरत onView या onDate (डेटा की तरह आधारित विचारों को खोजने के लिए इस्तेमाल किया AdapterView से मेल खाते हैं और वांछित दृश्य को खोजने के लिए विधि मंगलाचरण)। onView या onData ViewInteraction ऑब्जेक्ट देता है ।

  • एक बार जब ViewInteraction ऑब्जेक्ट वापस आ जाता है, तो हम या तो चयनित दृश्य की कार्रवाई को लागू कर सकते हैं या दावे के साथ हमारे अपेक्षित दृश्य के लिए दृश्य की जांच कर सकते हैं।

  • उपलब्ध दृश्य क्रियाओं में से किसी एक को पारित करके ViewInteraction ऑब्जेक्ट के प्रदर्शन विधि का उपयोग करके कार्रवाई को लागू किया जा सकता है ।

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

वर्कफ़्लो का आरेख निरूपण इस प्रकार है,

उदाहरण — देखें जोर

आइए हम "हैलो वर्ल्ड!" वाले टेक्स्ट व्यू को खोजने के लिए एक साधारण टेस्ट केस लिखते हैं। हमारे "HelloWorldApp" एप्लिकेशन में पाठ और फिर दृश्य अभिकथन का उपयोग करके इसे मुखर करें। पूरा कोड इस प्रकार है,

package com.tutorialspoint.espressosamples.helloworldapp;

import android.content.Context;
import androidx.test.InstrumentationRegistry;
import androidx.test.rule.ActivityTestRule;
import androidx.test.runner.AndroidJUnit4;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;
import static androidx.test.espresso.Espresso.onView;
import static androidx.test.espresso.matcher.ViewMatchers.withText;;
import static androidx.test.espresso.assertion.ViewAssertions.matches;
import static org.junit.Assert.*;
/**
   * Instrumented test, which will execute on an Android device.
   *
   * @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
*/
@RunWith(AndroidJUnit4.class)
public class ExampleInstrumentedTest {
   @Rule
   public ActivityTestRule<MainActivity> mActivityTestRule = new ActivityTestRule<>(MainActivity.class);
   @Test
   public void view_isCorrect() {
      onView(withText("Hello World!")).check(matches(isDisplayed()));
   }
   @Test
   public void useAppContext() {
      // Context of the app under test.
      Context appContext = InstrumentationRegistry.getTargetContext();
      assertEquals("com.tutorialspoint.espressosamples.helloworldapp", appContext.getPackageName());
   }
}

यहाँ, हम इस्तेमाल किया है withText दृश्य matchers होने पाठ दृश्य को खोजने के लिए "नमस्ते दुनिया!" पाठ और मिलान इस बात पर जोर देते हैं कि पाठ दृश्य ठीक से प्रदर्शित हो। एंड्रॉइड स्टूडियो में परीक्षण का मामला आने के बाद, यह परीक्षण मामले को चलाएगा और नीचे दिए गए सफलता संदेश को रिपोर्ट करेगा।

view_isCorrect test मामला

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

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

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

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

Hamcrest provides a simple function assertThat and a collection of matchers to assert any objects. assertThat has three arguments and they are as shown below −

  • String (description of the test, optional)

  • Object (actual)

  • Matcher (expected)

Let us write a simple example to test whether a list object has expected value.

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"));
}

Here, hasItem returns a matcher, which checks whether the actual list has specified value as one of the item.

Hamcrest has a lot of built-in matchers and also options to create new matchers. Some of the important built-in matchers useful in espresso testing framework are as follows −

anything - always matchers

Logical based matchers

  • allOf − accept any number of matchers and matches only if all matchers are succeeded.

  • anyOf − accept any number of matchers and matches if any one matcher succeeded.

  • not − accept one matcher and matches only if the matcher failed and vice versa.

Text based matchers

  • equalToIgnoringCase − used to test whether the actual input equals the expected string ignoring case.

  • equalToIgnoringWhiteSpace − used to test whether the actual input equals the specified string ignoring case and white spaces.

  • containsString − used to test whether the actual input contains specified string.

  • endsWith − used to test whether the actual input starts with specified string.

  • startsWith − used to test whether actual the input ends with specified string.

Number based matchers

  • closeTo − used to test whether the actual input is close to the expected number.

  • greaterThan − used to test whether the actual input is greater than the expected number.

  • greaterThanOrEqualTo − used to test whether the actual input is greater than or equal to the expected number.

  • lessThan − used to test whether the actual input is less than the expected number.

  • lessThanOrEqualTo − used to test whether the actual input is less than or equal to the expected number.

Object based matchers

  • equalTo − used to test whether the actual input is equals to the expected object

  • hasToString − used to test whether the actual input has toString method.

  • instanceOf − used to test whether the actual input is the instance of expected class.

  • isCompatibleType − used to test whether the actual input is compatible with the expected type.

  • notNullValue − used to test whether the actual input is not null.

  • sameInstance − used to test whether the actual input and expected are of same instance.

  • hasProperty − used to test whether the actual input has the expected property

is − Sugar or short cut for equalTo

Matchers

Espresso provides the onView() method to match and find the views. It accepts view matchers and returns ViewInteraction object to interact with the matched view. The frequently used list of view matchers are described below −

withId()

withId() accepts an argument of type int and the argument refers the id of the view. It returns a matcher, which matches the view using the id of the view. The sample code is as follows,

onView(withId(R.id.testView))

withText()

withText() accepts an argument of type string and the argument refers the value of the view’s text property. It returns a matcher, which matches the view using the text value of the view. It applies to TextView only. The sample code is as follows,

onView(withText("Hello World!"))

withContentDescription()

withContentDescription() accepts an argument of type string and the argument refers the value of the view’s content description property. It returns a matcher, which matches the view using the description of the view. The sample code is as follows,

onView(withContentDescription("blah"))

We can also pass the resource id of the text value instead of the text itself.

onView(withContentDescription(R.id.res_id_blah))

hasContentDescription()

hasContentDescription() has no argument. It returns a matcher, which matches the view that has any content description. The sample code is as follows,

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

withTagKey()

withTagKey() accepts an argument of type string and the argument refers the view’s tag key. It returns a matcher, which matches the view using its tag key. The sample code is as follows,

onView(withTagKey("blah"))

We can also pass the resource id of the tag name instead of the tag name itself.

onView(withTagKey(R.id.res_id_blah))

withTagValue()

withTagValue() accepts an argument of type Matcher <Object> and the argument refers the view’s tag value. It returns a matcher, which matches the view using its tag value. The sample code is as follows,

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

Here, is is Hamcrest matcher.

withClassName()

withClassName() accepts an argument of type Matcher<String> and the argument refers the view’s class name value. It returns a matcher, which matches the view using its class name. The sample code is as follows,

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

Here, endsWith is Hamcrest matcher and return Matcher<String>

withHint()

withHint() accepts an argument of type Matcher<String> and the argument refers the view’s hint value. It returns a matcher, which matches the view using the hint of the view. The sample code is as follows,

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

withInputType()

withInputType() accepts an argument of type int and the argument refers the input type of the view. It returns a matcher, which matches the view using its input type. The sample code is as follows,

onView(withInputType(TYPE_CLASS_DATETIME))

Here, TYPE_CLASS_DATETIME refers edit view supporting dates and times.

withResourceName()

withResourceName() accepts an argument of type Matcher<String> and the argument refers the view’s class name value. It returns a matcher, which matches the view using resource name of the view. The sample code is as follows,

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

It accepts string argument as well. The sample code is as follows,

onView(withResourceName("my_res_name"))

withAlpha()

withAlpha() accepts an argument of type float and the argument refers the alpha value of the view. It returns a matcher, which matches the view using the alpha value of the view. The sample code is as follows,

onView(withAlpha(0.8))

withEffectiveVisibility()

withEffectiveVisibility() accepts an argument of type ViewMatchers.Visibility and the argument refers the effective visibility of the view. It returns a matcher, which matches the view using the visibility of the view. The sample code is as follows,

onView(withEffectiveVisibility(withEffectiveVisibility.INVISIBLE))

withSpinnerText()

withSpinnerText() accepts an argument of type Matcher<String> and the argument refers the Spinner’s current selected view’s value. It returns a matcher, which matches the the spinner based on it’s selected item’s toString value. The sample code is as follows,

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

It accepts string argument or resource id of the string as well. The sample code is as follows,

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

withSubstring()

withSubString() is similar to withText() except it helps to test substring of the text value of the view.

onView(withSubString("Hello"))

hasLinks()

hasLinks() has no arguments and it returns a matcher, which matches the view having links. It applies to TextView only. The sample code is as follows,

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

Here, allOf is a Hamcrest matcher. allOf returns a matcher, which matches all the passed in matchers and here, it is used to match a view as well as check whether the view has links in its text value.

hasTextColor()

hasTextColor() accepts a single argument of type int and the argument refers the resource id of the color. It returns a matcher, which matches the TextView based on its color. It applies to TextView only. The sample code is as follows,

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

hasEllipsizedText()

hasEllipsizedText() has no argument. It returns a matcher, which matches the TextView that has long text and either ellipsized (first.. ten.. last) or cut off (first…). The sample code is as follows,

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

hasMultilineText()

hasMultilineText() has no argument. It returns a matcher, which matches the TextView that has any multi line text. The sample code is as follows,

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

hasBackground()

hasBackground() accepts a single argument of type int and the argument refers the resource id of the background resource. It returns a matcher, which matches the view based on its background resources. The sample code is as follows,

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

hasErrorText()

hasErrorText() accepts an argument of type Matcher<String> and the argument refers the view’s (EditText) error string value. It returns a matcher, which matches the view using error string of the view. This applies to EditText only. The sample code is as follows,

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

It accepts string argument as well. The sample code is as follows,

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

hasImeAction()

hasImeAction() accepts an argument of type Matcher<Integer> and the argument refers the view’s (EditText) supported input methods. It returns a matcher, which matches the view using supported input method of the view. This applies to EditText only. The sample code is as follows,

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

Here, EditorInfo.IME_ACTION_GO is on of the input methods options. hasImeAction() accepts integer argument as well. The sample code is as follows,

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

supportsInputMethods()

supportsInputMethods() has no argument. It returns a matcher, which matches the view if it supports input methods. The sample code is as follows,

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

isRoot()

isRoot() has no argument. It returns a matcher, which matches the root view. The sample code is as follows,

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

isDisplayed()

isDisplayed() has no argument. It returns a matcher, which matches the view that are currently displayed. The sample code is as follows,

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

isDisplayingAtLeast()

isDisplayingAtLeast() accepts a single argument of type int. It returns a matcher, which matches the view that are current displayed at least the specified percentage. The sample code is as follows,

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

isCompletelyDisplayed()

isCompletelyDisplayed() has no argument. It returns a matcher, which matches the view that are currently displayed completely on the screen. The sample code is as follows,

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

isEnabled()

isEnabled() has no argument. It returns a matcher, which matches the view that is enabled. The sample code is as follows,

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

isFocusable()

isFocusable() has no argument. It returns a matcher, which matches the view that has focus option. The sample code is as follows,

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

hasFocus()

hasFocus() has no argument. It returns a matcher, which matches the view that is currently focused. The sample code is as follows,

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

isClickable()

isClickable() has no argument. It returns a matcher, which matches the view that is click option. The sample code is as follows,

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

isSelected()

isSelected() has no argument. It returns a matcher, which matches the view that is currently selected. The sample code is as follows,

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

isChecked()

isChecked() has no argument. It returns a matcher, which matches the view that is of type CompoundButton (or subtype of it) and is in checked state. The sample code is as follows,

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))))

एस्प्रेसो हमारे अपने कस्टम व्यू मैचर्स बनाने के लिए विभिन्न विकल्प प्रदान करता है और यह हैमरेस्ट मैचर्स पर आधारित है । कस्टम मिलानर फ्रेमवर्क का विस्तार करने के लिए और हमारे स्वाद के लिए फ्रेमवर्क को अनुकूलित करने के लिए एक बहुत शक्तिशाली अवधारणा है। कस्टम मैचर्स लिखने के कुछ फायदे इस प्रकार हैं,

  • अपने स्वयं के कस्टम विचारों की अनूठी विशेषता का फायदा उठाने के लिए

  • कस्टम मिलानकर्ता अलग-अलग प्रकार के अंतर्निहित डेटा के साथ मिलान करने के लिए AdapterView आधारित परीक्षण मामलों में मदद करता है ।

  • एकाधिक मिलान करने वाले की विशेषताओं को मिलाकर वर्तमान मिलान को सरल बनाने के लिए

जब और जब मांग उठती है तब हम नया मिलान कर सकते हैं और यह काफी आसान है। आइए हम एक नया कस्टम मिलानकर्ता बनाते हैं, जो एक मिलानकर्ता को एक टेक्स्ट व्यू की आईडी और पाठ दोनों का परीक्षण करने के लिए लौटाता है ।

एस्प्रेसो नए मिलान लिखने के लिए निम्नलिखित दो कक्षाएं प्रदान करता है -

  • TypeSafeMatcher

  • BoundedMatcher

दोनों वर्ग प्रकृति में समान हैं सिवाय इसके कि बाउन्डमैचर पारदर्शी ढंग से सही प्रकार की जांच के बिना ऑब्जेक्ट की कास्टिंग को सही प्रकार से जांचता है । हम एक नया माचिस बनाएँगे , जिसके साथ IndIAndText बाउंडेडमैच क्लास का उपयोग करेगा । आइए हम नए मिलान लिखने के लिए चरणों की जाँच करें।

  • एप्लिकेशन / 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!")));
}

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

onView(withId(R.id.my_view)) .check(matches(withText("Hello")))

यहाँ,

  • onView () मिलान किए गए दृश्य के अनुरूप ViewInteration ऑब्जेक्ट देता है । मिलान दृश्य के साथ सहभागिता करने के लिए ViewInteraction का उपयोग किया जाता है।

  • withId (R.id.my_view) एक दृश्य मिलान करता है, जो दृश्य (वास्तविक) आईडी विशेषताओं के साथ मेल खाता है, जो my_view के बराबर है ।

  • withText ("Hello") भी एक दृश्य मिलान करता है जो दृश्य के साथ मेल खाता होगा (अपेक्षित) पाठ विशेषताओं वाले Hello के बराबर है ।

  • चेक एक ऐसी विधि है, जो व्यूअर्सर्शन के एक तर्क को स्वीकार करती है और व्यूअर्सर्शन ऑब्जेक्ट में पारित का उपयोग करके अभिकथन करती है।

  • माचिस (withText ("Hello")) एक दृश्य अभिकथन देता है, जो करेगाreal jobयह सुनिश्चित करने के लिए कि दोनों वास्तविक दृश्य ( withId का उपयोग करते हुए पाए गए ) और अपेक्षित दृश्य ( withText का उपयोग करते हुए ) एक और समान हैं।

आइए वस्तुओं को मुखर करने के लिए एस्प्रेसो परीक्षण ढांचे द्वारा प्रदान किए गए कुछ तरीकों को जानें।

अस्तित्व में नहीं है()

एक दृश्य अभिकथन लौटाता है, जो यह सुनिश्चित करता है कि दृश्य मिलान करने वाले को कोई मेल खाने वाला दृश्य नहीं मिले।

onView(withText("Hello")) .check(doesNotExist());

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि पाठ हैलो के साथ कोई दृश्य नहीं है।

मैचों ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और लक्ष्य दृश्य मिलानकर्ता द्वारा देखे गए दृश्य से मेल खाता है।

onView(withId(R.id.textView_hello)) .check(matches(withText("Hello World!")));

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि आईडी, R.id.textView_hello वाले दृश्य मौजूद हैं और हैलो वर्ल्ड के साथ लक्ष्य दृश्य के साथ मेल खाते हैं!

isBottomAlignedWith ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और नीचे लक्ष्य व्यूअर के साथ संरेखित है।

onView(withId(R.id.view)) .check(isBottomAlignedWith(withId(R.id.target_view)))

इधर, परीक्षण का मामला यह सुनिश्चित करता है कि आईडी, R.id.view मौजूद है और नीचे आईडी, R.id.target_view वाले दृश्य के साथ संरेखित है ।

isCompletelyAbove ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और पूरी तरह से लक्ष्य दृश्य मिलानकर्ता के ऊपर स्थित है।

onView(withId(R.id.view)) .check(isCompletelyAbove(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि दृश्य आईडी, R.id.view मौजूद है और यह आईडी, R.id.target_view वाले दृश्य के ऊपर पूरी तरह से स्थित है

isCompletelyBelow ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और लक्ष्य दृश्य मिलानकर्ता के नीचे पूरी तरह से स्थित है।

onView(withId(R.id.view)) .check(isCompletelyBelow(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि आईडी, R.id.view मौजूद है और आईडी, R.id.target_view वाले दृश्य के नीचे पूरी तरह से स्थित है ।

isCompletelyLeftOf ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन लौटाता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और लक्ष्य दृश्य मिलानकर्ता के पूरी तरह से शेष है।

onView(withId(R.id.view)) .check(isCompletelyLeftOf(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि दृश्य आईडी, R.id.view मौजूद है और आईडी, R.id.target_view वाले दृश्य के पूरी तरह से स्थित है

isCompletelyRightOf ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और लक्ष्य दृश्य मिलानकर्ता के पूर्ण रूप से सही स्थान पर स्थित है।

onView(withId(R.id.view)) .check(isCompletelyRightOf(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि दृश्य आईडी, R.id.view मौजूद है और आईडी, R.id.target_view वाले दृश्य के पूरी तरह से स्थित है।

isLeftAlignedWith ()

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

onView(withId(R.id.view)) .check(isLeftAlignedWith(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि दृश्य आईडी, R.id.view मौजूद है और आईडी, R.id.target_view वाले दृश्य के साथ संरेखित किया गया है

isPartiallyAbove ()

एक लक्ष्य दृश्य मिलानकर्ता स्वीकार करता है और एक दृश्य अभिकथन लौटाता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और आंशिक रूप से लक्ष्य दृश्य मिलानकर्ता के ऊपर स्थित है।

onView(withId(R.id.view)) .check(isPartiallyAbove(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि दृश्य आईडी, R.id.view मौजूद है और आईडी, R.id.target_view वाले दृश्य के ऊपर आंशिक रूप से स्थित है

isPartiallyBelow ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और इसे आंशिक रूप से लक्ष्य दृश्य मिलानकर्ता के नीचे स्थित किया गया है।

onView(withId(R.id.view)) .check(isPartiallyBelow(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि दृश्य आईडी, R.id.view मौजूद है और आईडी, R.id.target_view वाले दृश्य के नीचे आंशिक रूप से स्थित है ।

isPartiallyLeftOf ()

एक लक्ष्य दृश्य मिलानकर्ता स्वीकार करता है और एक दृश्य अभिकथन लौटाता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और इसे लक्ष्य दृश्य मिलानकर्ता के आंशिक रूप से छोड़ दिया गया है।

onView(withId(R.id.view)) .check(isPartiallyLeftOf(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि दृश्य आईडी, R.id.view मौजूद है और आईडी, R.id.target_view वाले दृश्य के आंशिक रूप से बचे हुए हैं ।

isPartiallyRightOf ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और लक्ष्य दृश्य मिलानकर्ता के आंशिक रूप से सही स्थित है

onView(withId(R.id.view)) .check(isPartiallyRightOf(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि आईडी, R.id.view मौजूद है और आईडी, R.id.target_view वाले दृश्य के आंशिक रूप से दाईं ओर स्थित है ।

isRightAlignedWith ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और लक्ष्य दृश्य मिलानकर्ता के साथ ठीक संरेखित है।

onView(withId(R.id.view)) .check(isRightAlignedWith(withId(R.id.target_view)))

यहां, परीक्षण का मामला यह सुनिश्चित करता है कि आईडी, R.id.view मौजूद है और सही आईडी, R.id.target_view वाले दृश्य के साथ संरेखित है ।

isTopAlignedWith ()

एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि दृश्य मिलानकर्ता (वास्तविक) मौजूद है और लक्ष्य दृश्य मिलानकर्ता के साथ शीर्ष संरेखित है।

onView(withId(R.id.view)) .check(isTopAlignedWith(withId(R.id.target_view)))

यहाँ, परीक्षण का मामला यह सुनिश्चित करता है कि आईडी, R.id.view मौजूद है और आईडी, R.id.target_view वाले दृश्य के साथ शीर्ष संरेखित है

noEllipsizedText ()

एक दृश्य अभिकथन लौटाता है, जो यह सुनिश्चित करता है कि दृश्य पदानुक्रम में पाठ विचारों को दीर्घवृत्त या काट नहीं है।

onView(withId(R.id.view)) .check(noEllipsizedText());

noMultilineButtons ()

एक दृश्य अभिकथन लौटाता है, जो यह सुनिश्चित करता है कि दृश्य पदानुक्रम में मल्टी लाइन बटन नहीं हैं।

onView(withId(R.id.view)) .check(noMultilineButtons());

noOverlaps ()

एक दृश्य अभिकथन लौटाता है, जो यह सुनिश्चित करता है कि TextView या ImageView के लिए असाइन की गई वंशज वस्तु एक-दूसरे को ओवरलैप नहीं करती है। इसका एक और विकल्प है, जो एक लक्ष्य दृश्य मिलानकर्ता को स्वीकार करता है और एक दृश्य अभिकथन देता है, जो यह सुनिश्चित करता है कि लक्ष्य दृश्य से मेल खाने वाला वंशज ओवरलैप न हो।

जैसा कि पहले सीखा गया है, देखें कार्रवाइयां Android एप्लिकेशन में उपयोगकर्ताओं द्वारा प्रदर्शन किए जाने वाले सभी संभावित कार्यों को स्वचालित करती हैं। एस्प्रेसो onView और "onData" प्रदर्शन विधि प्रदान करता है , जो देखने के कार्यों को स्वीकार करता है और परीक्षण वातावरण में संबंधित उपयोगकर्ता कार्यों को आमंत्रित / स्वचालित करता है। उदाहरण के लिए, "क्लिक ()" एक व्यू एक्शन है, जो जब onView ( R.id.myButton ) (.perform (क्लिक)) विधि से पास होता है, तो बटन के क्लिक इवेंट (आईडी के साथ: "myButton ) को आग लगा देगा। ) परीक्षण वातावरण में।

इस अध्याय में, आइए एस्प्रेसो टेस्टिंग फ्रेमवर्क द्वारा प्रदान की गई क्रियाओं के बारे में जानें।

पाठ टाइप करे()

typeText () प्रकार स्ट्रिंग के एक तर्क (पाठ) को स्वीकार करता है और एक दृश्य कार्रवाई देता है। दिए गए दृश्य क्रिया दृश्य में दिए गए पाठ को टाइप करते हैं। पाठ रखने से पहले, यह एक बार दृश्य को टैप करता है। यदि यह पाठ पहले से ही है तो सामग्री को मनमाने स्थान पर रखा जा सकता है।

onView(withId(R.id.text_view)).perform(typeText("Hello World!"))

typeTextIntoFocusedView ()

typeTextIntoFocusedView () के समान है typeText () यह सही ध्यान में रखते हुए कर्सर की स्थिति के बगल में पाठ देता है सिवाय इसके कि।

onView(withId(R.id.text_view)).perform(typeTextIntoFocusedView("Hello World!"))

replaceText ()

replaceText () के समान है typeText () को छोड़कर यह देखने की सामग्री को बदल देता है।

onView(withId(R.id.text_view)).perform(typeTextIntoFocusedView("Hello World!"))

स्पष्ट पाठ()

ClearText () में कोई तर्क नहीं है और एक दृश्य कार्रवाई देता है, जो दृश्य में पाठ को साफ़ कर देगा।

onView(withId(R.id.text_view)).perform(clearText())

कुंजी दबाएं()

pressKey () कुंजी कोड को स्वीकार करता है (जैसे KeyEvent.KEYCODE_ENTER) और एक दृश्य कार्रवाई देता है, जो कुंजी को दबाएगा कुंजी कोड से मेल खाती है।

onView(withId(R.id.text_view)).perform(typeText(
   "Hello World!", pressKey(KeyEvent.KEYCODE_ENTER))

pressMenuKey ()

pressMenuKey () में कोई तर्क नहीं है और एक दृश्य कार्रवाई देता है, जो हार्डवेयर मेनू कुंजी दबाएगा

onView(withId(R.id.text_view)).perform(typeText(
   "Hello World!", pressKey(KeyEvent.KEYCODE_ENTER), pressMenuKey())

closeSoftKeyboard ()

closeSoftKeyboard () में कोई तर्क नहीं है और एक दृश्य कार्रवाई देता है, जो कीबोर्ड को बंद कर देगा, यदि कोई खोला गया है।

onView(withId(R.id.text_view)).perform(typeText(
   "Hello World!", closeSoftKeyboard())

क्लिक करें ()

क्लिक () में कोई तर्क नहीं है और एक दृश्य कार्रवाई लौटाता है, जो दृश्य की क्लिक कार्रवाई को आमंत्रित करेगा।

onView(withId(R.id.button)).perform(click())

डबल क्लिक करें()

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

onView(withId(R.id.button)).perform(doubleClick())

longClick ()

longClick () के पास कोई तर्क नहीं है और एक दृश्य कार्रवाई लौटाता है, जो दृश्य की लंबी क्लिक कार्रवाई को आमंत्रित करेगा।

onView(withId(R.id.button)).perform(longClick())

pressBack ()

pressBack () में कोई तर्क नहीं है और एक व्यू एक्शन देता है, जो बैक बटन पर क्लिक करेगा।

onView(withId(R.id.button)).perform(pressBack())

pressBackUnconditionally ()

pressBackUncondately () के पास कोई तर्क नहीं है और एक दृश्य कार्रवाई देता है, जो बैक बटन पर क्लिक करेगा और यदि कोई अपवाद नहीं फेंकता है यदि बैक बटन कार्रवाई एप्लिकेशन से बाहर निकलती है।

onView(withId(R.id.button)).perform(pressBack())

खुली लिंक()

openLink () में दो तर्क हैं। पहला तर्क (लिंक टेक्स्ट) टाइप मिलानकर्ता का है और HTML एंकर टैग के पाठ को संदर्भित करता है। दूसरा तर्क (url) प्रकार का मिलानकर्ता है और HTML एंकर टैग के url को संदर्भित करता है। यह केवल TextView के लिए लागू है । यह एक व्यू एक्शन देता है, जो टेक्स्ट व्यू की सामग्री में उपलब्ध सभी HTML एंकर टैग को एकत्रित करता है, एंकर टैग को पहले तर्क (लिंक टेक्स्ट) और दूसरे तर्क (url) से मेल खाता है और अंत में संबंधित यूआरएल को खोलता है। आइए सामग्री के रूप में एक टेक्स्ट दृश्य पर विचार करें -

<a href="http://www.google.com/">copyright</a>

फिर, लिंक को नीचे परीक्षण मामले का उपयोग करके खोला और परीक्षण किया जा सकता है,

onView(withId(R.id.text_view)).perform(openLink(is("copyright"),
   is(Uri.parse("http://www.google.com/"))))

यहां, ओपनलिंक में टेक्स्ट व्यू की सामग्री मिलेगी, लिंक को टेक्स्ट के रूप में कॉपीराइट, www.google.com को url के रूप में ढूंढें और एक ब्राउज़र में यूआरएल खोलें।

openLinkWithText ()

openLinkWithText () में एक तर्क है, जो या तो टाइपिंग ** स्ट्रिंग या माचिस का हो सकता है। यह केवल ओपनलिंक * विधि के लिए एक छोटा कट है ।

onView(withId(R.id.text_view)).perform(openLinkWithText("copyright"))

openLinkWithUri ()

OpenLinkWithUri () में एक तर्क है, जो या तो स्ट्रिंग या मिलानकर्ता का हो सकता है । यह केवल ओपनलिंक * विधि के लिए एक छोटा कट है ।

onView(withId(R.id.text_view)).perform(openLinkWithUri("http://www.google.com/"))

pressImeActionButton ()

pressImeActionButton () में कोई तर्क नहीं है और एक दृश्य कार्रवाई देता है, जो एंड्रॉइड में सेट की गई कार्रवाई को निष्पादित करेगा : imeOptions कॉन्फ़िगरेशन। उदाहरण के लिए, यदि android: imeOptions क्रिया के समान है, तो यह कर्सर को स्क्रीन में अगले संभावित EditText दृश्य में ले जाएगा।

onView(withId(R.id.text_view)).perform(pressImeActionButton())

scrollTo ()

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

onView(withId(R.id.scrollView)).perform(scrollTo())

नीचे स्वाइप करें()

स्वाइपडाउन () में कोई तर्क नहीं है और एक दृश्य कार्रवाई देता है, जो स्क्रीन पर कार्रवाई को स्वाइप करेगा।

onView(withId(R.id.root)).perform(swipeDown())

स्वाइप करना()

स्वाइपअप () में कोई तर्क नहीं है और एक दृश्य कार्रवाई देता है, जो स्क्रीन पर कार्रवाई को स्वाइप करेगा।

onView(withId(R.id.root)).perform(swipeUp())

क्रेडिट कार्ड आदि को इलैक्ट्रॉनिक रीडर से सही से गुजारना()

swipeRight () में कोई तर्क नहीं है और एक दृश्य कार्रवाई देता है, जो स्क्रीन पर सही कार्रवाई स्वाइप करेगा।

onView(withId(R.id.root)).perform(swipeRight())

बायें सरकाओ()

swipeLeft () के पास कोई तर्क नहीं है और एक दृश्य कार्रवाई देता है, जो स्क्रीन पर बाईं कार्रवाई को स्वाइप करेगा।

onView(withId(R.id.root)).perform(swipeLeft())

एडॉप्टर व्यू एक विशेष प्रकार का दृश्य है जिसे विशेष रूप से इसी तरह की जानकारी के संग्रह को प्रस्तुत करने के लिए डिज़ाइन किया गया है और एडेप्टर का उपयोग करके अंतर्निहित डेटा स्रोत से प्राप्त उपयोगकर्ता संपर्क । डेटा स्रोत जटिल डेटाबेस प्रविष्टियों के लिए सरल सूची हो सकती है। दृश्य से प्राप्त से कुछ AdapterView हैं ListView , GridView और स्पिनर

AdapterView अंतर्निहित डेटा स्रोत में उपलब्ध डेटा की मात्रा के आधार पर उपयोगकर्ता इंटरफ़ेस को गतिशील रूप से प्रस्तुत करता है। इसके अलावा, AdcapeView केवल न्यूनतम आवश्यक डेटा प्रदान करता है, जिसे स्क्रीन के उपलब्ध दृश्यमान क्षेत्र में प्रदान किया जा सकता है। AdapterView मेमोरी को संरक्षित करने और अंतर्निहित डेटा बड़े होने पर भी उपयोगकर्ता इंटरफ़ेस को सुचारू बनाने के लिए ऐसा करता है।

विश्लेषण करने पर, अडैप्टर व्यू आर्किटेक्चर की प्रकृति, ऑन व्यू विकल्प और इसके व्यू मैचर्स को अप्रासंगिक बना देती है क्योंकि परीक्षण किए जाने वाले विशेष दृश्य को पहली बार में प्रस्तुत नहीं किया जा सकता है। सौभाग्य से, एस्प्रेसो एक विधि प्रदान करता है, onData ( ), जो अंतर्निहित डेटा से मिलान करने के लिए हैमरेस्ट मैचर्स (अंतर्निहित डेटा के डेटा प्रकार के लिए प्रासंगिक) को स्वीकार करता है और ओ डेटा मिलान के अनुसार इसी प्रकार के डेटाइंटरनेक्शन की वस्तु देता है । एक नमूना कोड इस प्रकार है,

onData(allOf(is(instanceOf(String.class)), startsWith("Apple"))).perform(click())

यहाँ, onData () प्रविष्टि "Apple" से मेल खाती है, यदि यह अंतर्निहित डेटा (सरणी सूची) में उपलब्ध है और मिलान किए गए दृश्य ("Apple" प्रविष्टि के अनुरूप TextView ) के साथ बातचीत करने के लिए DataInteraction ऑब्जेक्ट देता है ।

तरीकों

DataInteraction देखने के साथ बातचीत करने के लिए नीचे दिए गए तरीके प्रदान करता है,

प्रदर्शन ()

यह दृश्य क्रियाओं को स्वीकार करता है और दृश्य क्रियाओं में उत्तीर्ण होता है।

onData(allOf(is(instanceOf(String.class)), startsWith("Apple"))).perform(click())

जाँच()

यह दृश्य अभिकथनों को स्वीकार करता है और देखे गए विचारों में पारित जाँच करता है।

onData(allOf(is(instanceOf(String.class)), startsWith("Apple")))
   .check(matches(withText("Apple")))

inAdapterView ()

यह मैच देखने वालों को स्वीकार करता है। यह देखने वाले मैचर्स में पास किए गए विशेष एडाप्टर व्यू का चयन करता है और मिलान किए गए AdwareView के साथ बातचीत करने के लिए DataInteraction ऑब्जेक्ट देता है

onData(allOf())
   .inAdapterView(withId(R.id.adapter_view))
   .atPosition(5)
   .perform(click())

atPosition ()

यह प्रकार पूर्णांक के एक तर्क को स्वीकार करता है और अंतर्निहित डेटा में आइटम की स्थिति को संदर्भित करता है। यह डेटा के स्थितीय मूल्य में पारित दृश्य के अनुरूप दृश्य का चयन करता है और मिलान किए गए दृश्य के साथ सहभागिता करने के लिए DataInteraction ऑब्जेक्ट देता है । यह उपयोगी होगा, अगर हम अंतर्निहित डेटा का सही क्रम जानते हैं।

onData(allOf())
   .inAdapterView(withId(R.id.adapter_view))
   .atPosition(5)
   .perform(click())

onChildView ()

यह मैच देखने वालों को स्वीकार करता है और विशिष्ट बच्चे के दृश्य के अंदर के दृश्य से मेल खाता है। उदाहरण के लिए, हम उत्पाद सूची पर आधारित AdapterView में खरीदें बटन जैसी विशिष्ट वस्तुओं के साथ बातचीत कर सकते हैं ।

onData(allOf(is(instanceOf(String.class)), startsWith("Apple")))
   .onChildView(withId(R.id.buy_button))
   .perform(click())

एक नमूना आवेदन लिखें

AdapterView पर आधारित एक साधारण एप्लिकेशन लिखने और onData () पद्धति का उपयोग करके एक परीक्षण केस लिखने के लिए नीचे दिए गए चरणों का पालन करें ।

  • Android स्टूडियो प्रारंभ करें।

  • पहले चर्चा की गई नई परियोजना बनाएं और इसे नाम दें, MyFruitApp

  • का उपयोग कर AndroidX ढांचे के लिए ऐप्लिकेशन माइग्रेट Refactorमाइग्रेट करने के लिए AndroidX विकल्प मेनू।

  • मुख्य गतिविधि में डिफ़ॉल्ट डिज़ाइन निकालें और सूची दृश्य जोड़ें । की सामग्री activity_main.xml इस प्रकार है,

<?xml version = "1.0" encoding = "utf-8"?>
<RelativeLayout xmlns:android = "http://schemas.android.com/apk/res/android"
   xmlns:app = "http://schemas.android.com/apk/res-auto"
   xmlns:tools = "http://schemas.android.com/tools"
   android:layout_width = "match_parent"
   android:layout_height = "match_parent"
   tools:context = ".MainActivity">
   <ListView
      android:id = "@+id/listView"
      android:layout_width = "wrap_content"
      android:layout_height = "wrap_content" />
</RelativeLayout>
  • सूची दृश्य के आइटम टेम्पलेट को निर्दिष्ट करने के लिए नया लेआउट संसाधन, item.xml जोड़ें । आइटम की सामग्री। Xml इस प्रकार है,

<?xml version = "1.0" encoding = "utf-8"?>
<TextView xmlns:android = "http://schemas.android.com/apk/res/android"
   android:id = "@+id/name"
   android:layout_width = "fill_parent"
   android:layout_height = "fill_parent"
   android:padding = "8dp"
/>
  • अब, अंतर्निहित डेटा के रूप में फल सरणी वाले एक एडाप्टर बनाएं और इसे सूची दृश्य पर सेट करें। यह नीचे दिए गए अनुसार मुख्यता के onCreate () में किए जाने की आवश्यकता है ,

@Override
protected void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setContentView(R.layout.activity_main);
   
   // Find fruit list view
   final ListView listView = (ListView) findViewById(R.id.listView);
   
   // Initialize fruit data
   String[] fruits = new String[]{
      "Apple", 
      "Banana", 
      "Cherry", 
      "Dates", 
      "Elderberry", 
      "Fig", 
      "Grapes", 
      "Grapefruit", 
      "Guava",
      "Jack fruit", 
      "Lemon",
      "Mango", 
      "Orange", 
      "Papaya", 
      "Pears", 
      "Peaches", 
      "Pineapple",
      "Plums", 
      "Raspberry",
      "Strawberry", 
      "Watermelon"
   };
   
   // Create array list of fruits
   final ArrayList<String> fruitList = new ArrayList<String>();
   for (int i = 0; i < fruits.length; ++i) {
      fruitList.add(fruits[i]);
   }
   
   // Create Array adapter
   final ArrayAdapter adapter = new ArrayAdapter(this, R.layout.item, fruitList);
   
   // Set adapter in list view
   listView.setAdapter(adapter);
}
  • अब, कोड संकलित करें और एप्लिकेशन चलाएं। मेरा फल ऐप का स्क्रीनशॉट इस प्रकार है,

  • अब, खुला ExampleInstrumentedTest.java फ़ाइल और ऐड ActivityTestRule नीचे निर्दिष्ट है,

@Rule
public ActivityTestRule<MainActivity> mActivityRule =
   new ActivityTestRule<MainActivity>(MainActivity.class);

यह भी सुनिश्चित करें कि परीक्षण विन्यास ऐप / बिल्ड.ग्रेड में किया गया है -

dependencies {
   testImplementation 'junit:junit:4.12'
   androidTestImplementation 'androidx.test:runner:1.1.1'
   androidTestImplementation 'androidx.test:rules:1.1.1'
   androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
}
  • नीचे दिए गए सूची दृश्य का परीक्षण करने के लिए एक नया परीक्षण मामला जोड़ें,

@Test
public void listView_isCorrect() {
   // check list view is visible
   onView(withId(R.id.listView)).check(matches(isDisplayed()));
   onData(allOf(is(instanceOf(String.class)), startsWith("Apple"))).perform(click());
   onData(allOf(is(instanceOf(String.class)), startsWith("Apple")))
      .check(matches(withText("Apple")));
   // click a child item
   onData(allOf())
      .inAdapterView(withId(R.id.listView))
      .atPosition(10)
      .perform(click());
}
  • अंत में, एंड्रॉइड स्टूडियो के संदर्भ मेनू का उपयोग करके टेस्ट केस को चलाएं और जांचें कि क्या सभी टेस्ट केस सफल हो रहे हैं।

WebView एप्लिकेशन द्वारा वेब पेज प्रदर्शित करने के लिए Android द्वारा प्रदान किया गया एक विशेष दृश्य है। WebView क्रोम और फ़ायरफ़ॉक्स जैसे पूर्ण-ब्राउज़र ब्राउज़र एप्लिकेशन की सभी सुविधाएँ प्रदान नहीं करता है। हालांकि, यह दिखाई जाने वाली सामग्री पर पूर्ण नियंत्रण प्रदान करता है और वेब पेज के अंदर आने के लिए सभी Android सुविधाओं को उजागर करता है। यह WebView को सक्षम करता है और एक विशेष वातावरण प्रदान करता है जहां UI को आसानी से एचटीएमएल तकनीक और देशी सुविधाओं जैसे कैमरा का उपयोग करके और एक संपर्क डायल किया जा सकता है। यह सुविधा सेट एक हाइब्रिड एप्लिकेशन नामक एक नए प्रकार का अनुप्रयोग प्रदान करने के लिए एक WebView को सक्षम करता है , जहां UI HTML में किया जाता है और व्यावसायिक तर्क जावास्क्रिप्ट में या बाहरी एपीआई समापन बिंदु के माध्यम से किया जाता है।

आम तौर पर, WebView का परीक्षण करना एक चुनौती है, क्योंकि यह मूल उपयोगकर्ता इंटरफ़ेस / विचारों के बजाय अपने उपयोगकर्ता इंटरफ़ेस तत्वों के लिए HTML तकनीक का उपयोग करता है। एस्प्रेसो इस क्षेत्र में वेब मैचर्स और वेब दावे के लिए एक नया सेट प्रदान करता है, जो कि जानबूझकर देशी व्यू मैचर्स और व्यू के समान है। एक ही समय में, यह एक वेब प्रौद्योगिकी आधारित परीक्षण वातावरण को भी शामिल करके एक अच्छी तरह से असंतुलित दृष्टिकोण प्रदान करता है।

एस्प्रेसो वेब वेबड्राइवर एटम फ्रेमवर्क पर बनाया गया है , जिसका उपयोग वेब तत्वों को खोजने और हेरफेर करने के लिए किया जाता है। परमाणु क्रियाओं को देखने के समान है। एटम वेब पेज के अंदर सभी इंटरैक्शन करेगा। WebDriver वेब तत्वों को खोजने के लिए findElement () , getElement () जैसे तरीकों के पूर्वनिर्धारित सेट को उजागर करता है और संबंधित परमाणुओं (वेब ​​पेज में कार्रवाई करने के लिए) लौटाता है।

एक मानक वेब परीक्षण विवरण नीचे दिए गए कोड की तरह दिखता है,

onWebView()
   .withElement(Atom)
   .perform(Atom)
   .check(WebAssertion)

यहाँ,

  • onWebView () - onView के समान (), यह WebView का परीक्षण करने के लिए API के एक सेट को उजागर करता है।

  • withElement () - Atom का उपयोग करके वेब पेज के अंदर वेब तत्वों का पता लगाने के लिए उपयोग किए जाने वाले कई तरीकों में से एक WebInteration ऑब्जेक्ट, जो ViewInteraction के समान है।

  • प्रदर्शन () - एटम का उपयोग करके वेब पेज के अंदर कार्रवाई को निष्पादित करता है और वेबइंटरेक्शन को लौटाता है।

  • check () - यह WebAssertion का उपयोग करके आवश्यक अभिकथन करता है।

एक नमूना वेब परीक्षण कोड निम्नानुसार है,

onWebView()
   .withElement(findElement(Locator.ID, "apple"))
   .check(webMatches(getText(), containsString("Apple")))

यहाँ,

  • findElement () एक तत्व का पता लगाता है और एक एटम देता है

  • वेबमैच मैच विधि के समान है

एक नमूना आवेदन लिखें

आइए हम WebView पर आधारित एक सरल एप्लिकेशन लिखें और onWebView () विधि का उपयोग करके एक परीक्षण केस लिखें । नमूना आवेदन लिखने के लिए इन चरणों का पालन करें -

  • Android स्टूडियो प्रारंभ करें।

  • पहले चर्चा की गई नई परियोजना बनाएं और इसे नाम दें, MyWebViewApp

  • का उपयोग कर AndroidX ढांचे के लिए ऐप्लिकेशन माइग्रेट Refactorमाइग्रेट करने के लिए AndroidX विकल्प मेनू।

  • इंटरनेट का उपयोग करने की अनुमति देने के लिए AndroidManifest.xml फ़ाइल में नीचे कॉन्फ़िगरेशन विकल्प जोड़ें ।

<uses-permission android:name = "android.permission.INTERNET" />
  • एस्प्रेसो वेब को एक अलग प्लगइन के रूप में प्रदान किया गया है। तो, एप्लिकेशन / build.gradle में निर्भरता जोड़ें और इसे सिंक करें।

dependencies {
   androidTestImplementation 'androidx.test:rules:1.1.1'
   androidTestImplementation 'androidx.test.espresso:espresso-web:3.1.1'
}
  • मुख्य गतिविधि में डिफ़ॉल्ट डिज़ाइन निकालें और WebView जोड़ें। Activity_main.xml की सामग्री इस प्रकार है,

<?xml version = "1.0" encoding = "utf-8"?>
<RelativeLayout xmlns:android = "http://schemas.android.com/apk/res/android"
   xmlns:app = "http://schemas.android.com/apk/res-auto"
   xmlns:tools = "http://schemas.android.com/tools"
   android:layout_width = "match_parent"
   android:layout_height = "match_parent"
   tools:context = ".MainActivity">
   <WebView
      android:id = "@+id/web_view_test"
      android:layout_width = "fill_parent"
      android:layout_height = "fill_parent" />
</RelativeLayout>
  • उसी WebView में लिंक कार्रवाई को लोड करने के लिए एक नया वर्ग, ExtendedWebViewClient का विस्तार करते हुए WebViewClient और ओवरराइड को ओवरऑवरराइड करें । अन्यथा, यह एप्लिकेशन के बाहर एक नई ब्राउज़र विंडो खोलेगा। इसे MainActivity.java में रखें

private class ExtendedWebViewClient extends WebViewClient {
   @Override
   public boolean shouldOverrideUrlLoading(WebView view, String url) {
      view.loadUrl(url);
      return true;
   }
}
  • अब, मेनएक्टिविटी के ऑनक्रिएट विधि में नीचे दिए गए कोड को जोड़ें । कोड का उद्देश्य WebView को खोजना है , इसे ठीक से कॉन्फ़िगर करना है और फिर अंत में लक्ष्य url को लोड करना है।

// Find web view
WebView webView = (WebView) findViewById(R.id.web_view_test);

// set web view client
webView.setWebViewClient(new ExtendedWebViewClient());

// Clear cache
webView.clearCache(true);

// load Url
webView.loadUrl("http://<your domain or IP>/index.html");

यहाँ,

  • Index.html की सामग्री इस प्रकार है -

<html>
   <head>
      <title>Android Web View Sample</title>
   </head>
   <body>
      <h1>Fruits</h1>
      <ol>
         <li><a href = "apple.html" id = "apple">Apple</a></li>
         <li><a href = "banana.html" id = "banana">Banana</a></li>
         </ol>
   </body>
</html>
  • Index.html में संदर्भित Apple.html फ़ाइल की सामग्री इस प्रकार है -

<html>
   <head>
      <title>Android Web View Sample</title>
   </head>
   
   <body>
      <h1>Apple</h1>
   </body>
</html>
  • Banana.html फ़ाइल की सामग्री banana.html में उल्लिखित है,

<html>
   <head>
      <title>Android Web View Sample</title>
   </head>
   
   <body>
      <h1>Banana</h1>
   </body>
</html>
  • एक वेब सर्वर में index.html, apple.html और banana.html रखें

  • Url को अपने कॉन्फ़िगर किए गए url के साथ loadUrl विधि में बदलें।

  • अब, एप्लिकेशन चलाएँ और मैन्युअल रूप से जांचें कि क्या सब कुछ ठीक है। नीचे WebView नमूना एप्लिकेशन का स्क्रीनशॉट है -

  • अब, ExampleInstrumentedTest.java फ़ाइल खोलें और नीचे का नियम जोड़ें -

@Rule
public ActivityTestRule<MainActivity> mActivityRule =
   new ActivityTestRule<MainActivity>(MainActivity.class, false, true) {
   @Override
   protected void afterActivityLaunched() {
      onWebView(withId(R.id.web_view_test)).forceJavascriptEnabled();
   }
};

यहाँ, हमने पाया WebView और की जावास्क्रिप्ट सक्रिय WebView क्योंकि एस्प्रेसो वेब परीक्षण ढांचे JavaScript इंजन के माध्यम से विशेष रूप से काम करता है की पहचान करने और वेब तत्व हेरफेर करने के लिए।

  • अब, हमारे WebView और उसके व्यवहार का परीक्षण करने के लिए परीक्षण केस जोड़ें ।

@Test
public void webViewTest(){
   onWebView()
      .withElement(findElement(Locator.ID, "apple"))
      .check(webMatches(getText(), containsString("Apple")))
      .perform(webClick())
      .withElement(findElement(Locator.TAG_NAME, "h1"))
      .check(webMatches(getText(), containsString("Apple")));
}

यहाँ, परीक्षण निम्नलिखित क्रम में किया गया था,

  • लिंक मिला, सेब के माध्यम से अपनी आईडी गुण का उपयोग कर findElement () विधि और Locator.ID गणन।

  • वेबमैच () विधि का उपयोग करके लिंक के पाठ की जांच करता है

  • लिंक पर क्लिक क्रिया करता है। यह Apple.html पेज खोलता है ।

  • फिर findElement () तरीकों और का उपयोग कर h1 तत्व पाया Locator.TAG_NAME गणन।

  • अंत में फिर से webMatches () विधि का उपयोग करके h1 टैग के पाठ की जांच करता है ।

  • अंत में, एंड्रॉइड स्टूडियो संदर्भ मेनू का उपयोग करके परीक्षण केस चलाएं।

इस अध्याय में, हम एस्प्रेसो आइडलिंग रिसोर्सेस का उपयोग करके अतुल्यकालिक संचालन का परीक्षण करना सीखेंगे।

आधुनिक अनुप्रयोग की चुनौतियों में से एक चिकनी उपयोगकर्ता अनुभव प्रदान करना है। सुचारू उपयोगकर्ता अनुभव प्रदान करने के लिए पृष्ठभूमि में बहुत काम शामिल है, यह सुनिश्चित करने के लिए कि आवेदन प्रक्रिया कुछ मिलीसेकंड से अधिक समय नहीं लेती है। बैकग्राउंड टास्क सरल एक से लेकर महंगा और जटिल कार्य दूरस्थ API / डेटाबेस से डेटा लाने का होता है। अतीत में चुनौती का सामना करने के लिए, एक डेवलपर एक बैकग्राउंड थ्रेड में महंगा और लंबे समय तक चलने वाला काम लिखता था और बैकग्राउंड थ्रेड पूरा होते ही मुख्य UIThread के साथ सिंक हो जाता था।

यदि एक बहु-थ्रेडेड एप्लिकेशन विकसित करना जटिल है, तो इसके लिए परीक्षण मामले लिखना और भी जटिल है। उदाहरण के लिए, डेटाबेस से आवश्यक डेटा लोड होने से पहले हमें एक एडॉप्टर व्यू का परीक्षण नहीं करना चाहिए । यदि डेटा को अलग थ्रेड में लाया जाता है, तो थ्रेड पूरा होने तक परीक्षण की प्रतीक्षा करनी होगी। तो, परीक्षण वातावरण को पृष्ठभूमि थ्रेड और UI थ्रेड के बीच समन्वयित किया जाना चाहिए। एस्प्रेसो बहु-थ्रेडेड अनुप्रयोग के परीक्षण के लिए एक उत्कृष्ट समर्थन प्रदान करता है। एक एप्लिकेशन निम्न तरीकों से धागे का उपयोग करता है और एस्प्रेसो हर परिदृश्य का समर्थन करता है।

उपयोगकर्ता इंटरफ़ेस थ्रेडिंग

यह जटिल यूआई तत्वों के साथ चिकनी उपयोगकर्ता अनुभव प्रदान करने के लिए एंड्रॉइड एसडीके द्वारा आंतरिक रूप से उपयोग किया जाता है। एस्प्रेसो पारदर्शी रूप से इस परिदृश्य का समर्थन करता है और किसी भी कॉन्फ़िगरेशन और विशेष कोडिंग की आवश्यकता नहीं है।

Async कार्य

आधुनिक प्रोग्रामिंग भाषाएं थ्रेड प्रोग्रामिंग की जटिलता के बिना हल्के वजन वाले थ्रेडिंग करने के लिए async प्रोग्रामिंग का समर्थन करती हैं। एस्प्रेसो टास्क एस्प्रेसो फ्रेमवर्क द्वारा पारदर्शी रूप से समर्थित है।

उपयोगकर्ता थ्रेड

एक डेवलपर डेटाबेस से जटिल या बड़ा डेटा लाने के लिए एक नया थ्रेड शुरू कर सकता है। इस परिदृश्य का समर्थन करने के लिए, एस्प्रेसो आइडलिंग संसाधन अवधारणा प्रदान करता है।

आइए इस अध्याय में आइडलिंग रिसोर्स की अवधारणा और इसे कैसे सीखें का उपयोग करें।

अवलोकन

निष्क्रिय संसाधन की अवधारणा बहुत सरल और सहज है। मूल विचार एक परिवर्तनीय (बूलियन मूल्य) बनाना है जब भी एक लंबी थ्रेडिंग प्रक्रिया को एक अलग थ्रेड में शुरू किया जाता है ताकि यह पता लगाया जा सके कि प्रक्रिया चल रही है या नहीं और इसे परीक्षण वातावरण में पंजीकृत किया गया है। परीक्षण के दौरान, परीक्षण धावक पंजीकृत चर की जांच करेगा, यदि कोई पाया गया है और फिर इसकी चल रही स्थिति का पता लगाएं। यदि रनिंग स्टेटस सही है, तो टेस्ट रनर स्टेटस के गलत होने तक इंतजार करेगा।

एस्प्रेसो रनिंग स्टेटस को बनाए रखने के उद्देश्य से एक इंटरफ़ेस, IdlingResources प्रदान करता है। लागू करने के लिए मुख्य विधि isIdleNow () है। यदि IsIndNow () सही है, तो एस्प्रेसो परीक्षण प्रक्रिया को फिर से शुरू करेगा या तब तक प्रतीक्षा करेगा जब तक कि IsIloNow () गलत न हो जाए। हमें IdlingResources को लागू करने और व्युत्पन्न वर्ग का उपयोग करने की आवश्यकता है। एस्प्रेसो हमारे काम के बोझ को कम करने के लिए कुछ बिल्ट-इन IdlingResources कार्यान्वयन भी प्रदान करता है। वे इस प्रकार हैं,

CountingIdlingResource

यह रनिंग कार्य का एक आंतरिक काउंटर रखता है। यह वेतन वृद्धि () और वेतन वृद्धि () विधियों को उजागर करता है । वेतन वृद्धि () काउंटर में से एक को जोड़ता है और गिरावट () काउंटर से एक को हटाता है। isIdleNow () केवल तभी सही होता है जब कोई कार्य सक्रिय न हो।

UriIdlingResource

यह CounintIdlingResource के समान है सिवाय इसके कि नेटवर्क को विलंबता लेने के लिए विस्तारित अवधि के लिए काउंटर को शून्य करने की आवश्यकता है।

IdlingThreadPoolExecutor

वर्तमान थ्रेड पूल में संख्या सक्रिय रनिंग कार्य को बनाए रखने के लिए यह थ्रेडपूल एक्ज़ीक्यूटर का एक कस्टम कार्यान्वयन है ।

IdlingScheduledThreadPoolExecutor

यह IdlingThreadPoolExecutor के समान है , लेकिन यह किसी कार्य को शेड्यूल करता है और शेड्यूल्डड्रेडपूल Executor का एक कस्टम कार्यान्वयन है।

यदि IdlingResources या कस्टम एक के उपरोक्त कार्यान्वयन में से किसी एक का उपयोग अनुप्रयोग में किया जाता है, तो हमें परीक्षण वातावरण में और साथ ही नीचे दिए गए IdlingRegistry वर्ग का उपयोग करके आवेदन का परीक्षण करने से पहले इसे पंजीकृत करना होगा ,

IdlingRegistry.getInstance().register(MyIdlingResource.getIdlingResource());

इसके अलावा, इसे नीचे परीक्षण पूरा होते ही हटाया जा सकता है -

IdlingRegistry.getInstance().unregister(MyIdlingResource.getIdlingResource());

एस्प्रेसो एक अलग पैकेज में यह कार्यक्षमता प्रदान करता है, और पैकेज को नीचे app.gradle में कॉन्फ़िगर करने की आवश्यकता है।

dependencies {
   implementation 'androidx.test.espresso:espresso-idling-resource:3.1.1'
   androidTestImplementation "androidx.test.espresso.idling:idlingconcurrent:3.1.1"
}

नमूना आवेदन

आइए एक अलग थ्रेड में वेब सेवा से प्राप्त करके फलों को सूचीबद्ध करने के लिए एक सरल एप्लिकेशन बनाएं और फिर, आइडलिंग रिसोर्स कॉन्सेप्ट का उपयोग करके इसका परीक्षण करें।

  • Android स्टूडियो प्रारंभ करें।

  • पहले चर्चा की गई नई परियोजना बनाएं और इसे नाम दें, MyIdlingFruitApp

  • माइग्रेट का उपयोग कर AndroidX ढांचे के लिए आवेदन Refactor लिए → माइग्रेट AndroidX विकल्प मेनू।

  • नीचे दिए गए अनुसार एप / बिल्ड.gradle (और इसे सिंक करें) में एस्प्रेसो आइडलिंग रिसोर्स लाइब्रेरी जोड़ें ।

dependencies {
   implementation 'androidx.test.espresso:espresso-idling-resource:3.1.1'
   androidTestImplementation "androidx.test.espresso.idling:idlingconcurrent:3.1.1"
}
  • मुख्य गतिविधि में डिफ़ॉल्ट डिज़ाइन निकालें और सूची दृश्य जोड़ें। की सामग्री activity_main.xml इस प्रकार है,

<?xml version = "1.0" encoding = "utf-8"?>
<RelativeLayout xmlns:android = "http://schemas.android.com/apk/res/android"
   xmlns:app = "http://schemas.android.com/apk/res-auto"
   xmlns:tools = "http://schemas.android.com/tools"
   android:layout_width = "match_parent"
   android:layout_height = "match_parent"
   tools:context = ".MainActivity">
   <ListView
      android:id = "@+id/listView"
      android:layout_width = "wrap_content"
      android:layout_height = "wrap_content" />
</RelativeLayout>
  • सूची दृश्य के आइटम टेम्पलेट को निर्दिष्ट करने के लिए नया लेआउट संसाधन, item.xml जोड़ें । आइटम की सामग्री। Xml इस प्रकार है,

<?xml version = "1.0" encoding = "utf-8"?>
<TextView xmlns:android = "http://schemas.android.com/apk/res/android"
   android:id = "@+id/name"
   android:layout_width = "fill_parent"
   android:layout_height = "fill_parent"
   android:padding = "8dp"
/>
  • एक नया वर्ग बनाएं - MyIdlingResourceMyIdlingResource का उपयोग हमारे IdlingResource को एक स्थान पर रखने और जब भी आवश्यक हो, करने के लिए किया जाता है। हम अपने उदाहरण में CountingIdlingResource का उपयोग करने जा रहे हैं ।

package com.tutorialspoint.espressosamples.myidlingfruitapp;
import androidx.test.espresso.IdlingResource;
import androidx.test.espresso.idling.CountingIdlingResource;

public class MyIdlingResource {
   private static CountingIdlingResource mCountingIdlingResource =
      new CountingIdlingResource("my_idling_resource");
   public static void increment() {
      mCountingIdlingResource.increment();
   }
   public static void decrement() {
      mCountingIdlingResource.decrement();
   }
   public static IdlingResource getIdlingResource() {
      return mCountingIdlingResource;
   }
}
  • एक वैश्विक चर घोषित करें, mIdlingResource प्रकार के CountingIdlingResource में MainActivity नीचे के रूप में वर्ग,

@Nullable
private CountingIdlingResource mIdlingResource = null;
  • नीचे दिए गए वेब से फलों की सूची प्राप्त करने के लिए एक निजी विधि लिखें,

private ArrayList<String> getFruitList(String data) {
   ArrayList<String> fruits = new ArrayList<String>();
   try {
      // Get url from async task and set it into a local variable
      URL url = new URL(data);
      Log.e("URL", url.toString());
      
      // Create new HTTP connection
      HttpURLConnection conn = (HttpURLConnection) url.openConnection();
      
      // Set HTTP connection method as "Get"
      conn.setRequestMethod("GET");
      
      // Do a http request and get the response code
      int responseCode = conn.getResponseCode();
      
      // check the response code and if success, get response content
      if (responseCode == HttpURLConnection.HTTP_OK) {
         BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream()));
         String line;
         StringBuffer response = new StringBuffer();
         while ((line = in.readLine()) != null) {
            response.append(line);
         }
         in.close();
         JSONArray jsonArray = new JSONArray(response.toString());
         Log.e("HTTPResponse", response.toString());
         for(int i = 0; i < jsonArray.length(); i++) {
            JSONObject jsonObject = jsonArray.getJSONObject(i);
            String name = String.valueOf(jsonObject.getString("name"));
            fruits.add(name);
         }
      } else {
         throw new IOException("Unable to fetch data from url");
      }
      conn.disconnect();
   } catch (IOException | JSONException e) {
      e.printStackTrace();
   }
   return fruits;
}
  • ऑन - क्रिएट () विधि में एक नया कार्य बनाएं वेब से डेटा प्राप्त करने के लिए हमारे गेटफ़्लिट विधि का उपयोग करके एक नया एडेप्टर का निर्माण और इसे सूची दृश्य में सेट करना। इसके अलावा, यदि हमारा कार्य थ्रेड में पूरा हो जाता है, तो निष्क्रिय संसाधन को घटा दें। कोड निम्नानुसार है,

// Get data
class FruitTask implements Runnable {
   ListView listView;
   CountingIdlingResource idlingResource;
   FruitTask(CountingIdlingResource idlingRes, ListView listView) {
      this.listView = listView;
      this.idlingResource = idlingRes;
   }
   public void run() {
      //code to do the HTTP request
      final ArrayList<String> fruitList = getFruitList("http://<your domain or IP>/fruits.json");
      try {
         synchronized (this){
            runOnUiThread(new Runnable() {
               @Override
               public void run() {
                  // Create adapter and set it to list view
                  final ArrayAdapter adapter = new
                     ArrayAdapter(MainActivity.this, R.layout.item, fruitList);
                  ListView listView = (ListView)findViewById(R.id.listView);
                  listView.setAdapter(adapter);
               }
            });
         }
      } catch (Exception e) {
         e.printStackTrace();
      }
      if (!MyIdlingResource.getIdlingResource().isIdleNow()) {
         MyIdlingResource.decrement(); // Set app as idle.
      }
   }
}

यहां, फलों के यूआरएल को http: // <अपने डोमेन या IP / फल.json के रूप में माना जाता है और इसे JSON के रूप में तैयार किया जाता है। सामग्री इस प्रकार है,

[ 
   {
      "name":"Apple"
   },
   {
      "name":"Banana"
   },
   {
      "name":"Cherry"
   },
   {
      "name":"Dates"
   },
   {
      "name":"Elderberry"
   },
   {
      "name":"Fig"
   },
   {
      "name":"Grapes"
   },
   {
      "name":"Grapefruit"
   },
   {
      "name":"Guava"
   },
   {
      "name":"Jack fruit"
   },
   {
      "name":"Lemon"
   },
   {
      "name":"Mango"
   },
   {
      "name":"Orange"
   },
   {
      "name":"Papaya"
   },
   {
      "name":"Pears"
   },
   {
      "name":"Peaches"
   },
   {
      "name":"Pineapple"
   },
   {
      "name":"Plums"
   },
   {
      "name":"Raspberry"
   },
   {
      "name":"Strawberry"
   },
   {
      "name":"Watermelon"
   }
]

Note - फ़ाइल को अपने स्थानीय वेब सर्वर में रखें और उसका उपयोग करें।

  • अब, दृश्य ढूंढें , फ्रूटटस्क पास करके एक नया धागा बनाएं , निष्क्रिय संसाधन को बढ़ाएं और अंत में कार्य शुरू करें।

// Find list view
ListView listView = (ListView) findViewById(R.id.listView);
Thread fruitTask = new Thread(new FruitTask(this.mIdlingResource, listView));
MyIdlingResource.increment();
fruitTask.start();
  • MainActivity का पूरा कोड इस प्रकार है,

package com.tutorialspoint.espressosamples.myidlingfruitapp;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.annotation.VisibleForTesting;
import androidx.appcompat.app.AppCompatActivity;
import androidx.test.espresso.idling.CountingIdlingResource;

import android.os.Bundle;
import android.util.Log;
import android.widget.ArrayAdapter;
import android.widget.ListView;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;

public class MainActivity extends AppCompatActivity {
   @Nullable
   private CountingIdlingResource mIdlingResource = null;
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      
      // Get data
      class FruitTask implements Runnable {
         ListView listView;
         CountingIdlingResource idlingResource;
         FruitTask(CountingIdlingResource idlingRes, ListView listView) {
            this.listView = listView;
            this.idlingResource = idlingRes;
         }
         public void run() {
            //code to do the HTTP request
            final ArrayList<String> fruitList = getFruitList(
               "http://<yourdomain or IP>/fruits.json");
            try {
               synchronized (this){
                  runOnUiThread(new Runnable() {
                     @Override
                     public void run() {
                        // Create adapter and set it to list view
                        final ArrayAdapter adapter = new ArrayAdapter(
                           MainActivity.this, R.layout.item, fruitList);
                        ListView listView = (ListView) findViewById(R.id.listView);
                        listView.setAdapter(adapter);
                     }
                  });
               }
            } catch (Exception e) {
               e.printStackTrace();
            }
            if (!MyIdlingResource.getIdlingResource().isIdleNow()) {
               MyIdlingResource.decrement(); // Set app as idle.
            }
         }
      }
      // Find list view
      ListView listView = (ListView) findViewById(R.id.listView);
      Thread fruitTask = new Thread(new FruitTask(this.mIdlingResource, listView));
      MyIdlingResource.increment();
      fruitTask.start();
   }
   private ArrayList<String> getFruitList(String data) {
      ArrayList<String> fruits = new ArrayList<String>();
      try {
         // Get url from async task and set it into a local variable
         URL url = new URL(data);
         Log.e("URL", url.toString());
         
         // Create new HTTP connection
         HttpURLConnection conn = (HttpURLConnection) url.openConnection();
         
         // Set HTTP connection method as "Get"
         conn.setRequestMethod("GET");
         
         // Do a http request and get the response code
         int responseCode = conn.getResponseCode();
         
         // check the response code and if success, get response content
         if (responseCode == HttpURLConnection.HTTP_OK) {
            BufferedReader in = new BufferedReader(new InputStreamReader(conn.getInputStream()));
            String line;
            StringBuffer response = new StringBuffer();
            while ((line = in.readLine()) != null) {
               response.append(line);
            }
            in.close();
            JSONArray jsonArray = new JSONArray(response.toString());
            Log.e("HTTPResponse", response.toString());
            
            for(int i = 0; i < jsonArray.length(); i++) {
               JSONObject jsonObject = jsonArray.getJSONObject(i);
               String name = String.valueOf(jsonObject.getString("name"));
               fruits.add(name);
            }
         } else {
            throw new IOException("Unable to fetch data from url");
         }
         conn.disconnect();
      } catch (IOException | JSONException e) {
         e.printStackTrace();
      }
      return fruits;
   }
}
  • अब, एप्लिकेशन मैनिफ़ेस्ट फ़ाइल, AndroidManifest.xml में नीचे कॉन्फ़िगरेशन जोड़ें

<uses-permission android:name = "android.permission.INTERNET" />
  • अब, उपरोक्त कोड संकलित करें और एप्लिकेशन चलाएं। My Idling Fruit App का स्क्रीनशॉट इस प्रकार है,

  • अब, ExampleInstrumentedTest.java फ़ाइल खोलें और नीचे दिए गए अनुसार गतिविधिटेस्ट नियम जोड़ें।

@Rule
public ActivityTestRule<MainActivity> mActivityRule = 
   new ActivityTestRule<MainActivity>(MainActivity.class);
Also, make sure the test configuration is done in app/build.gradle
dependencies {
   testImplementation 'junit:junit:4.12'
   androidTestImplementation 'androidx.test:runner:1.1.1'
   androidTestImplementation 'androidx.test:rules:1.1.1'
   androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
   implementation 'androidx.test.espresso:espresso-idling-resource:3.1.1'
   androidTestImplementation "androidx.test.espresso.idling:idlingconcurrent:3.1.1"
}
  • नीचे दिए गए सूची दृश्य का परीक्षण करने के लिए एक नया परीक्षण मामला जोड़ें,

@Before
public void registerIdlingResource() {
   IdlingRegistry.getInstance().register(MyIdlingResource.getIdlingResource());
}
@Test
public void contentTest() {
   // click a child item
   onData(allOf())
   .inAdapterView(withId(R.id.listView))
   .atPosition(10)
   .perform(click());
}
@After
public void unregisterIdlingResource() {
   IdlingRegistry.getInstance().unregister(MyIdlingResource.getIdlingResource());
}
  • अंत में, एंड्रॉइड स्टूडियो के संदर्भ मेनू का उपयोग करके टेस्ट केस को चलाएं और जांचें कि क्या सभी टेस्ट केस सफल हो रहे हैं।

एंड्रॉइड इंटेंट का उपयोग नई गतिविधि को खोलने के लिए किया जाता है, या तो आंतरिक (उत्पाद सूची स्क्रीन से उत्पाद विवरण स्क्रीन खोलना) या बाहरी (जैसे कॉल करने के लिए डायलर खोलना)। आंतरिक आशय गतिविधि को एस्प्रेसो परीक्षण ढांचे द्वारा पारदर्शी रूप से नियंत्रित किया जाता है और इसे उपयोगकर्ता की ओर से किसी विशिष्ट कार्य की आवश्यकता नहीं होती है। हालांकि, बाहरी गतिविधि को लागू करना वास्तव में एक चुनौती है क्योंकि यह हमारे दायरे से बाहर है, परीक्षण के तहत आवेदन। एक बार जब उपयोगकर्ता किसी बाहरी एप्लिकेशन को इनवॉइस करता है और परीक्षण के तहत एप्लिकेशन से बाहर चला जाता है, तो उपयोगकर्ता द्वारा कार्रवाई के पूर्वनिर्धारित अनुक्रम के साथ एप्लिकेशन पर वापस आने की संभावना कम होती है। इसलिए, हमें एप्लिकेशन का परीक्षण करने से पहले उपयोगकर्ता कार्रवाई को मानने की आवश्यकता है। एस्प्रेसो इस स्थिति को संभालने के लिए दो विकल्प प्रदान करता है। वे इस प्रकार हैं,

इरादा

यह उपयोगकर्ता को यह सुनिश्चित करने की अनुमति देता है कि परीक्षण के तहत आवेदन से सही इरादा खोला गया है।

इच्छुक

यह उपयोगकर्ता को कैमरे से एक तस्वीर लेने, संपर्क सूची से एक नंबर डायल करने, इत्यादि जैसी बाहरी गतिविधि का मजाक बनाने की अनुमति देता है, और मूल्यों के पूर्वनिर्धारित सेट के साथ आवेदन पर वापस लौटता है (जैसे वास्तविक छवि के बजाय कैमरे से पूर्वनिर्धारित छवि) ।

सेट अप

एस्प्रेसो एक प्लगइन लाइब्रेरी के माध्यम से इरादे के विकल्प का समर्थन करता है और लाइब्रेरी को एप्लिकेशन के ग्रेड फ़ाइल में कॉन्फ़िगर करने की आवश्यकता होती है। कॉन्फ़िगरेशन विकल्प निम्नानुसार है,

dependencies {
   // ...
   androidTestImplementation 'androidx.test.espresso:espresso-intents:3.1.1'
}

इरादा ()

एस्प्रेसो इरादे प्लगइन विशेष मिलानकर्ताओं को यह जांचने के लिए प्रदान करता है कि आह्वान किया गया इरादा अपेक्षित इरादा है या नहीं। प्रदान किए गए मैचर्स और मैचर्स का उद्देश्य इस प्रकार है,

hasAction

यह इरादे की कार्रवाई को स्वीकार करता है और एक मिलानकर्ता को लौटाता है, जो निर्दिष्ट इरादे से मेल खाता है।

hasData

यह डेटा को स्वीकार करता है और एक मिलानकर्ता को लौटाता है, जो इसे प्रदान करते समय आशय को प्रदान किए गए डेटा से मेल खाता है।

पैकेज के लिए

यह आशय पैकेज नाम को स्वीकार करता है और एक मिलानकर्ता को लौटाता है, जो कि आशयित इरादे के पैकेज के नाम से मेल खाता है।

अब, एक नया एप्लिकेशन बनाते हैं और अवधारणा को समझने के लिए () का उपयोग करके बाहरी गतिविधि के लिए एप्लिकेशन का परीक्षण करते हैं ।

  • Android स्टूडियो प्रारंभ करें।

  • पहले से चर्चा के अनुसार एक नया प्रोजेक्ट बनाएं और इसे नाम दें, IntentSampleApp।

  • का उपयोग कर AndroidX ढांचे के लिए ऐप्लिकेशन माइग्रेट Refactor → माइग्रेट करने के लिए AndroidX विकल्प मेनू।

  • एक पाठ बॉक्स, संपर्क सूची खोलने के लिए एक बटन और एक और एक गतिविधि डायल करने के लिए कॉल करके डायल करें_मैं. xml नीचे दिखाए अनुसार,

<?xml version = "1.0" encoding = "utf-8"?>
<RelativeLayout xmlns:android = "http://schemas.android.com/apk/res/android"
   xmlns:app = "http://schemas.android.com/apk/res-auto"
   xmlns:tools = "http://schemas.android.com/tools"
   android:layout_width = "match_parent"
   android:layout_height = "match_parent"
   tools:context = ".MainActivity">
   <EditText
      android:id = "@+id/edit_text_phone_number"
      android:layout_width = "wrap_content"
      android:layout_height = "wrap_content"
      android:layout_centerHorizontal = "true"
      android:text = ""
      android:autofillHints = "@string/phone_number"/>
   <Button
      android:id = "@+id/call_contact_button"
      android:layout_width = "wrap_content"
      android:layout_height = "wrap_content"
      android:layout_centerHorizontal = "true"
      android:layout_below = "@id/edit_text_phone_number"
      android:text = "@string/call_contact"/>
   <Button
      android:id = "@+id/button"
      android:layout_width = "wrap_content"
      android:layout_height = "wrap_content"
      android:layout_centerHorizontal = "true"
      android:layout_below = "@id/call_contact_button"
      android:text = "@string/call"/>
</RelativeLayout>
  • इसके अलावा, स्ट्रिंग्स . xml संसाधन फ़ाइल में निम्न आइटम जोड़ें ,

<string name = "phone_number">Phone number</string>
<string name = "call">Call</string>
<string name = "call_contact">Select from contact list</string>
  • अब, मुख्य गतिविधि (में नीचे दिए गए कोड को जोड़ने MainActivity.java के तहत) onCreate विधि।

public class MainActivity extends AppCompatActivity {
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      // ... code
      // Find call from contact button
      Button contactButton = (Button) findViewById(R.id.call_contact_button);
      contactButton.setOnClickListener(new View.OnClickListener() {
         @Override
         public void onClick(View view) {
            // Uri uri = Uri.parse("content://contacts");
            Intent contactIntent = new Intent(Intent.ACTION_PICK,
               ContactsContract.Contacts.CONTENT_URI);
            contactIntent.setType(ContactsContract.CommonDataKinds.Phone.CONTENT_TYPE);
            startActivityForResult(contactIntent, REQUEST_CODE);
         }
      });
      // Find edit view
      final EditText phoneNumberEditView = (EditText)
         findViewById(R.id.edit_text_phone_number);
      // Find call button
      Button button = (Button) findViewById(R.id.button);
      button.setOnClickListener(new View.OnClickListener() {
         @Override
         public void onClick(View view) {
            if(phoneNumberEditView.getText() != null) {
               Uri number = Uri.parse("tel:" + phoneNumberEditView.getText());
               Intent callIntent = new Intent(Intent.ACTION_DIAL, number);
               startActivity(callIntent);
            }
         }
      });
   }
   // ... code
}

यहाँ, हम आईडी के साथ बटन, प्रोग्राम किया है call_contact_button संपर्क सूची और आईडी, साथ बटन खोलने के लिए बटन कॉल डायल करने के लिए।

  • नीचे दिखाए गए अनुसार MainActivity क्लास में एक स्थिर चर REQUEST_CODE जोड़ें ,

public class MainActivity extends AppCompatActivity {
   // ...
   private static final int REQUEST_CODE = 1;
   // ...
}
  • अब, नीचे के रूप में MainActivity वर्ग में onActivityResult विधि जोड़ें ,

public class MainActivity extends AppCompatActivity {
   // ...
   @Override
   protected void onActivityResult(int requestCode, int resultCode, Intent data) {
      if (requestCode == REQUEST_CODE) {
         if (resultCode == RESULT_OK) {
            // Bundle extras = data.getExtras();
            // String phoneNumber = extras.get("data").toString();
            Uri uri = data.getData();
            Log.e("ACT_RES", uri.toString());
            String[] projection = {
               ContactsContract.CommonDataKinds.Phone.NUMBER, 
               ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME };
            Cursor cursor = getContentResolver().query(uri, projection, null, null, null);
            cursor.moveToFirst();
            
            int numberColumnIndex =
               cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER);
            String number = cursor.getString(numberColumnIndex);
            
            int nameColumnIndex = cursor.getColumnIndex(
               ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME);
            String name = cursor.getString(nameColumnIndex);
            Log.d("MAIN_ACTIVITY", "Selected number : " + number +" , name : "+name);
            
            // Find edit view
            final EditText phoneNumberEditView = (EditText)
               findViewById(R.id.edit_text_phone_number);
            phoneNumberEditView.setText(number);
         }
      }
   };
   // ...
}

यहां, onActivityResult को तब कॉल किया जाएगा जब कोई उपयोगकर्ता call_contact_button बटन का उपयोग करके संपर्क सूची खोलने और संपर्क का चयन करने के बाद आवेदन पर लौटता है । एक बार onActivityResult विधि लागू होने के बाद, यह उपयोगकर्ता द्वारा चयनित संपर्क प्राप्त करता है, संपर्क नंबर ढूंढता है और इसे पाठ बॉक्स में सेट करता है।

  • एप्लिकेशन चलाएँ और सुनिश्चित करें कि सब कुछ ठीक है। आशय नमूना आवेदन का अंतिम रूप नीचे दिखाया गया है,

  • अब, नीचे दिखाए गए के रूप में आवेदन की ग्रेड फ़ाइल में एस्प्रेसो इरादे कॉन्फ़िगर करें,

dependencies {
   // ...
   androidTestImplementation 'androidx.test.espresso:espresso-intents:3.1.1'
}
  • एंड्रॉइड स्टूडियो द्वारा प्रदान किए गए सिंक नाउ मेनू विकल्प पर क्लिक करें । यह आशय परीक्षण पुस्तकालय डाउनलोड करेगा और इसे ठीक से कॉन्फ़िगर करेगा।

  • ExampleInstrumentedTest.java फ़ाइल खोलें और आम तौर पर उपयोग किए जाने वाले AndroidTestRule के बजाय IntentsTestRule जोड़ें । IntentTestRule इरादे परीक्षण को संभालने के लिए एक विशेष नियम है।

public class ExampleInstrumentedTest {
   // ... code
   @Rule
   public IntentsTestRule<MainActivity> mActivityRule =
   new IntentsTestRule<>(MainActivity.class);
   // ... code
}
  • नीचे दिए गए परीक्षण फोन नंबर और डायलर पैकेज का नाम सेट करने के लिए दो स्थानीय चर जोड़ें,

public class ExampleInstrumentedTest {
   // ... code
   private static final String PHONE_NUMBER = "1 234-567-890";
   private static final String DIALER_PACKAGE_NAME = "com.google.android.dialer";
   // ... code
}
  • Android स्टूडियो द्वारा दिए गए Alt + Enter विकल्प का उपयोग करके आयात के मुद्दों को ठीक करें या फिर नीचे दिए गए आयात विवरणों को शामिल करें,

import android.content.Context;
import android.content.Intent;

import androidx.test.InstrumentationRegistry;
import androidx.test.espresso.intent.rule.IntentsTestRule;
import androidx.test.runner.AndroidJUnit4;

import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;

import static androidx.test.espresso.Espresso.onView;
import static androidx.test.espresso.action.ViewActions.click;
import static androidx.test.espresso.action.ViewActions.closeSoftKeyboard;
import static androidx.test.espresso.action.ViewActions.typeText;
import static androidx.test.espresso.intent.Intents.intended;
import static androidx.test.espresso.intent.matcher.IntentMatchers.hasAction;
import static androidx.test.espresso.intent.matcher.IntentMatchers.hasData;
import static androidx.test.espresso.intent.matcher.IntentMatchers.toPackage;
import static androidx.test.espresso.matcher.ViewMatchers.withId;
import static org.hamcrest.core.AllOf.allOf;
import static org.junit.Assert.*;
  • डायलर को ठीक से बुलाया जाए या नहीं, यह जांचने के लिए नीचे का परीक्षण मामला जोड़ें

public class ExampleInstrumentedTest {
   // ... code
   @Test
   public void validateIntentTest() {
      onView(withId(R.id.edit_text_phone_number))
         .perform(typeText(PHONE_NUMBER), closeSoftKeyboard());
      onView(withId(R.id.button)) .perform(click());
      intended(allOf(
         hasAction(Intent.ACTION_DIAL),
         hasData("tel:" + PHONE_NUMBER),
         toPackage(DIALER_PACKAGE_NAME)));
   }
   // ... code
}

यहाँ, हैवेशन , हैडटा और टापेज मैचर्स का उपयोग ऑलऑफ मैचर के साथ किया जाता है, तभी सफल होगा जब सभी मैचर्स पास हो जाएंगे

  • अब, Android स्टूडियो में सामग्री मेनू के माध्यम से ExampleInstrumentedTest चलाएं

इच्छुक ()

एस्प्रेसो एक विशेष विधि प्रदान करता है - इरादा () बाहरी इरादे की कार्रवाई का मजाक उड़ाना। इरादा () मंज़ूर किए जाने के इरादे के पैकेज के नाम को स्वीकार करते हैं और एक विधि का जवाब प्रदान करते हैं। यह निर्धारित करने के लिए कि नीचे दिए गए इरादे के साथ किस तरह मॉक किए गए इरादे का जवाब देना है

intending(toPackage("com.android.contacts")).respondWith(result);

यहाँ, responseWith () टाइप इंस्ट्रूमेंटेशन के अभिप्राय परिणाम को स्वीकार करता है। ActivityResult । हम नए स्टब आशय बना सकते हैं और मैन्युअल रूप से परिणाम को नीचे बताए अनुसार सेट कर सकते हैं,

// Stub intent
Intent intent = new Intent();
intent.setData(Uri.parse("content://com.android.contacts/data/1"));
Instrumentation.ActivityResult result =
   new Instrumentation.ActivityResult(Activity.RESULT_OK, intent);

यह जानने के लिए कि क्या कोई एप्लिकेशन ठीक से खोला गया है, यह जांचने के लिए पूरा कोड निम्नानुसार है,

@Test
public void stubIntentTest() {
   // Stub intent
   Intent intent = new Intent();
   intent.setData(Uri.parse("content://com.android.contacts/data/1"));
   Instrumentation.ActivityResult result =
      new Instrumentation.ActivityResult(Activity.RESULT_OK, intent);
   intending(toPackage("com.android.contacts")).respondWith(result);
   
   // find the button and perform click action
   onView(withId(R.id.call_contact_button)).perform(click());
   
   // get context
   Context targetContext2 = InstrumentationRegistry.getInstrumentation().getTargetContext();
   
   // get phone number
   String[] projection = { ContactsContract.CommonDataKinds.Phone.NUMBER,
      ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME };
   Cursor cursor =
      targetContext2.getContentResolver().query(Uri.parse("content://com.android.cont
      acts/data/1"), projection, null, null, null);
   
   cursor.moveToFirst();
   int numberColumnIndex =
      cursor.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER);
   String number = cursor.getString(numberColumnIndex);
   
   // now, check the data
   onView(withId(R.id.edit_text_phone_number))
   .check(matches(withText(number)));
}

यहां, हमने एक नया इरादा बनाया है और संपर्क सूची, सामग्री: //com.android.contacts/data/1 की पहली प्रविष्टि के रूप में रिटर्न वैल्यू (जब इरादे को लागू करते हैं) सेट किया है । फिर हमने संपर्क सूची के स्थान पर नए बनाए गए इरादों का मजाक उड़ाने का इरादा बनाया है। यह पैकेज, com.android.contacts को लागू करने पर हमारी नई बनाई गई मंशा को सेट और कॉल करता है और सूची की डिफ़ॉल्ट पहली प्रविष्टि वापस आ जाती है। फिर, हमने नकली इरादे को शुरू करने के लिए क्लिक () कार्रवाई को निकाल दिया और अंत में जाँच करता है कि क्या नकली इरादे को लागू करने से फोन नंबर और संपर्क सूची में पहली प्रविष्टि की संख्या समान हैं।

यह कोई भी गायब आयात समस्या है, फिर उन आयात मुद्दों को Alt + Enter विकल्प का उपयोग करके ठीक करें जो कि एंड्रॉइड स्टूडियो द्वारा दिए गए हैं या फिर नीचे दिए गए आयात विवरणों को शामिल करें,

import android.app.Activity;
import android.app.Instrumentation;
import android.content.Context;
import android.content.Intent;
import android.database.Cursor;
import android.net.Uri;
import android.provider.ContactsContract;

import androidx.test.InstrumentationRegistry;
import androidx.test.espresso.ViewInteraction;
import androidx.test.espresso.intent.rule.IntentsTestRule;
import androidx.test.runner.AndroidJUnit4;

import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;

import static androidx.test.espresso.Espresso.onView;
import static androidx.test.espresso.action.ViewActions.click;
import static androidx.test.espresso.action.ViewActions.closeSoftKeyboard;
import static androidx.test.espresso.action.ViewActions.typeText;
import static androidx.test.espresso.assertion.ViewAssertions.matches;
import static androidx.test.espresso.intent.Intents.intended;
import static androidx.test.espresso.intent.Intents.intending;
import static androidx.test.espresso.intent.matcher.IntentMatchers.hasAction;
import static androidx.test.espresso.intent.matcher.IntentMatchers.hasData;
import static androidx.test.espresso.intent.matcher.IntentMatchers.toPackage;
import static androidx.test.espresso.matcher.ViewMatchers.withId;
import static androidx.test.espresso.matcher.ViewMatchers.withText;
import static org.hamcrest.core.AllOf.allOf;
import static org.junit.Assert.*;

संपर्क सूची पढ़ने की अनुमति प्रदान करने के लिए परीक्षण वर्ग में नीचे का नियम जोड़ें -

@Rule
public GrantPermissionRule permissionRule =
GrantPermissionRule.grant(Manifest.permission.READ_CONTACTS);

एप्लिकेशन मैनिफ़ेस्ट फ़ाइल में निम्न विकल्प जोड़ें, AndroidManifest.xml -

<uses-permission android:name = "android.permission.READ_CONTACTS" />

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

Android उपयोगकर्ता इंटरफ़ेस परीक्षण का समर्थन करता है जिसमें एक से अधिक अनुप्रयोग शामिल हैं। आइए विचार करें कि हमारे आवेदन में संदेश भेजने के लिए हमारे आवेदन से संदेश भेजने के लिए आवेदन करने का विकल्प है और फिर हमारे आवेदन पर वापस आता है। इस परिदृश्य में, UI ऑटोमेटर परीक्षण ढांचा हमें अनुप्रयोग का परीक्षण करने में मदद करता है। यूआई ऑटोमेकर को एस्प्रेसो टेस्टिंग फ्रेमवर्क के लिए एक अच्छा साथी माना जा सकता है। हम यूआई ऑटोमेकर के लिए चुनने से पहले एस्प्रेसो टेस्टिंग फ्रेमवर्क में इंटेंडिंग () विकल्प का फायदा उठा सकते हैं ।

सेटअप निर्देश

एंड्रॉइड यूआई ऑटोमेटर को एक अलग प्लगइन के रूप में प्रदान करता है। इसे नीचे दिए गए अनुसार एप्लिकेशन / build.gradle में कॉन्फ़िगर करना होगा ।

dependencies {
   ...
   androidTestImplementation 'androidx.test.uiautomator:uiautomator:2.2.0'
}

टेस्ट केस लिखने के लिए वर्कफ़्लो

आइए हम समझते हैं कि यूआई ऑटोमेटर आधारित टेस्ट केस कैसे लिखना है ,

  • GetInstance () विधि को कॉल करके और इंस्ट्रूमेंटेशन ऑब्जेक्ट को पास करके UiDevice ऑब्जेक्ट प्राप्त करें ।

myDevice = UiDevice.getInstance(InstrumentationRegistry.getInstrumentation());
myDevice.pressHome();
  • FindObject () विधि का उपयोग करके UiObject ऑब्जेक्ट प्राप्त करें । इस पद्धति का उपयोग करने से पहले, हम uiautomatorviewer एप्लिकेशन को लक्ष्य एप्लिकेशन UI घटकों का निरीक्षण करने के लिए खोल सकते हैं क्योंकि लक्ष्य एप्लिकेशन को समझने से हमें बेहतर परीक्षण मामलों को लिखने में सक्षम बनाता है।

UiObject button = myDevice.findObject(new UiSelector()
   .text("Run")
   .className("android.widget.Button"));
  • UiObject की विधि को कॉल करके उपयोगकर्ता इंटरैक्शन का अनुकरण करें । उदाहरण के लिए, एक पाठ क्षेत्र को संपादित करने के लिए सेटटेक्स्ट () और एक बटन के क्लिक इवेंट को आग लगाने के लिए क्लिक करें ()

if(button.exists() && button.isEnabled()) {
   button.click();
}
  • अंत में, हम जांचते हैं कि क्या UI अपेक्षित स्थिति को दर्शाता है।

टेस्ट केस लिखना एक थकाऊ काम है। भले ही एस्प्रेसो बहुत आसान और लचीला एपीआई प्रदान करता है, परीक्षण मामलों को लिखना एक आलसी और समय लेने वाला कार्य हो सकता है। इसे दूर करने के लिए, एंड्रॉइड स्टूडियो एस्प्रेसो टेस्ट मामलों को रिकॉर्ड करने और उत्पन्न करने के लिए एक सुविधा प्रदान करता है। रिकॉर्ड एस्प्रेसो टेस्ट रन मेनू के तहत उपलब्ध है ।

हमें नीचे वर्णित चरणों का पालन करके अपने HelloWorldApp में एक साधारण परीक्षण मामला दर्ज करें,

  • HelloWorldApp एप्लिकेशन के बाद Android स्टूडियो खोलें ।

  • रनरिकॉर्ड एस्प्रेसो टेस्ट पर क्लिक करें और मेनऐक्टिविटी चुनें ।

  • रिकॉर्डर स्क्रीनशॉट के रूप में इस प्रकार है,

  • Add Assertion पर क्लिक करें । यह नीचे दिखाए अनुसार एप्लिकेशन स्क्रीन को खोलेगा,

  • हैलो वर्ल्ड पर क्लिक करें ! रिकॉर्डर करने के लिए स्क्रीन पाठ दृश्य का चयन इस प्रकार है,

  • फिर से सहेजें दावे पर क्लिक करें यह दावे को बचाएगा और इसे निम्नानुसार दिखाएगा,

  • ओके पर क्लिक करें । यह एक नई विंडो खोलेगा और परीक्षण मामले का नाम पूछेगा। डिफ़ॉल्ट नाम MainActivityTest है

  • यदि आवश्यक हो तो परीक्षण मामले का नाम बदलें।

  • फिर से, ठीक पर क्लिक करें । यह हमारे रिकॉर्ड किए गए परीक्षण मामले के साथ एक फ़ाइल, MainActivityTest उत्पन्न करेगा । पूरा कोडिंग इस प्रकार है,

package com.tutorialspoint.espressosamples.helloworldapp;

import android.view.View;
import android.view.ViewGroup;
import android.view.ViewParent;

import org.hamcrest.Description;
import org.hamcrest.Matcher;
import org.hamcrest.TypeSafeMatcher;
import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;

import androidx.test.espresso.ViewInteraction;
import androidx.test.filters.LargeTest;
import androidx.test.rule.ActivityTestRule;
import androidx.test.runner.AndroidJUnit4;

import static androidx.test.espresso.Espresso.onView;
import static androidx.test.espresso.assertion.ViewAssertions.matches;
import static androidx.test.espresso.matcher.ViewMatchers.isDisplayed;
import static androidx.test.espresso.matcher.ViewMatchers.withId;
import static androidx.test.espresso.matcher.ViewMatchers.withText;
import static org.hamcrest.Matchers.allOf;

@LargeTest
@RunWith(AndroidJUnit4.class)
public class MainActivityTest {
   @Rule
   public ActivityTestRule<MainActivity> mActivityTestRule = new ActivityTestRule<>(MainActivity.class);
   @Test
   public void mainActivityTest() {
      ViewInteraction textView = onView(
         allOf(withId(R.id.textView_hello), withText("Hello World!"),
         childAtPosition(childAtPosition(withId(android.R.id.content),
         0),0),isDisplayed()));
      textView.check(matches(withText("Hello World!")));
   }
   private static Matcher<View> childAtPosition(
      final Matcher<View> parentMatcher, final int position) {
      return new TypeSafeMatcher<View>() {
         @Override
         public void describeTo(Description description) {
            description.appendText("Child at position " + position + " in parent ");
            parentMatcher.describeTo(description);
         }
         @Override
         public boolean matchesSafely(View view) {
            ViewParent parent = view.getParent();
            return parent instanceof ViewGroup &&
               parentMatcher.matches(parent)&& view.equals(((ViewGroup)
               parent).getChildAt(position));
         }
      };
   }
}
  • अंत में, संदर्भ मेनू का उपयोग करके परीक्षण चलाएं और जांचें कि क्या परीक्षण मामला चलता है।

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

आइए इस अध्याय में UI प्रदर्शन का विश्लेषण करने के लिए Android में उपलब्ध कुछ विकल्प जानें।

dumpsys

dumpsys एंड्रॉइड डिवाइस में उपलब्ध एक इन-बिल्ट टूल है। यह सिस्टम सेवाओं के बारे में वर्तमान जानकारी को आउटपुट करता है। डंप्स में विशेष श्रेणी के बारे में जानकारी डंप करने का विकल्प होता है। Gfxinfo पासिंग आपूर्ति पैकेज की एनीमेशन जानकारी प्रदान करेगा। आदेश निम्नानुसार है,

> adb shell dumpsys gfxinfo <PACKAGE_NAME>

framestats

framestats dumpsys कमान के एक विकल्प है। एक बार जब dumpsys साथ शुरू हो जाती है framestats , यह हाल के फ्रेम की विस्तृत फ्रेम समय जानकारी डंप हो जाएगा। आदेश निम्नानुसार है,

> adb shell dumpsys gfxinfo <PACKAGE_NAME> framestats

यह CSV (अल्पविराम से अलग किए गए मान) के रूप में जानकारी को आउटपुट करता है। CSV प्रारूप में आउटपुट डेटा को आसानी से एक्सेल में धकेलने में मदद करता है और बाद में एक्सेल फ़ार्मुलों और चार्ट के माध्यम से उपयोगी जानकारी निकालता है।

Systrace

systrace भी एक इन-बिल्ड टूल है जो Android डिवाइस में उपलब्ध है। यह एप्लिकेशन प्रक्रियाओं के निष्पादन समय को कैप्चर और प्रदर्शित करता है। सिस्ट्रेस को एंड्रॉइड स्टूडियो के टर्मिनल में नीचे कमांड का उपयोग करके चलाया जा सकता है,

python %ANDROID_HOME%/platform-tools/systrace/systrace.py --time=10 -o
my_trace_output.html gfx view res

पहुँच सुविधा किसी भी अनुप्रयोग के लिए प्रमुख विशेषताओं में से एक है। एक विक्रेता द्वारा विकसित किए गए एप्लिकेशन को सफल और उपयोगी एप्लिकेशन होने के लिए एंड्रॉइड एसडीके द्वारा निर्धारित न्यूनतम पहुंच दिशानिर्देश का समर्थन करना चाहिए। पहुँच मानक का पालन करना बहुत महत्वपूर्ण है और यह एक आसान काम नहीं है। एंड्रॉइड एसडीके सुलभ उपयोगकर्ता इंटरफेस बनाने के लिए ठीक से डिज़ाइन किए गए दृश्य प्रदान करके बहुत सहायता प्रदान करता है।

इसी तरह, एस्प्रेसो टेस्टिंग फ्रेमवर्क डेवलपर और अंतिम उपयोगकर्ता दोनों के लिए एक महान उपकार करता है जो मुख्य रूप से कोर-टेस्टिंग इंजन में एक्सेसिबिलिटी टेस्टिंग फीचर्स का पारदर्शिता से समर्थन करता है।

एस्प्रेसो में, एक डेवलपर AccessibilityChecks वर्ग के माध्यम से पहुंच परीक्षण को सक्षम और कॉन्फ़िगर कर सकता है । नमूना कोड निम्नानुसार है,

AccessibilityChecks.enable();

डिफ़ॉल्ट रूप से, जब आप कोई दृश्य क्रिया करते हैं तो पहुँच-क्षमता जाँच चलती है। चेक में वह दृश्य शामिल है जिस पर कार्रवाई के साथ-साथ सभी वंशज दृश्य भी शामिल हैं। आप निम्न कोड का उपयोग करके स्क्रीन के पूरे दृश्य पदानुक्रम की जांच कर सकते हैं -

AccessibilityChecks.enable().setRunChecksFromRootView(true);

निष्कर्ष

एस्प्रेसो एंड्रॉइड डेवलपर्स के लिए अपने एप्लिकेशन को पूरी तरह से बहुत आसान तरीके से परीक्षण करने के लिए और परीक्षण रूपरेखा द्वारा सामान्य रूप से आवश्यक अतिरिक्त प्रयास किए बिना एक महान उपकरण है। यहां तक ​​कि इसमें कोड को मैन्युअल रूप से लिखे बिना टेस्ट केस बनाने के लिए रिकॉर्डर भी है। इसके अलावा, यह सभी प्रकार के उपयोगकर्ता इंटरफ़ेस परीक्षण का समर्थन करता है। एस्प्रेसो टेस्टिंग फ्रेमवर्क का उपयोग करके, एक एंड्रॉइड डेवलपर आत्मविश्वास से एक शानदार दिखने वाला एप्लिकेशन विकसित कर सकता है और साथ ही साथ कम समय में किसी भी मुद्दे के बिना एक सफल एप्लिकेशन भी बना सकता है।