diff options
Diffstat (limited to 'tests/phpunit/includes/SampleTest.php')
| -rw-r--r-- | tests/phpunit/includes/SampleTest.php | 47 | 
1 files changed, 27 insertions, 20 deletions
| diff --git a/tests/phpunit/includes/SampleTest.php b/tests/phpunit/includes/SampleTest.php index 59ba0a04..8516a4ce 100644 --- a/tests/phpunit/includes/SampleTest.php +++ b/tests/phpunit/includes/SampleTest.php @@ -5,43 +5,50 @@ class TestSample extends MediaWikiLangTestCase {  	/**  	 * Anything that needs to happen before your tests should go here.  	 */ -	function setUp() { -		global $wgContLang; +	protected function setUp() { +		// Be sure to do call the parent setup and teardown functions. +		// This makes sure that all the various cleanup and restorations +		// happen as they should (including the restoration for setMwGlobals).  		parent::setUp(); -		/* For example, we need to set $wgContLang for creating a new Title */ -		$wgContLang = Language::factory( 'en' ); +		// This sets the globals and will restore them automatically +		// after each test. +		$this->setMwGlobals( array( +			'wgContLang' => Language::factory( 'en' ), +			'wgLanguageCode' => 'en', +		) );  	}  	/**  	 * Anything cleanup you need to do should go here.  	 */ -	function tearDown() { +	protected function tearDown() {  		parent::tearDown();  	}  	/** -	 * Name tests so that PHPUnit can turn them into sentances when +	 * Name tests so that PHPUnit can turn them into sentences when  	 * they run.  While MediaWiki isn't strictly an Agile Programming  	 * project, you are encouraged to use the naming described under  	 * "Agile Documentation" at  	 * http://www.phpunit.de/manual/3.4/en/other-uses-for-tests.html  	 */ -	function testTitleObjectStringConversion() { -		$title = Title::newFromText("text"); -		$this->assertEquals("Text", $title->__toString(), "Title creation"); -		$this->assertEquals("Text", "Text", "Automatic string conversion"); - -		$title = Title::newFromText("text", NS_MEDIA); -		$this->assertEquals("Media:Text", $title->__toString(), "Title creation with namespace"); +	public function testTitleObjectStringConversion() { +		$title = Title::newFromText( "text" ); +		$this->assertInstanceOf( 'Title', $title, "Title creation" ); +		$this->assertEquals( "Text", $title, "Automatic string conversion" ); +		$title = Title::newFromText( "text", NS_MEDIA ); +		$this->assertEquals( "Media:Text", $title, "Title creation with namespace" );  	}  	/**  	 * If you want to run a the same test with a variety of data. use a data provider.  	 * see: http://www.phpunit.de/manual/3.4/en/writing-tests-for-phpunit.html +	 * +	 * Note: Data providers are always called statically and outside setUp/tearDown!  	 */ -	public function provideTitles() { +	public static function provideTitles() {  		return array(  			array( 'Text', NS_MEDIA, 'Media:Text' ),  			array( 'Text', null, 'Text' ), @@ -55,14 +62,14 @@ class TestSample extends MediaWikiLangTestCase {  	 * @dataProvider provideTitles  	 * See http://www.phpunit.de/manual/3.4/en/appendixes.annotations.html#appendixes.annotations.dataProvider  	 */ -	public function testCreateBasicListOfTitles($titleName, $ns, $text) { -		$title = Title::newFromText($titleName, $ns); -		$this->assertEquals($text, "$title", "see if '$titleName' matches '$text'"); +	public function testCreateBasicListOfTitles( $titleName, $ns, $text ) { +		$title = Title::newFromText( $titleName, $ns ); +		$this->assertEquals( $text, "$title", "see if '$titleName' matches '$text'" );  	}  	public function testSetUpMainPageTitleForNextTest() {  		$title = Title::newMainPage(); -		$this->assertEquals("Main Page", "$title", "Test initial creation of a title"); +		$this->assertEquals( "Main Page", "$title", "Test initial creation of a title" );  		return $title;  	} @@ -78,6 +85,7 @@ class TestSample extends MediaWikiLangTestCase {  	 * example) as arguments to the next method (e.g. $title in  	 * testTitleDepends is whatever testInitialCreatiion returned.)  	 */ +  	/**  	 * @depends testSetUpMainPageTitleForNextTest  	 * See http://www.phpunit.de/manual/3.4/en/appendixes.annotations.html#appendixes.annotations.depends @@ -90,9 +98,8 @@ class TestSample extends MediaWikiLangTestCase {  	 * @expectedException MWException object  	 * See http://www.phpunit.de/manual/3.4/en/appendixes.annotations.html#appendixes.annotations.expectedException  	 */ -	function testTitleObjectFromObject() { +	public function testTitleObjectFromObject() {  		$title = Title::newFromText( Title::newFromText( "test" ) );  		$this->assertEquals( "Test", $title->isLocal() );  	}  } - | 
