setMwGlobals( array( 'wgHtml5' => true, 'wgWellFormedXml' => true, ) ); $this->select = new XmlSelect(); } protected function tearDown() { parent::tearDown(); $this->select = null; } ### START OF TESTS ### public function testConstructWithoutParameters() { $this->assertEquals( '', $this->select->getHTML() ); } /** * Parameters are $name (false), $id (false), $default (false) * @dataProvider provideConstructionParameters */ public function testConstructParameters( $name, $id, $default, $expected ) { $this->select = new XmlSelect( $name, $id, $default ); $this->assertEquals( $expected, $this->select->getHTML() ); } /** * Provide parameters for testConstructParameters() which use three * parameters: * - $name (default: false) * - $id (default: false) * - $default (default: false) * Provides a fourth parameters representing the expected HTML output * */ public static function provideConstructionParameters() { return array( /** * Values are set following a 3-bit Gray code where two successive * values differ by only one value. * See http://en.wikipedia.org/wiki/Gray_code */ # $name $id $default array( false, false, false, '' ), array( false, false, 'foo', '' ), array( false, 'id', 'foo', '' ), array( false, 'id', false, '' ), array( 'name', 'id', false, '' ), array( 'name', 'id', 'foo', '' ), array( 'name', false, 'foo', '' ), array( 'name', false, false, '' ), ); } # Begin XmlSelect::addOption() similar to Xml::option public function testAddOption() { $this->select->addOption( 'foo' ); $this->assertEquals( '', $this->select->getHTML() ); } public function testAddOptionWithDefault() { $this->select->addOption( 'foo', true ); $this->assertEquals( '', $this->select->getHTML() ); } public function testAddOptionWithFalse() { $this->select->addOption( 'foo', false ); $this->assertEquals( '', $this->select->getHTML() ); } public function testAddOptionWithValueZero() { $this->select->addOption( 'foo', 0 ); $this->assertEquals( '', $this->select->getHTML() ); } # End XmlSelect::addOption() similar to Xml::option public function testSetDefault() { $this->select->setDefault( 'bar1' ); $this->select->addOption( 'foo1' ); $this->select->addOption( 'bar1' ); $this->select->addOption( 'foo2' ); $this->assertEquals( '', $this->select->getHTML() ); } /** * Adding default later on should set the correct selection or * raise an exception. * To handle this, we need to render the options in getHtml() */ public function testSetDefaultAfterAddingOptions() { $this->select->addOption( 'foo1' ); $this->select->addOption( 'bar1' ); $this->select->addOption( 'foo2' ); $this->select->setDefault( 'bar1' ); # setting default after adding options $this->assertEquals( '', $this->select->getHTML() ); } public function testGetAttributes() { # create some attributes $this->select->setAttribute( 'dummy', 0x777 ); $this->select->setAttribute( 'string', 'euro €' ); $this->select->setAttribute( 1911, 'razor' ); # verify we can retrieve them $this->assertEquals( $this->select->getAttribute( 'dummy' ), 0x777 ); $this->assertEquals( $this->select->getAttribute( 'string' ), 'euro €' ); $this->assertEquals( $this->select->getAttribute( 1911 ), 'razor' ); # inexistant keys should give us 'null' $this->assertEquals( $this->select->getAttribute( 'I DO NOT EXIT' ), null ); # verify string / integer $this->assertEquals( $this->select->getAttribute( '1911' ), 'razor' ); $this->assertEquals( $this->select->getAttribute( 'dummy' ), 0x777 ); } }