Go to the documentation of this file.
21 12303 =>
'TEST-JS_TALK',
26 'wgNamespaceContentModels',
47 [
'Main Page',
'Main Page',
true ],
48 [
'Main Page',
'Not The Main Page',
false ],
49 [
'Main Page',
'Project:Main Page',
false ],
50 [
'File:Example.png',
'Image:Example.png',
true ],
51 [
'Special:Version',
'Special:Version',
true ],
52 [
'Special:Version',
'Special:Recentchanges',
false ],
53 [
'Special:Version',
'Main Page',
false ],
61 public function testEquals( $titleA, $titleB, $expectedBool ) {
65 $this->assertEquals( $expectedBool, $titleA->equals( $titleB ) );
66 $this->assertEquals( $expectedBool, $titleB->equals( $titleA ) );
88 $this->assertEquals( $expectedBool,
$title->inNamespace( $ns ) );
97 $this->assertTrue( $mainpage->inNamespaces( [
NS_MAIN,
NS_USER ] ) );
98 $this->assertTrue( $mainpage->inNamespaces( [
NS_USER,
NS_MAIN ] ) );
121 $this->assertEquals( $expectedBool,
$title->hasSubjectNamespace( $ns ) );
155 $this->assertEquals( $expectedModelId,
$title->getContentModel() );
164 $this->assertTrue(
$title->hasContentModel( $expectedModelId ) );
169 [
'Help:Foo',
false ],
170 [
'Help:Foo.js',
false ],
171 [
'Help:Foo/bar.js',
false ],
172 [
'User:Foo',
false ],
173 [
'User:Foo.js',
false ],
174 [
'User:Foo/bar.js',
false ],
175 [
'User:Foo/bar.css',
false ],
176 [
'User talk:Foo/bar.css',
false ],
177 [
'User:Foo/bar.js.xxx',
false ],
178 [
'User:Foo/bar.xxx',
false ],
179 [
'MediaWiki:Foo.js',
true ],
180 [
'MediaWiki:Foo.css',
true ],
181 [
'MediaWiki:Foo.JS',
false ],
182 [
'MediaWiki:Foo.CSS',
false ],
183 [
'MediaWiki:Foo.css.xxx',
false ],
184 [
'TEST-JS:Foo',
false ],
185 [
'TEST-JS:Foo.js',
false ],
195 $this->assertEquals( $expectedBool,
$title->isCssOrJsPage() );
200 [
'Help:Foo',
false ],
201 [
'Help:Foo.js',
false ],
202 [
'Help:Foo/bar.js',
false ],
203 [
'User:Foo',
false ],
204 [
'User:Foo.js',
false ],
205 [
'User:Foo/bar.js',
true ],
206 [
'User:Foo/bar.css',
true ],
207 [
'User talk:Foo/bar.css',
false ],
208 [
'User:Foo/bar.js.xxx',
false ],
209 [
'User:Foo/bar.xxx',
false ],
210 [
'MediaWiki:Foo.js',
false ],
211 [
'User:Foo/bar.JS',
false ],
212 [
'User:Foo/bar.CSS',
false ],
213 [
'TEST-JS:Foo',
false ],
214 [
'TEST-JS:Foo.js',
false ],
224 $this->assertEquals( $expectedBool,
$title->isCssJsSubpage() );
229 [
'Help:Foo',
false ],
230 [
'Help:Foo.css',
false ],
231 [
'User:Foo',
false ],
232 [
'User:Foo.js',
false ],
233 [
'User:Foo.css',
false ],
234 [
'User:Foo/bar.js',
false ],
235 [
'User:Foo/bar.css',
true ],
245 $this->assertEquals( $expectedBool,
$title->isCssSubpage() );
250 [
'Help:Foo',
false ],
251 [
'Help:Foo.css',
false ],
252 [
'User:Foo',
false ],
253 [
'User:Foo.js',
false ],
254 [
'User:Foo.css',
false ],
255 [
'User:Foo/bar.js',
true ],
256 [
'User:Foo/bar.css',
false ],
266 $this->assertEquals( $expectedBool,
$title->isJsSubpage() );
271 [
'Help:Foo',
true ],
272 [
'Help:Foo.js',
true ],
273 [
'Help:Foo/bar.js',
true ],
274 [
'User:Foo',
true ],
275 [
'User:Foo.js',
true ],
276 [
'User:Foo/bar.js',
false ],
277 [
'User:Foo/bar.css',
false ],
278 [
'User talk:Foo/bar.css',
true ],
279 [
'User:Foo/bar.js.xxx',
true ],
280 [
'User:Foo/bar.xxx',
true ],
281 [
'MediaWiki:Foo.js',
false ],
282 [
'MediaWiki:Foo.css',
false ],
283 [
'MediaWiki:Foo/bar.css',
false ],
284 [
'User:Foo/bar.JS',
true ],
285 [
'User:Foo/bar.CSS',
true ],
286 [
'TEST-JS:Foo',
false ],
287 [
'TEST-JS:Foo.js',
false ],
288 [
'TEST-JS_TALK:Foo.js',
true ],
298 $this->assertEquals( $expectedBool,
$title->isWikitextPage() );
303 [
'Main Page',
'Talk:Main Page' ],
304 [
'Talk:Main Page',
'Main Page' ],
305 [
'Help:Main Page',
'Help talk:Main Page' ],
306 [
'Help talk:Main Page',
'Help:Main Page' ],
307 [
'Special:FooBar', null ],
308 [
'Media:File.jpg', null ],
320 if ( $expected ===
null ) {
321 $this->setExpectedException(
'MWException' );
325 $this->assertEquals( $expected,
$title->getOtherPage()->getPrefixedText() );
332 $linkCache->addGoodLinkObj( 23, $title1 );
337 $this->assertNotSame( $title1, $title2,
'title cache should be empty' );
338 $this->assertEquals( 0, $linkCache->getGoodLinkID(
'Foo' ),
'link cache should be empty' );
when a variable name is used in a function
testHasSubjectNamespace( $title, $ns, $expectedBool)
provideHasSubjectNamespace Title::hasSubjectNamespace
static newFromText( $text, $defaultNamespace=NS_MAIN)
Create a new Title from text, such as what one would find in a link.
testEquals( $titleA, $titleB, $expectedBool)
provideEquals Title::equals
static provideGetOtherPage()
processing should stop and the error should be shown to the user * false
static provideIsCssSubpage()
static provideIsCssJsSubpage()
testHasContentModel( $title, $expectedModelId)
dataGetContentModel Title::hasContentModel
static clearCaches()
Text form (spaces not underscores) of the main part.
static provideIsWikitextPage()
testInNamespaces()
Title::inNamespaces.
const CONTENT_MODEL_WIKITEXT
you have access to all of the normal MediaWiki so you can get a DB use the cache
testIsWikitextPage( $title, $expectedBool)
provideIsWikitextPage Title::isWikitextPage
injection txt This is an overview of how MediaWiki makes use of dependency injection The design described here grew from the discussion of RFC T384 The term dependency this means that anything an object needs to operate should be injected from the the object itself should only know narrow no concrete implementation of the logic it relies on The requirement to inject everything typically results in an architecture that based on two main types of and essentially stateless service objects that use other service objects to operate on the value objects As of the beginning MediaWiki is only starting to use the DI approach Much of the code still relies on global state or direct resulting in a highly cyclical dependency which acts as the top level factory for services in MediaWiki which can be used to gain access to default instances of various services MediaWikiServices however also allows new services to be defined and default services to be redefined Services are defined or redefined by providing a callback the instantiator that will return a new instance of the service When it will create an instance of MediaWikiServices and populate it with the services defined in the files listed by thereby bootstrapping the DI framework Per $wgServiceWiringFiles lists includes ServiceWiring php
namespace and then decline to actually register it file or subcat img or subcat $title
testGetOtherPage( $text, $expected)
provideGetOtherpage Title::getOtherPage
testIsJsSubpage( $title, $expectedBool)
provideIsJsSubpage Title::isJsSubpage
when a variable name is used in a it is silently declared as a new masking the global
testGetContentModel( $title, $expectedModelId)
dataGetContentModel Title::getContentModel
static provideIsCssOrJsPage()
testIsCssSubpage( $title, $expectedBool)
provideIsCssSubpage Title::isCssSubpage
static provideHasSubjectNamespace()
static provideInNamespace()
testIsCssOrJsPage( $title, $expectedBool)
provideIsCssOrJsPage Title::isCssOrJsPage
static singleton()
Get an instance of this class.
static getCanonicalNamespaces( $rebuild=false)
Returns array of all defined namespaces with their canonical (English) names.
we sometimes make exceptions for this Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally NO WARRANTY BECAUSE THE PROGRAM IS LICENSED FREE OF THERE IS NO WARRANTY FOR THE TO THE EXTENT PERMITTED BY APPLICABLE LAW EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND OR OTHER PARTIES PROVIDE THE PROGRAM AS IS WITHOUT WARRANTY OF ANY EITHER EXPRESSED OR BUT NOT LIMITED THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU SHOULD THE PROGRAM PROVE YOU ASSUME THE COST OF ALL NECESSARY REPAIR OR CORRECTION IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT OR ANY OTHER PARTY WHO MAY MODIFY AND OR REDISTRIBUTE THE PROGRAM AS PERMITTED BE LIABLE TO YOU FOR INCLUDING ANY INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES END OF TERMS AND CONDITIONS How to Apply These Terms to Your New Programs If you develop a new and you want it to be of the greatest possible use to the public
null means default in associative array with keys and values unescaped Should be merged with default with a value of false meaning to suppress the attribute in associative array with keys and values unescaped noclasses just before the function returns a value If you return true
static provideIsJsSubpage()
const CONTENT_MODEL_JAVASCRIPT
testInNamespace( $title, $ns, $expectedBool)
provideInNamespace Title::inNamespace
testIsCssJsSubpage( $title, $expectedBool)
provideIsCssJsSubpage Title::isCssJsSubpage
this class mediates it Skin Encapsulates a look and feel for the wiki All of the functions that render HTML and make choices about how to render it are here and are called from various other places when and is meant to be subclassed with other skins that may override some of its functions The User object contains a reference to a and so rather than having a global skin object we just rely on the global User and get the skin with $wgUser and also has some character encoding functions and other locale stuff The current user interface language is instantiated as and the content language as $wgContLang