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 ],
];
}
}
|