aboutsummaryrefslogtreecommitdiffstats
path: root/tests/phpunit/includes/installer/DatabaseUpdaterTest.php
blob: b8d5d57406fcb1782715b176cfbd34b6903d02d2 (plain) (blame)
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 ],
		];
	}
}