2024-04-08 16:46:41 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace MediaWiki\Tests\Integration\HTMLForm;
|
|
|
|
|
|
|
|
|
|
use InvalidArgumentException;
|
2024-06-13 21:21:02 +00:00
|
|
|
use MediaWiki\HTMLForm\HTMLForm;
|
2024-04-08 16:46:41 +00:00
|
|
|
use MediaWiki\HTMLForm\HTMLFormField;
|
|
|
|
|
use MediaWikiIntegrationTestCase;
|
|
|
|
|
|
|
|
|
|
abstract class HTMLFormFieldTestCase extends MediaWikiIntegrationTestCase {
|
2024-09-13 20:19:49 +00:00
|
|
|
/** @var string|null */
|
2024-04-08 16:46:41 +00:00
|
|
|
protected $className = null;
|
|
|
|
|
|
2024-05-05 08:23:34 +00:00
|
|
|
/**
|
|
|
|
|
* Augment assertEquals a little bit by stripping newlines and tabs from $expected.
|
|
|
|
|
* This allows $expected to be expressed as a heredoc string.
|
|
|
|
|
*
|
|
|
|
|
* @param string $expected HTML
|
|
|
|
|
* @param string $actual HTML
|
|
|
|
|
* @param string $msg Optional message
|
|
|
|
|
*/
|
|
|
|
|
private function assertHTMLEqualStrippingWhitespace( $expected, $actual, $msg = '' ) {
|
|
|
|
|
$this->assertEquals(
|
|
|
|
|
str_replace( [ "\n", "\t" ], '', $expected ),
|
|
|
|
|
str_replace( [ "\n", "\t" ], '', $actual ),
|
|
|
|
|
$msg
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2024-04-08 16:46:41 +00:00
|
|
|
public function constructField( array $params ): HTMLFormField {
|
|
|
|
|
if ( $this->className === null ) {
|
|
|
|
|
throw new InvalidArgumentException(
|
|
|
|
|
'HTMLFormFieldTestCase subclass ' . __CLASS__ . ' must override $className or constructField()'
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
return new $this->className( $params + [
|
|
|
|
|
'parent' => $this->createMock( HTMLForm::class ),
|
|
|
|
|
'name' => 'testfield'
|
|
|
|
|
] );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static function provideInputHtml() {
|
|
|
|
|
return [];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @dataProvider provideInputHtml
|
|
|
|
|
*/
|
|
|
|
|
public function testGetInputHtml( $params, $value, $expected ) {
|
|
|
|
|
$field = $this->constructField( $params );
|
2024-05-05 08:23:34 +00:00
|
|
|
$this->assertHTMLEqualStrippingWhitespace( $expected, $field->getInputHtml( $value ) );
|
2024-04-08 16:46:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static function provideInputOOUI() {
|
|
|
|
|
return [];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @dataProvider provideInputOOUI
|
|
|
|
|
*/
|
|
|
|
|
public function testGetInputOOUI( $params, $value, $expected ) {
|
2024-04-08 20:08:37 +00:00
|
|
|
\OOUI\Theme::setSingleton( new \OOUI\BlankTheme() );
|
|
|
|
|
|
2024-04-08 16:46:41 +00:00
|
|
|
$field = $this->constructField( $params );
|
2024-05-05 08:23:34 +00:00
|
|
|
$this->assertHTMLEqualStrippingWhitespace( $expected, $field->getInputOOUI( $value ) );
|
2024-04-08 16:46:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static function provideInputCodex() {
|
|
|
|
|
return [];
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @dataProvider provideInputCodex
|
|
|
|
|
*/
|
|
|
|
|
public function testGetInputCodex( $params, $value, $hasError, $expected ) {
|
|
|
|
|
$field = $this->constructField( $params );
|
2024-05-05 08:23:34 +00:00
|
|
|
$this->assertHTMLEqualStrippingWhitespace( $expected, $field->getInputCodex( $value, $hasError ) );
|
2024-04-08 16:46:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|