wiki.techinc.nl/tests/phpunit/unit/includes/FormOptionsTest.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

105 lines
2.6 KiB
PHP

<?php
/**
* This file host two test case classes for the MediaWiki FormOptions class:
* - FormOptionsInitializationTest : tests initialization of the class.
* - FormOptionsTest : tests methods an on instance
*
* The split let us take advantage of setting up a fixture for the methods
* tests.
*/
/**
* Test class for FormOptions methods.
*
* Copyright © 2011, Antoine Musso
*
* @author Antoine Musso
*/
class FormOptionsTest extends \MediaWikiUnitTestCase {
/**
* @var FormOptions
*/
protected $object;
/**
* Instanciates a FormOptions object to play with.
* FormOptions::add() is tested by the class FormOptionsInitializationTest
* so we assume the function is well tested already an use it to create
* the fixture.
*/
protected function setUp() {
parent::setUp();
$this->object = new FormOptions;
$this->object->add( 'string1', 'string one' );
$this->object->add( 'string2', 'string two' );
$this->object->add( 'integer', 0 );
$this->object->add( 'float', 0.0 );
$this->object->add( 'intnull', 0, FormOptions::INTNULL );
}
/** Helpers for testGuessType() */
/* @{ */
private function assertGuessBoolean( $data ) {
$this->guess( FormOptions::BOOL, $data );
}
private function assertGuessInt( $data ) {
$this->guess( FormOptions::INT, $data );
}
private function assertGuessFloat( $data ) {
$this->guess( FormOptions::FLOAT, $data );
}
private function assertGuessString( $data ) {
$this->guess( FormOptions::STRING, $data );
}
private function assertGuessArray( $data ) {
$this->guess( FormOptions::ARR, $data );
}
/** Generic helper */
private function guess( $expected, $data ) {
$this->assertEquals(
$expected,
FormOptions::guessType( $data )
);
}
/* @} */
/**
* Reuse helpers above assertGuessBoolean assertGuessInt assertGuessString
* @covers FormOptions::guessType
*/
public function testGuessTypeDetection() {
$this->assertGuessBoolean( true );
$this->assertGuessBoolean( false );
$this->assertGuessInt( 0 );
$this->assertGuessInt( -5 );
$this->assertGuessInt( 5 );
$this->assertGuessInt( 0x0F );
$this->assertGuessFloat( 0.0 );
$this->assertGuessFloat( 1.5 );
$this->assertGuessFloat( 1e3 );
$this->assertGuessString( 'true' );
$this->assertGuessString( 'false' );
$this->assertGuessString( '5' );
$this->assertGuessString( '0' );
$this->assertGuessString( '1.5' );
$this->assertGuessArray( [ 'foo' ] );
}
/**
* @expectedException MWException
* @covers FormOptions::guessType
*/
public function testGuessTypeOnNullThrowException() {
$this->object->guessType( null );
}
}