blob: 11d6d3223105ecf5f2bc2889c0133f640e4c5f02 [file] [log] [blame]
# Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
import json
import logging
import os
import subprocess
import urllib2
from autotest_lib.client.common_lib import error
# Absolute path from INSIDE chroot.
DOWNLOAD_PATH = '/tmp/chromium-webdriver-parts'
WEBDRIVER = 'chromedriver'
class WebdriverDownloadError(Exception):
"""Base class for exceptions in this module."""
def _webdriver_is_installed():
"""Checks for presence of required webdriver binary inside chroot.
@returns a boolean: True iff the binary is present.
webdriver_path = os.path.join(DOWNLOAD_PATH, WEBDRIVER)
if not os.path.exists(webdriver_path):
logging.error('Missing webdriver binary %r.', webdriver_path)
return False'Located webdriver binary inside chroot.')
return True
def _webdriver_is_running(webdriver_port=9515):
"""Checks if webdriver binary is running.
Webdriver binary must be running either on the local machine or in
the lab as a service.
@param webdriver_port: the port of the webdriver server
@returns a string: of the address of a successful connection; None
if a connection cannot be established.
# address and port are pulled from establish_driver_connection() in
# ../ap_configurators/
# While working on, we will use krisr's
# workstation as a stop gap.
servers = ['', '',
# Perform a proper request
for address in servers:
url = 'http://%s:%d/session' % (address, webdriver_port)
req = urllib2.Request(url, '{"desiredCapabilities":{}}')
response = urllib2.urlopen(req)
except:'Webdriver on server %s is not running.', address)
json_dict = json.loads(
if json_dict['status'] == 0:
# Connection was successful, close the session
session_url = os.path.join(url, json_dict['sessionId'])
req = urllib2.Request(session_url)
req.get_method = lambda: 'DELETE'
response = urllib2.urlopen(req)'Webdriver connection established to server %s',
return address'Webdriver host was running, but could not establish '
'a connection: %s', json_dict)'No available webdriver service found.')
return None
def download_chromium_prebuilt_binaries():
"""Downloads and installs webdriver binary inside chroot.
@raises IOError: if error fetching prebuilt binaries.
# FIXME(tgao): this is a temporary hack until we completely and cleanly
# deprecates use of PyAuto across the board.
fetch_prebuilt = os.path.join(os.path.dirname(__file__),
'')'Attempt to locate: %s', fetch_prebuilt)
if not os.path.exists(fetch_prebuilt):
err = ('Unable to locate script to fetch prebuilt binaries: %s' %
raise WebdriverDownloadError(err)
cmds = ['/usr/bin/python', fetch_prebuilt, '-d', DOWNLOAD_PATH, '-l']
if, shell=False) != 0:
err = (' threw an error, the download '
'was aborted. Please view stdout for more information.')
raise WebdriverDownloadError(err)'Successfully downloaded and installed prebuilt binaries to '
'%s (inside chroot).', DOWNLOAD_PATH)
def check_webdriver_ready(webdriver_port=9515):
"""Checks if webdriver binary is installed and running.
If it is running, skip install path check. This is needed to run dynamic
tests on Autotest drones.
@param webdriver_port: port of the webdriver server
@returns a string: of the address of webdriver running on port 9515.
@raises TestError: if failed to download and install webdriver binary.
Or if webdriver is installed but not running.
err = ('Webdriver is installed but not running. From outside chroot, run: '
'<path to chroot directory>%s/%s' % (DOWNLOAD_PATH, WEBDRIVER))
server_address = _webdriver_is_running(webdriver_port)
if server_address is not None:
return server_address
if not _webdriver_is_installed():
except WebdriverDownloadError as e:
raise error.TestError('Download failed: %s.' % e)
raise error.TestError(err)