1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
<?php
namespace MediaWiki\Tests\Installer;
use MediaWiki\Installer\DatabaseUpdater;
use MediaWikiIntegrationTestCase;
/**
* @covers \MediaWiki\Installer\DatabaseUpdater
* @group Database
*/
class DatabaseUpdaterTest extends MediaWikiIntegrationTestCase {
/** @dataProvider provideUpdateRowExists */
public function testUpdateRowExists( $key, $expectedReturnValue ) {
// Add a testing row to the updatelog table to test lookup
$this->getDb()->newInsertQueryBuilder()
->insertInto( 'updatelog' )
->row( [ 'ul_key' => 'test', 'ul_value' => null ] )
->caller( __METHOD__ )
->execute();
// Call the method under test
$objectUnderTest = DatabaseUpdater::newForDB(
$this->getServiceContainer()->getDBLoadBalancer()->getMaintenanceConnectionRef( DB_PRIMARY )
);
$this->assertSame( $expectedReturnValue, $objectUnderTest->updateRowExists( $key ) );
}
public static function provideUpdateRowExists() {
return [
'Key is present in updatelog table' => [ 'test', true ],
'Key is not present in updatelog table' => [ 'testing', false ],
];
}
/** @dataProvider provideInsertUpdateRow */
public function testInsertUpdateRow( $key, $val ) {
// Call the method under test
$objectUnderTest = DatabaseUpdater::newForDB(
$this->getServiceContainer()->getDBLoadBalancer()->getMaintenanceConnectionRef( DB_PRIMARY )
);
$objectUnderTest->insertUpdateRow( $key, $val );
// Expect that the updatelog contains the expected row
$this->newSelectQueryBuilder()
->select( [ 'ul_key', 'ul_value' ] )
->from( 'updatelog' )
->caller( __METHOD__ )
->assertRowValue( [ $key, $val ] );
}
public static function provideInsertUpdateRow() {
return [
'Value is not null' => [ 'test', 'test' ],
'Value is null' => [ 'testing', null ],
];
}
}
|