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

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

पासकोड सेव करने के लिए पासकोड स्टोर का इस्तेमाल करना

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

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

JSONFileKeyStore

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

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

{
  "test_account": "foo@gmail.com",
  "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 के साथ बताई गई पासकोड फ़ाइल में बताई गई वैल्यू को बदल देती है.

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