2020-10-23 17:50:06 +00:00
|
|
|
<?php
|
|
|
|
|
2021-11-25 21:35:46 +00:00
|
|
|
use MediaWiki\Extension\TemplateData\Hooks as TemplateDataHooks;
|
|
|
|
|
2020-10-23 17:50:06 +00:00
|
|
|
/**
|
|
|
|
* @group TemplateData
|
2021-11-25 21:35:46 +00:00
|
|
|
* @covers \MediaWiki\Extension\TemplateData\Hooks
|
2020-10-23 17:50:06 +00:00
|
|
|
*/
|
2021-10-11 23:06:08 +00:00
|
|
|
class SerializationTest extends MediaWikiIntegrationTestCase {
|
2020-10-23 17:50:06 +00:00
|
|
|
public function testParserOutputPersistenceForwardCompatibility() {
|
|
|
|
$output = new ParserOutput();
|
|
|
|
|
|
|
|
$status = Status::newFatal( 'a', 'b', 'c' );
|
|
|
|
$status->fatal( 'f' );
|
|
|
|
$status->warning( 'd', 'e' );
|
|
|
|
|
|
|
|
// Set JSONified state. Should work before we set JSON-serializable data,
|
|
|
|
// to be robust against old code reading new data after a rollback.
|
|
|
|
$output->setExtensionData( 'TemplateDataStatus',
|
2021-11-25 21:35:46 +00:00
|
|
|
TemplateDataHooks::jsonSerializeStatus( $status )
|
|
|
|
);
|
2020-10-23 17:50:06 +00:00
|
|
|
|
|
|
|
$result = TemplateDataHooks::getStatusFromParserOutput( $output );
|
|
|
|
$this->assertEquals( $status->getStatusValue(), $result->getStatusValue() );
|
2021-08-28 09:08:24 +00:00
|
|
|
$this->assertSame( (string)$status, (string)$result );
|
2020-10-23 17:50:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function testParserOutputPersistenceBackwardCompatibility() {
|
|
|
|
$output = new ParserOutput();
|
|
|
|
|
|
|
|
$status = Status::newFatal( 'a', 'b', 'c' );
|
|
|
|
$status->fatal( 'f' );
|
|
|
|
$status->warning( 'd', 'e' );
|
|
|
|
|
|
|
|
// Set the object directly. Should still work once we normally set JSON-serializable data.
|
|
|
|
$output->setExtensionData( 'TemplateDataStatus', $status );
|
|
|
|
|
|
|
|
$result = TemplateDataHooks::getStatusFromParserOutput( $output );
|
|
|
|
$this->assertEquals( $status->getStatusValue(), $result->getStatusValue() );
|
2021-08-28 09:08:24 +00:00
|
|
|
$this->assertSame( (string)$status, (string)$result );
|
2020-10-23 17:50:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public function provideStatus() {
|
|
|
|
yield [ Status::newGood() ];
|
|
|
|
$status = Status::newFatal( 'a', 'b', 'c' );
|
|
|
|
$status->fatal( 'f' );
|
|
|
|
$status->warning( 'd', 'e' );
|
|
|
|
yield [ $status ];
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dataProvider provideStatus
|
|
|
|
*/
|
|
|
|
public function testParserOutputPersistenceRoundTrip( Status $status ) {
|
|
|
|
$parserOutput = new ParserOutput();
|
|
|
|
TemplateDataHooks::setStatusToParserOutput( $parserOutput, $status );
|
|
|
|
$result = TemplateDataHooks::getStatusFromParserOutput( $parserOutput );
|
|
|
|
$this->assertEquals( $status->getStatusValue(), $result->getStatusValue() );
|
2021-08-28 09:08:24 +00:00
|
|
|
$this->assertSame( (string)$status, (string)$result );
|
2020-10-23 17:50:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @dataProvider provideStatus
|
|
|
|
*/
|
|
|
|
public function testJsonRoundTrip( Status $status ) {
|
|
|
|
$json = TemplateDataHooks::jsonSerializeStatus( $status );
|
|
|
|
$result = TemplateDataHooks::newStatusFromJson( $json );
|
|
|
|
$this->assertEquals( $status->getStatusValue(), $result->getStatusValue() );
|
2021-08-28 09:08:24 +00:00
|
|
|
$this->assertSame( (string)$status, (string)$result );
|
2020-10-23 17:50:06 +00:00
|
|
|
}
|
|
|
|
}
|