diff options
author | Pierre Schmitz <pierre@archlinux.de> | 2011-06-22 11:28:20 +0200 |
---|---|---|
committer | Pierre Schmitz <pierre@archlinux.de> | 2011-06-22 11:28:20 +0200 |
commit | 9db190c7e736ec8d063187d4241b59feaf7dc2d1 (patch) | |
tree | 46d1a0dee7febef5c2d57a9f7b972be16a163b3d /maintenance/tests/selenium/SeleniumConfig.php | |
parent | 78677c7bbdcc9739f6c10c75935898a20e1acd9e (diff) |
update to MediaWiki 1.17.0
Diffstat (limited to 'maintenance/tests/selenium/SeleniumConfig.php')
-rw-r--r-- | maintenance/tests/selenium/SeleniumConfig.php | 88 |
1 files changed, 88 insertions, 0 deletions
diff --git a/maintenance/tests/selenium/SeleniumConfig.php b/maintenance/tests/selenium/SeleniumConfig.php new file mode 100644 index 00000000..ca69b1f0 --- /dev/null +++ b/maintenance/tests/selenium/SeleniumConfig.php @@ -0,0 +1,88 @@ +<?php +if ( !defined( 'SELENIUMTEST' ) ) { + die( 1 ); +} + +class SeleniumConfig { + + /* + * Retreives the Selenium configuration values from an ini file. + * See sample config file in selenium_settings.ini.sample + * + */ + + public static function getSeleniumSettings ( &$seleniumSettings, + &$seleniumBrowsers, + &$seleniumTestSuites, + $seleniumConfigFile = null ) { + if ( strlen( $seleniumConfigFile ) == 0 ) { + global $wgSeleniumConfigFile; + if ( isset( $wgSeleniumConfigFile ) ) $seleniumConfigFile = $wgSeleniumConfigFile ; + } + + if ( strlen( $seleniumConfigFile ) == 0 || !file_exists( $seleniumConfigFile ) ) { + throw new MWException( "Unable to read local Selenium Settings from " . $seleniumConfigFile . "\n" ); + } + + if ( !defined( 'PHP_VERSION_ID' ) || + ( PHP_MAJOR_VERSION == 5 && PHP_MINOR_VERSION < 3 ) ) { + $configArray = self::parse_5_2_ini_file( $seleniumConfigFile ); + } else { + $configArray = parse_ini_file( $seleniumConfigFile, true ); + } + if ( $configArray === false ) { + throw new MWException( "Error parsing " . $seleniumConfigFile . "\n" ); + } + + if ( array_key_exists( 'SeleniumSettings', $configArray) ) { + wfSuppressWarnings(); + //we may need to change how this is set. But for now leave it in the ini file + $seleniumBrowsers = $configArray['SeleniumSettings']['browsers']; + + $seleniumSettings['host'] = $configArray['SeleniumSettings']['host']; + $seleniumSettings['port'] = $configArray['SeleniumSettings']['port']; + $seleniumSettings['wikiUrl'] = $configArray['SeleniumSettings']['wikiUrl']; + $seleniumSettings['username'] = $configArray['SeleniumSettings']['username']; + $seleniumSettings['userPassword'] = $configArray['SeleniumSettings']['userPassword']; + $seleniumSettings['testBrowser'] = $configArray['SeleniumSettings']['testBrowser']; + $seleniumSettings['startserver'] = $configArray['SeleniumSettings']['startserver']; + $seleniumSettings['stopserver'] = $configArray['SeleniumSettings']['stopserver']; + $seleniumSettings['seleniumserverexecpath'] = $configArray['SeleniumSettings']['seleniumserverexecpath']; + $seleniumSettings['jUnitLogFile'] = $configArray['SeleniumSettings']['jUnitLogFile']; + $seleniumSettings['runAgainstGrid'] = $configArray['SeleniumSettings']['runAgainstGrid']; + + wfRestoreWarnings(); + } + if ( array_key_exists( 'SeleniumTests', $configArray) ) { + wfSuppressWarnings(); + $seleniumTestSuites = $configArray['SeleniumTests']['testSuite']; + wfRestoreWarnings(); + } + return true; + } + + private static function parse_5_2_ini_file ( $ConfigFile ) { + + $configArray = parse_ini_file( $ConfigFile, true ); + if ( $configArray === false ) return false; + + // PHP 5.2 ini files have [browsers] and [testSuite] sections + // to get around lack of support for array keys. It then + // inserts the section arrays into the appropriate places in + // the SeleniumSettings and SeleniumTests arrays. + + if ( isset( $configArray['browsers'] ) ) { + $configArray['SeleniumSettings']['browsers'] = $configArray['browsers']; + unset ( $configArray['browsers'] ); + } + + if ( isset( $configArray['testSuite'] ) ) { + $configArray['SeleniumTests']['testSuite'] = $configArray['testSuite']; + unset ( $configArray['testSuite'] ); + } + + return $configArray; + + } + +} |