2019-05-13 10:38:00 +00:00
|
|
|
<?php
|
|
|
|
|
|
2023-02-13 21:42:09 +00:00
|
|
|
use MediaWiki\MediaWikiServices;
|
2021-10-08 19:26:24 +00:00
|
|
|
use Wikimedia\TestingAccessWrapper;
|
|
|
|
|
|
2019-05-13 10:38:00 +00:00
|
|
|
/**
|
|
|
|
|
* @covers MWHttpRequest
|
|
|
|
|
*/
|
|
|
|
|
class MWHttpRequestTest extends PHPUnit\Framework\TestCase {
|
|
|
|
|
|
|
|
|
|
/**
|
2022-12-11 14:20:06 +00:00
|
|
|
* Feeds URI to test a long regular expression in MWHttpRequest::isValidURI
|
2019-05-13 10:38:00 +00:00
|
|
|
*/
|
|
|
|
|
public static function provideURI() {
|
|
|
|
|
/** Format: 'boolean expectation', 'URI to test', 'Optional message' */
|
|
|
|
|
return [
|
|
|
|
|
[ false, '¿non sens before!! http://a', 'Allow anything before URI' ],
|
|
|
|
|
|
|
|
|
|
# (http|https) - only two schemes allowed
|
|
|
|
|
[ true, 'http://www.example.org/' ],
|
|
|
|
|
[ true, 'https://www.example.org/' ],
|
|
|
|
|
[ true, 'http://www.example.org', 'URI without directory' ],
|
|
|
|
|
[ true, 'http://a', 'Short name' ],
|
|
|
|
|
[ true, 'http://étoile', 'Allow UTF-8 in hostname' ], # 'étoile' is french for 'star'
|
|
|
|
|
[ false, '\\host\directory', 'CIFS share' ],
|
|
|
|
|
[ false, 'gopher://host/dir', 'Reject gopher scheme' ],
|
|
|
|
|
[ false, 'telnet://host', 'Reject telnet scheme' ],
|
|
|
|
|
|
|
|
|
|
# :\/\/ - double slashes
|
|
|
|
|
[ false, 'http//example.org', 'Reject missing colon in protocol' ],
|
|
|
|
|
[ false, 'http:/example.org', 'Reject missing slash in protocol' ],
|
|
|
|
|
[ false, 'http:example.org', 'Must have two slashes' ],
|
|
|
|
|
# Following fail since hostname can be made of anything
|
|
|
|
|
[ false, 'http:///example.org', 'Must have exactly two slashes, not three' ],
|
|
|
|
|
|
|
|
|
|
# (\w+:{0,1}\w*@)? - optional user:pass
|
|
|
|
|
[ true, 'http://user@host', 'Username provided' ],
|
|
|
|
|
[ true, 'http://user:@host', 'Username provided, no password' ],
|
|
|
|
|
[ true, 'http://user:pass@host', 'Username and password provided' ],
|
|
|
|
|
|
|
|
|
|
# (\S+) - host part is made of anything not whitespaces
|
|
|
|
|
// commented these out in order to remove @group Broken
|
2022-12-11 14:20:06 +00:00
|
|
|
// @todo are these valid tests? if so, fix MWHttpRequest::isValidURI so it can handle them
|
2019-05-13 10:38:00 +00:00
|
|
|
// [ false, 'http://!"èèè¿¿¿~~\'', 'hostname is made of any non whitespace' ],
|
|
|
|
|
// [ false, 'http://exam:ple.org/', 'hostname can not use colons!' ],
|
|
|
|
|
|
|
|
|
|
# (:[0-9]+)? - port number
|
|
|
|
|
[ true, 'http://example.org:80/' ],
|
|
|
|
|
[ true, 'https://example.org:80/' ],
|
|
|
|
|
[ true, 'http://example.org:443/' ],
|
|
|
|
|
[ true, 'https://example.org:443/' ],
|
|
|
|
|
|
|
|
|
|
# Part after the hostname is / or / with something else
|
|
|
|
|
[ true, 'http://example/#' ],
|
|
|
|
|
[ true, 'http://example/!' ],
|
|
|
|
|
[ true, 'http://example/:' ],
|
|
|
|
|
[ true, 'http://example/.' ],
|
|
|
|
|
[ true, 'http://example/?' ],
|
|
|
|
|
[ true, 'http://example/+' ],
|
|
|
|
|
[ true, 'http://example/=' ],
|
|
|
|
|
[ true, 'http://example/&' ],
|
|
|
|
|
[ true, 'http://example/%' ],
|
|
|
|
|
[ true, 'http://example/@' ],
|
|
|
|
|
[ true, 'http://example/-' ],
|
|
|
|
|
[ true, 'http://example//' ],
|
|
|
|
|
[ true, 'http://example/&' ],
|
|
|
|
|
|
|
|
|
|
# Fragment
|
|
|
|
|
[ true, 'http://exam#ple.org', ], # This one is valid, really!
|
|
|
|
|
[ true, 'http://example.org:80#anchor' ],
|
|
|
|
|
[ true, 'http://example.org/?id#anchor' ],
|
|
|
|
|
[ true, 'http://example.org/?#anchor' ],
|
|
|
|
|
|
|
|
|
|
[ false, 'http://a ¿non !!sens after', 'Allow anything after URI' ],
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2022-12-11 14:20:06 +00:00
|
|
|
* T29854 : MWHttpRequest::isValidURI is too lax
|
2019-05-13 10:38:00 +00:00
|
|
|
* @dataProvider provideURI
|
2019-10-09 07:56:14 +00:00
|
|
|
* @covers MWHttpRequest::isValidURI
|
2019-05-13 10:38:00 +00:00
|
|
|
*/
|
2019-10-09 07:56:14 +00:00
|
|
|
public function testIsValidUri( $expect, $uri, $message = '' ) {
|
|
|
|
|
$this->assertSame( $expect, MWHttpRequest::isValidURI( $uri ), $message );
|
2019-05-13 10:38:00 +00:00
|
|
|
}
|
|
|
|
|
|
2021-10-08 19:26:24 +00:00
|
|
|
public function testSetReverseProxy() {
|
|
|
|
|
$req = TestingAccessWrapper::newFromObject(
|
2023-02-13 21:42:09 +00:00
|
|
|
MediaWikiServices::getInstance()->getHttpRequestFactory()->create( 'https://example.org/path?query=string' )
|
2021-10-08 19:26:24 +00:00
|
|
|
);
|
|
|
|
|
$req->setReverseProxy( 'http://localhost:1234' );
|
2021-10-22 20:43:16 +00:00
|
|
|
$this->assertSame( 'http://localhost:1234/path?query=string', $req->url );
|
|
|
|
|
$this->assertSame( 'example.org', $req->reqHeaders['Host'] );
|
2021-10-08 19:26:24 +00:00
|
|
|
}
|
|
|
|
|
|
2019-05-13 10:38:00 +00:00
|
|
|
}
|