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
182 lines
4.7 KiB
PHP
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
|
|
);
|
|
}
|
|
}
|