1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
|
<?php
namespace MediaWiki\Tests\Site;
use MediaWiki\MainConfigNames;
use MediaWiki\Site\MediaWikiSite;
/**
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
* http://www.gnu.org/copyleft/gpl.html
*
* @file
* @since 1.21
*
* @ingroup Site
* @ingroup Test
*
* @group Site
*
* @author Jeroen De Dauw < jeroendedauw@gmail.com >
*/
class MediaWikiSiteTest extends SiteTest {
/**
* @covers \MediaWiki\Site\MediaWikiSite::normalizePageName
*/
public function testNormalizePageTitle() {
$this->overrideConfigValue( MainConfigNames::CapitalLinks, true );
$site = new MediaWikiSite();
$site->setGlobalId( 'enwiki' );
// NOTE: this does not actually call out to the enwiki site to perform the normalization,
// but uses a local Title object to do so. This is hardcoded on SiteLink::normalizePageTitle
// for the case that MW_PHPUNIT_TEST is set.
$this->assertEquals( 'Foo', $site->normalizePageName( ' foo ' ) );
}
public static function fileUrlProvider() {
return [
// url, filepath, path arg, expected
[ 'https://en.wikipedia.org', '/w/$1', 'api.php', 'https://en.wikipedia.org/w/api.php' ],
[ 'https://en.wikipedia.org', '/w/', 'api.php', 'https://en.wikipedia.org/w/' ],
[
'https://en.wikipedia.org',
'/foo/page.php?name=$1',
'api.php',
'https://en.wikipedia.org/foo/page.php?name=api.php'
],
[
'https://en.wikipedia.org',
'/w/$1',
'',
'https://en.wikipedia.org/w/'
],
[
'https://en.wikipedia.org',
'/w/$1',
'foo/bar/api.php',
'https://en.wikipedia.org/w/foo/bar/api.php'
],
];
}
/**
* @dataProvider fileUrlProvider
* @covers \MediaWiki\Site\MediaWikiSite::getFileUrl
*/
public function testGetFileUrl( $url, $filePath, $pathArgument, $expected ) {
$site = new MediaWikiSite();
$site->setFilePath( $url . $filePath );
$this->assertEquals( $expected, $site->getFileUrl( $pathArgument ) );
}
public static function provideGetPageUrl() {
return [
// path, page, expected substring
[ 'http://acme.test/wiki/$1', 'Berlin', '/wiki/Berlin' ],
[ 'http://acme.test/wiki/', 'Berlin', '/wiki/' ],
[ 'http://acme.test/w/index.php?title=$1', 'Berlin', '/w/index.php?title=Berlin' ],
[ 'http://acme.test/wiki/$1', '', '/wiki/' ],
[ 'http://acme.test/wiki/$1', 'Berlin/subpage', '/wiki/Berlin/subpage' ],
[ 'http://acme.test/wiki/$1', 'Berlin/subpage with spaces', '/wiki/Berlin/subpage_with_spaces' ],
[ 'http://acme.test/wiki/$1', 'Cork (city) ', '/Cork_(city)' ],
[ 'http://acme.test/wiki/$1', 'M&M', '/wiki/M%26M' ],
];
}
/**
* @dataProvider provideGetPageUrl
* @covers \MediaWiki\Site\MediaWikiSite::getPageUrl
*/
public function testGetPageUrl( $path, $page, $expected ) {
$site = new MediaWikiSite();
$site->setLinkPath( $path );
$this->assertStringContainsString( $path, $site->getPageUrl() );
$this->assertStringContainsString( $expected, $site->getPageUrl( $page ) );
}
}
|