इस पेज पर, डेवलपर की मदद से बनाए गए सीटीएस (सीटीएस-डी) के इस्तेमाल से जुड़े दिशा-निर्देशों के बारे में बताया गया है.
टेस्ट कवरेज
सीटीएस और सीटीएस की पुष्टि करने वाले टूल की तरह, सीटीएस-डी भी सिर्फ़ इन चीज़ों को लागू कर सकता है:
- सभी सार्वजनिक एपीआई, जिनके बारे में डेवलपर एसडीके (developer.android.com) में बताया गया है.
- किसी एपीआई लेवल के लिए, Android Compatibility Definition Document (CDD) में शामिल सभी ज़रूरी शर्तें.
'ज़रूरी नहीं' के तौर पर मार्क की गई ज़रूरी शर्तों, जैसे कि 'बेहद ज़रूरी', 'होना चाहिए', 'हो सकता है' को पूरा करना ज़रूरी नहीं है. साथ ही, CTS का इस्तेमाल करके इनकी जांच नहीं की जा सकती.
सभी एपीआई और सीडीडी की ज़रूरी शर्तें, किसी खास एपीआई लेवल से जुड़ी होती हैं. इसलिए, सभी सीटीएस टेस्ट (सीटीएस, सीटीएस-डी, और सीटीएस वेरिफ़ायर) उसी एपीआई लेवल से जुड़े होते हैं जिस एपीआई लेवल से उनके एपीआई या ज़रूरी शर्तें जुड़ी होती हैं. अगर किसी एपीआई को बंद कर दिया जाता है या उसमें बदलाव किया जाता है, तो उससे जुड़े टेस्ट को भी बंद कर दिया जाना चाहिए या अपडेट कर दिया जाना चाहिए.
सीटीएस टेस्ट बनाने के नियम
- किसी टेस्ट से, एक ही मकसद का नतीजा लगातार मिलना चाहिए.
- टेस्ट से यह पता चलना चाहिए कि डिवाइस पास हुआ है या फ़ेल. इसके लिए, डिवाइस को बॉक्स से निकालकर एक बार टेस्ट करना होगा.
- टेस्ट बनाने वाले लोगों को, उन सभी संभावित फ़ैक्टर को हटाना होगा जिनसे टेस्ट के नतीजों पर असर पड़ सकता है.
- अगर किसी डिवाइस के लिए, हार्डवेयर की कोई खास शर्त/एनवायरमेंट/सेटअप ज़रूरी है, तो कमिट मैसेज में उस सेटअप के बारे में साफ़ तौर पर बताया जाना चाहिए. उदाहरण के तौर पर, सेटअप करने के निर्देशों के लिए, सीटीएस सेट अप करना लेख पढ़ें.
- एक बार में, टेस्ट को छह घंटे से ज़्यादा नहीं चलाया जा सकता. अगर इसे ज़्यादा समय तक चलाना है, तो कृपया अपने टेस्ट के प्रस्ताव में इसकी वजह बताएं, ताकि हम इसकी समीक्षा कर सकें.
यहां ऐप्लिकेशन पर पाबंदी लगाने की सुविधा की जांच करने के लिए, टेस्ट की शर्तों का एक उदाहरण दिया गया है:
- वाई-फ़ाई कनेक्शन स्टेबल हो (ऐसी जांच के लिए जो वाई-फ़ाई पर निर्भर करती है).
- जांच के दौरान डिवाइस को स्थिर रखा जाता है. हालांकि, यह जांच के हिसाब से अलग-अलग हो सकता है.
- डिवाइस को किसी भी पावर सोर्स से अनप्लग कर दिया गया है और उसमें X प्रतिशत बैटरी बची है.
- CTS के अलावा, कोई ऐप्लिकेशन, फ़ोरग्राउंड सेवा या बैकग्राउंड सेवा नहीं चल रही है.
- CTS चलाते समय स्क्रीन बंद रहती है.
- डिवाइस
isLowRamDevice
नहीं है. - बैटरी सेवर / ऐप्लिकेशन पर लगी पाबंदियों को “आउट-ऑफ़-द-बॉक्स” स्थिति से नहीं बदला गया है.
टेस्ट की ज़रूरी शर्तें
हम ऐसे नए टेस्ट स्वीकार करते हैं जो ऐसे व्यवहार को लागू करते हैं जिसे मौजूदा सीटीएस, सीटीएस वेरिफ़ायर या सीटीएस-डी टेस्ट से टेस्ट नहीं किया जाता है. अगर कोई टेस्ट, टेस्ट कवरेज के दायरे से बाहर के व्यवहार की जांच करता है, तो उसे अस्वीकार कर दिया जाएगा.
सीटीएस सबमिट करने की प्रोसेस
- टेस्ट का सुझाव देना: ऐप्लिकेशन डेवलपर, Google Issue Tracker का इस्तेमाल करके टेस्ट का सुझाव देता है. इसमें, वह उस समस्या के बारे में बताता है जिसका पता चला है. साथ ही, उस समस्या की जांच करने के लिए टेस्ट का सुझाव देता है. प्रस्ताव में, उससे जुड़ा सीडीडी की ज़रूरी शर्त का आईडी शामिल होना चाहिए. Android टीम, प्रस्ताव की समीक्षा करती है.
- सीटीएस टेस्ट डेवलप करना: प्रस्ताव के स्वीकार होने के बाद, उसे सबमिट करने वाला व्यक्ति, Android की नई रिलीज़ ब्रांच (
android16-release
) पर AOSP के लिए सीटीएस टेस्ट बनाता है. Android टीम, कोड की समीक्षा करती है. अगर कोड स्वीकार कर लिया जाता है, तो वह बदलाव को चुनकर उसे इंटरनल डेवलपमेंट ब्रांच में मर्ज कर देती है. ज़्यादा जानकारी के लिए, मुझे AOSP में बदलावों के सुझाव कहां देने चाहिए? लेख पढ़ें.
CTS-D टेस्ट लिखने के दिशा-निर्देश
- Java कोड स्टाइल गाइड का पालन करें.
- CTS डेवलपमेंट में बताए गए सभी चरणों का पालन करें.
- अपने टेस्ट को सही टेस्ट प्लान में जोड़ें:
- अपने नए टेस्ट को CTS-D टेस्ट प्लान में जोड़ने के लिए,
include-filters
platform/cts/tools/cts-tradefed/res/config/cts-developer.xml
का इस्तेमाल करें. - मुख्य CTS टेस्ट प्लान से अपने नए टेस्ट हटाने के लिए,
exclude-filters
का इस्तेमाल करें:platform/cts/tools/cts-tradefed/res/config/cts-developer-exclude.xml
.
- अपने नए टेस्ट को CTS-D टेस्ट प्लान में जोड़ने के लिए,
build_error.log
में,errorprone
से जुड़ी सभी चेतावनियों और सुझावों को मैनेज करें.- अपने बदलावों को
head
पर रीबेस करें. इसमेंcts-developer.xml
औरcts-developer-exclude.xml
टेस्ट प्लान शामिल हैं. - अपने Google इंजीनियरिंग संपर्क के साथ मिलकर काम करें, ताकि यह तय किया जा सके कि आपके टेस्ट केस को किसी मौजूदा सीटीएस मॉड्यूल में शामिल किया जा सकता है या नहीं. अगर ऐसा नहीं हो पाता है, तो वे आपको नया मॉड्यूल बनाने में मदद करेंगे.
- बनाए गए हर नए टेस्ट मॉड्यूल के लिए, नए टेस्ट मॉड्यूल डायरेक्ट्री में OWNERS फ़ाइल बनाएं.
- आपकी OWNERS फ़ाइल में यह जानकारी होनी चाहिए. यह जानकारी, आपको Google के उस टेस्ट ओनर से मिलेगी जिसके साथ आपको काम करना है:
# Bug component: xxx
- Google के टेस्ट के मालिक का एलडीएपी आईडी
AndroidTest.xml
में, यहां दिए गए पैरामीटर तय करें. उदाहरणों के लिए, सैंपल फ़ाइलें (1, 2) देखें:Instant_app
याnot_instant_app
secondary_user
याnot_secondary_user
all_foldable_states
याno_foldable_states
- सही minSDK तय करने के लिए, <uses-sdk> दस्तावेज़ देखें.
- टेस्ट के नए तरीके, क्लास या मॉड्यूल की जांच करते समय, उन्हें CTS-D टेस्ट प्लान में जोड़ें. साथ ही, उन्हें मुख्य CTS टेस्ट प्लान से उसी तरह हटाएं जिस तरह नए टेस्ट के लिए किया जाता है.
CTS-D टेस्ट चलाना
run cts --plan cts-developer
का इस्तेमाल करके, कमांड लाइन से CTS-D टेस्ट प्लान चलाएं.
किसी खास टेस्ट केस को चलाने के लिए, run cts --include-filter "test_module_name test_name"
का इस्तेमाल करें.
पूरे सीटीएस को चलाने के बारे में जानकारी के लिए, सीटीएस टेस्ट चलाएं लेख पढ़ें.
स्वीकार किए जाने और रिलीज़ किए जाने की जानकारी
जांच का अनुरोध सबमिट करने के बाद, हमारी टीम इसकी समीक्षा करेगी. इससे यह पक्का किया जा सकेगा कि यह अनुरोध, सीडीडी की किसी ज़रूरी शर्त या एपीआई के किसी ऐसे व्यवहार की जांच करता हो जिसके बारे में दस्तावेज़ में बताया गया है. अगर टेस्ट में किसी मान्य ज़रूरी शर्त या व्यवहार की जांच की जा रही है, तो टीम इस टेस्ट केस को Google इंजीनियर को भेज देगी, ताकि वह इसकी समीक्षा कर सके. Google इंजीनियर, आपसे संपर्क करेगा और बताएगा कि सीटीएस में शामिल करने से पहले, टेस्ट को कैसे बेहतर बनाया जा सकता है.
सीटीएस के रिलीज़ शेड्यूल के बारे में जानकारी के लिए, रिलीज़ शेड्यूल और ब्रांच की जानकारी देखें.