Refactored the handling of Selenium2 capabilities
Saucelabs-specific capabilities are removed from the Selenium2Factory in favor of the SaucelabsFactory. The SaucelabsFactory now supports all normal capabilities (inherited from the Selenium2Factory) and the list of Saucelabs-specific ones is completed.
This commit is contained in:
@@ -39,72 +39,7 @@ class Selenium2Factory implements DriverFactory
|
||||
$builder
|
||||
->children()
|
||||
->scalarNode('browser')->defaultValue('%mink.browser_name%')->end()
|
||||
->arrayNode('capabilities')
|
||||
->addDefaultsIfNotSet()
|
||||
->normalizeKeys(false)
|
||||
->children()
|
||||
->scalarNode('browserName')->defaultValue('firefox')->end()
|
||||
->scalarNode('version')->defaultValue('9')->end()
|
||||
->scalarNode('platform')->defaultValue('ANY')->end()
|
||||
->scalarNode('browserVersion')->defaultValue('9')->end()
|
||||
->scalarNode('browser')->defaultValue('firefox')->end()
|
||||
->scalarNode('ignoreZoomSetting')->defaultValue('false')->end()
|
||||
->scalarNode('name')->defaultValue('Behat Test')->end()
|
||||
->scalarNode('deviceOrientation')->defaultValue('portrait')->end()
|
||||
->scalarNode('deviceType')->defaultValue('tablet')->end()
|
||||
->scalarNode('selenium-version')->defaultValue('2.31.0')->end()
|
||||
->scalarNode('max-duration')->defaultValue('300')->end()
|
||||
->booleanNode('javascriptEnabled')->end()
|
||||
->booleanNode('databaseEnabled')->end()
|
||||
->booleanNode('locationContextEnabled')->end()
|
||||
->booleanNode('applicationCacheEnabled')->end()
|
||||
->booleanNode('browserConnectionEnabled')->end()
|
||||
->booleanNode('webStorageEnabled')->end()
|
||||
->booleanNode('rotatable')->end()
|
||||
->booleanNode('acceptSslCerts')->end()
|
||||
->booleanNode('nativeEvents')->end()
|
||||
->booleanNode('passed')->end()
|
||||
->booleanNode('record-video')->end()
|
||||
->booleanNode('record-screenshots')->end()
|
||||
->booleanNode('capture-html')->end()
|
||||
->booleanNode('disable-popup-handler')->end()
|
||||
->arrayNode('proxy')
|
||||
->children()
|
||||
->scalarNode('proxyType')->end()
|
||||
->scalarNode('proxyAuthconfigUrl')->end()
|
||||
->scalarNode('ftpProxy')->end()
|
||||
->scalarNode('httpProxy')->end()
|
||||
->scalarNode('sslProxy')->end()
|
||||
->end()
|
||||
->validate()
|
||||
->ifTrue(function ($v) {
|
||||
return empty($v);
|
||||
})
|
||||
->thenUnset()
|
||||
->end()
|
||||
->end()
|
||||
->arrayNode('firefox')
|
||||
->children()
|
||||
->scalarNode('profile')
|
||||
->validate()
|
||||
->ifTrue(function ($v) {
|
||||
return !file_exists($v);
|
||||
})
|
||||
->thenInvalid('Cannot find profile zip file %s')
|
||||
->end()
|
||||
->end()
|
||||
->scalarNode('binary')->end()
|
||||
->end()
|
||||
->end()
|
||||
->arrayNode('chrome')
|
||||
->children()
|
||||
->arrayNode('switches')->prototype('scalar')->end()->end()
|
||||
->scalarNode('binary')->end()
|
||||
->arrayNode('extensions')->prototype('scalar')->end()->end()
|
||||
->end()
|
||||
->end()
|
||||
->end()
|
||||
->end()
|
||||
->append($this->getCapabilitiesNode())
|
||||
->scalarNode('wd_host')->defaultValue('http://localhost:4444/wd/hub')->end()
|
||||
->end()
|
||||
;
|
||||
@@ -116,9 +51,10 @@ class Selenium2Factory implements DriverFactory
|
||||
public function buildDriver(array $config)
|
||||
{
|
||||
if (!class_exists('Behat\Mink\Driver\Selenium2Driver')) {
|
||||
throw new \RuntimeException(
|
||||
'Install MinkSelenium2Driver in order to use selenium2 driver.'
|
||||
);
|
||||
throw new \RuntimeException(sprintf(
|
||||
'Install MinkSelenium2Driver in order to use %s driver.',
|
||||
$this->getDriverName()
|
||||
));
|
||||
}
|
||||
|
||||
return new Definition('Behat\Mink\Driver\Selenium2Driver', array(
|
||||
@@ -127,4 +63,70 @@ class Selenium2Factory implements DriverFactory
|
||||
$config['wd_host'],
|
||||
));
|
||||
}
|
||||
|
||||
protected function getCapabilitiesNode()
|
||||
{
|
||||
$node = new ArrayNodeDefinition('capabilities');
|
||||
|
||||
$node
|
||||
->addDefaultsIfNotSet()
|
||||
->normalizeKeys(false)
|
||||
->children()
|
||||
->scalarNode('browserName')->defaultValue('firefox')->end()
|
||||
->scalarNode('version')->defaultValue('21')->end()
|
||||
->scalarNode('platform')->defaultValue('ANY')->end()
|
||||
->scalarNode('browserVersion')->defaultValue('9')->end()
|
||||
->scalarNode('browser')->defaultValue('firefox')->end()
|
||||
->scalarNode('ignoreZoomSetting')->defaultValue('false')->end()
|
||||
->scalarNode('name')->defaultValue('Behat feature suite')->end()
|
||||
->scalarNode('deviceOrientation')->defaultValue('portrait')->end()
|
||||
->scalarNode('deviceType')->defaultValue('tablet')->end()
|
||||
->booleanNode('javascriptEnabled')->end()
|
||||
->booleanNode('databaseEnabled')->end()
|
||||
->booleanNode('locationContextEnabled')->end()
|
||||
->booleanNode('applicationCacheEnabled')->end()
|
||||
->booleanNode('browserConnectionEnabled')->end()
|
||||
->booleanNode('webStorageEnabled')->end()
|
||||
->booleanNode('rotatable')->end()
|
||||
->booleanNode('acceptSslCerts')->end()
|
||||
->booleanNode('nativeEvents')->end()
|
||||
->arrayNode('proxy')
|
||||
->children()
|
||||
->scalarNode('proxyType')->end()
|
||||
->scalarNode('proxyAuthconfigUrl')->end()
|
||||
->scalarNode('ftpProxy')->end()
|
||||
->scalarNode('httpProxy')->end()
|
||||
->scalarNode('sslProxy')->end()
|
||||
->end()
|
||||
->validate()
|
||||
->ifTrue(function ($v) {
|
||||
return empty($v);
|
||||
})
|
||||
->thenUnset()
|
||||
->end()
|
||||
->end()
|
||||
->arrayNode('firefox')
|
||||
->children()
|
||||
->scalarNode('profile')
|
||||
->validate()
|
||||
->ifTrue(function ($v) {
|
||||
return !file_exists($v);
|
||||
})
|
||||
->thenInvalid('Cannot find profile zip file %s')
|
||||
->end()
|
||||
->end()
|
||||
->scalarNode('binary')->end()
|
||||
->end()
|
||||
->end()
|
||||
->arrayNode('chrome')
|
||||
->children()
|
||||
->arrayNode('switches')->prototype('scalar')->end()->end()
|
||||
->scalarNode('binary')->end()
|
||||
->arrayNode('extensions')->prototype('scalar')->end()->end()
|
||||
->end()
|
||||
->end()
|
||||
->end();
|
||||
|
||||
return $node;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user