You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

165 lines
4.6 KiB

// Copyright 2013 Selenium committers
// Copyright 2013 Software Freedom Conservancy
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
'use strict';
var fs = require('fs'),
util = require('util');
var webdriver = require('./index'),
LogLevel = webdriver.logging.LevelName,
executors = require('./executors'),
io = require('./io'),
portprober = require('./net/portprober'),
remote = require('./remote');
/**
* Name of the PhantomJS executable.
* @type {string}
* @const
*/
var PHANTOMJS_EXE =
process.platform === 'win32' ? 'phantomjs.exe' : 'phantomjs';
/**
* Capability that designates the location of the PhantomJS executable to use.
* @type {string}
* @const
*/
var BINARY_PATH_CAPABILITY = 'phantomjs.binary.path';
/**
* Capability that designates the CLI arguments to pass to PhantomJS.
* @type {string}
* @const
*/
var CLI_ARGS_CAPABILITY = 'phantomjs.cli.args';
/**
* Default log file to use if one is not specified through CLI args.
* @type {string}
* @const
*/
var DEFAULT_LOG_FILE = 'phantomjsdriver.log';
/**
* Finds the PhantomJS executable.
* @param {string=} opt_exe Path to the executable to use.
* @return {string} The located executable.
* @throws {Error} If the executable cannot be found on the PATH, or if the
* provided executable path does not exist.
*/
function findExecutable(opt_exe) {
var exe = opt_exe || io.findInPath(PHANTOMJS_EXE, true);
if (!exe) {
throw Error(
'The PhantomJS executable could not be found on the current PATH. ' +
'Please download the latest version from ' +
'http://phantomjs.org/download.html and ensure it can be found on ' +
'your PATH. For more information, see ' +
'https://github.com/ariya/phantomjs/wiki');
}
if (!fs.existsSync(exe)) {
throw Error('File does not exist: ' + exe);
}
return exe;
}
/**
* Maps WebDriver logging level name to those recognised by PhantomJS.
* @type {!Object.<webdriver.logging.LevelName, string>}
* @const
*/
var WEBDRIVER_TO_PHANTOMJS_LEVEL = (function() {
var map = {};
map[LogLevel.ALL] = map[LogLevel.DEBUG] = 'DEBUG';
map[LogLevel.INFO] = 'INFO';
map[LogLevel.WARNING] = 'WARN';
map[LogLevel.SEVERE] = map[LogLevel.OFF] = 'ERROR';
return map;
})();
/**
* Creates a new PhantomJS WebDriver client.
* @param {webdriver.Capabilities=} opt_capabilities The desired capabilities.
* @return {!webdriver.WebDriver} A new WebDriver instance.
*/
function createDriver(opt_capabilities) {
var capabilities = opt_capabilities || webdriver.Capabilities.phantomjs();
var exe = findExecutable(capabilities.get(BINARY_PATH_CAPABILITY));
var args = ['--webdriver-logfile=' + DEFAULT_LOG_FILE];
var logPrefs = capabilities.get(webdriver.Capability.LOGGING_PREFS);
if (logPrefs && logPrefs[webdriver.logging.Type.DRIVER]) {
var level = WEBDRIVER_TO_PHANTOMJS_LEVEL[
logPrefs[webdriver.logging.Type.DRIVER]];
if (level) {
args.push('--webdriver-loglevel=' + level);
}
}
var proxy = capabilities.get(webdriver.Capability.PROXY);
if (proxy) {
switch (proxy.proxyType) {
case 'manual':
if (proxy.httpProxy) {
args.push(
'--proxy-type=http',
'--proxy=http://' + proxy.httpProxy);
}
break;
case 'pac':
throw Error('PhantomJS does not support Proxy PAC files');
case 'system':
args.push('--proxy-type=system');
break;
case 'direct':
args.push('--proxy-type=none');
break;
}
}
args = args.concat(capabilities.get(CLI_ARGS_CAPABILITY) || []);
var port = portprober.findFreePort();
var service = new remote.DriverService(exe, {
port: port,
args: webdriver.promise.when(port, function(port) {
args.push('--webdriver=' + port);
return args;
})
});
var executor = executors.createExecutor(service.start());
var driver = webdriver.WebDriver.createSession(executor, capabilities);
var boundQuit = driver.quit.bind(driver);
driver.quit = function() {
return boundQuit().thenFinally(service.kill.bind(service));
};
return driver;
}
// PUBLIC API
exports.createDriver = createDriver;