wiki.techinc.nl/tests/phpunit/unit/includes/XmlSelectTest.php
Máté Szabó 344481f60d Move trivially compatible tests to the unit tests suite
This changeset resumes work on T89432 and related tickets
by porting an initial set of tests to the new unit test suite
separated out in I69b92db3e70093570e05cc0a64c7780a278b321a.
The tests were only ported if they worked immediately without
requiring any changes other than changing the test case class
to MediaWikiUnitTestCase and moving the test to the new suite.
If a test failed for any reason (even trivial misconfiguration),
it was NOT ported.

With this change, the unit tests suite now consits of a total
of 455 tests. As before, you can run these tests via the following
command:
$ composer phpunit:unit

Bug: T84948
Bug: T89432
Bug: T87781
Change-Id: Ibb8175981092d7f41864e641cc3c118af70a5c76
2019-06-30 15:23:53 +02:00

182 lines
4.7 KiB
PHP

<?php
/**
* @group Xml
*/
class XmlSelectTest extends \MediaWikiUnitTestCase {
/**
* @var XmlSelect
*/
protected $select;
protected function setUp() {
parent::setUp();
$this->select = new XmlSelect();
}
protected function tearDown() {
parent::tearDown();
$this->select = null;
}
/**
* @covers XmlSelect::__construct
*/
public function testConstructWithoutParameters() {
$this->assertEquals( '<select></select>', $this->select->getHTML() );
}
/**
* Parameters are $name (false), $id (false), $default (false)
* @dataProvider provideConstructionParameters
* @covers XmlSelect::__construct
*/
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 [
/**
* Values are set following a 3-bit Gray code where two successive
* values differ by only one value.
* See https://en.wikipedia.org/wiki/Gray_code
*/
# $name $id $default
[ false, false, false, '<select></select>' ],
[ false, false, 'foo', '<select></select>' ],
[ false, 'id', 'foo', '<select id="id"></select>' ],
[ false, 'id', false, '<select id="id"></select>' ],
[ 'name', 'id', false, '<select name="name" id="id"></select>' ],
[ 'name', 'id', 'foo', '<select name="name" id="id"></select>' ],
[ 'name', false, 'foo', '<select name="name"></select>' ],
[ 'name', false, false, '<select name="name"></select>' ],
];
}
/**
* @covers XmlSelect::addOption
*/
public function testAddOption() {
$this->select->addOption( 'foo' );
$this->assertEquals(
'<select><option value="foo">foo</option></select>',
$this->select->getHTML()
);
}
/**
* @covers XmlSelect::addOption
*/
public function testAddOptionWithDefault() {
$this->select->addOption( 'foo', true );
$this->assertEquals(
'<select><option value="1">foo</option></select>',
$this->select->getHTML()
);
}
/**
* @covers XmlSelect::addOption
*/
public function testAddOptionWithFalse() {
$this->select->addOption( 'foo', false );
$this->assertEquals(
'<select><option value="foo">foo</option></select>',
$this->select->getHTML()
);
}
/**
* @covers XmlSelect::addOption
*/
public function testAddOptionWithValueZero() {
$this->select->addOption( 'foo', 0 );
$this->assertEquals(
'<select><option value="0">foo</option></select>',
$this->select->getHTML()
);
}
/**
* @covers XmlSelect::setDefault
*/
public function testSetDefault() {
$this->select->setDefault( 'bar1' );
$this->select->addOption( 'foo1' );
$this->select->addOption( 'bar1' );
$this->select->addOption( 'foo2' );
$this->assertEquals(
'<select><option value="foo1">foo1</option>' . "\n" .
'<option value="bar1" selected="">bar1</option>' . "\n" .
'<option value="foo2">foo2</option></select>', $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()
* @covers XmlSelect::setDefault
*/
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(
'<select><option value="foo1">foo1</option>' . "\n" .
'<option value="bar1" selected="">bar1</option>' . "\n" .
'<option value="foo2">foo2</option></select>', $this->select->getHTML() );
}
/**
* @covers XmlSelect::setAttribute
* @covers XmlSelect::getAttribute
*/
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'
);
# inexistent 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
);
}
}