एस्प्रेसो टेस्टिंग फ्रेमवर्क - वेब व्यू
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 टैग के पाठ की जांच करता है ।
अंत में, एंड्रॉइड स्टूडियो संदर्भ मेनू का उपयोग करके परीक्षण केस चलाएं।