इस गाइड में, gcloud सीएलआई का इस्तेमाल करके, इंस्ट्रूमेंटेशन, रोबो या गेम लूप टेस्ट चलाने का तरीका बताया गया है.
gcloud
निर्देशों की पूरी सूची के लिए, इनका इस्तेमाल किया जा सकता है
Test Lab में अपने Android ऐप्लिकेशन की मदद से, इस लिंक पर जाएं
gcloud firebase test android
के बारे में दस्तावेज़.
शुरू करने से पहले
अगर आपने पहले से Firebase को नहीं जोड़ा है, तो अपने Android प्रोजेक्ट में Firebase जोड़ें.
पहला चरण. gcloud सीएलआई सेट अप करें
- Google Cloud SDK डाउनलोड करें
- पक्का करें कि आपका इंस्टॉलेशन अप-टू-डेट हो:
gcloud components update
- अपने Google खाते का इस्तेमाल करके gcloud सीएलआई में साइन इन करें:
gcloud auth login
- अपना Firebase प्रोजेक्ट gcloud में सेट करें, जहां PROJECT_ID है
आपके Firebase प्रोजेक्ट का आईडी:
gcloud config set project PROJECT_ID
इसमें gcloud सीएलआई टूल शामिल है.
दूसरा चरण. टेस्ट के लिए उपलब्ध डिवाइस देखें
टेस्ट के लिए इस्तेमाल होने वाले डिवाइसों और स्थान-भाषाओं को देखने के लिए, gcloud के इन निर्देशों का पालन करें आपके टेस्ट के लिए उपलब्ध है.
विकल्प के रूप में, आप इसका नमूना डाउनलोड भी कर सकते हैं
शुरू करने के लिए, Notepad ऐप्लिकेशन
निर्देशों को तुरंत लागू कर देता है. बाइनरी फ़ाइल app-debug-unaligned.apk
का इस्तेमाल करें
और इंस्ट्रुमेंटेशन टेस्ट फ़ाइल app-debug-test-unaligned.apk
, जो मौजूद हैं
NotePad/app/build/outputs/apk/
में.
models list
: उन Android डिवाइसों की मौजूदा सूची पाएं जो आपके लिए जांच के लिए उपलब्ध हैं टीम में हुए हैं.gcloud firebase test android models list
कमांड आउटपुट में:
- कॉलम
MODEL_ID
में वह आइडेंटिफ़ायर होता है जिसका इस्तेमाल, बाद में डिवाइस मॉडल पर टेस्ट चलाने के लिए किया जा सकता है. - कॉलम
OS_VERSION_ID
में, काम करने वाले ऑपरेटिंग सिस्टम वर्शन शामिल हैं से कनेक्ट होता है.
आउटपुट का उदाहरण
- कॉलम
models describe
: किसी खास AndroidMODEL_ID
के बारे में ज़्यादा जानकारी पाएं.gcloud firebase test android models describe MODEL_ID
आउटपुट में डिवाइस मॉडल का ब्रैंड, मैन्युफ़ैक्चरर, ओएस वर्शन, काम करने वाले एपीआई लेवल, काम करने वाला ऐप्लिकेशन बाइनरी इंटरफ़ेस (एबीआई), रिलीज़ की तारीखें बताएंगे और डिवाइस का फ़िज़िकल है या वर्चुअल.
versions list
: जांच करने के लिए, मौजूदा ओएस वर्शन की सूची पाएं टीम में हुए हैं.gcloud firebase test android versions list
कमांड के पहले दो कॉलम में से किसी एक से आइडेंटिफ़ायर का इस्तेमाल किया जा सकता है आउटपुट (
OS_VERSION_ID
औरVERSION
) में, बाद में किसी Android के लिए टेस्ट चलाने के लिए किया जाता है ओएस वर्शन का होना चाहिए. अगर आपने टेस्ट करने के लिए Android OS के वर्शन तय नहीं किए हैं, तोTAGS
कॉलम में, डिफ़ॉल्ट रूप से नोट की गई सेटिंग का इस्तेमाल किया जाता है.आउटपुट का उदाहरण
locales list
: परीक्षण के लिए उपलब्ध स्थान-भाषाओं की मौजूदा सूची पाएं.gcloud firebase test android versions list
कमांड आउटपुट के पहले कॉलम,
LOCALE
में आइडेंटिफ़ायर होता है जिनका इस्तेमाल बाद में किसी स्थान-भाषा से जुड़ी जांच के लिए किया जा सकता है. अगर आप तय नहीं करते हैं, तो जिन स्थानों के लिए जांच करनी है, डिफ़ॉल्ट स्थान-भाषा के तौर पर अंग्रेज़ी का इस्तेमाल किया जाता है.
चरण 3. जांच करें
अब आपको अलग-अलग तरह के डिवाइस मॉडल, स्थान-भाषा, और ओएस वर्शन के बारे में जानकारी है
टेस्ट करने के लिए, आप इसका इस्तेमाल करके डिवाइस तय कर सकते हैं
gcloud firebase test android run
निर्देश और
रोबो या इंस्ट्रुमेंटेशन टेस्ट चलाने के लिए --device
फ़्लैग.
रोबो टेस्ट शुरू करें
भले ही आपने कोई इंस्ट्रुमेंटेशन टेस्ट न किया हो, तब भी आप के लिए सबसे अच्छा है. अपने-आप होने वाली समीक्षा की कार्रवाई करने के लिए, रोबो टेस्ट का इस्तेमाल करें यूज़र इंटरफ़ेस पर कुछ काम करता है. रोबो टेस्ट, ऐप्लिकेशन के यूज़र इंटरफ़ेस के ज़रिए अलग-अलग पाथ का स्टैटिक विश्लेषण करके, ऐप्लिकेशन की जांच करता है. इसके बाद, ऐप्लिकेशन को क्रॉल करके क्रैश और अन्य संभावित समस्याओं का पता लगाता है.
रोबो टेस्ट चलाने के लिए, यहां दिया गया कमांड चलाएं:
gcloud firebase test android run \ --type robo \ --app app-debug-unaligned.apk \ --device model=Nexus6,version=21,locale=en,orientation=portrait \ --device model=Nexus7,version=19,locale=fr,orientation=landscape \ --timeout 90s \ --client-details matrixLabel="Example matrix label"
- अगर
--type
की कोई वैल्यू तय नहीं की गई है, तो--type robo
पैरामीटर लागू नहीं होता है. - Firebase कंसोल में, अपने टेस्ट मैट्रिक्स की पहचान करने और उनका पता लगाने में आपकी मदद करने के लिए,
--client-details matrixLabel="Example matrix label"
का इस्तेमाल किया जा सकता है. फ़्लैग करें. - आप इनके लिए कमांड लाइन विकल्पों का पूरा सेट देख सकते हैं
यह टाइप करके परीक्षण चलाए जा सकते हैं:
gcloud help firebase test android run
.
कमांड लाइन पर इन आर्ग्युमेंट को बताने के विकल्प के तौर पर,
इसके अलावा, YAML फ़ॉर्मैट वाली आर्ग्युमेंट फ़ाइल में भी अपने आर्ग्युमेंट इस्तेमाल करें. दौड़ना
इस सुविधा के इस्तेमाल का तरीका जानने के लिए gcloud topic arg-files
.
रोबो टेस्ट से जांच के नतीजों की जांच करने का तरीका जानने के लिए, देखें अपने जांच के नतीजों का विश्लेषण करें.
इंस्ट्रुमेंटेशन टेस्ट चलाना
अब Notepad ऐप्लिकेशन को चलाने के लिए, gcloud
कमांड लाइन टूल का इस्तेमाल करें
एस्प्रेसो
आपके बताए गए Android डिवाइस कॉन्फ़िगरेशन पर टेस्ट करता है. app-debug-test-unaligned.apk
में जांच करने के लिए, instrumentation
जांच के टाइप का इस्तेमाल करें. इसके लिए, यह तरीका अपनाएं:
gcloud firebase test android run \ --type instrumentation \ --app app-debug-unaligned.apk \ --test app-debug-test-unaligned.apk \ --device model=Nexus6,version=21,locale=en,orientation=portrait \ --device model=Nexus7,version=19,locale=fr,orientation=landscape --client-details matrixLabel="Example matrix label"
- अगर टेस्ट APK दिया गया है, तो
--type
इंस्ट्रुमेंटेशन पैरामीटर लागू नहीं होता--test
के साथ. - Firebase कंसोल में अपने टेस्ट मैट्रिक की पहचान करने और उन्हें ढूंढने में मदद पाने के लिए, अपने टेस्ट मैट्रिक को लेबल करने के लिए,
--client-details matrixLabel="Example matrix label"
फ़्लैग का इस्तेमाल किया जा सकता है. हालांकि, ऐसा करना ज़रूरी नहीं है. - आप इनके लिए कमांड लाइन विकल्पों का पूरा सेट देख सकते हैं
gcloud help firebase test android run
टाइप करके परीक्षण चलाए जा सकते हैं.
कमांड लाइन पर इन आर्ग्युमेंट को बताने के विकल्प के तौर पर,
इसके अलावा, YAML फ़ॉर्मैट वाली आर्ग्युमेंट फ़ाइल में भी अपने आर्ग्युमेंट इस्तेमाल करें. दौड़ना
इस सुविधा के इस्तेमाल का तरीका जानने के लिए gcloud topic arg-files
.
gcloud सीएलआई, Android Test Orchestrator के साथ काम करता है.
ऑर्चेस्ट्रेटर के लिए AndroidJUnitRunner v1.1 या इसके बाद के वर्शन की ज़रूरत होती है. इसे चालू करने के लिए,
--use-orchestrator
के साथ gcloud firebase test android run
फ़्लैग करें. इस सुविधा को बंद करने के लिए, --no-use-orchestrator
फ़्लैग का इस्तेमाल करें.
ऊपर नहीं दिखाए गए अन्य फ़्लैग का इस्तेमाल करके, यह भी कंट्रोल किया जा सकता है कि Test Lab आपके इंस्ट्रूमेंटेशन टेस्ट कैसे चलाए. उदाहरण के लिए, आप
किसी एक क्लास या आपके टेस्ट में इस्तेमाल होने वाले क्लास मेथड की जांच करने के लिए --test-targets
फ़्लैग
APK के साथ दिखेगा. यह भी पता लगाया जा सकता है कि टेस्ट में हुई गड़बड़ी असल में अमान्य थी या नहीं
नहीं करने के लिए --num-flaky-test-attempts
फ़्लैग का इस्तेमाल करें. इससे यह पता चलता है कि
अगर किसी टेस्ट केस के एक या एक से ज़्यादा टेस्ट केस होने पर, उस टेस्ट को बार-बार करने की फिर से कोशिश की जानी चाहिए
किसी भी वजह से शेड्यूल नहीं किया जा सकता. ज़्यादा जानकारी के लिए, gcloud firebase टेस्ट android Run देखें.
इंस्ट्रुमेंटेशन टेस्ट के लिए कोड कवरेज रिपोर्ट
Test Lab, कोड कवरेज की रिपोर्टिंग करने वाले टूल के साथ काम करता है. जैसे, EMMA और JaCoCo. अगर आपके पास इनमें से कोई एक टूल है
ऐप्लिकेशन के बिल्ड में इंटिग्रेट किया गया है, तो आपको
कुछ उपयोगकर्ताओं के साथ gcloud firebase test android run
चलाकर Test Lab टेस्ट किए गए
की भी ज़रूरत नहीं है. अगर Android Test Orchestrator चालू नहीं है, तो
फ़ॉलो किया जा रहा है:
gcloud firebase test android run \ --type instrumentation \ --app your-app.apk \ --test your-app-test.apk \ --device model=TestDevice,version=AndroidVersion \ --environment-variables coverage=true,coverageFile="/sdcard/Download/coverage.ec" \ --directories-to-pull /sdcard/Download
अगर Android Test का इस्तेमाल करते हुए भी कोड कवरेज रिपोर्ट जनरेट की जा रही हैं ऑर्केस्ट्रेटर, अपने एनवायरमेंट वैरिएबल में इस तरह से बदलाव करें:
gcloud firebase test android run \ --type instrumentation \ --app your-app.apk \ --test your-app-test.apk \ --device model=TestDevice,version=AndroidVersion \ --environment-variables clearPackageData=true,coverage=true,coverageFilePath="/sdcard/Download/" \ --directories-to-pull /sdcard/Download
Test Lab की जांच पूरी होने के बाद, कोड कवरेज की रिपोर्ट देखें Google Cloud Storage में:
- Firebase कंसोल लिंक खोलें, जिसे
gcloud
टूल ने आपके टर्मिनल में जांच के नतीजे वाली टेबल के ऊपर प्रिंट किया है. - उस लिंक पर मौजूद सूची में से किसी टेस्ट एक्ज़ीक्यूशन पर क्लिक करें और उस एक्ज़ीक्यूशन को खोलें क्लिक करें.
- टेस्ट के नतीजे पर क्लिक करके, उस Cloud Storage बकेट पर जाएं जिसमें उस एक्सीक्यूशन के टेस्ट के नतीजे हैं.
- अपने कोड कवरेज की रिपोर्ट देखने के लिए,
artifacts/coverage.ec
खोलें.
टेस्ट के नतीजों का विश्लेषण करना
कुछ मिनटों के बाद, आपकी जांच के नतीजों की बुनियादी जानकारी को gcloud टूल:
आपके कमांड लाइन टेस्ट रन के आउटपुट में, टेस्ट देखने का लिंक भी शामिल होता है नतीजे. इन नतीजों को समझने के तरीके के बारे में ज़्यादा जानने के लिए, Android पर मिले नतीजों के लिए Firebase Test Lab का विश्लेषण करना लेख पढ़ें.
रोबो टेस्ट के साथ पसंद के मुताबिक लॉगिन और टेक्स्ट इनपुट
जब तक --no-auto-google-login
पैरामीटर का इस्तेमाल नहीं किया जाता, तब तक रोबो टेस्ट, पुष्टि करने के लिए Google खाते का इस्तेमाल करने वाली साइन इन स्क्रीन को अपने-आप पूरा कर देता है. यह आपके दिए गए टेस्ट खाते के क्रेडेंशियल का इस्तेमाल करके, कस्टम लॉगिन स्क्रीन भी बना सकता है. इस पैरामीटर का इस्तेमाल, अपने ऐप्लिकेशन में इस्तेमाल किए जाने वाले अन्य टेक्स्ट फ़ील्ड के लिए, कस्टम इनपुट टेक्स्ट देने के लिए भी किया जा सकता है.
अपने ऐप्लिकेशन में टेक्स्ट फ़ील्ड भरने के लिए,
--robo-directives
पैरामीटर और key-value
जोड़े की एक कॉमा-सेपरेटेड लिस्ट दें, जहां
key
, टारगेट यूज़र इंटरफ़ेस (यूआई) एलिमेंट का Android संसाधन नाम है और value
है
टेक्स्ट स्ट्रिंग. इस फ़्लैग का इस्तेमाल करके, रोबो को किसी खास नियम को अनदेखा करने के लिए कहा जा सकता है
यूज़र इंटरफ़ेस (यूआई) एलिमेंट (उदाहरण के लिए, "लॉग आउट करें" बटन).
EditText
फ़ील्ड काम करते हैं, लेकिन WebView
यूज़र इंटरफ़ेस (यूआई) एलिमेंट में टेक्स्ट फ़ील्ड नहीं.
उदाहरण के लिए, कस्टम पैरामीटर के लिए इस पैरामीटर का इस्तेमाल किया जा सकता है लॉगिन करें:
--robo-directives username_resource=username,password_resource=password
उपलब्ध निर्देश और फ़्लैग
Test Lab gcloud सीएलआई में कई कमांड और फ़्लैग उपलब्ध हैं. इनकी मदद से, अलग-अलग खास निर्देशों के साथ टेस्ट करें:
Android Test Orchestrator फ़्लैग: Orchestrator को चालू करने के लिए,एक फ़्लैग इस टूल की मदद से, अपनी हर सुविधा को ऐप्लिकेशन के परीक्षण को
Instrumentation
को शामिल करना चाहिए. हमेशा Test Lab ऑर्केस्ट्रेटर का सबसे नया वर्शन चलाता है.गेम लूप के टेस्ट फ़्लैग: कॉन्फ़िगरेशन फ़्लैग का एक सेट जो "डेमो" को चालू और कंट्रोल करता है मोड" इस्तेमाल करके प्लेयर, गेम ऐप्लिकेशन में खिलाड़ी की कार्रवाइयों को सिम्युलेट कर सकते हैं. Test Lab की मदद से गेम लूप टेस्ट चलाने के बारे में ज़्यादा जानें.
यूनिफ़ॉर्म शार्डिंग फ़्लैग (बीटा में): ऐसा फ़्लैग जो शार्ड की संख्या तय करता है और जिनमें आप समान रूप से शामिल करना चाहते हैं टेस्ट केस उपलब्ध कराना. शार्ड अलग-अलग डिवाइस पर समानांतर रूप से चलाए जाते हैं.
मैन्युअल शार्डिंग फ़्लैग (बीटा में): ऐसा फ़्लैग जो चलाने के लिए पैकेज, क्लास, और/या टेस्ट केस के ग्रुप के बारे में बताता है शार्ड (टेस्ट केस का एक समूह) में होती है. शार्ड नीचे समानांतर रूप से चलते हैं अलग-अलग डिवाइस.
नेटवर्क ट्रैफ़िक प्रोफ़ाइल फ़्लैग (बीटा वर्शन में): यह फ़्लैग बताता है कि आपके टेस्ट, फ़िज़िकल डिवाइसों के साथ किस नेटवर्क प्रोफ़ाइल का इस्तेमाल करते हैं. नेटवर्क प्रोफ़ाइल कई तरह की नेटवर्क स्थितियों की नकल करती हैं. आपको ऐसे नेटवर्क पर अपने ऐप्लिकेशन की परफ़ॉर्मेंस की जांच करनी होगी जिनका अनुमान न लगाया जा सके.
Test Lab की मदद से gcloud कमांड की स्क्रिप्ट बनाना
मोबाइल ऐप्लिकेशन की जांच करने के उन निर्देशों को ऑटोमेट करने के लिए, शेल स्क्रिप्ट या बैच फ़ाइलों का इस्तेमाल किया जा सकता है जिन्हें आम तौर पर gcloud कमांड लाइन का इस्तेमाल करके चलाया जाता है. नीचे दिए गए उदाहरण के लिए, बैश स्क्रिप्ट दो मिनट के टाइम आउट के साथ इंस्ट्रुमेंटेशन टेस्ट करती है और परीक्षण सफलतापूर्वक पूरा होने पर रिपोर्ट करता है:
if gcloud firebase test android run --app my-app.apk --test my-test.apk --timeout 2m then echo "Test matrix successfully finished" else echo "Test matrix exited abnormally with non-zero exit code: " $? fi
स्क्रिप्ट एग्ज़िट कोड
Test Lab में कई एग्ज़िट कोड मिलते हैं, जिनका इस्तेमाल करके स्क्रिप्ट या बैच फ़ाइलों का इस्तेमाल करके चलाए गए टेस्ट के नतीजे.
Test Lab के लिए एग्ज़िट कोड स्क्रिप्ट किए जा रहे हैं
कोड से बाहर निकलें | नोट |
---|---|
0 | सभी जांच पास हो गईं. |
1 | कोई सामान्य गड़बड़ी हुई. संभावित कारणों में शामिल हैं: एक फ़ाइल नाम जो मौजूद नहीं है या एचटीटीपी/नेटवर्क की गड़बड़ी है. |
2 | अनजान निर्देश या आर्ग्युमेंट दिए जाने की वजह से, जांच से बाहर हो गया. |
10 | टेस्ट के दौरान, एक या एक से ज़्यादा टेस्ट केस (जांच की गई क्लास या क्लास के तरीके) पास नहीं हुए. |
15 | Firebase Test Lab यह तय नहीं कर सका कि टेस्ट मैट्रिक्स पास हुआ या नहीं या अचानक हुई गड़बड़ी की वजह से कार्रवाई नहीं की जा सकी. |
18 | इस जांच के निष्पादन के लिए टेस्ट एनवायरमेंट काम नहीं करता है, क्योंकि टेस्ट डाइमेंशन काम नहीं करते. यह गड़बड़ी तब हो सकती है, जब Android API को चुना गया हो स्तर का चयन चुने गए डिवाइस प्रकार पर नहीं किया जा सकता है. |
19 | टेस्ट मैट्रिक्स को उपयोगकर्ता ने रद्द कर दिया था. |
20 | परीक्षण संरचना में कोई गड़बड़ी हुई. |