protractor
Version:
Webdriver E2E test wrapper for Angular.
63 lines (55 loc) • 1.61 kB
JavaScript
/*
* This is an implementation of the Hosted Driver Provider.
* It is responsible for setting up the account object, tearing
* it down, and setting up the driver correctly.
*/
var util = require('util'),
webdriver = require('selenium-webdriver'),
q = require('q');
var HostedDriverProvider = function(config) {
this.config_ = config;
this.driver_ = null;
};
/**
* Configure and launch (if applicable) the object's environment.
* @public
* @return {q.promise} A promise which will resolve when the environment is
* ready to test.
*/
HostedDriverProvider.prototype.setupEnv = function() {
util.puts('Using the selenium server at ' + this.config_.seleniumAddress);
return q.fcall(function() {});
};
/**
* Teardown and destroy the environment and do any associated cleanup.
* Shuts down the driver.
*
* @public
* @return {q.promise} A promise which will resolve when the environment
* is down.
*/
HostedDriverProvider.prototype.teardownEnv = function() {
var deferred = q.defer();
this.driver_.quit().then(function() {
deferred.resolve();
});
return deferred.promise;
};
/**
* Return the webdriver for the runner.
* @public
* @return webdriver instance
*/
HostedDriverProvider.prototype.getDriver = function() {
if (!this.driver_) {
this.driver_ = new webdriver.Builder().
usingServer(this.config_.seleniumAddress).
withCapabilities(this.config_.capabilities).
build();
}
return this.driver_;
};
// new instance w/ each include
module.exports = function(config) {
return new HostedDriverProvider(config);
};