mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/Math
synced 2024-11-12 09:20:05 +00:00
c7197bee19
Currently the PNG and the LaTeXML rendering mode use a common table in the database. If both rendering modes are allowed in a wiki simultaneously this causes problems, because the fields are continuously overwritten. This is patch changes the logic of the rendering engine to use the specific database. The caching logic is now simpler to understand. A entry is written to the database if the changed field of the MathRenderer class is true. Is is triggered by the setters of the database relevant fields. Bug: 65522 Change-Id: Ief9de889b9292b21c9d1529a8b1797f38196edad
89 lines
3 KiB
PHP
89 lines
3 KiB
PHP
<?php
|
|
/**
|
|
* Test the database access and core functionality of MathRenderer.
|
|
*
|
|
* @group Math
|
|
* @group Database //Used by needsDB
|
|
*/
|
|
class MathDatabaseTest extends MediaWikiTestCase {
|
|
var $renderer;
|
|
const SOME_TEX = "a+b";
|
|
const SOME_HTML = "a<sub>b</sub> and so on";
|
|
const SOME_MATHML = "iℏ∂_tΨ=H^Ψ<mrow><\ci>";
|
|
const SOME_CONSERVATIVENESS = 2;
|
|
const SOME_OUTPUTHASH = 'C65c884f742c8591808a121a828bc09f8<';
|
|
|
|
|
|
/**
|
|
* creates a new database connection and a new math renderer
|
|
* TODO: Check if there is a way to get database access without creating
|
|
* the connection to the database explicitly
|
|
* function addDBData() {
|
|
* $this->tablesUsed[] = 'math';
|
|
* }
|
|
* was not sufficient.
|
|
*/
|
|
protected function setup() {
|
|
parent::setUp();
|
|
// TODO: figure out why this is necessary
|
|
$this->db = wfGetDB( DB_MASTER );
|
|
// Create a new instance of MathSource
|
|
$this->renderer = new MathTexvc( self::SOME_TEX );
|
|
$this->tablesUsed[] = 'math';
|
|
self::setupTestDB( $this->db, "mathtest" );
|
|
}
|
|
/**
|
|
* Checks the tex and hash functions
|
|
* @covers MathRenderer::getInputHash()
|
|
*/
|
|
public function testInputHash() {
|
|
$expectedhash = $this->db->encodeBlob( pack( "H32", md5( self::SOME_TEX ) ) );
|
|
$this->assertEquals( $expectedhash, $this->renderer->getInputHash() );
|
|
}
|
|
|
|
/**
|
|
* Helper function to set the current state of the sample renderer instance to the test values
|
|
*/
|
|
public function setValues() {
|
|
// set some values
|
|
$this->renderer->setTex( self::SOME_TEX );
|
|
$this->renderer->setMathml( self::SOME_MATHML );
|
|
$this->renderer->setHtml( self::SOME_HTML );
|
|
$this->renderer->setOutputHash( self::SOME_OUTPUTHASH);
|
|
}
|
|
/**
|
|
* Checks database access. Writes an entry and reads it back.
|
|
* @covers MathRenderer::writeDatabaseEntry()
|
|
* @covers MathRenderer::readDatabaseEntry()
|
|
*/
|
|
public function testDBBasics() {
|
|
$this->setValues();
|
|
$this->renderer->writeToDatabase( $this->db );
|
|
$renderer2 = new MathTexvc( self::SOME_TEX );
|
|
$this->assertTrue( $renderer2->readFromDatabase(), 'Reading from database failed' );
|
|
// comparing the class object does now work due to null values etc.
|
|
$this->assertEquals( $this->renderer->getTex(), $renderer2->getTex(), "test if tex is the same" );
|
|
$this->assertEquals( $this->renderer->getMathml(), $renderer2->getMathml(), "Check MathML encoding" );
|
|
$this->assertEquals( $this->renderer->getHtml(), $renderer2->getHtml(), 'test if HTML is the same' );
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* Checks the creation of the math table without debugging enabled.
|
|
* @covers MathHooks::onLoadExtensionSchemaUpdates
|
|
*/
|
|
public function testCreateTable() {
|
|
$this->setMwGlobals( 'wgMathValidModes', array( MW_MATH_PNG ) );
|
|
$this->db->dropTable( "math", __METHOD__ );
|
|
$dbu = DatabaseUpdater::newForDB( $this->db );
|
|
$dbu->doUpdates( array( "extensions" ) );
|
|
$this->expectOutputRegex( '/(.*)Creating math table(.*)/' );
|
|
$this->setValues();
|
|
$this->renderer->writeToDatabase();
|
|
$res = $this->db->select( "math", "*" );
|
|
$row = $res->fetchRow();
|
|
$this->assertEquals( 10, sizeof( $row ) );
|
|
}
|
|
}
|