ChromeDriver के लिए सबसे नए बाइनरी को, अलग-अलग होस्ट प्लैटफ़ॉर्म के लिए ज़िप फ़ाइलों के तौर पर पैकेज किया जाता है.
ChromeDriver के पुराने वर्शन, डाउनलोड में देखे जा सकते हैं.
सुरक्षित ब्राउज़िंग की सुविधा वाले ऐप्लिकेशन
ChromeDriver, Chrome ब्राउज़र (30 या उसके बाद के वर्शन) और Android 4.4 (KitKat) के बाद के वर्शन वाले वेबव्यू पर आधारित ऐप्लिकेशन पर टेस्ट चलाने की सुविधा देता है. हालांकि, इसके लिए वेब डीबगिंग और JavaScript की सुविधा चालू होनी चाहिए.
Chrome ऐप्लिकेशन को इन जगहों से इंस्टॉल किया जा सकता है:
स्टेबल वर्शन: https://play.google.com/store/apps/details?id=com.android.chrome
Selenium WebDriver भाषा बाइंडिंग
अपनी पसंद की भाषा में टेस्ट लिखने के लिए, Selenium प्रोजेक्ट की WebDriver भाषा बाइंडिंग को इंस्टॉल करना ज़रूरी है. यह लाइब्रेरी, आपके लोकल पैकेज मैनेजर या Selenium प्रोजेक्ट में उपलब्ध है.
उदाहरण के लिए, Python के लिए भाषा बाइंडिंग को pip की मदद से इंस्टॉल किया जा सकता है.
$ pip install selenium
Android SDK
SDK टूल को developer.android.com/sdk/ से डाउनलोड किया जा सकता है.
डिवाइस की ज़रूरी शर्तें
Chrome के 33 वर्शन के बाद, रूट किए गए डिवाइस की ज़रूरत नहीं है. अगर Chrome के पुराने वर्शन पर जांच की जा रही है, तो डिवाइसों को रूट किया जाना चाहिए. ऐसा इसलिए, क्योंकि Chrome की कमांडलाइन आर्ग्युमेंट सेट करने के लिए, ChromeDriver को /data/local डायरेक्ट्री में लिखने का ऐक्सेस चाहिए.
ChromeDriver चलाना
Android SDK टूल का Android डीबग ब्रिज (adb) सर्वर शुरू करें:
$ adb start-serverअगर आपको Chrome ऐप्लिकेशन के 33 से पहले के वर्शन पर टेस्ट करना है, तो पक्का करें कि adb shell के पास डिवाइस पर
/data/localडायरेक्ट्री को पढ़ने और उसमें बदलाव करने का ऐक्सेस हो:$ adb shell su -c chmod 777 /data/localहमारा सुझाव है कि आप Selenium लाइब्रेरी की मदद से ChromeDriver शुरू करें. हालांकि, इसे कमांड-लाइन से मैन्युअल तरीके से भी शुरू किया जा सकता है.
$ ./chromedriver
सिर्फ़ Android के लिए उपलब्ध विकल्प
Chrome के ये विकल्प, Chrome और WebView ऐप्लिकेशन, दोनों पर लागू होते हैं:
androidPackage: Chrome या वेबव्यू ऐप्लिकेशन का पैकेज नाम.androidDeviceSerial: (ज़रूरी नहीं) उस डिवाइस का सीरियल नंबर जिस पर ऐप्लिकेशन लॉन्च करना है (यहां दिए गए 'एक से ज़्यादा डिवाइस' सेक्शन देखें).androidUseRunningApp: (ज़रूरी नहीं) ऐप्लिकेशन को साफ़ डेटा डायरेक्ट्री के साथ लॉन्च करने के बजाय, पहले से चल रहे ऐप्लिकेशन से अटैच करें.
यहां दी गई सुविधाएं सिर्फ़ वेबव्यू वाले ऐप्लिकेशन पर लागू होती हैं.
- androidActivity: वेबव्यू को होस्ट करने वाली गतिविधि का नाम.
- androidProcess: (ज़रूरी नहीं) वेबव्यू को होस्ट करने वाली गतिविधि का नाम (जैसा कि ps ने दिया है). अगर यह एट्रिब्यूट नहीं दिया गया है, तो प्रोसेस का नाम
androidPackageके तौर पर माना जाता है.
टेस्ट चलाना
जांचों को androidPackage विकल्प की मदद से, ऐप्लिकेशन के पैकेज का नाम ChromeDriver को देना चाहिए. उदाहरण के लिए, Python का छोटा सा टेस्ट कुछ ऐसा दिखता है:
from selenium import webdriver
options = webdriver.ChromeOptions()
options.add_experimental_option('androidPackage', 'com.android.chrome')
driver = webdriver.Chrome('./chromedriver', options=options)
driver.get('https://google.com')
driver.quit()
कई डिवाइस
किसी सेशन के लिए किसी खास डिवाइस का इस्तेमाल करने के लिए, Chrome के विकल्प के तौर पर androidDeviceSerial डालें.
अगर सीरियल नंबर नहीं दिया गया है, तो सर्वर हर सेशन के साथ जोड़ने के लिए, बिना इस्तेमाल किए गए किसी डिवाइस को रैंडम तौर पर चुनता है. अगर सभी डिवाइसों पर पहले से ही सक्रिय सेशन मौजूद हैं, तो गड़बड़ी का मैसेज दिखता है. इसलिए, टेस्ट के खत्म होने पर, 'quit' को कॉल करना न भूलें.
wd/hub से कनेक्ट करें
अगर आपके टेस्ट wd/hub से कनेक्ट होने वाले हैं, तो सर्वर लॉन्च करते समय --url-base=wd/hub जोड़ा जा सकता है:
$ ./chromedriver --url-base=wd/hub