wiki.techinc.nl/tests/phpunit/unit/includes/WikiReferenceTest.php
Func 4d1da6f7f8 phpunit: Update @covers annotations for namespaced classes
We renamed many classes to be namespaced, but the `@covers` and
`@coversDefaultClass` annotations weren't updated properly.

PHPUnit didn't support short cover annotations with `use` statements,
these didn't trigger any errors yet, because they are class alias.

This patch is populated by a modified version of PhpunitAnnotationsSniff.

Change-Id: I6c602290a30099239b17d2dc0d67b1488b4eaeeb
2023-05-27 17:43:12 +08:00

166 lines
3.6 KiB
PHP

<?php
use MediaWiki\WikiMap\WikiReference;
/**
* @covers MediaWiki\WikiMap\WikiReference
*/
class WikiReferenceTest extends MediaWikiUnitTestCase {
public static function provideGetDisplayName() {
return [
'http' => [ 'foo.bar', 'http://foo.bar' ],
'https' => [ 'foo.bar', 'http://foo.bar' ],
// apparently, this is the expected behavior
'invalid' => [ 'purple kittens', 'purple kittens' ],
];
}
/**
* @dataProvider provideGetDisplayName
*/
public function testGetDisplayName( $expected, $canonicalServer ) {
$reference = new WikiReference( $canonicalServer, '/wiki/$1' );
$this->assertEquals( $expected, $reference->getDisplayName() );
}
public function testGetCanonicalServer() {
$reference = new WikiReference( 'https://acme.com', '/wiki/$1', '//acme.com' );
$this->assertEquals( 'https://acme.com', $reference->getCanonicalServer() );
}
public static function provideGetCanonicalUrl() {
return [
'no fragment' => [
'https://acme.com/wiki/Foo',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo',
null
],
'empty fragment' => [
'https://acme.com/wiki/Foo',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo',
''
],
'fragment' => [
'https://acme.com/wiki/Foo#Bar',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo',
'Bar'
],
'double fragment' => [
'https://acme.com/wiki/Foo#Bar%23Xus',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo',
'Bar#Xus'
],
'escaped fragment' => [
'https://acme.com/wiki/Foo%23Bar',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo#Bar',
null
],
'empty path' => [
'https://acme.com/Foo',
'https://acme.com',
'//acme.com',
'/$1',
'Foo',
null
],
];
}
/**
* @dataProvider provideGetCanonicalUrl
*/
public function testGetCanonicalUrl(
$expected, $canonicalServer, $server, $path, $page, $fragmentId
) {
$reference = new WikiReference( $canonicalServer, $path, $server );
$this->assertEquals( $expected, $reference->getCanonicalUrl( $page, $fragmentId ) );
}
/**
* @dataProvider provideGetCanonicalUrl
* @note getUrl is an alias for getCanonicalUrl
*/
public function testGetUrl( $expected, $canonicalServer, $server, $path, $page, $fragmentId ) {
$reference = new WikiReference( $canonicalServer, $path, $server );
$this->assertEquals( $expected, $reference->getUrl( $page, $fragmentId ) );
}
public static function provideGetFullUrl() {
return [
'no fragment' => [
'//acme.com/wiki/Foo',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo',
null
],
'empty fragment' => [
'//acme.com/wiki/Foo',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo',
''
],
'fragment' => [
'//acme.com/wiki/Foo#Bar',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo',
'Bar'
],
'double fragment' => [
'//acme.com/wiki/Foo#Bar%23Xus',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo',
'Bar#Xus'
],
'escaped fragment' => [
'//acme.com/wiki/Foo%23Bar',
'https://acme.com',
'//acme.com',
'/wiki/$1',
'Foo#Bar',
null
],
'empty path' => [
'//acme.com/Foo',
'https://acme.com',
'//acme.com',
'/$1',
'Foo',
null
],
];
}
/**
* @dataProvider provideGetFullUrl
*/
public function testGetFullUrl( $expected, $canonicalServer, $server, $path, $page, $fragmentId ) {
$reference = new WikiReference( $canonicalServer, $path, $server );
$this->assertEquals( $expected, $reference->getFullUrl( $page, $fragmentId ) );
}
}