Test with ChromeDriver {: .doctitle}
From ChromeDriver project home page:
WebDriver is an open source tool for automated testing of webapps across many browsers. It provides capabilities for navigating to web pages, user input, JavaScript execution, and more. ChromeDriver is a standalone server which implements WebDriver’s wire protocol for Chromium. ChromeDriver is available for Chrome on Android and Chrome on Desktop (Mac, Linux, Windows and ChromeOS).
NW.js provide a customized ChromeDriver for automated testing NW.js based apps. You can use it with tools like selenium.
Getting started
The following workflow uses selenium-python to drive the tests. You can use any language port for Selenium to work with chromedriver
.
Installing
- Download ChromeDriver from NW.js website. It’s in the SDK build.
- Extract the package and place
chromedriver
under the same dir that contains the NW.js binaries:nw
for Linux,nw.exe
for Windows, ornode-webkit.app
for Mac. - Install
selenium-python
in your project:
pip install selenium
Running
Suppose your app shows a form for searching from remote. The page basically something like this:
<form action="http://mysearch.com/search" method="GET">
<input type="text" name="q"><input type="submit" value="Submit">
</form>
Write a Python script to automatically fill in the search box and submit the form:
import time
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
chrome_options = Options()
chrome_options.add_argument("nwapp=/path/to/your/app")
driver = webdriver.Chrome(executable_path='/path/to/nwjs/chromedriver', chrome_options=chrome_options)
time.sleep(5) # Wait 5s to see the web page
search_box = driver.find_element_by_name('q')
search_box.send_keys('ChromeDriver')
search_box.submit()
time.sleep(5) # Wait 5s to see the search result
driver.quit()
See http://selenium-python.readthedocs.org/ for detailed documents of selenium-python
.
Modifications on the upstream chromedriver
-
chromedriver is modified to find NW executable in the same directory by default
-
An additional option
nwargs
is added if you want to pass non-switch argument to the command line:
import time
from selenium import webdriver
from selenium.webdriver.chrome.options import Options
chrome_options = Options()
chrome_options.add_argument("nwapp=/path/to/your/app")
chrome_options.add_experimental_option("nwargs", ["arg1", "arg2"])
driver = webdriver.Chrome(executable_path='/path/to/nwjs/chromedriver', chrome_options=chrome_options)