wiki.techinc.nl/tests/phpunit/structure/ApiPrefixUniquenessTest.php
Inductiveload 5381c92e69 Revert "tests: suppress API prefix uniqueness check for 'pi'"
This is no longer required now that the prefix of the proofreadpage
meta query is set to 'prpi'.

This reverts commit d6db8f4ad0.

Bug: T290585
Depends-On: If2041873eac35806ae14645064d1f544142186e1
Change-Id: Ie7092cf26c4e55d324834f3478188498012f48cb
2021-09-09 08:35:24 +01:00

48 lines
1.3 KiB
PHP

<?php
/**
* Checks that all API query modules, core and extensions, have unique prefixes.
*
* @group API
*/
class ApiPrefixUniquenessTest extends MediaWikiIntegrationTestCase {
public function testPrefixes() {
$main = new ApiMain( new FauxRequest() );
$query = new ApiQuery( $main, 'foo' );
$moduleManager = $query->getModuleManager();
$modules = $moduleManager->getNames();
$prefixes = [];
foreach ( $modules as $name ) {
$module = $moduleManager->getModule( $name );
$class = get_class( $module );
$prefix = $module->getModulePrefix();
if ( $prefix === '' /* HACK: T196962 */ || $prefix === 'wbeu' ) {
continue;
}
if ( isset( $prefixes[$prefix] ) ) {
$this->fail(
"Module prefix '{$prefix}' is shared between {$class} and {$prefixes[$prefix]}"
);
}
$prefixes[$module->getModulePrefix()] = $class;
if ( $module instanceof ApiQueryGeneratorBase ) {
// namespace with 'g', a generator can share a prefix with a module
$prefix = 'g' . $prefix;
if ( isset( $prefixes[$prefix] ) ) {
$this->fail(
"Module prefix '{$prefix}' is shared between {$class} and {$prefixes[$prefix]}" .
" (as a generator)"
);
}
$prefixes[$module->getModulePrefix()] = $class;
}
}
$this->assertTrue( true ); // dummy call to make this test non-incomplete
}
}