The name change happened some time ago, and I think its about time to start using the name name! (Done with a find and replace) My personal motivation for doing this is that I have started trying out vscode as an IDE for mediawiki development, and right now it doesn't appear to handle php aliases very well or at all. Change-Id: I412235d91ae26e4c1c6a62e0dbb7e7cf3c5ed4a6
100 lines
2.7 KiB
PHP
100 lines
2.7 KiB
PHP
<?php
|
|
|
|
namespace MediaWiki\Auth;
|
|
|
|
/**
|
|
* @group AuthManager
|
|
*/
|
|
abstract class AuthenticationRequestTestCase extends \MediaWikiIntegrationTestCase {
|
|
|
|
/**
|
|
* @param array $args
|
|
*
|
|
* @return AuthenticationRequest
|
|
*/
|
|
abstract protected function getInstance( array $args = [] );
|
|
|
|
/**
|
|
* @dataProvider provideGetFieldInfo
|
|
*/
|
|
public function testGetFieldInfo( array $args ) {
|
|
$info = $this->getInstance( $args )->getFieldInfo();
|
|
$this->assertIsArray( $info );
|
|
|
|
foreach ( $info as $field => $data ) {
|
|
$this->assertIsArray( $data, "Field $field" );
|
|
$this->assertArrayHasKey( 'type', $data, "Field $field" );
|
|
$this->assertArrayHasKey( 'label', $data, "Field $field" );
|
|
$this->assertInstanceOf( \Message::class, $data['label'], "Field $field, label" );
|
|
|
|
if ( $data['type'] !== 'null' ) {
|
|
$this->assertArrayHasKey( 'help', $data, "Field $field" );
|
|
$this->assertInstanceOf( \Message::class, $data['help'], "Field $field, help" );
|
|
}
|
|
|
|
if ( isset( $data['optional'] ) ) {
|
|
$this->assertIsBool( $data['optional'], "Field $field, optional" );
|
|
}
|
|
if ( isset( $data['image'] ) ) {
|
|
$this->assertIsString( $data['image'], "Field $field, image" );
|
|
}
|
|
if ( isset( $data['sensitive'] ) ) {
|
|
$this->assertIsBool( $data['sensitive'], "Field $field, sensitive" );
|
|
}
|
|
if ( $data['type'] === 'password' ) {
|
|
$this->assertTrue( !empty( $data['sensitive'] ),
|
|
"Field $field, password field must be sensitive" );
|
|
}
|
|
|
|
switch ( $data['type'] ) {
|
|
case 'string':
|
|
case 'password':
|
|
case 'hidden':
|
|
break;
|
|
case 'select':
|
|
case 'multiselect':
|
|
$this->assertArrayHasKey( 'options', $data, "Field $field" );
|
|
$this->assertIsArray( $data['options'], "Field $field, options" );
|
|
foreach ( $data['options'] as $val => $msg ) {
|
|
$this->assertInstanceOf( \Message::class, $msg, "Field $field, option $val" );
|
|
}
|
|
break;
|
|
case 'checkbox':
|
|
break;
|
|
case 'button':
|
|
break;
|
|
case 'null':
|
|
break;
|
|
default:
|
|
$this->fail( "Field $field, unknown type " . $data['type'] );
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
public static function provideGetFieldInfo() {
|
|
return [
|
|
[ [] ]
|
|
];
|
|
}
|
|
|
|
/**
|
|
* @dataProvider provideLoadFromSubmission
|
|
* @param array $args
|
|
* @param array $data
|
|
* @param array|bool $expectState
|
|
*/
|
|
public function testLoadFromSubmission( array $args, array $data, $expectState ) {
|
|
$instance = $this->getInstance( $args );
|
|
$ret = $instance->loadFromSubmission( $data );
|
|
if ( is_array( $expectState ) ) {
|
|
$this->assertTrue( $ret );
|
|
$expect = $instance::__set_state( $expectState );
|
|
$this->assertEquals( $expect, $instance );
|
|
} else {
|
|
$this->assertFalse( $ret );
|
|
}
|
|
}
|
|
|
|
abstract public function provideLoadFromSubmission();
|
|
}
|