GTS परीक्षण (GtsSafetyCenterTestCases
)
GTS टेस्ट कॉन्फ़िगरेशन फ़ाइल पर पाबंदियां लागू करते हैं. कॉन्फ़िगरेशन फ़ाइल अपडेट करना देखें. अगर किसी डिवाइस पर Safety Center काम नहीं करता है, तो उसे इन टेस्ट से छूट मिलती है.
ये पाबंदियां हैं:
- Safety Center में कम से कम सात सोर्स ग्रुप होने चाहिए. ये ग्रुप, बिना बदलाव वाली या डिफ़ॉल्ट स्थिति में होने चाहिए. सोर्स के टाइटल, शुरुआती डिसप्ले स्टेटस, और खास जानकारी जैसे कुछ फ़ील्ड में, कभी-कभी ओवरले की जा सकने वाली स्ट्रिंग होती हैं. इनमें बदलाव किया जा सकता है.
GoogleAppSecuritySources
के लिए:GooglePlayProtect
सुरक्षा सोर्स को न हटाएं और न ही उसमें बदलाव करें.- आपके पास
GoogleAppProtectionService
के सुरक्षा सोर्स को हटाने या बदलने का विकल्प है. अगर यह मौजूद है, तो:- इसमें लॉगिंग की सुविधा होनी चाहिए.
- अगर पैकेज के नाम में कोई बदलाव नहीं किया गया है, तो Android 13 में उसका नाम
initialDisplayState="hidden"
होना चाहिए. Android 14 में, उसका नामissue-only-safety-source
होना चाहिए औरdeduplicationGroup
में कोई बदलाव नहीं होना चाहिए. - अगर पैकेज का नाम बदला जाता है, तो उसमें
"android.app.role.SYSTEM_APP_PROTECTION_SERVICE"
की भूमिका होनी चाहिए. इसके अलावा, Android 14 में इसमेंdeduplicationGroup
भी नहीं होना चाहिए.
AndroidLockScreenSources
के लिए:- ग्रुप का
summary
इंस्टेंस ज़रूरी है. आपके पास इसमें बदलाव करने का विकल्प भी है. ऐसा स्ट्रिंग ओवरले की मदद से भी किया जा सकता है. - कम से कम एक सुरक्षा सोर्स होना चाहिए.
- सुरक्षा से जुड़ा पहला सोर्स, लॉक स्क्रीन की सेटिंग को कंट्रोल करता है. यह
SEVERITY_LEVEL_RECOMMENDATION
(maxSeverityLevel="300"
या पीले रंग की एंट्री या चेतावनी वाले कार्ड तक) से ज़्यादा गंभीर समस्याओं या एंट्री को पुश नहीं कर सकता. Android 14 में,deduplicationGroup
में कोई बदलाव नहीं होना चाहिए. - सुरक्षा से जुड़े अन्य सोर्स, बायोमेट्रिक अनलॉक करने के तरीकों से जुड़े होने चाहिए. साथ ही, इनमें
maxSeverityLevel="0"
होना चाहिए.
- ग्रुप का
Android 13 में,
GoogleAccountSources
,GoogleDeviceFinderSources
याAndroidAdvancedSources
में बदलाव न करें. Android 14 में, इन ग्रुप में जोड़े गए कुछ नए सोर्स हटाए जा सकते हैं.जैसे, बैकअप और वापस लाना. साथ ही,AndroidAdvancedSources
ग्रुप में नए स्टैटिक सोर्स भी जोड़े जा सकते हैं.GoogleUpdateSources
के लिए:GoogleSecurityUpdates
के लिएintentAction
को बदला जा सकता है. साथ ही, स्ट्रिंग ओवरले की मदद से भी इसमें बदलाव किया जा सकता है.GooglePlaySystemUpdate
में बदलाव न करें.
AndroidPrivacySources
के लिए:- कुछ सोर्स जोड़े, हटाए या उनमें बदलाव किया जा सकता है, बशर्ते वे
issue-only
हों. - उन्हें
packageName="com.google.android.permissioncontroller"
रखना होगा. - बाकी के
AndroidPrivacySources
सोर्स में बदलाव न करें.
- कुछ सोर्स जोड़े, हटाए या उनमें बदलाव किया जा सकता है, बशर्ते वे
सुरक्षा सोर्स के बाकी ग्रुप के लिए (अगर कोई है):
- ग्रुप में
summary
याstatelessIconType
नहीं होना चाहिए. ऐसा होने पर, ग्रुपSAFETY_SOURCES_GROUP_TYPE_RIGID
ग्रुप (Android 14 मेंSAFETY_SOURCES_GROUP_TYPE_STATELESS
) बन जाता है. - हर ग्रुप में मौजूद हर सोर्स या तो स्टैटिक होना चाहिए या उसमें
maxSeverityLevel="0"
होना चाहिए. उदाहरण के लिए, उसमें ग्रे या हरे रंग की एंट्री करने की अनुमति है, लेकिन कोई समस्या नहीं है.
- ग्रुप में
सीटीएस टेस्ट (CtsSafetyCenterTestCases
)
Android 13 की शुरुआत से, सीटीएस टेस्ट उन सभी OEM पर लागू होंगे
जो PermissionController
के साथ काम करते हैं.
कॉन्फ़िगरेशन फ़ाइल की जांच (XmlConfigTest
)
इन जांचों से यह पक्का होता है कि:
- पार्स की गई एक्सएमएल कॉन्फ़िगरेशन फ़ाइल, सुरक्षा केंद्र से पार्स और दिखाए गए कॉन्फ़िगरेशन से मेल खाती है. साथ ही, डेटा पार्स करने की यह प्रोसेस पूरी हो गई है.
- अगर एक्सएमएल फ़ाइल में इंटेंट ऐक्शन
android.settings.PRIVACY_ADVANCED_SETTINGS
मौजूद है, तो यह कार्रवाई पूरी होनी चाहिए. - अगर एक्सएमएल फ़ाइल में इंटेंट ऐक्शन
android.settings.PRIVACY_CONTROLS
मौजूद है, तो यह कार्रवाई ठीक होनी चाहिए.
यूज़र इंटरफ़ेस (यूआई) की जांच (SafetyCenterActivityTest
)
इन जांचों से यह पक्का होता है कि:
android.intent.action.SAFETY_CENTER
इंटेंट ऐक्शन से, Safety Center के चालू होने पर सुरक्षा और निजता सेटिंग स्क्रीन खुलती है. वहीं, Safety Center के बंद होने पर सेटिंग स्क्रीन खुलती है.
एपीआई जांच (SafetyCenterManagerTest
)
SafetyCenterManagerTest API टेस्ट का मकसद यह पक्का करना है कि Safety Center के एपीआई सही तरीके से काम कर रहे हैं या नहीं.
इन जांचों से यह पक्का होता है कि:
SafetyCenterManager.isSafetyCenterEnabled
को इससे जुड़ेDeviceConfig
फ़्लैग से कंट्रोल किया जाता है.- बंद होने पर, सुरक्षा केंद्र के एपीआई काम नहीं करते.
- सुरक्षा केंद्र के एपीआई का इस्तेमाल सिर्फ़ तब किया जा सकता है, जब इनसे जुड़ी अनुमतियां लागू हों.
- Safety Center को डेटा सिर्फ़ मौजूदा कॉन्फ़िगरेशन के हिसाब से दिया जा सकता है.
- सुरक्षा केंद्र को डेटा उपलब्ध कराए जाने पर, वह उसके मुताबिक दिखता है.
- ये एपीआई, Safety Center के सोर्स एपीआई का इस्तेमाल करें में बताए गए स्पेसिफ़िकेशन से मेल खाते हैं. उदाहरण के लिए, रीफ़्रेश या फिर फिर से स्कैन करने का तरीका, डेटा सेट करना या मिटाना, और गड़बड़ियों की शिकायत करना.
- यूज़र इंटरफ़ेस (यूआई) के लिए उपलब्ध कराए गए इंटरनल एपीआई ठीक से काम कर रहे हैं. उदाहरण के लिए, Safety Center में डेटा को सही तरीके से मर्ज किया गया है और डेटा को रीफ़्रेश किया जा सकता है.
सुरक्षा केंद्र पर काम नहीं करने वाला टेस्ट (SafetyCenterUnsupportedTest
)
यह टेस्ट पक्का करता है कि फ़्रेमवर्क की एक्सएमएल कॉन्फ़िगरेशन फ़ाइल में सहायता बंद होने पर, सुरक्षा केंद्र डिवाइस पर काम न करे.
अगर डिवाइस पर Safety Center काम करता है, तो यह जांच नहीं की जाती. अगर डिवाइस पर Safety Center काम नहीं करता है, तो सिर्फ़ यह टेस्ट और डेटा क्लास के टेस्ट चलते हैं.
इस जांच से यह पक्का होता है कि:
android.intent.action.SAFETY_CENTER
इंटेंट ऐक्शन से सेटिंग स्क्रीन खुलती है.SafetyCenterManager.isSafetyCenterEnabled
,false
दिखाता है.- ज़्यादातर Safety Center API, कॉल किए जाने पर जवाब नहीं देते.
डेटा क्लास टेस्ट (SafetySourceDataTest
, SafetySourceIssueTest
वगैरह)
SafetySourceDataTest
और SafetySourceIssueTest
जैसी डेटा क्लास की जांच से यह पक्का होता है कि सुरक्षा केंद्र से एक्सपोज़ की गई डेटा क्लास सही तरीके से काम कर रही हैं. उदाहरण के लिए, SafetySourceData
, SafetySourceIssue
, और इससे जुड़ी अन्य इंटरनल क्लास.
MTS टेस्ट (SafetyCenterFunctionalTestCases
और अन्य)
ये जांच मेनलाइन अपडेट पर की जाती हैं और PermissionController
के साथ काम करने वाले सभी OEM पर लागू होती हैं. इन टेस्ट के लिए लागू की गई ज़रूरी शर्तों में, मेनलाइन अपडेट में
बदलाव हो सकता है.
एपीआई टेस्ट (SafetyCenterManagerTest
)
ये टेस्ट, सीटीएस टेस्ट SafetyCenterManagerTest
की तरह होते हैं. हालांकि, इनमें उन ज़रूरतों की जांच की जाती है जो मेनलाइन अपडेट में बदल सकती हैं. उदाहरण के लिए:
- यूज़र इंटरफ़ेस (यूआई) के लिए उपलब्ध इंटरनल एपीआई से मिले डेटा के असल कॉन्टेंट की जांच करना
यूज़र इंटरफ़ेस (यूआई) की जांच (SafetyCenterActivityTest
, SafetyCenterStatusCardTest
, SafetyCenterQsActivityTest
वगैरह)
इन टेस्ट से यह पक्का होता है कि:
- खास पैरामीटर के साथ सुरक्षा केंद्र पर रीडायरेक्ट करने की सुविधा, उम्मीद के मुताबिक काम करती है. उदाहरण के लिए, किसी खास समस्या पर रीडायरेक्ट करना. सुरक्षा केंद्र पर रीडायरेक्ट करें देखें.
- यूज़र इंटरफ़ेस (यूआई), सुरक्षा की सही स्थिति दिखाता है.
- यूज़र इंटरफ़ेस (यूआई) की मदद से, अलग-अलग स्क्रीन पर नेविगेट किया जा सकता है.
SafetySourceIssue
के निर्देश पर, यूज़र इंटरफ़ेस (यूआई) की मदद से, सीधे सुरक्षा केंद्र की स्क्रीन से सुरक्षा से जुड़ी समस्याओं को हल किया जा सकता है.- यूज़र इंटरफ़ेस (यूआई) एक आइटम में कई चेतावनी कार्ड को छोटा करता है और इसे वापस कई चेतावनी कार्ड में बड़ा करने की अनुमति देता है.
- सुरक्षा केंद्र के काम के सोर्स के लिए, सुरक्षा केंद्र का पेज खोलने पर डेटा रीफ़्रेश हो जाता है.
- 'फिर से स्कैन करें' बटन सिर्फ़ कुछ खास स्थितियों में दिखता है.
- 'फिर से स्कैन करें' बटन पर टैप करने से नया डेटा फ़ेच होता है.
सुरक्षा केंद्र के लिए भी इसी तरह के टेस्ट किए जाते हैं. अपने ऐप्लिकेशन के लिए, कस्टम क्विक सेटिंग टाइल बनाना देखें
गड़बड़ी की स्थितियां और बाकी स्थितियां जैसे अन्य एज केस.
एक से ज़्यादा उपयोगकर्ताओं वाले टेस्ट (SafetyCenterMultiUsersTest
)
इन टेस्ट का मकसद यह पक्का करना है कि कई उपयोगकर्ताओं या प्रोफ़ाइलों के लिए डेटा उपलब्ध कराने पर, एपीआई सही तरीके से काम करे. एक से ज़्यादा उपयोगकर्ताओं और प्रोफ़ाइलों के लिए डेटा उपलब्ध कराना लेख पढ़ें. यह सेटअप, किसी इंटरनल लाइब्रेरी का इस्तेमाल करके किया जाता है. इस लाइब्रेरी की मदद से, Bedstead का इस्तेमाल करके डिवाइस पर अलग-अलग उपयोगकर्ताओं और प्रोफ़ाइलों को सेट अप किया जा सकता है.
इस जांच से यह पक्का होता है कि:
- अगर किसी उपयोगकर्ता का डेटा मौजूद है, तो उसे इससे जुड़ी मैनेज की जा रही प्रोफ़ाइल के साथ मर्ज कर दिया जाता है.
- सिर्फ़
profile="all_profiles"
के साथ मार्क किए गए सोर्स, उपयोगकर्ता की मैनेज की जा रही प्रोफ़ाइल में डेटा दे सकते हैं. - उपयोगकर्ता से जुड़ी हर मैनेज की जा रही प्रोफ़ाइल के लिए, एक नई एंट्री बनाई जाती है.
- किसी एक उपयोगकर्ता का डेटा, उससे जुड़े किसी दूसरे उपयोगकर्ता के पास नहीं जाता.