पासवर्ड को पासकीस्टोर में सेव करना

Tradefed में keystore का कॉन्सेप्ट शामिल है. इसमें सीक्रेट को keystore सेवा में सेव किया जा सकता है. साथ ही, टेस्ट रन के दौरान टेस्ट में इस्तेमाल करने के लिए इनका अनुरोध किया जा सकता है.

कीस्टोर का इस्तेमाल करना

कीस्टोर का इस्तेमाल करने के लिए, आपको सबसे पहले अपने ग्लोबल कॉन्फ़िगरेशन में कीस्टोर के सोर्स को तय करना होगा.

सेव करने के बाद, सेव किए गए पासकोड का इस्तेमाल इन तरीकों से किया जा सकता है: USE_KEYSTORE@{key}

JSONFileKeyStore

Tradefed कोर में सैंपल के तौर पर लागू किए गए JSON कीस्टोर में, JSONFileKeyStoreClient का इस्तेमाल किया जाता है. इस कीस्टोर का इस्तेमाल करने के लिए, आपको एक JSON कुंजी वाली फ़ाइल तय करनी होगी. इसमें कुंजी से वैल्यू मैपिंग होती है.

उदाहरण के लिए, /path/to/keystore.json फ़ाइल को इस तरह से तय किया जा सकता है

{
  "test_account": "[email protected]",
  "test_account_pwd": "helloworld",
  "wifi_lab_ssid": "Google_private_AP",
  "wifi_lab_pwd": "secret123",
}

इसके बाद, TF की ग्लोबल कॉन्फ़िगरेशन फ़ाइल में ये लाइनें जोड़ें:

<key_store class="com.android.tradefed.util.keystore.JSONFileKeyStoreFactory">
<option name="json-key-store-file" value="/path/to/keystore.json" />
</key_store>

अब संबंधित टेस्ट को लागू करते समय, USE_KEYSTORE@test_account के तौर पर वैल्यू पास की जा सकती हैं. इसके बाद, TF कीस्टोर से क्वेरी करेगा और टेस्ट के हिस्से के तौर पर इसकी वैल्यू का इस्तेमाल करेगा.

होस्ट पर आधारित कीस्टोर फ़ाइल

होस्ट के आधार पर की-वैल्यू पेयर तय करने के लिए, /path/to/keystore_ssid.json फ़ाइल को इस तरह से तय किया जा सकता है

{
  "host_a.*\\.corp\\.com": {
    "wifi_lab_ssid": "ssid_a",
    "wifi_lab_pwd": "secret_a"
  },
  "host_b.*\\.corp\\.com": {
    "wifi_lab_ssid": "ssid_b",
    "wifi_lab_pwd": "secret_b"
  }
}

फ़ाइल में मौजूद किसी एंट्री की कुंजी, होस्टनेम के लिए रेगुलर एक्सप्रेशन (regex) पैटर्न होती है. साथ ही, वैल्यू, होस्टनेम से मेल खाने वाले किसी भी होस्ट के लिए, कुंजी-वैल्यू पेयर का सेट होती है.

इसके बाद, होस्ट-आधारित कीस्टोर फ़ाइल को शामिल करने के लिए, अपनी TF ग्लोबल कॉन्फ़िगरेशन फ़ाइल को अपडेट करें:

<key_store class="com.android.tradefed.util.keystore.JSONFileKeyStoreFactory">
<option name="json-key-store-file" value="/path/to/keystore.json" />
<option name="host-based-key-store-file" value="/path/to/keystore-ssid.json" />
</key_store>

होस्ट-आधारित कीस्टोर फ़ाइल में तय की गई किसी कुंजी की वैल्यू, json-key-store-file में बताई गई कीस्टोर फ़ाइल में तय की गई वैल्यू को बदल देती है.

जब कीस्टोर में होस्ट-आधारित कई कीस्टोर फ़ाइलें मौजूद हों, तो क्रम मायने रखता है. अगर किसी कुंजी की वैल्यू कई फ़ाइलों में तय की गई है, तो ऐसी आखिरी फ़ाइल में मौजूद वैल्यू, बाकी वैल्यू को बदल देती है.