3 class TestSample
extends MediaWikiLangTestCase
{
6 * Anything that needs to happen before your tests should go here.
8 protected function setUp() {
9 // Be sure to do call the parent setup and teardown functions.
10 // This makes sure that all the various cleanup and restorations
11 // happen as they should (including the restoration for setMwGlobals).
14 // This sets the globals and will restore them automatically
16 $this->setMwGlobals( [
17 'wgContLang' => Language
::factory( 'en' ),
18 'wgLanguageCode' => 'en',
19 'wgCapitalLinks' => true,
24 * Anything cleanup you need to do should go here.
26 protected function tearDown() {
31 * Name tests so that PHPUnit can turn them into sentences when
32 * they run. While MediaWiki isn't strictly an Agile Programming
33 * project, you are encouraged to use the naming described under
34 * "Agile Documentation" at
35 * https://www.phpunit.de/manual/3.4/en/other-uses-for-tests.html
37 public function testTitleObjectStringConversion() {
38 $title = Title
::newFromText( "text" );
39 $this->assertInstanceOf( 'Title', $title, "Title creation" );
40 $this->assertEquals( "Text", $title, "Automatic string conversion" );
42 $title = Title
::newFromText( "text", NS_MEDIA
);
43 $this->assertEquals( "Media:Text", $title, "Title creation with namespace" );
47 * If you want to run a the same test with a variety of data, use a data provider.
48 * see: https://www.phpunit.de/manual/3.4/en/writing-tests-for-phpunit.html
50 public static function provideTitles() {
52 [ 'Text', NS_MEDIA
, 'Media:Text' ],
53 [ 'Text', null, 'Text' ],
54 [ 'text', null, 'Text' ],
55 [ 'Text', NS_USER
, 'User:Text' ],
56 [ 'Photo.jpg', NS_FILE
, 'File:Photo.jpg' ]
60 // @codingStandardsIgnoreStart Generic.Files.LineLength
62 * @dataProvider provideTitles
63 * See https://phpunit.de/manual/3.7/en/appendixes.annotations.html#appendixes.annotations.dataProvider
65 // @codingStandardsIgnoreEnd
66 public function testCreateBasicListOfTitles( $titleName, $ns, $text ) {
67 $title = Title
::newFromText( $titleName, $ns );
68 $this->assertEquals( $text, "$title", "see if '$titleName' matches '$text'" );
71 public function testSetUpMainPageTitleForNextTest() {
72 $title = Title
::newMainPage();
73 $this->assertEquals( "Main Page", "$title", "Test initial creation of a title" );
79 * Instead of putting a bunch of tests in a single test method,
80 * you should put only one or two tests in each test method. This
81 * way, the test method names can remain descriptive.
83 * If you want to make tests depend on data created in another
84 * method, you can create dependencies feed whatever you return
85 * from the dependant method (e.g. testInitialCreation in this
86 * example) as arguments to the next method (e.g. $title in
87 * testTitleDepends is whatever testInitialCreatiion returned.)
91 * @depends testSetUpMainPageTitleForNextTest
92 * See https://phpunit.de/manual/3.7/en/appendixes.annotations.html#appendixes.annotations.depends
94 public function testCheckMainPageTitleIsConsideredLocal( $title ) {
95 $this->assertTrue( $title->isLocal() );
98 // @codingStandardsIgnoreStart Generic.Files.LineLength
100 * @expectedException InvalidArgumentException
101 * See https://phpunit.de/manual/3.7/en/appendixes.annotations.html#appendixes.annotations.expectedException
103 // @codingStandardsIgnoreEnd
104 public function testTitleObjectFromObject() {
105 $title = Title
::newFromText( Title
::newFromText( "test" ) );
106 $this->assertEquals( "Test", $title->isLocal() );