diff options
Diffstat (limited to 'tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php')
| -rw-r--r-- | tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php | 77 | 
1 files changed, 54 insertions, 23 deletions
| diff --git a/tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php b/tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php index 192689f8..41230a1e 100644 --- a/tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php +++ b/tests/phpunit/includes/GlobalFunctions/wfExpandUrlTest.php @@ -1,17 +1,17 @@  <?php  /** - * Unit tests for wfExpandUrl() + * @covers ::wfExpandUrl   */ - -class wfExpandUrl extends MediaWikiTestCase { -	/** @dataProvider provideExpandableUrls */ +class WfExpandUrlTest extends MediaWikiTestCase { +	/** +	 * @dataProvider provideExpandableUrls +	 */  	public function testWfExpandUrl( $fullUrl, $shortUrl, $defaultProto, $server, $canServer, $httpsMode, $message ) {  		// Fake $wgServer and $wgCanonicalServer -		global $wgServer, $wgCanonicalServer; -		$oldServer = $wgServer; -		$oldCanServer = $wgCanonicalServer; -		$wgServer = $server; -		$wgCanonicalServer = $canServer; +		$this->setMwGlobals( array( +			'wgServer' => $server, +			'wgCanonicalServer' => $canServer, +		) );  		// Fake $_SERVER['HTTPS'] if needed  		if ( $httpsMode ) { @@ -21,10 +21,6 @@ class wfExpandUrl extends MediaWikiTestCase {  		}  		$this->assertEquals( $fullUrl, wfExpandUrl( $shortUrl, $defaultProto ), $message ); - -		// Restore $wgServer and $wgCanonicalServer -		$wgServer = $oldServer; -		$wgCanonicalServer = $oldCanServer;  	}  	/** @@ -32,25 +28,49 @@ class wfExpandUrl extends MediaWikiTestCase {  	 *  	 * @return array  	 */ -	public function provideExpandableUrls() { +	public static function provideExpandableUrls() {  		$modes = array( 'http', 'https' ); -		$servers = array( 'http' => 'http://example.com', 'https' => 'https://example.com', 'protocol-relative' => '//example.com' ); -		$defaultProtos = array( 'http' => PROTO_HTTP, 'https' => PROTO_HTTPS, 'protocol-relative' => PROTO_RELATIVE, 'current' => PROTO_CURRENT, 'canonical' => PROTO_CANONICAL ); +		$servers = array( +			'http' => 'http://example.com', +			'https' => 'https://example.com', +			'protocol-relative' => '//example.com' +		); +		$defaultProtos = array( +			'http' => PROTO_HTTP, +			'https' => PROTO_HTTPS, +			'protocol-relative' => PROTO_RELATIVE, +			'current' => PROTO_CURRENT, +			'canonical' => PROTO_CANONICAL +		);  		$retval = array();  		foreach ( $modes as $mode ) {  			$httpsMode = $mode == 'https';  			foreach ( $servers as $serverDesc => $server ) { -				foreach ( $modes as $canServerMode  ) { +				foreach ( $modes as $canServerMode ) {  					$canServer = "$canServerMode://example2.com";  					foreach ( $defaultProtos as $protoDesc => $defaultProto ) { -						$retval[] = array( 'http://example.com', 'http://example.com', $defaultProto, $server, $canServer, $httpsMode, "Testing fully qualified http URLs (no need to expand) (defaultProto: $protoDesc , wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" ); -						$retval[] = array( 'https://example.com', 'https://example.com', $defaultProto, $server, $canServer, $httpsMode, "Testing fully qualified https URLs (no need to expand) (defaultProto: $protoDesc , wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" ); +						$retval[] = array( +							'http://example.com', 'http://example.com', +							$defaultProto, $server, $canServer, $httpsMode, +							"Testing fully qualified http URLs (no need to expand) ' . +							'(defaultProto: $protoDesc , wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" +						); +						$retval[] = array( +							'https://example.com', 'https://example.com', +							$defaultProto, $server, $canServer, $httpsMode, +							"Testing fully qualified https URLs (no need to expand) ' . +							'(defaultProto: $protoDesc , wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" +						);  						# Would be nice to support this, see fixme on wfExpandUrl() -						$retval[] = array( "wiki/FooBar", 'wiki/FooBar', $defaultProto, $server, $canServer, $httpsMode, "Test non-expandable relative URLs (defaultProto: $protoDesc , wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" ); +						$retval[] = array( +							"wiki/FooBar", 'wiki/FooBar', +							$defaultProto, $server, $canServer, $httpsMode, +							"Test non-expandable relative URLs ' . +							'(defaultProto: $protoDesc , wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" +						);  						// Determine expected protocol -						$p = $protoDesc . ':'; // default case  						if ( $protoDesc == 'protocol-relative' ) {  							$p = '';  						} elseif ( $protoDesc == 'current' ) { @@ -69,12 +89,23 @@ class wfExpandUrl extends MediaWikiTestCase {  							$srv = $server;  						} -						$retval[] = array( "$p//wikipedia.org", '//wikipedia.org', $defaultProto, $server, $canServer, $httpsMode, "Test protocol-relative URL (defaultProto: $protoDesc, wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" ); -						$retval[] = array( "$srv/wiki/FooBar", '/wiki/FooBar', $defaultProto, $server, $canServer, $httpsMode, "Testing expanding URL beginning with / (defaultProto: $protoDesc , wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" ); +						$retval[] = array( +							"$p//wikipedia.org", '//wikipedia.org', +							$defaultProto, $server, $canServer, $httpsMode, +							"Test protocol-relative URL ' . +							'(defaultProto: $protoDesc, wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" +						); +						$retval[] = array( +							"$srv/wiki/FooBar", '/wiki/FooBar', +							$defaultProto, $server, $canServer, $httpsMode, +							"Testing expanding URL beginning with / ' . +							'(defaultProto: $protoDesc , wgServer: $server, wgCanonicalServer: $canServer, current request protocol: $mode )" +						);  					}  				}  			}  		} +  		return $retval;  	}  } | 
