MessageValue and friends are pure value objects and newable, so it makes sense for them to be (de)serializable too. There are some places where we want to serialize messages, such as in ParserOutput. The structure of the resulting JSON is inspired by the way we represent Message objects as plain values elsewhere in MediaWiki, e.g. StatusValue::getStatusArray(). Co-Authored-By: C. Scott Ananian <cscott@cscott.net> Depends-On: Ia32f95a6bdf342262b4ef044140527f0676402b9 Depends-On: I7bafe80cd36c2558517f474871148286350a4e76 Change-Id: Id47d58b5e26707fa0e0dbdd37418c0d54c8dd503
70 lines
1.9 KiB
PHP
70 lines
1.9 KiB
PHP
<?php
|
|
|
|
namespace Wikimedia\Tests\Message;
|
|
|
|
use MediaWiki\Json\JsonCodec;
|
|
use MediaWikiUnitTestCase;
|
|
use Wikimedia\Message\ListParam;
|
|
use Wikimedia\Message\ListType;
|
|
use Wikimedia\Message\MessageParam;
|
|
use Wikimedia\Message\MessageValue;
|
|
use Wikimedia\Message\ParamType;
|
|
use Wikimedia\Message\ScalarParam;
|
|
|
|
/**
|
|
* @covers \Wikimedia\Message\ListParam
|
|
*/
|
|
class ListParamTest extends MediaWikiUnitTestCase {
|
|
use MessageSerializationTestTrait;
|
|
|
|
/**
|
|
* Overrides SerializationTestTrait::getClassToTest
|
|
* @return string
|
|
*/
|
|
public static function getClassToTest(): string {
|
|
return ListParam::class;
|
|
}
|
|
|
|
public static function provideConstruct() {
|
|
return [
|
|
'commaList' => [
|
|
[ ListType::COMMA, [ 1, 2, 3 ] ],
|
|
'<list listType="comma"><text>1</text><text>2</text><text>3</text></list>',
|
|
],
|
|
'andList' => [
|
|
[ ListType::AND, [ new ScalarParam( ParamType::NUM, 5 ), new MessageValue( 'key' ) ] ],
|
|
'<list listType="text"><num>5</num><text><message key="key"></message></text></list>',
|
|
],
|
|
];
|
|
}
|
|
|
|
/** @dataProvider provideConstruct */
|
|
public function testSerialize( $args, $_ ) {
|
|
[ $type, $values ] = $args;
|
|
$codec = new JsonCodec;
|
|
$obj = new ListParam( $type, $values );
|
|
|
|
$serialized = $codec->serialize( $obj );
|
|
$newObj = $codec->deserialize( $serialized );
|
|
|
|
// XXX: would be nice to have a proper ::equals() method.
|
|
$this->assertEquals( $obj->dump(), $newObj->dump() );
|
|
}
|
|
|
|
/** @dataProvider provideConstruct */
|
|
public function testConstruct( $args, $expected ) {
|
|
[ $type, $values ] = $args;
|
|
$mp = new ListParam( $type, $values );
|
|
|
|
$expectValues = [];
|
|
foreach ( $values as $v ) {
|
|
$expectValues[] = $v instanceof MessageParam ? $v : new ScalarParam( ParamType::TEXT, $v );
|
|
}
|
|
|
|
$this->assertSame( ParamType::LIST, $mp->getType() );
|
|
$this->assertSame( $type, $mp->getListType() );
|
|
$this->assertEquals( $expectValues, $mp->getValue() );
|
|
$this->assertSame( $expected, $mp->dump() );
|
|
}
|
|
|
|
}
|